/*
Theme Name: Utility
Theme URI: http://www.utility.co.nz
Author: Consofas Desgin Lab
Author URI: https://consofas.com
Description: theme for utiltiy based on gutneberg.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: gutenbergtheme
Tags: translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.

gutenbergtheme is based on Underscores http://underscores.me/, (C) 2012-2016 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal http://necolas.github.io/normalize.css/
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Widgets
# Content
	## Posts and pages
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  margin: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

header {
	position: absolute;
	width: 80%;
	margin: 0 10%;
	z-index: 99;
}
.single header {
	position: inherit;
}
.single main#primary {
	clear: both;
	padding-top: 90px;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b,
strong {
  font-weight: 600;
}

dfn {
  font-style: italic;
}

h1 {
  font-size: 4em;
  margin: 0.67em 0;
  line-height: 1;
}

h2 {
  font-size: 3.5em;
  line-height: 1.4;
}

h3 {
  font-size: 2.8em;
  line-height: 1;
}

h4 {
  font-size: 1.25em;
  line-height: 1.5;
}

h5 {
  font-size: 1em;
}

h6 {
  font-size: 0.8em;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 40px;
}

hr {
  box-sizing: content-box;
  height: 0;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/
body,
button,
input,
select,
optgroup,
textarea {
  color: #444;
  font-family: "freight-sans-pro", "Open-Sans", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.8;
  font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
  color: #32373c;
  clear: both;
  font-family: "alternate-gothic-no-3-d", "Open-Sans", sans-serif;
}

.entry-header h1.entry-title {
  font-size: 2.44em;
  line-height: 1.4;
  margin: 1em 0;
}
.single .entry-header h1.entry-title {
  font-size: 4em;
  line-height: 1;
  margin: 1em 0 0;
  text-transform: uppercase;
}
.has-regular-font-size {
	line-height: 22px;
}
dfn, cite, em, i {
  font-style: italic;
}

blockquote {
  margin: 0 1.5em;
}

address {
  margin: 0 0 1.5em;
}

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", Courier, monospace;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em;
}

code, kbd, tt, var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  font-size: 15px;
  font-size: 0.9375rem;
}

abbr, acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

mark, ins {
  background: #fff9c0;
  text-decoration: none;
}

big {
  font-size: 125%;
}

.archive .site-header {
	margin-bottom: 3.5em;
}

.site-title {
	display: none;
	/*
	margin: .4375em 0 0;
	font-size: 38px;
	font-weight: bold;
	line-height: 1.2;
	color: #333332;
	*/
}

.site-title a {
	text-decoration: none;
	color: inherit;
}

.site-branding {
	margin-bottom: 1.75em;
}

.site-description {
	margin: .4375em 0 0;
	font-size: 17px;
	font-weight: inherit;
	line-height: 1.4;
	word-wrap: break-word;
	color: #929292;
}

.ugb-header-title {
	font-size: 80px;
	line-height: 75px;
	text-transform: uppercase;
}
/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  /* Inherit box-sizing to make it easier to change the property for components that leverage other behavior; see http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
  box-sizing: inherit;
}

body {
  background: #fff;
  /* Fallback for when there is no custom background color defined. */ }

blockquote, q {
  quotes: "" ""; }
  blockquote:before, blockquote:after, q:before, q:after {
    content: ""; }

hr {
  border: 0;
  height: 1px;
  margin-bottom: 1.5em;
}

ul, ol {
  margin: 0 0 1.5em 3em;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

li > ul,
li > ol {
  margin-bottom: 0;
  margin-left: 1.5em;
}

dt {
  font-weight: bold;
}

dd {
  margin: 0 1.5em 1.5em;
}

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */
}

figure {
  margin: 1em 0;
  /* Extra wide images within figure tags don't overflow the content area. */
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  border: 1px solid;
  border-color: #ccc #ccc #bbb;
  border-radius: 3px;
  background: #e6e6e6;
  color: rgba(0, 0, 0, 0.8);
  font-size: 28px;
  font-size: 1.3rem;
  line-height: 1;
  padding: .6em 1em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
  border-color: #ccc #bbb #aaa;
}

button:active, button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
  border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
  color: #666;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 3px 8px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
  color: #111;
}

select {
  border: 1px solid #ccc;
}

textarea {
  width: 100%;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
  color: #799700;
}

a:visited {
  color: #799700;
}

a:hover, a:focus, a:active {
  color: #799700;
  text-decoration: underline;
}

