/*
Theme Name: Visco Design
Theme URI: http://glaciermediadigital.ca/
Author: Glacier Digital
Author URI: http://glaciermediadigital.ca/
Description: Custom theme design and build by Glacier Digital
Version: 1.0.0
License: Copyright Glacier Digital
License URI: http://glaciermediadigital.ca/
Text Domain: visco-design
Tags:

Visco Design 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
# Clearings
# Widgets
# Content
	## Posts and pages
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Color Variables
--------------------------------------------------------------*/
:root {
  --primary: rgb(119,176,78);
  --secondary: rgb(12,61,85);
  --light: rgb(245,243,245);
  --grey: rgb(131,139,136);
  --dark: rgb(24,33,28);
  --font-family: 'Source Sans Pro', 'Helvetica Neue', Helvetica, sans-serif;
  --content-width: 800px;
}

/*--------------------------------------------------------------
# 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;
}

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: bold;
}

dfn {
	font-style: italic;
}

h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

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,
textarea {
	color: var(--dark);
	font: 400 normal 1em/1 var(--font-family);
}

h1 {
	font: 400 normal 2em/1.25 var(--font-family);
	color: var(--grey);
	margin: 0 0 1em;
}
h2 {
	font: 200 normal 1.5em/1.15 var(--font-family);
	color: var(--primary);
	margin: 0 0 0.75em;
}
h3 {
	font: 700 normal 1.15em/1.25 var(--font-family);
	color: var(--dark);
	margin: 0 0 0.5em;
}
h4 {
	font: 700 normal 1em/1.1 var(--font-family);
	color: var(--dark);
	text-transform: uppercase;
	margin: 0 0 1em;
}
h5 {
	font: 700 normal 1em/1.2 var(--font-family);
	color: var(--primary);
	text-transform: uppercase;
	margin: 0 0 1em;
}
h6 {
	font: 700 normal 1em/1 var(--font-family);
	color: var(--secondary);
	text-transform: uppercase;
	margin: 0 0 1em;
}
p, ul, ol {
	font: 400 normal 1em/1.75 var(--font-family);
	color: var(--dark);
	margin: 0 0 1em;
}

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%;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
	box-sizing: border-box;
}

*,
*:before,
*:after { 
	box-sizing: inherit;
}

body {
	background: #fff; 
}

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

blockquote,
q {
	quotes: "" "";
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 25px 0;
	padding-left: 1.125em;
}

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; 
	max-width: 100%; 
}

figure {
	margin: 1em 0;
}

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

/*--------------------------------------------------------------
## Tables
--------------------------------------------------------------*/
table {
	width: 100%;
	margin: 0 auto 25px;
	text-align: left;
	border: 1px solid #ddd;
	border-collapse: separate;
	border-spacing: 0;
}
table thead {
	border-bottom: 1px solid #ddd;
	background-color: #eee;
}
table thead th {
	color: var(--primary);
	font-weight: 700;
	padding: 10px;
}
table tr td {
	color: var(--dark);
	font-size: 14px;
	padding: 10px;
	border-top: 1px solid #ddd;
}

/*--------------------------------------------------------------
# Structure
--------------------------------------------------------------*/

/* Global
--------------------------------------------------------------*/
.flex-container {
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-ms-flex-direction: row;
	-ms-flex-wrap: wrap;
    -webkit-flex-direction: row;
    -webkit-flex-wrap: wrap;
	flex-flow: row wrap;
	-ms-flex-pack: start;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-ms-flex: 0 0 100%;
	-webkit-flex: 0 0 100%;
	flex: 0 0 100%;
	margin: 0;
	padding: 0;
}

/* Layout
--------------------------------------------------------------*/
.site {
	margin: 0 auto;
	padding: 0;
}
.site-content {
	margin: 0 auto;
	padding: 0;
}
#primary {
	width: 100%;
	margin: 0;
	padding: 25px;
}
.outer-wrapper {
	width: 100%;
	margin: 0 auto;
	padding: 25px;
}
.inner-wrapper {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
}
.content-width {
	max-width: var(--content-width);
}
#secondary {
	width: 100%;
	margin: 0;
	padding: 25px;
	border-top: 1px solid #ddd;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	color: #fff;
	padding: 15px 30px;
	background-color: var(--primary);
	border-radius: 3em;
	border: none;
	transition: all 0.5s ease;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	opacity: 0.65;
}

button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
button:active,
input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
}

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"] {
	-webkit-appearance: none;
	color: #666;
	padding: 15px 30px;
	line-height: 16px;
	border: 1px solid #ccc;
	border-radius: 4px;
}
textarea {
	-webkit-appearance: none;
	color: #666;
	width: 100%;
	padding: 15px;
	line-height: 16px;
	border: 1px solid #ccc;
	border-radius: 4px;
}
select {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	margin: 0 auto;
	padding: 14px 40px 14px 15px;
	color: var(--dark);
	border: 1px solid #ccc;
	border-radius: 4px;
	background: url('images/dropdown-arrow.png') var(--light) right center no-repeat;
}
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: var(--dark);
}

