/***********************************************************************************

Section index - Sections in block capitals to make for easy case-sensitive searching

BOX MODEL
CLEARFIX
TYPOGRAPHY
COLOURS
GENERAL
MOBILE MENU
HEADER
FOOTER
SIDEBAR
SOCIAL
BLOCKS
POSTS
SLICK

***********************************************************************************/


/*
*
* BOX MODEL
*
*/

html {
	box-sizing: border-box;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

*, *:before, *:after {
	box-sizing: inherit;
}





/*
*
* CLEARFIX
*
*/

.clearfix:before,
.clearfix:after,
.container:before,
.container:after,
.grid:before,
.grid:after {
	content: " ";
	display: table;
}

.clearfix:after,
.container:after,
.grid:after {
	clear: both;
}





/*
*
* TYPOGRAPHY
*
*/

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0 0 .8em;
	line-height: 1;
	font-weight: 400;
}

h1 {
	font-size: 36px;
}

h2 {
	font-size: 24px;
	line-height: 36px;
}

h3 {
	font-size: 21px;
}

h4 {
	font-size: 18px;
}

h5 {
	font-size: 16px;
}

h6 {
	font-size: 15px;
}

a {
	text-decoration: none;
	color: #0074d9;
}

a:hover {
	color: #7f675b;
}

p {
	margin: 0 0 20px;
}

p:last-child {
	margin: 0;
}





/*
*
* COLOURS
*
*/

.bg-white {
	background: #fff;
}

.bg-grey {
	background: #ddd;
}

.bg-black {
	background: #111;
}

.bg-primary {
	background: #0074d9;
}

.bg-secondary {
	background: #7f675b;
}

.bg-tertiary {
	background: #ffeaee;
}

.white {
	color: #fff;
}

.grey {
	color: #ddd;
}

.black {
	color: #111;
}

.primary {
	color: #0074d9;
}

.secondary {
	color: #7f675b;
}

.tertiary {
	color: #ffeaee;
}





/*
*
* GENERAL
*
*/

body {
	background: #333;
	min-width: 320px;
	font-size: 14px;
	line-height: 1.4;
}

.page-slide-container {
	overflow: hidden;
}

.page-slide {
	position: relative;
	left: 0;
	-webkit-transition: left .5s ease;
	transition: left .5s ease;
}

.page-slide[data-menu-state="open"] {
	left: 375px;
}

main {
	background: #fff;
}

.container {
	width: 95%;
	max-width: 1202px;
	margin: 0 auto;
}

.container.half {
	width: 50%;
}

a,
span,
button,
input[type="submit"] {
	-webkit-transition: background .5s ease, border .5s ease, color .5s ease;
	transition: background .5s ease, border .5s ease, color .5s ease;
}

a span {
	-webkit-transition: none;
	transition: none;
}

input,
textarea,
select,
button {
	resize: none;
	outline: none;
	font-family: Arial, sans-serif;
	font-size: 14px;
}

input[type="submit"],
input[type="text"],
input[type="email"],
input[type="search"],
input[type="tel"],
input[type="password"],
textarea {
	/* -webkit-appearance: none; */
}

input[type="submit"],
button {
	border: none;
	cursor: pointer;
}

:focus {
	outline: none;
}

button::-moz-focus-inner {
	border: 0;
}

img {
	max-width: 100%;
	height: auto;
}

.btn {
	display: inline-block;
	background: #444;
	padding: 5px 10px;
	cursor: pointer;
	font-size: 16px;
	text-align: center;
	color: #fff;
}

.btn:hover {
	background: #111;
	color: #fff;
}

.icon {
	display: inline-block;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	height: 0;
	overflow: hidden;
}