a:focus {
  outline: thin dotted;
}

a:hover, a:active {
  outline: 0;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
	float: right;
	display: block;
	margin: 35px 0 0 0;
	max-width: 750px;
	text-align: center;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
  text-align: left;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	left: 100%;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
  display: block;
	left: auto;
}

.main-navigation li {
	position: relative;
	padding: 0 20px;
}

.main-navigation a {
	color: #fff;
	display: block;
	text-decoration: none;
	font-size: 12px;
	font-weight: 400;
	line-height: 12px;
	text-transform: uppercase;
	letter-spacing: 1.6px;
	padding-bottom: 3px;
}
.main-navigation a:hover {
	border-bottom: 1px solid #FFF;
}
.single .main-navigation a {
	color: #231F20;
}
.single .main-navigation a:hover {
	color: #799700;
}

.main-navigation .current_page_item a {
	border-bottom: 1px solid #FFF;
	font-weight: 600;
}

.single .main-navigation .current_page_item a {
	border-bottom: 1px solid #799700;
	font-weight: 600;
}

.menu-toggle {
  padding: 1em;
}

@media screen and (max-width: 950px) {

	header {
	    width: 92%;
		margin: 0 3%;
	}
	.main-navigation li {
		padding: 0 10px;
	}

	.single .entry-content {
	    margin: 0 auto;
	    width: 92%;
	}
	.single .entry-content p {
	    margin: 24px auto;
	    padding: 0;
	}

	.utility-card.utility-image-left, .utility-card.utility-image-right {
		grid-template-columns: 1fr 1fr;
	}
}

@media screen and (max-width: 750px) {

	header {
	    width: 92%;
		margin: 0 3%;
	}
	/* Small menu. */
	.menu-toggle,
	.main-navigation.toggled ul {
		display: block;
		margin: 0 auto;
	}
	.menu-toggle {
	  float: right;
	}
	ul#primary-menu {
		padding: 15px;
	}
	.menu-menu-1-container {
		clear: both;
		background-color: #ccc;
	}
	.main-navigation li {
		padding: 10px;
	}
	.main-navigation a:hover, .main-navigation .current_page_item a {
	    border-bottom: none;
	}
	.wp-block-columns {
	    display: block;
	}
	.cdl-left-border .wp-block-column p:first-child {
	    margin-top: 20px !important;
	}
}


@media screen and (min-width: 750px) {
	.menu-toggle {
		display: none;
	}
	.main-navigation ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
  border-bottom: 1px solid #111;
	margin: 0 auto 60px;
  max-width: 750px;
	overflow: hidden;
  padding-bottom: 60px;
  background-color: #EFF0EF;
}

.nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	width: 50%;
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}


/*--------------------------------------------------------------
## ShiftNav
--------------------------------------------------------------*/

.shiftnav-open #shiftnav-toggle-main.shiftnav-toggle-icon-x .shiftnav-toggle-burger .fa::before, .shiftnav-open #shiftnav-toggle-main.shiftnav-toggle-main-entire-bar.shiftnav-toggle-icon-x::before {
    content: none !important;
}
#shiftnav-toggle-main.shiftnav-toggle-edge-right {
    top: 18px;
}
.shiftnav.shiftnav-right-edge {
	border-left: 1px solid #e7e7e7;
}
.shiftnav ul.shiftnav-menu li.menu-item {
    border-top: 1px solid #e7e7e7;
    text-transform: uppercase;
}
.shiftnav ul.shiftnav-menu li.current-menu-item {
	background-color: #f5f5f5 !important;
}
.shiftnav ul.shiftnav-menu li.menu-item > .shiftnav-target, .shiftnav ul.shiftnav-menu li.shiftnav-retract > .shiftnav-target {
	font-size: 0.9em !important;
}
.shiftnav::after {
    content: ' ';
    display: block;
    position: absolute;
    right: -15px;
    top: 0;
    height: 100%;
    width: 15px;
    background: 0 0;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    -ms-box-shadow: none !important;
    -o-box-shadow: none !important;
    box-shadow: none !important;
    z-index: 10000;
}


/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
  outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/

.alignleft,
.alignright {
	max-width: 750px !important;	/* Let's work to make this !important unnecessary */
}

.alignleft img,
.alignright img,
.alignleft figcaption,
.alignright figcaption {
	max-width: 50%;
	width: 50%;
}

.alignleft figcaption {
	clear: left;
}

.alignright figcaption {
	clear: right;
}