/* Search Form */
#sitesearchform {
	display: inline-block;
}
.search-form {
	display: inline-block;
}
input.search-field {
	float: left;
	width: calc(100% - 55px);
	max-width: 250px;
	margin: 0;
	padding: 15px;
	border: none;
	background-color: var(--light);
	box-shadow: inset 0 2px 5px 0 rgba(0,0,0,0.1);
	border-radius: 4px 0 0 4px;
	line-height: 19px;
}
#sitesearchform label {
	line-height: 0;
}
.search-submit {
	float: left;
	margin: 0;
	padding: 15px 20px;
	border-radius: 0 4px 4px 0;
	line-height: 19px;
	background-color: var(--primary);
}
.search-submit .fa {
	margin: 0;
}

/* Ninja Forms */
.nf-form-cont {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	border-radius: 4px;
	border: 1px solid #ddd;
}
.nf-form-title h3 {
	margin: 0;
	padding: 15px 25px;
	border-bottom: 1px solid #ddd;
	background-color: var(--light);
}
.nf-form-fields-required {
	margin: 0 0 1em;
	padding: 10px 25px;
	color: var(--grey);
	border-bottom: 1px solid #ddd;
}
.nf-error-msg {
	margin: 0;
	padding: 5px 25px;
}
.nf-form {
	margin: 0;
	padding: 0;
}
.nf-field {
	margin: 0;
	padding: 5px 25px;
}
.horizontal-wrap ul {
	margin: 0 auto;
	padding: 0;
}
.horizontal-wrap ul li {
	display: inline-block;
	margin-right: 20px;
	padding: 0;
}
.list-checkbox-wrap.label-above ul li {
	padding: 0;
}
.horizontal-wrap ul li input[type="checkbox"] {
	margin-right: 6px;
}
.nf-form .datepicker {
	position: relative !important;
}
.ninja-forms-field-description {
	clear: both;
}
.nf-form-cont .one-half,
.nf-form-cont .three-sixths,
.nf-form-cont .two-fourths {
	width: 100% !important;
}

/* Dark Form */
.dark-form .nf-form-cont {
	max-width: 100%;
	padding: 0;
	border: none;
	color: #fff;
}
.dark-form .nf-form-title h3 {
	display: none;
}
.dark-form .nf-form-fields-required {
	color: #fff;
	padding: 5px 0;
	border: none;
}
.dark-form .nf-field-container {
	margin-bottom: 10px;
}
.dark-form .nf-field,
.dark-form .error-msg {
	color: #fff;
	padding: 0;
}
.dark-form input[type="text"],
.dark-form input[type="email"],
.dark-form input[type="tel"],
.dark-form textarea {
	border-radius: 0;
	border: none;
	padding: 10px;
	color: #fff;
	border-bottom: 1px solid #fff;
	background-color: rgba(255,255,255,0.1);
}
.dark-form select {
	max-width: 100%;
	padding: 12px 40px 12px 10px;
	color: #fff;
	border: none;
	border-bottom: 1px solid #fff;
	border-radius: 0;
	background: url('images/dropdown-arrow-rev.png') rgba(255,255,255,0.1) right center no-repeat;
}
.dark-form input[type="button"] {
	color: var(--dark);
	background-color: #fff;
}
.dark-form p {
	color: #fff;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
	color: var(--primary);
}
a:visited {
	color: var(--primary);
}
a:hover,
a:focus,
a:active {
	color: var(--primary);
}
a:focus,
a:hover,
a:active {
	outline: 0;
}

/* Styled Links */
a.btn {
	display: inline-block;
	color: #fff;
	padding: 15px 30px;
	text-decoration: none;
	border-radius: 3em;
	background-color: var(--primary);
	transition: all 0.5s ease;
}
a.btn:hover {
	opacity: 0.65;
}
.btn.more::after,
.btn.add::after,
.btn.ease::after {
	font-family: FontAwesome;
	margin-left: 8px;
	color: inherit;
	opacity: 0.5;
}
.less::before,
.video::before {
	font-family: FontAwesome;
	margin-right: 8px;
	color: inherit;
	opacity: 0.5;
}
.more::after {
	content: "\f105";
}
.less::before {
	content: "\f104";
}
.add::after {
	content: "\f067";
}
.ease::after {
	content: "\f107";
}
.video::before {
	content: "\f16a";
}
.btn.small {
	font-size: 75%;
	padding: 10px 15px;
}
.btn.large {
	font-size: 125%;
	padding: 25px 45px;
}
button.primary,
.btn.primary {
	background-color: var(--primary);
}
button.secondary,
.btn.secondary {
	background-color: var(--secondary);
}
button.white,
.btn.white {
	color: var(--dark);
	background-color: #fff;
}
button.light,
.btn.light {
	color: var(--dark);
	background-color: var(--light);
}
button.dark,
.btn.dark {
	background-color: var(--dark);
}
button.transparent,
.btn.transparent {
	color: var(--dark);
	border: 2px solid #aaa;
	background-color: transparent;
}
button.transparent.white,
.btn.transparent.white {
	color: #fff;
	border: 2px solid #fff;
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
/* Primary Menu */
.main-navigation {
	display: none;
	flex: 0 1 auto;
	margin: 0;
	padding: 0 25px;
	text-align: left;
}
#primary_menu {
	display: inline-block;
	list-style: none;
	margin: 0;
	padding: 0;
}
#primary_menu li {
	position: relative;
	display: inline-block;
	padding: 0;
}
#primary_menu li a {
	display: block;
	color: #fff;
	padding: 25px 15px;
	line-height: 36px;
	text-decoration: none;
	text-transform: uppercase;
	transition: all 0.5s ease;
}
#primary_menu li.menu-item-has-children > a::after {
	float: right;
	content: "\f107";
	font-family: 'FontAwesome';
	text-decoration: none;
	color: inherit;
	opacity: 0.5;
	font-size: 16px;
	padding-left: 8px;
	border: none;
	vertical-align: baseline;
}
#primary_menu ul li.menu-item-has-children > a::after {
	content: "\f105";
}
#primary_menu li:hover > a {
	color: var(--primary);
}
#primary_menu li.menu-item-has-children:hover > a {
	color: #fff;
	background-color: var(--primary);
}