.cover {
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.dbl {
	display: table;
	width: 100%;
}

.dblr {
	display: table-row;
}

.dblc {
	display: table-cell;
}

.list-reset,
.list-reset ul {
	padding: 0;
	margin: 0;
	list-style: none;
	font-size: inherit;
}

.list-reset li {
	padding: 0;
	margin: 0;
}

.grid {
	margin: 0 -15px;
}

.column-25,
.column-33,
.column-50,
.column-66,
.column-75 {
	padding: 0 15px;
	float: left;
}

.column-25 {
	width: 25%;
}

.column-33 {
	width: 33.333333%;
}

.column-50 {
	width: 50%;
}

.column-66 {
	width: 66.666666%;
}

.column-75 {
	width: 75%;
}

.video-container {
	height: 0;
	padding-bottom: 56.25%;
	position: relative;
	overflow: hidden;
	z-index: 0;
}

.video-container iframe,
.video-container object,
.video-container embed {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0; left: 0;
}

img.alignright {
	margin: 0 0 10px 10px;
	float: right;
}

img.alignleft {
	margin: 0 10px 10px 0;
	float: left;
}

img.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.aligncenter {
	text-align: center;
}

.alignright {
	text-align: right;
}

.alignleft {
	text-align: left;
}

.wp-caption {
	text-align: center;
}

.wp-caption-text,
.wp-caption-text:last-child {
	margin: 5px 0 0;
}

.page-content {
	overflow: hidden;
}

.pagination {
	margin: 15px 0 0;
	float: right;
	font-weight: 400;
	text-align: center;
}

.pagination a,
.pagination span,
.pagination button {
	display: inline-block;
	background: #ddd;
	padding: 0;
	margin: 0 2px 5px;
	line-height: 23px;
	color: #111;
}

.pagination a:hover,
.pagination button:hover,
.pagination .current,
.pagination .current:hover {
	background: #efefef;
}

.pagination a,
.pagination .current {
	margin: 0 2px;
	font-size: 14px;
}

.page-numbers {
	width: 34px;
}

.pagination .dots {
	font-size: 20px;
}

.pagination .next,
.pagination .prev {
	width: auto;
	padding: 0 5px;
}





/*
*
* MOBILE MENU
*
*/

.mbl-menu {
	background: #444;
	width: 375px;
	position: absolute;
	top: 0; bottom: 0; left: -375px;
	z-index: 1002;
	overflow-y: auto;
}

[data-menu-state="open"] .mbl-menu {
	box-shadow: 2px 0px 11px 0 rgba(0, 0, 0, .8);
}

.mm-inner {
	padding: 30px 20px;
}

.header-nav-sticky .mm-inner {
	width: 375px;
	padding: 0 20px;
	position: fixed;
	top: 30px; bottom: 30px; left: -375px;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-transition: -webkit-transform .5s ease;
			transition: transform .5s ease;
}

.header-nav-sticky[data-menu-state="open"] .mm-inner {
	-webkit-transform: translateX(375px);
			transform: translateX(375px);
}

.mbl-menu ul {
	padding: 0;
	margin: 0;
	list-style: none;
}

.mbl-menu .menu-item {
	font-size: 24px;
	text-transform: uppercase;
}

.mbl-menu .menu-item a {
	display: block;
	padding: 15px 0;
	text-decoration: none;
	color: #fff;
}

.mbl-menu .menu-item a:hover {
	color: #fff;
}

.mbl-menu .sub-menu {
	padding: 0 0 0 20px;
}





/*
*
* HEADER
*
*/

header {
	background: #ddd;
	padding: 20px 0;
	text-align: center;
}

.logo,
.custom-logo-link {
	display: block;
	max-width: 300px;
	margin: 0 auto 20px;
}

.logo img,
.custom-logo {
	display: block;
}

.header-fixed {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 1002;
}

.header-nav {
	background: #444;
}

.header-nav.fix-nav {
	width: 100%;
	max-width: 100%;
	margin: 0;
	position: fixed;
	top: 0; left: 0;
	z-index: 1002;
}

.menu {
	padding: 0;
	margin: 0;
	list-style: none;
}

.fix-nav ul {
	max-width: 940px;
	margin: 0 auto;
}

.header-nav ul {
	text-align: center;
}

.header-nav li {
	display: inline-block;
	padding: 0;
	margin: 0;
	position: relative;
}

.header-nav a {
	display: inline-block;
	padding: 8px 11px;
	text-decoration: none;
	color: #fff;
}

.header-nav .current-menu-item > a,
.header-nav .current-menu-item > a:hover,
.header-nav .current-menu-item:hover > a,
.header-nav .current-menu-parent > a,
.header-nav .current-menu-parent > a:hover,
.header-nav .current-menu-parent:hover > a,
.header-nav .current-menu-ancestor > a,
.header-nav .current-menu-ancestor > a:hover,
.header-nav .current-menu-ancestor:hover > a {
	background: #111;
}

.header-nav li:hover > a {
	background: #111;
	color: #fff;
}

.header-nav .sub-menu {
	display: none;
	background: #444;
	padding: 0;
	position: absolute;
	z-index: 1002;
	font-size: 14px;
}

.header-nav li:hover > .sub-menu {
	display: block;
}

.header-nav .menu > li > .sub-menu {
	min-width: 235px;
	left: 50%;
	-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
			transform: translateX(-50%);
}

.header-nav .sub-menu li,
.header-nav .sub-menu a {
	display: block;
}

.header-nav .sub-menu .sub-menu {
	min-width: 200px;
	top: 0; left: 100%;
}

.mm-toggle {
	display: none;
	padding: 0 0 0 50px;
	margin: 10px 0;
	float: left;
	position: relative;
	overflow: hidden;
	cursor: pointer;
	font-size: 18px;
	line-height: 30px;
	text-transform: uppercase;
	color: #fff;
}

.mmt-bar {
	background: #fff;
	width: 35px;
	height: 5px;
	border-radius: 2px;
	position: absolute;
	left: 0;
	backface-visibility: hidden;
	-webkit-transition: .2s;
	transition: .2s;
}

.mmt-top {
	top: 0;
}

.mmt-middle {
	top: 12px;
}

.mmt-bottom {
	top: 24px;
}

[data-menu-state="open"] .mmt-top {
	top: 13px;
	-webkit-transform: rotate(50deg);
	transform: rotate(50deg);
	-webkit-transition: .2s .3s;
	transition: .2s .3s;
}

[data-menu-state="open"] .mmt-middle {
	opacity: 0;
}

[data-menu-state="open"] .mmt-bottom {
	top: 13px;
	-webkit-transform: rotate(310deg);
	transform: rotate(310deg);
	-webkit-transition: .2s .3s;
	transition: .2s .3s;
}





/*
*
* FOOTER
*
*/

footer {
	padding: 20px 0;
	text-align: center;
	color: #fff;
}

.footer-nav-bar ul {
	padding: 0;
	margin: 0;
	list-style: none;
	text-align: left;
}

.footer-nav-bar ul li a {
	color: #ddd;
}

.footer-nav-bar ul li .sub-menu {
	padding: 0 0 0 10px;
}





/*
*
* SIDEBAR
*
*/

.sidebar {
	background: #333;
	width: 270px;
	margin: 0 0 0 30px;
	float: right;
	color: #fff;
}

.sidebar-toggle {
	display: none;
	padding: 15px 20px;
	position: relative;
	cursor: pointer;
	font-size: 20px;
}

.sidebar-toggle:after {
	content:"\f078";
	position: absolute;
	top: 50%; right: 20px;
	font: normal normal normal 24px/1 FontAwesome;
	text-rendering: auto;
	color: #fff;
	-webkit-font-smoothing: antialiased;
	   -moz-osx-font-smoothing: grayscale;
	-webkit-transform: translateY(-50%);
			transform: translateY(-50%);
}

.sidebar[data-mbl-state="open"] .sidebar-toggle:after {
	content:"\f077";
}

.sidebar-content {
	padding: 20px;
}

.sidebar-title {
	display: block;
	margin: 0 0 5px;
	font-size: 16px;
}

.sidebar-content ul {
	margin: 0 0 15px;
}

.sidebar-content a {
	color: #eaeaea;
}





/*
*
* SOCIAL
*
*/

.social-links {
	padding: 40px 0;
	text-align: center;
}

.social-link {
	display: inline-block;
	background: #efefef;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	margin: 0 0 10px 10px;
	vertical-align: top;
	font-size: 25px;
	line-height: 40px;
	text-align: center;
	color: #fff;
}

.facebook-link {
	background: #415d9a;
}

.facebook-link:hover {
	background: #efefef;
	color: #415d9a;
}

.twitter-link {
	background: #15b0e0;
}

.twitter-link:hover {
	background: #efefef;
	color: #15b0e0;
}

.instagram-link {
	background: #2f5e86;
}

.instagram-link:hover {
	background: #efefef;
	color: #2f5e86;
}

.youtube-link {
	background: #c41e19;
}

.youtube-link:hover {
	background: #efefef;
	color: #c41e19;
}

.googleplus-link {
	background: #dc4c38;
}

.googleplus-link:hover {
	background: #efefef;
	color: #dc4c38;
}

.snapchat-link {
	background: #fffb00;
}

.snapchat-link:hover {
	background: #efefef;
	color: #fffb00;
}

.flickr-link {
	background: #0c62dd;
}

.flickr-link:hover {
	background: #efefef;
	color: #0c62dd;
}

.linkedin-link {
	background: #1981b9;
}

.linkedin-link:hover {
	background: #efefef;
	color: #1981b9;
}

.pinterest-link {
	background: #ac181f;
}

.pinterest-link:hover {
	background: #efefef;
	color: #ac181f;
}





/*
*
* BLOCKS
*
*/

.block {

}

.bg-top {
	background-position: center top;
	background-size: 100% auto;
	background-repeat: no-repeat;
}

.bg-cover {
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.spacing-inside {
	padding: 40px 0;
}

.spacing-outside {
	margin: 40px 0;
}

.spacing-both {
	padding: 40px 0;
	margin: 40px 0;
}

.block-single-column-text {

}

.block-single-column-image {

}

.block-single-column-image img {
	width: 100%;
	height: auto;
}

.block-single-column-video {

}

.block-two-column-text {

}

.block-two-column-text-image {
	position: relative;
}

.two-column-text {
	width: 50%;
}

.two-column-text-left {
	padding-right: 40px;
	float: left;
}

.two-column-text-right {
	padding-left: 40px;
	float: right;
}

.two-column-image {
	display: block;
	position: absolute;
	top: 0; bottom: 0;
}

.two-column-image-left {
	left: 0; right: 50%;
}

.two-column-image-right {
	left: 50%; right: 0;
}

.block-collapsible-section-text {

}

.dd-list .dd-block:not(:last-child) {
	margin: 0 0 20px;
}

.dd-title {
	padding: 20px 30px;
	position: relative;
	cursor: pointer;
	font-size: 21px;
}

.dd-title-inner {
	display: block;
	padding: 0 25px 0 0;
}

.dd-title .icon {
	display: block;
	width: 20px;
	padding: 24px 0 0;
	margin: -12px 0 0;
	position: absolute;
	top: 50%; right: 30px;
	font: normal normal normal 24px/1 FontAwesome;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-transition: .3s all ease;
			transition: .3s all ease;
}

.plus {
	opacity: 1;
	-webkit-transform: rotate(0deg);
			transform: rotate(0deg);
}

.dd-title .plus:before {
	content: "\f067";
	display: block;
	margin: -24px 0 0;
}

.minus {
	opacity: 0;
	-webkit-transform: rotate(-90deg);
			transform: rotate(-90deg);
}

.dd-title .minus:before {
	content: "\f068";
	display: block;
	margin: -24px 0 0;
}

.dd-open .plus {
	opacity: 0;
	-webkit-transform: rotate(90deg);
			transform: rotate(90deg);
}

.dd-open .minus {
	opacity: 1;
	-webkit-transform: rotate(0deg);
			transform: rotate(0deg);
}

.dd-text {
	padding: 0 30px 30px;
}

.block-video-block {

}

.block-gallery-block {

}

.block-gallery .grid {
	margin: -10px -5px 0;
}

.gallery-item {
	width: 20%;
	padding: 10px 5px 0;
	float: left;
}

.gi-inner,
.gi-inner img {
	display: block;
}

.block-gallery .slideshow-slide img {
	width: 100%;
}

.block-latest-posts {

}

.block-text-slider {

}

.text-slider {

}

.text-slides {
	padding: 0 100px;
}

.text-slides .slick-slide {

}

.block-image-slider {

}

.block-image-slider img {
	width: 100%;
	height: auto;
}

.block-video-slider {

}

.block-video-slider .slick-slide {
	background-size: cover;
	position: relative;
}

.block-video-slider .video-slide-cover-text {
	width: 300px;
	position: absolute;
	top: 50%; left: 50%;
	font-size: 22px;
	text-align: center;
	color: #fff;
	-webkit-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
			transform: translate(-50%, -50%);
}

.block-video-slider .video-slide-play {
	display: inline-block;
	background: #cfcfcf;
	width: 110px;
	height: 0;
	padding: 110px 0 0;
	border-radius: 50%;
	position: relative;
	overflow: hidden;
	opacity: .5;
	cursor: pointer;
	-webkit-transition: opacity .5s ease;
			transition: opacity .5s ease;
}

.block-video-slider .video-slide-play:after {
	content: "";
	border-top: 35px solid transparent;
	border-bottom: 35px solid transparent;
	border-left: 60px solid #272727;
	margin: -35px 0 0 -22px;
	position: absolute;
	top: 50%; left: 50%;
}

.block-video-slider .video-slide-play:hover {
	opacity: 1;
}

.nav-slides .slick-slide {
	cursor: pointer;
}

.block-gallery .carousel-slide img {
	width: 100%;
	max-width: 100%;
	height: auto;
}

.block-parallax .parallax-image {
	background-position: center center;
	background-size: cover;
	background-attachment: fixed ;
	width: 100%;
	min-height: 400px;
	position: relative;
}

.block-parallax .parallax-image-push {
	display: none;
	opacity: 0;
	visibility: hidden;
}

.block-parallax .parallax-image-text-overlay,
.block-full-height-image .full-height-image-text-overlay {
	width: 95%;
	max-width: 750px;
	position: absolute;
	top: 50%; left: 50%;
	font-size: 20px;
	text-align: center;
	color: #fff;
	-webkit-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
			transform: translate(-50%, -50%);
}

.block-google-map .acf-map {
	width: 100%;
	height: 400px;	
}

.map-directions label {
	display: block;
	margin: 0 0 5px;
}

.map-directions-input {
	overflow: hidden;
}

.map-directions-submit {
	float: right;
}

.block-collapsible .collapsible-title {
	background: #ddd;
	padding: 10px;
	margin: 20px 0;
	cursor: pointer;
	font-size: 20px;
}

.block-collapsible .collapsible-content {
	padding: 20px 0;
}

.block-full-height-image {
	position: relative;
	overflow: hidden;
}

.block-full-height-image .full-height-image {
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	min-height: 480px;
	max-height: 1000px;
}

.block-full-height-image .full-height-next-section {
	display: inline-block;
	width: 70px;
	border: 2px solid #fff;
	border-radius: 50%;
	margin: -140px 0 0 -35px;
	position: absolute;
	left: 50%;
	font-size: 55px;
	line-height: 66px;
	text-align: center;
	color: #fff;
}

.block-404 {
	text-align: center;
}





/*
*
* POSTS
*
*/

.posts-filter-links {
	padding: 10px 0;
}

.posts-filter-links span {
	cursor: pointer;
}

.blog-posts .grid {
	margin: 0 -10px;
}

.blog-posts .grid-sizer {
	width: 33.333333%;
}

.post-item {
	width: 33.333333%;
	padding: 0 10px;
	margin: 0 0 15px;
	float: left;
}

.post-item-inner {
	background: #eaeaea;
}

.post-item-image {
	display: block;
	padding: 0 0 56.25%;
	position: relative;
	overflow: hidden;
}

.post-item-image span {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0; left: 0;
	-webkit-transition: -webkit-transform 1s ease;
			transition: transform 1s ease;
}

.post-item-image:hover span {
	-webkit-transform: scale(1.2);
			transform: scale(1.2);
}

.post-item-text {
	padding: 15px;
}

.post-item-title {
	display: inline-block;
	margin: 0 0 10px;
	font-size: 18px;
}

.post-item-info {
	display: block;
	margin: 0 0 10px;
	font-size: 12px;
}

.blog-posts .pagination {
	float: none;
}

.blog-posts .pagination a,
.blog-posts .pagination button {
	padding: 0 20px 0 15px;
	margin: 0 15px;
	line-height: 50px;
}

.blog-posts .pagination .fa {
	margin: -4px 10px 0 0;
	vertical-align: middle;
	font-size: 30px;
}

.js .blog-posts .pagination a {
	display: none;
}





/*
*
* SLICK
*
*/

.slick-next,
.slick-prev {
	display: block;
	background: #111;
	width: 42px;
	height: 0;
	padding: 42px 0 0;
	border-radius: 50%;
	margin: -21px 0 0;
	position: absolute;
	top: 50%;
	z-index: 1001;
	cursor: pointer;
	overflow: hidden;
	-webkit-transition: background-color .5s ease, color .5s ease;
			transition: background-color .5s ease, color .5s ease;
}

.slick-next {
	right: 20px;
}

.slick-prev {
	left: 20px;
}

.container .slick-next {
	right: -62px;
}

.container .slick-prev {
	left: -62px;
}

.slick-next:hover,
.slick-prev:hover {
	
}


/***********************************************************

By default, slick next and prev are using Font Awesome
arrow-right and arrow-left. If you wish to use images instead,
simply add the following CSS to site.css and then add
background images to  .slick-next and .slick-prev

.slick-next:before,
.slick-prev:before {
	display: none;
}

************************************************************/


.slick-next:before,
.slick-prev:before {
	margin: -11px 0 0 -9px;
	position: absolute;
	top: 50%; left: 50%;
	font: normal normal normal 14px/1 FontAwesome;
	font-size: 21px;
	text-rendering: auto;
	color: #fff;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.slick-next:before {
	content: "\f061";
}

.slick-prev:before {
	content: "\f060";
}

.slick-next.slick-disabled,
.slick-prev.slick-disabled {
	cursor: default;
}

.slick-dots {
	width: 100%;
	height: 12px;
	list-style: none;
	padding: 0;
	margin: 0;
	position: absolute;
	bottom: 40px; left: 0;
	z-index: 1001;
	text-align: center;
}

.text-slider .slick-dots {
	margin: 40px 0 0;
	position: static;
}

.slick-dots li {
	display: inline-block;
	height: 12px;
	padding: 0;
	margin: 0;
}

.slick-dots li button {
	background: rgba(255, 255, 255, .5);
	width: 12px;
	height: 0;
	padding: 10px 0 0;
	border: 1px solid #111;
	border-radius: 50%;
	margin: 0 2px;
	overflow: hidden;
	cursor: pointer;
	-webkit-transition: background .5s ease, border .5s ease;
			transition: background .5s ease, border .5s ease;
}

.slick-dots li button:hover {
	background: rgba(255, 255, 255, .75);
}

.slick-dots .slick-active button,
.slick-dots .slick-active:hover button {
	background: rgba(255, 255, 255, 1);
}

.slick-vertical .slick-slide {
	border: none;
}