.alignleft img,
.alignleft figcaption {
  float: left;
  margin-right: 1.5em;
}

.alignright img,
.alignright figcaption {
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}


/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget-area {
	width: 25%;
}

.widget {
  margin: 0 0 1.5em;
  /* Make sure select elements fit in widgets. */
}

.widget select {
  max-width: 100%;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
#page {
  margin: 0 auto;
  max-width: 100%;
}

.site-branding {
	float: left;
	text-align: left;
	margin: 20px 0;
}

.site-footer {
  margin: 0;
}

p.utility-border-top:before {
    content: " ";
    border: 2px solid #799700;
    margin-top: 15px;
    margin-bottom: 25px;
    display: block;
    max-width: 100px
}

#utility-newsletter {
	background-color: #6E6E72;
    text-align: center;
    padding: 20px;
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    letter-spacing: .5px;
}
#utility-newsletter form {
	display: inline-block;
	margin-left: 40px;
}

#utility-footer {
	background-color: #000;
	font-size: 16px;
    letter-spacing: .5px;
    line-height: 21px;
}

#utility-footer .widget-grid {
	display: grid;
	grid-template-columns: 1fr 2fr 1fr 1fr;
	margin: 0 auto;
    max-width: 950px;
}

#utility-footer .widget {
    margin: 20px;
    color: white;
}
#utility-footer .widget a {
    color: white;
}
#utility-footer .widget .fa {
    font-size: 26px !important;
}
#utility-footer .widget_media_image {
	margin-top: 34px;
}
#utility-footer .widget img {
	max-width: 60%;
}
#utility-footer .widget h4 {
	color: white;
	font-family: "freight-sans-pro", "Open-Sans", sans-serif;font-size: 20px;
	font-weight: 600;
	letter-spacing: .5px;
	margin-bottom: 10px;
}

.entry-meta {
	margin-bottom: 40px;
}

.site-footer .site-info {
	text-align: center;
	font-size: 12px;
}

/*--------------------------------------------------------------
## Utility Blocks
--------------------------------------------------------------*/

.ab-block-post-grid.solutions .is-grid {
    grid-gap: 10px;
}
.ab-block-post-grid.solutions .ab-block-post-grid-text {
	bottom: auto;
	left: auto;
    position: relative;
    text-align: center;
    max-width: 80%;
    margin: 20px auto 30px;
}
.ab-block-post-grid.solutions .cdl-grid-item-1 {
    grid-column: 1;
    grid-row: 1;
}
.ab-block-post-grid.solutions .ab-block-post-grid-image {
    height: auto;
    width: 100%;
}
.ab-block-post-grid.solutions h2 a, .ab-block-post-grid.solutions .ab-block-post-grid-link {
	color: #444;
}
.ab-block-post-grid.solutions h2 {
	font-size: 24px;
}
.ab-block-post-grid.solutions .ab-block-post-grid-text p {
    font-size: 16px;
}