/* Submenu */
#primary_menu ul {
	display: none;
}
#primary_menu li:hover > ul {
	display: block;
	position: absolute;
	top: 100%;
	left: 0;
	width: auto;
	min-width: 225px;
	margin: 0;
	padding: 10px 0;
	background-color: var(--primary);
	box-shadow: 0 2px 2px rgba(0,0,0,0.15);
}
#primary_menu ul li {
	float: none;
	display: block;
	margin: 0;
	padding: 0;
}
#primary_menu ul li a {
	color: #fff;
	line-height: 1;
	padding: 10px 20px;
}
#primary_menu ul li a:hover {
	opacity: 0.5;
}

/* Primary Current Page */
#primary_menu .current_page_item > a,
#primary_menu .current-menu-item > a,
#primary_menu .current_page_ancestor > a {
	color: var(--primary);
	font-weight: 700;
}
#primary_menu .current_page_item > a:hover,
#primary_menu .current-menu-item > a:hover,
#primary_menu .current_page_ancestor > a:hover {
}

#primary_menu ul .current_page_item > a,
#primary_menu ul .current-menu-item > a,
#primary_menu ul .current_page_ancestor > a {
	color: #fff;
	opacity: 0.5;
}

/* Footer Menu */
#footer_navigation {
	margin: 0 auto;
}
#footer_menu {
	margin: 0 auto;
	padding: 0;
	list-style-type: none;
}
#footer_menu li {
	display: block;
	margin: 0;
	line-height: 1;
}
#footer_menu li a {
	display: inline-block;
	color: #fff;
	padding: 0 0 10px;
	text-decoration: none;
	transition: all 0.5s ease;
}
#footer_menu li a:hover {
	opacity: 0.5;
}
#footer_menu .current_page_item > a,
#footer_menu .current-menu-item > a,
#footer_menu .current_page_ancestor > a {
	opacity: 0.5;
}

/*--------------------------------------------------------------
# Social Media Lists
--------------------------------------------------------------*/
.social-links {
	display: block;
	list-style-type: none;
	margin: 0 auto;
	padding: 0;
}
.social-links li {
	float: left;
	display: inline-block;
	margin: 0 5px;
	padding: 0;
	line-height: 0;
}
.social-links .fa {
	width: 36px;
	height: 36px;
	font-size: 16px;
	line-height: 16px;
	padding: 10px;
	color: #fff;
	text-align: center;
	vertical-align: middle;
	background-color: var(--primary);
	border-radius: 100%;
	transition: all 0.5s ease;
}
.social-links .fa:hover {
	background-color: var(--secondary);
}
span.hidden {
	position: absolute;
	overflow: hidden;
	clip: rect(0 0 0 0);
	height: 1px; 
	width: 1px;
	margin: -1px; 
	padding: 0; 
	border: 0;
}

/*--------------------------------------------------------
##	Accordion
--------------------------------------------------------*/
.accordion-toggle {
	width: 100%;
	margin: 0;
	cursor: pointer;
}
.accordion-toggle::before {
	content: '\f067';
	font-family: FontAwesome;
	font-size: 75%;
	color: var(--primary);
	margin-right: 0.75em;
}
.accordion-toggle.active::before {
	content: '\f068';
}
.accordion-toggle:focus,
.accordion-toggle:active {
	outline: none;
}
.accordion-content {
	display: none;
	padding: 1em 0 0;
}
.accordion-content p:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
## Numeric Pagination
--------------------------------------------------------------*/
.numeric-pagination {
	margin: 25px auto;
	padding: 0;
	text-align: center;
}
.numeric-pagination * {
	display: inline-block;
	vertical-align: middle;
}
.numeric-pagination .fa {
	margin: 0;
	padding: 0;
}
.numeric-pagination a {
	color: var(--primary);
	font-size: 16px;
	line-height: 1;
	margin: 0;
	width: 40px;
	height: 40px;
	padding: 12px;
	text-decoration: none;
	border: 1px solid #ccc;
	border-radius: 4px;
	transition: all 0.5s ease;
}
.numeric-pagination a:hover {
	color: #fff;
	background-color: var(--dark);
	border-color: var(--dark);
}
.numeric-pagination .dots {
	color: #ccc;
	margin: 0;
	padding: 0.25em 0.8125em;
}
.numeric-pagination .current {
	width: 40px;
	height: 40px;
	margin: 0;
	padding: 12px;
	color: #fff;
	font-size: 16px;
	line-height: 1;
	text-decoration: none;
	border: none;
	border-radius: 4px;
	background-color: var(--secondary);
}

/*--------------------------------------------------------------
## Posts/Comments Navigation
--------------------------------------------------------------*/
.site-main .comment-navigation,
.site-main .post-navigation {
	max-width: var(--content-width);
	margin: 0 auto;
	padding: 15px 0 0;
	border-top: 5px solid var(--dark);
	overflow: hidden;
}
.nav-links {
	width: 100%;
	display: inline-block;
	margin: 0;
}
.nav-previous,
.nav-next {
	width: 50%;
	max-width: 50%;
	padding: 0;
}
.nav-previous a,
.nav-next a {
	font-size: 1em;
	font-weight: 400;
	color: var(--dark);
}
.nav-previous a:hover,
.nav-next a:hover {
	color: var(--primary);
}
.comment-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	padding-right: 25px;
	border-right: 1px solid #ddd;
}
.comment-navigation .nav-previous img,
.post-navigation .nav-previous img {
	float: left;
	width: 120px;
	margin-right: 25px;
}
.comment-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	padding-left: 25px;
	text-align: right;
}
.comment-navigation .nav-next img,
.post-navigation .nav-next img {
	float: right;
	width: 120px;
	margin-left: 25px;
}

/* Custom Prev/Next Navigation */
.custom-post-navigation {
	width: auto;
	margin: 0 auto;
	padding: 0;
	line-height: 1;
	text-align: center;
}
.custom-post-navigation .nav-links {
	display: inline-block;
	width: auto;
	margin: 0 auto;
	padding: 0;
	border: 1px solid #ddd;
}
.custom-post-navigation a {
	float: left;
	width: 40px;
	height: 40px;
	padding: 10px;
	font-size: 20px;
	color: #777;
	text-align: center;
	line-height: 1;
	transition: all 0.5s ease;
}
.custom-post-navigation a:hover {
	color: var(--dark);
	background-color: var(--light);
}
.custom-post-navigation a:last-of-type {
	width: 39px;
	border-left: 1px solid #ddd;
}
.custom-post-navigation a:only-child {
	border: none;
}

/*--------------------------------------------------------------
## Back To Top
--------------------------------------------------------------*/
.back-to-top {
	position: fixed;
	bottom: 0;
	right: 0;
	width: 60px;
	height: 60px;
	display: none;
}
.back-to-top a {
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 20px;
	line-height: 1;
	padding: 20px;
	vertical-align: middle;
	background-color: var(--grey);
	transition: all 0.5s ease;
}
.back-to-top .fa {
	vertical-align: middle;
}
.back-to-top a:hover {
	background-color: var(--primary);
}

/*--------------------------------------------------------------
# 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: 4px;
	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. */
#content[tabindex="-1"]:focus {
	outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.alignleft {
	display: inline;
	float: left;
	margin-right: 1.5em;
}
.alignright {
	display: inline;
	float: right;
	margin-left: 1.5em;
}
.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.columns:before,
.columns:after {
	content: "";
	display: table;
	table-layout: fixed;
}
.clear:after,
.columns:after {
	clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
	margin: 0 auto;
}
.widget select {
	max-width: 100%;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Header
--------------------------------------------------------------*/
/* Site Header */
.site-header {
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 0 15px;
	background-color: var(--secondary);
	transition: all 0.5s ease;
	z-index: 8000;
}
.site-title {
	display: inline-block;
	margin: 0 auto;
	vertical-align: middle;
}
.site-title a,
.site-title img {
	display: block;
	vertical-align: middle;
}
.site-branding {
	flex: 0 1 100%;
	order: 1;
	padding: 15px 25px;
	text-align: center;
}
.site-logo {
	width: auto;
	height: 56px;
	transition: all 0.75s ease;
}

/* Header Contact */
.header-contact {
	flex: 0 1 100%;
	order: 2;
	text-align: center;
	margin-left: 25px;
	padding: 0 0 25px;
	transition: all 0.5s ease;
}
.header-contact * {
	display: inline-block;
	vertical-align: middle;
}
.header-phone .fa {
	margin-right: 8px;
	width: 36px;
	height: 36px;
	color: #fff;
	font-size: 16px;
	padding: 10px;
	text-align: center;
	background-color: var(--primary);
	border-radius: 100%;
}
.header-phone a:hover .fa {
	background-color: var(--secondary);
}
.header-phone a {
	color: #fff;
	text-decoration: none;
	transition: all 0.5s ease;
}

/* Header CTA */
.header-cta {
	flex: 0 1 auto;
	order: 4;
	padding: 20px 0;
	text-align: center;
}

/*--------------------------------------------------------------
## Pages
--------------------------------------------------------------*/
.page-header {
	margin: 0 auto;
	padding: 25px;
	text-align: center;
	border-bottom: 1px solid var(--light);
}

/* Gallery Title */
.gallery-page-title h1 {
	color: #fff;
	font-size: 7vw;
	font-weight: 700;
	text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}

/* Page Titles */
.page-title {
	color: var(--dark);
	font-size: 7vw;
	margin: 0 auto;
}
.title-lead {
	display: inline-block;
	font-size: 50%;
	font-weight: 400;
}
.title-lead a {
	font-weight: 400;
	text-decoration: none;
}
.title-lead a:hover {
	text-decoration: underline;
}
.title-lead::after {
	content: '\f105';
	font-family: 'FontAwesome';
	font-size: 50%;
	color: inherit;
	opacity: 0.5;
	margin: 0 1em;
}

/* Page Content */
.page-content {
	max-width: var(--content-width);
	margin: 0 auto;
}
.page-links {
	clear: both;
	margin: 0 0 1.5em;
}
.highlight-box {
	margin: 25px auto;
	padding: 25px;
	border-radius: 5px;
	border: 1px solid #ccc;
	background-color: var(--light);
}

/* Featured Images */
.featured-image {
	position: relative;
	margin: 0 auto 25px;
}

/* 404 Page */
.error-404,
.not-found {
	text-align: center;
}
.image-404 {
	max-width: 400px;
}

/*--------------------------------------------------------------
## Front Page
--------------------------------------------------------------*/
/* Hero Global */
#front_slider,
#front_hero {
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 0;
}
#front_hero .entry-thumbnail > img {
	z-index: 1001;
	display: block;
	position: absolute;
	top: 50%; 
	left: 0;
	width: 100%;
	height: auto;
	transform: translateY(-50%);
}
.hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
  	width: 100%;
  	height: 100%;
  	background-color: var(--dark);
  	opacity: 0.1;
	z-index: 1002;
}
.cta-block {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
  	width: 90%;
  	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	z-index: 1003;
	-webkit-backface-visibility: hidden;
}
.hero-title {
	font-size: 7vw;
	font-weight: 700;
	color: #fff;
	margin: 0 auto 10px;
	text-shadow: 0 2px 3px rgba(0,0,0,0.75);
}
.hero-subtitle {
	margin: 0 auto 15px;
	font-size: 3vw;
	text-shadow: 0 2px 3px rgba(0,0,0,0.75);
}
.cta-block .btn {
	margin: 5px 0;
	box-shadow: 0 2px 3px rgba(0,0,0,0.75);
}