.cdl-parallax-box h1 {
	font-size: 120px;
	line-height: 100px;
	font-weight: normal;
}
.cdl-parallax-box p {
    font-size: 22px;
}
.home .cdl-parallax-box h1 {
	font-size: 188px;
	line-height: 140px;
}
.home .cdl-parallax-box p {
    font-size: 22px;
}
.ab-block-post-grid h2 a {
	text-transform: uppercase;
	font-weight: normal;
}
.cdl-skillset {
	margin-top: 55px;
}
.cdl-skillset p {
    font-size: 35px;
    line-height: 35px;
    font-family: "alternate-gothic-no-3-d", "Open-Sans", sans-serif;
    margin-top: 15px;
	margin-bottom: 12px;
}
.cdl-160 {
    font-size: 100px;
    line-height: 80px;
    margin-top: 15px;
    letter-spacing: -1px;
    font-weight: normal;
}
.cdl-colour-box a {
	text-decoration: none;
	font-weight: normal;
}
.wpls-logo-showcase-slider-wrp {
	background-color: #EFF0EF;
	width: 100%;
	max-width: 100% !important;
	padding: 40px;
	margin-bottom: 0 !important;
}
.wpls-logo-showcase {
    margin: 0 auto !important;
    width: 750px;
}
.ab-block-post-grid .ab-text-link::after {
	content: "\f344";
    font-family: dashicons;
    font-size: 12px;
    margin-left: 10px;
    vertical-align: middle;
}
.ab-block-post-grid .ab-text-link:hover {
	color: #fff;
	text-decoration: none;
}
.cdl-more-posts-container {
	background-color: #EFF0EF;
	padding: 40px;
}
.cdl-more-posts {
	margin: 1.5em auto;
	padding-left: 0;
	padding-right: 0;
	max-width: 950px;
}
.cdl-more-posts h3 {
	margin: 0;
}
.cdl-more-posts h3 span.dashicons {
	font-size: 30px;
    line-height: 1.5;
}
.cdl-more-posts ul {
	margin: 1em 0 0 0;
	padding: 0;
	list-style: none;
	line-height: 1.4;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-gap: 0 2em;
}
.cdl-more-posts li h3 {
	font-size: 2em;
	text-transform: uppercase;
}
.cdl-left-border .wp-block-column {
	border-left: 2px solid #799700;
	padding-left: 15px;
}
.cdl-left-border .wp-block-column p {
    font-family: "alternate-gothic-no-3-d", "Open-Sans", sans-serif;
    font-size: 30px;
    line-height: 1em;
    margin-top: 20px;
    margin-bottom: 0;
}
.cdl-left-border .wp-block-column p:first-child {
    margin-top: 0;
}
.cdl-border-top {
	border-top: 3px solid #799700;
	padding-top: 20px;
}
.cdl-border-top h2 {
	text-transform: uppercase;
    font-size: 83px;
    letter-spacing: -2px;
    font-weight: normal;
    margin-top: 25px;
    line-height: 70px;
}
.cdl-arrow-ul li {
	margin-bottom: 6px;
	margin-bottom: 0.6rem;
	list-style-type: none;
	padding-left: 25px;
}
.cdl-arrow-ul li:before {
    content: "\f345";
	display: inline-block;
    font: normal 16px/1 'dashicons';
	color: #799700;
	margin-left: -25px;
	margin-right: 10px;
	word-wrap: break-word;
}
.utilty-green {
	color: #799700;
}
a.utilty-green {
	color: #799700;
	text-decoration: none;
}
a.utilty-green:hover {
	color: #799700;
}
a.utilty-green span.dashicons, .utility-card p.utility-card-readmore span.dashicons {
	width: 14px;
	height: 14px;
	font-size: 14px;
	vertical-align: middle;
}
.willexpand {
    display: none;
}
.whitelink a {
  color: #FFFFFF;
  text-decoration: none;
}
.contact-bot-colour-box {
	margin-bottom: 0 !important;
}
.contact-bot-colour-box h2 {
	color: #FFF;
	font-weight: normal;
}
.contact-bot-colour-box .wp-block-button .wp-block-button__link {
	color: #FFF;
	border: 1px solid #fff;
    border-radius: 0;
    background-color: transparent;
}
@media screen and (max-width: 650px) {

	.site-branding {
	    margin: 20px;
	}
	.single .entry-header h1.entry-title {
		line-height: .85;
	}
	.single main#primary {
	    padding-top: 10px;
	}
	.single .entry-content {
	    margin: 0 auto;
	    width: 92%;
	    padding: 0 14px;
	}
	.single .entry-content p {
	    margin: 24px auto;
	    padding: 0;
	}
	.cdl-parallax-box {
    	padding: 4rem 25% 1rem;
    }
	.home .cdl-parallax-box section {
	    padding: 4em 0;
	    min-width: 90%;
	}
	.cdl-parallax-box.parallax {
	    margin-bottom: 3em !important;
	}
	.cdl-parallax-box h1, .home .cdl-parallax-box h1 {
	    font-size: 90px;
	    line-height: 80px;
	    font-weight: normal;
	}
	.cdl-colour-box, .contact-bot-colour-box {
    	margin: 0 !important;
		padding: 0 !important;
	}
	.cdl-colour-box section {
    	padding: 40px;
	}
	.cdl-colour-box h2 {
	    font-size: 70px;
	    line-height: 60px;
	}
	.cdl-colour-box h2::after {
		display: none;
	}
	.utility-card.utility-image-left, .utility-card.utility-image-right {
		grid-template-columns: 1fr;
	}
	.utility-card.utility-image-right .utility-card-image-container {
	    grid-column-start: initial;
	}
	.utility-card.utility-image-right .utility-card-text-container {
    	grid-column-start: initial;
		grid-row-start: initial;
	}
	.utility-card.has-image .utility-card-image-container {
		height: 400px;
	}
	.utility-card .utility-card-text-container {
		padding: 20px;
	}
	.utility-card h4 {
	    font-size: 80px;
	    line-height: 65px;
	    margin: 45px 0;
	}
	.utility-card .utility-card-tagline {
    	font-size: 30px;
    }
    .kt-row-column-wrap {
    	padding: 0;
    }
    #utility-footer {
	    text-align: center;
	}
	#utility-footer .widget_media_image {
		margin-left: auto;
		margin-right: auto;
		max-width: 200px;
	}
}
@media screen and (max-width: 37.5em) {
	.entry-content > * {
	    font-size: 18px;
	    line-height: 24px;
	    letter-spacing: .5px;
	}
	.cdl-border-top h2 {
	    font-size: 43px;
	    line-height: 35px;
		margin-bottom: 20px;
	}
	.cdl-left-border .wp-block-column p {
		text-align: center;
	}
	.cdl-left-border .wp-block-column {
		border-left: none;
	}
	.wp-block-columns.cdl-skillset {
	    display: inherit;
	}
	.cdl-skillset p {
    	font-size: 28px;
		line-height: 30px;
    }
	.wp-block-columns.cdl-skillset p.utility-border-top::before {
    	text-align: center;
		margin: 0 auto 25px auto;
	}

	.wp-block-columns.cdl-skillset .wp-block-column {
    	text-align: center;
	}
	.cdl-more-posts ul {
	    grid-template-columns: 1fr;
	}
	.cdl-160 {
	    font-size: 70px;
	    line-height: 55px;
	    margin-bottom: 32px;
	    margin-top: 50px;
	    letter-spacing: -1px;
	    font-weight: normal;

	}
	#utility-footer .widget-grid {
		grid-template-columns: 1fr;
	}
}
@media screen and (max-width: 450px) {
	.home .cdl-parallax-box section {
	    padding: 3em 0;
	    min-width: 90%;
	}
	.cdl-parallax-box h1, .home .cdl-parallax-box h1 {
	    font-size: 70px;
	    line-height: 55px;
	    font-weight: normal;
	}

	.cdl-colour-box h2 {
	    font-size: 60px;
	    line-height: 50px;
	}
}
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
.sticky {
  display: block;
}