/* Image Slider
--------------------------------------------------------------*/
#front_slider .home-slider {
	margin: 0 auto;
}

/* Single Image
--------------------------------------------------------------*/
#front_hero .entry-thumbnail.responsive,
#front_hero .entry-thumbnail.responsive img {
	border-radius: 0;
}

/* Content
--------------------------------------------------------------*/
.home #primary {
	text-align: center;
}

/* Video
--------------------------------------------------------------*/
#home_video {
	text-align: center;
}
#home_video h2 {
	margin: 0 auto 25px;
}
#home_video .video-wrapper {
	max-width: 480px;
	margin: 0 auto;
}
#home_video .btn {
	margin: 25px auto 0;
}

/* Testimonial
--------------------------------------------------------------*/
#testimonials {
	position: relative;
	text-align: center;
	background-color: var(--dark);
}
#testimonials h2 {
	color: #fff;
}
#testimonials p {
	margin: 0 auto 25px;
	padding: 0 25px;
	max-width: 800px;
	color: #fff;
}
.reviews-slider div:active,
.reviews-slider div:focus {
	outline: none;
}
.testimonial-reviewer {
	color: var(--grey);
	text-transform: none;
}
.testimonial-location {
	margin-left: 8px;
	color: #fff;
	font-size: 13px;
	font-weight: 400;
	text-transform: none;
}
.testimonial-rating {
	color: var(--primary);
}
.testimonial-rating .fa {
	font-size: 18px;
	padding: 2px;
}
.testimonial-rating .fa.empty {
	color: var(--grey);
}
#testimonials .entry-footer {
	margin-top: 25px;
}
.reviews-slider.slick-dotted.slick-slider {
    margin-bottom: 30px;
}
.reviews-slider .slick-prev:before,
.reviews-slider .slick-next:before {
	font-size: 40px;
	padding: 10px;
}

/* Latest News
--------------------------------------------------------------*/
#home_latest {
	margin: 0 auto;
	text-align: center;
}
.latest-news {
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
	margin: 0 auto;
}

/*--------------------------------------------------------------
## Instagram Feed
--------------------------------------------------------------*/
#instagram {
	text-align: center;
	background-color: var(--light);
}
#instagram h3 {
}
#instagram_feed {
	margin-bottom: 25px;
}
.insta-image {
	-ms-flex: 0 1 50%;
	-webkit-flex: 0 1 50%;
	flex: 0 1 50%;
	max-width: 50%;
	margin: 0;
	padding: 5px;
}
.insta-image .thumb-wrapper {
	position: relative;
	width: 100%;
	height: 0;
	margin: 0;
	padding-bottom: 100%;
	overflow: hidden;
}
.insta-image img {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: auto;
	transition: all 0.75s ease;
}
.insta-details {
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 100%;
	padding: 10px;
	transform: translateY(100%);
	background-color: rgba(175,30,43,0.85);
	transition: all 0.75s ease;
	overflow-y: scroll;
}
.insta-image:hover img {
	filter: grayscale(100%);
}
.insta-image:hover .insta-details {
	transform: translateY(0);
}
.insta-caption p {
	color: #fff;
	font-size: 14px;
	text-align: left;
	padding: 0;
}
.insta-caption a {
	color: #fff;
}
.insta-meta {
	color: #fff;
	font-size: 2em;
	text-align: left;
	padding: 0;
}
.insta-meta .fa {
	color: #fff;
	margin-right: 2px;
}

/*--------------------------------------------------------------
## FAQs
--------------------------------------------------------------*/
.faqs {
	margin: 10px auto 25px;
	padding: 0;
	text-align: left;
	border: 1px solid #ddd;
}
.faqs article {
	margin: 0;
	padding: 1em;
	border-top: 1px solid #ddd;
	transition: all 0.5s ease;
}
.faqs article:hover {
	background-color: #eee;
}
.faqs article:first-of-type {
	border-top: none;
}
.faqs article:last-of-type {
}
.faqs h3.accordion-toggle {
	font-size: 16px;
}

/*--------------------------------------------------------------
## Contact
--------------------------------------------------------------*/
ul.contact-info {
	list-style: none;
	margin: 0 auto 25px 30px;
	padding: 0;
}
ul.contact-info li {
	list-style-position: inside;
	text-indent: -20px;
}
.contact-cta {
	margin-bottom: 25px;
}
.contact-details .social-links {
	margin: 10px auto 25px;
}
.btn .fa-comment {
	opacity: 0.5;
	margin: 0 8px 0 0;
}

/* Location */
.map-wrapper {
	width: 100%;
	margin: 0 auto;
}
#location_map {
	position: relative;
	margin: 0;
	width: 100%;
	padding-bottom: 60%;
	overflow: hidden;
}
.google-map {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}
.marker {
	padding: 25px;
	font-size: 14px;
}
.marker p {
	margin: 0 auto 15px;
}
.marker a:not(.btn) {
	color: var(--dark);
}
.marker .fa {
	color: var(--secondary);
}
.marker .fa-map-marker {
	color: #fff;
	margin: 0 5px 0 0;
}
.map-logo {
	width: 200px;
	margin: 0 auto 15px;
}

/* Contact Form */
.quick-contact {
	background-color: var(--dark);
}
.quick-contact h2 {
	color: #fff;
}

/*--------------------------------------------------------------
## Posts
--------------------------------------------------------------*/
/* Archives */
article.archive {
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-ms-flex-direction: column;
	-ms-flex-wrap: wrap;
    -webkit-flex-direction: column;
    -webkit-flex-wrap: wrap;
	flex-flow: column wrap;
	-ms-flex: 0 1 100%;
	-webkit-flex: 0 1 100%;
	flex: 0 1 100%;
	margin: 0 0 25px;
	padding: 0;
	text-align: left;
	border-radius: 4px;
	background-color: #fff;
	box-shadow: 0 2px 4px rgba(0,0,0,0.25);
	transition: all 0.5s ease;
}
article.archive .entry-header {
	width: 100%;
	margin: 0;
	padding: 0 25px;
	border-radius: 4px 4px 0 0;
}
article.archive .entry-thumbnail,
article.archive .entry-thumbnail img {
	border-radius: 4px 4px 0 0;
}
h4.category a {
	font-size: 13px;
	text-decoration: none;
}
h4.category a:hover {
	color: var(--dark);
}
article.archive .entry-content {
	width: 100%;
	margin: 0;
	padding: 0 25px;
}
article.archive h3 {
	font-size: 1.25em;
}
article.archive .entry-content p {
	margin: 0;
}
article.archive .entry-content a {
	color: var(--dark);
	font-weight: 400;
	text-decoration: none;
}
article.archive .entry-footer {
	width: 100%;
	margin: auto 0 0;
	padding: 25px;
}
span.entry-date {
	float: right;
	margin-top: 15px;
	font-size: 12px;
	color: var(--grey);
}

/* Single Posts */
.sticky {
	display: block;
}
.hentry {
	margin: 0 0 1.5em;
}
.byline,
.updated:not(.published) {
	display: none;
}
.single .byline,
.group-blog .byline {
	display: inline;
}
.single-post .entry-title {
	margin-bottom: 25px;
}
.entry-meta {
	color: #999;
	margin: 0 auto 10px;
	padding: 10px 0;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}
.thumb-wrapper {
	width: 100%;
	margin: 0 auto 25px;
}
.entry-thumbnail {
	position: relative;
	width: 100%;
	margin: 0;
	overflow: hidden;
}
.entry-thumbnail img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}
.entry-thumbnail.responsive {
	position: relative;
	height: 0;
	padding-bottom: 55%;
}
.entry-thumbnail.responsive img {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
.entry-thumbnail a {
	display: block;
}
.entry-header,
.entry-meta,
.entry-content,
.entry-summary,
.entry-footer {
	margin: 0 auto;
	max-width: var(--content-width);
}
.single-post .entry-footer {
	padding: 25px 0;
	text-transform: uppercase;
}

/*--------------------------------------------------------------
## Footer
--------------------------------------------------------------*/
/* Footer CTA */
#footer_cta {
	text-align: center;
	background-color: var(--light);
}
#footer_cta * {
	vertical-align: middle;
}
#footer_cta h2 {
	display: inline-block;
	margin: 0 auto;
	color: var(--secondary);
	font-weight: 200;
	text-transform: none;
}
#footer_cta .btn {
	margin: 25px 0 0;
}

/* Site Footer */
.site-footer {
	width: 100%;
	background-color: #fff;
}

/* Footer Widgets */
.footer-widget-area {
	width: 100%;
}
.footer-widget-area .widget {
	-ms-flex: 0 1 100%;
	-webkit-flex: 0 1 100%;
	flex: 0 1 100%;
	margin: 0 0 25px;
	padding: 0 25px;
	text-align: center;
}
.footer-widget-area .widget h3 {
	margin: 0 auto 25px;
}