.hentry {
  margin: 0;
}

.updated:not(.published) {
  display: none;
}

.page-content,
.entry-summary {
  margin: 1.5em 0 0;
}


.entry-content {
  margin: 0;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

.entry-header,
.page-header,
.entry-footer,
.site-info,
.post-navigation,
.page-navigation,
.comments-area,
.not-found .page-content,
.search .entry-summary {
  margin: 1.5em auto;
  padding-left: 14px;
  padding-right: 14px;
  max-width: 950px;
}
.entry-header {
	display: none;
}
.single .entry-header {
	display: block;
}
.entry-header .wp-post-image {
  margin-bottom: 1.5em;
}

.entry-footer span{
  margin-right: 1em;
}

.entry-footer{
  color: #aaa;
  font-size: 90%;
  padding-bottom: 40px;
  border-bottom: 1px solid #111;
}

@media screen and (min-width: 664px) {
  .entry-header,
  .page-header,
  .entry-footer,
  .site-info,
  .post-navigation,
  .page-navigation,
  .comments-area,
  .not-found .page-content,
  .search .entry-summary {
    padding-left: 0;
    padding-right: 0;
  }
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
  word-wrap: break-word;
}

.bypostauthor {
  display: block;
}

.post-author {
	color: #799700;
	font-weight: 600;
	padding-bottom: 30px;
	padding-top: 30px;
}
.post-author .authordescription {
	color: #111;
	font-weight: 400;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
  display: inline-block;
}

img.custom-logo {
	width: 120px;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  margin-bottom: 1.5em;
  max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption .wp-caption-text {
  margin: 0.8075em 0;
}

.wp-caption-text {
  text-align: center;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
  margin-bottom: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%;
}

.gallery-columns-2 .gallery-item {
  max-width: 50%;
}

.gallery-columns-3 .gallery-item {
  max-width: 33.3333333333%;
}

.gallery-columns-4 .gallery-item {
  max-width: 25%;
}

.gallery-columns-5 .gallery-item {
  max-width: 20%;
}

.gallery-columns-6 .gallery-item {
  max-width: 16.6666666667%;
}

.gallery-columns-7 .gallery-item {
  max-width: 14.2857142857%;
}

.gallery-columns-8 .gallery-item {
  max-width: 12.5%;
}

.gallery-columns-9 .gallery-item {
  max-width: 11.1111111111%;
}

.gallery-caption {
  display: block;
}