/* Footer Branding */
img.footer-logo {
	width: 100%;
	max-width: 240px;
}

/* Footer Contact */
.footer-contact .contact-info {
	text-align: center;
	margin: 0;
}
.footer-contact .contact-info a {
	color: var(--primary);
}
.footer-contact .social-links {
	margin-top: 15px;
	text-align: center;
}
.footer-contact .social-links li {
	float: none;
	margin: 0 5px;
}

/* Footer Search */

/* Payment Methods */
#payments_accepted {
	text-align: center;
	border-top: 1px solid var(--light);
}
.payment-methods {
	list-style: none;
	margin: 0 auto;
}
.payment-methods li {
	display: inline-block;
	margin: 0 5px;
}
.payment-methods li img {
	height: 40px;
}

/* Site Info */
.site-info {
	margin: 0 auto;
	padding: 24px;
	border-top: 1px solid var(--light);
}
.site-info p {
	max-width: 1200px;
	margin: 0 auto;
	font-size: 12px;
	color: var(--grey);
	line-height: 1;
}
.webdev {
	display: inline-block;
	color: var(--grey);
	padding: 10px 0 0;
}
.webdev a {
	color: var(--grey);
	font-weight: 400;
}
.webdev a:hover {
	color: var(--dark);
}

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
	word-wrap: break-word;
}
.bypostauthor {
	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;
}
embed,
iframe,
object {
	max-width: 100%;
}
.embed-container {
	position: relative;
	margin: 0;
	width: 100%;
	height: 0;
	padding-bottom: 56.25%;
	overflow: hidden;
}
.embed-container embed,
.embed-container iframe,
.embed-container object {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	max-width: 100%;
	height: 100%;
}

/* Gallery Slider */
#photo_gallery {
	margin: 0 auto 25px;
}
#photo_gallery .gallery-slider {
	margin: 0 auto;
}
#photo_gallery .gallery-slider img {
	width: 100%;
}

/* Gallery Lightbox */
.gallery-lightbox {
	margin: 0 auto;
}
.gallery-lightbox .thumb-wrapper {
	float: left;
	width: calc(50% - 5px);
	margin: 0 5px 5px 0;
	padding: 0;
}

/*--------------------------------------------------------------
## Documents/Attachments
--------------------------------------------------------------*/
#documents {
	max-width: 600px;
	margin: 25px 0;
	padding: 0;
}
.files-heading {
}
.file-list {
	list-style-type: none;
	margin: 0;
	padding: 0;
	border: 1px solid #ddd;
}
.file-list li {
	margin: 0;
	padding: 20px;
	border-top: 1px solid #ddd;
	transition: all 0.5s ease;
}
.file-list li:first-of-type {
	border-top: none;
}
.file-list li:hover {
	background: var(--light);
}
.file-specs * {
	vertical-align: middle;
}
.file-specs {
	color: #777;
	text-transform: uppercase;
}
.file-specs .fa {
	color: #bbb;
	font-size: 30px;
	margin-right: 10px;
	transition: all 0.5s ease;
}
.file-specs .fa:hover {
	color: var(--secondary);
}

/*--------------------------------------------------------------
## 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.33%;
}
.gallery-columns-4 .gallery-item {
	max-width: 25%;
}
.gallery-columns-5 .gallery-item {
	max-width: 20%;
}
.gallery-columns-6 .gallery-item {
	max-width: 16.66%;
}
.gallery-columns-7 .gallery-item {
	max-width: 14.28%;
}
.gallery-columns-8 .gallery-item {
	max-width: 12.5%;
}
.gallery-columns-9 .gallery-item {
	max-width: 11.11%;
}
.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Media Queries
--------------------------------------------------------------*/

/* 	480px Breakpoint	*/
@media only screen and (min-width: 480px) {

}

/* 	600px Breakpoint	*/
@media only screen and (min-width: 600px) {

h1 {
	font-size: 2.5em;
}
h2 {
	font-size: 1.75em;
}
h3 {
	font-size: 1.25em;
}
.site-branding {
	flex: 0 1 auto;
	margin: 0;
	padding: 15px 0;
	text-align: left;
}
.header-contact {
	flex: 0 1 auto;
	margin-right: auto;
	padding: 25px 0;
}
#front_hero .entry-thumbnail.responsive,
#location_map {
	padding-bottom: 50%;
}
article.archive {
	-ms-flex: 0 1 48%;
	-webkit-flex: 0 1 48%;
	flex: 0 1 48%;
	max-width: 48%;
	margin: 0 1% 25px;
}
.gallery-lightbox .thumb-wrapper {
	width: calc(33.33% - 5px);
}
.file-list br {
	display: none;
}
.file-specs {
	float: right;
}
.footer-widget-area .widget {
	-ms-flex: 0 1 50%;
	-webkit-flex: 0 1 50%;
	flex: 0 1 50%;
	max-width: 50%;
	margin: 0;
	padding: 25px 25px 25px 0;
}
.footer-widget-area .widget.footer-contact {
	-ms-flex: 2 1 100%; 
	-webkit-flex: 2 1 100%; 
	flex: 2 1 100%; 
	max-width: 100%;
	order: 3;
}
.nf-form-cont .one-half,
.nf-form-cont .three-sixths,
.nf-form-cont .two-fourths {
	width: 48.717948717948715% !important;
}

}

/* 	700px Breakpoint	*/
@media only screen and (min-width: 700px) {

.cta-block.left {
	text-align: left;
}
.cta-block.right {
	text-align: right;
}
.cta-block.left .hero-title,
.cta-block.left .slide-title,
.cta-block.left .slide-text p {
	padding-right: 40%;
}
.cta-block.right .hero-title,
.cta-block.right .slide-title,
.cta-block.right .slide-text p {
	padding-left: 40%;
}
#primary,
#secondary,
.outer-wrapper {
	padding: 50px;
}
.columns > .column {
	float: left;
	width: 49%;
	max-width: 49%;
	margin: 0;
	padding: 0;
}
.columns > .column:nth-child(even) {
	float: right;
}
.insta-image {
	-ms-flex: 0 1 33%;
	-webkit-flex: 0 1 33%;
	flex: 0 1 33%;
	max-width: 33%;
	padding: 7px;
}
.insta-details {
	padding: 15px;
}

}

/* 	800px Breakpoint	*/
@media only screen and (min-width: 800px) {

#primary.sidebar {
	float: left;
	width: 70%;
}
#secondary {
	float: right;
	width: auto;
	width: 30%;
	max-width: 30%;
	border: none;
}
#front_hero .entry-thumbnail.responsive,
#location_map {
	padding-bottom: 45%;
}
#home_video .video-wrapper {
	max-width: 640px;
}
.highlight-box {
	padding: 50px;
}
.gallery-lightbox .thumb-wrapper {
	width: calc(25% - 5px);
}
table thead th,
table tr td {
	padding: 10px 25px;
}
#footer_cta br,
.site-info br {
	display: none;
}
#footer_cta .btn {
	margin: 0 0 0 25px;
}
.webdev {
	float: right;
	padding: 0 60px 0 25px;
}

}

/* 	1000px Breakpoint	*/
@media only screen and (min-width: 1000px) {

h1 {
	font-size: 3em;
}
h2 {
	font-size: 2em;
}
h3 {
	font-size: 1.5em;
}
.site-header {
	position: fixed;
	top: 0;
}
.home .site-header:not(.reduced) {
	padding: 25px 0;
	background-color: transparent;
	background-image: linear-gradient(to bottom, black 0%, transparent 100%);
}
.reduced {
	padding: 0;
	background-color: var(--secondary);
}
.reduced .site-logo {
	width: auto;
	height: 40px;
}
.reduced .header-contact {
	padding: 17px 0;
}
.reduced .header-cta {
	padding: 12px 0;
}
.reduced #primary_menu li a {
	padding: 17px 15px;
}
.main-navigation {
	display: flex;
	order: 3;
	margin-left: auto;
}
.page-header {
	padding: 111px 25px 50px;
}
#front_hero .entry-thumbnail.responsive,
#location_map {
	padding-bottom: 40%;
}
.cta-block {
	top: 57.5%;
}
.hero-title,
.page-title,
.gallery-page-title {
	font-size: 72px;
}
.map-wrapper {
	padding-top: 85px;
}
.featured-image .entry-thumbnail.responsive {
	padding-bottom: 45%;
}
#photo_gallery .slide-wrapper {
	padding-bottom: 50%;
}
.gallery-lightbox .thumb-wrapper {
	width: calc(20% - 5px);
}
article.archive,
.latest-news article.archive {
	-ms-flex: 0 1 30%;
	-webkit-flex: 0 1 30%;
	flex: 0 1 30%;
	max-width: 30%;
	margin: 0 1% 25px;
}
.insta-details {
	padding: 20px;
}
.footer-widget-area .widget {
	-ms-flex: 0 1 25%;
	-webkit-flex: 0 1 25%;
	flex: 0 1 25%;
}
.footer-widget-area .widget.footer-branding {
	order: 1;
}
.footer-widget-area .widget.footer-contact {
	-ms-flex: 2 1 50%; 
	-webkit-flex: 2 1 50%; 
	flex: 2 1 50%; 
	max-width: 50%;
	order: 2;
}
.footer-widget-area .widget.footer-search {
	order: 3;
}
.footer-search {
	text-align: right;
}

}

/* 	1200px Breakpoint	*/
@media only screen and (min-width: 1200px) {

#primary,
#secondary,
.outer-wrapper {
	padding: 75px;
}
.featured-image .entry-thumbnail.responsive {
	padding-bottom: 40%;
}
#photo_gallery .slide-wrapper {
	padding-bottom: 45%;
}
article.archive {
	-ms-flex: 0 1 23%;
	-webkit-flex: 0 1 23%;
	flex: 0 1 23%;
	max-width: 23%;
}
.insta-image {
	-ms-flex: 0 1 25%;
	-webkit-flex: 0 1 25%;
	flex: 0 1 25%;
	max-width: 25%;
	padding: 10px;
}
.insta-details {
	padding: 25px;
}
#location_map {
	padding-bottom: 35%;
}

}

/* 	1400px Breakpoint	*/
@media only screen and (min-width: 1400px) {

h1 {
	font-size: 3.5em;
}
h2 {
	font-size: 2.25em;
}
.featured-image .entry-thumbnail.responsive {
	padding-bottom: 35%;
}
.webdev {
	padding: 0;
}

}
