/*
Theme Name: Perfection Painting Pros
Author: Aubrey Strother | Crafted by Aubrey
Author URI: https://www.craftedbyaubrey.com
Description: A custom WordPress theme for Perfection Painting Pros.
Version: 1.0
*/

/* =Reset
-------------------------------------------------------------- */
*, *:before, *:after {
  -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box;
 }
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}
html {
	background: #fff;
	font-size: 62.5%; /* Corrects text resizing oddly in IE6/7 when body font-size is set using em units http://clagnut.com/blog/348/#c790 */
	overflow-y: scroll; /* Keeps page centred in all browsers regardless of content height */
	-webkit-text-size-adjust: 100%; /* Prevents iOS text size adjust after orientation change, without disabling user zoom */
	-ms-text-size-adjust: 100%; /* www.456bereastreet.com/archive/201012/controlling_text_size_in_safari_for_ios_without_disabling_user_zoom/ */
}
body {
	background: #fff;
	font-family: brandon-grotesque, sans-serif;
	font-weight: 400;
	width: auto;
	-webkit-backface-visibility: hidden;
	-webkit-font-smoothing: antialiased;
	overflow: hidden;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
nav,
section {
	display: block;
}
ol, ul {
	list-style: none;
}
table { /* tables still need 'cellspacing="0"' in the markup */
	border-collapse: separate;
	border-spacing: 0;
}
caption, th, td {
	font-weight: normal;
	text-align: left;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: "";
}
blockquote, q {
	quotes: "" "";
}
a:focus {
	outline: thin dotted;
}
a:hover,
a:active { /* Improves readability when focused and also mouse hovered in all browsers people.opera.com/patrickl/experiments/keyboard/test */
	outline: 0;
}
a img {
	border: 0;
}




/* =Global
----------------------------------------------- */
body,
button,
input,
select,
textarea {
	color: #404040;
	font-family: sans-serif;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
}

/* Headings */
h1,h2,h3,h4,h5,h6 {
	clear: both;
}
hr {
	background-color: #535456;
	border: 0;
	height: 2px;
	margin: 3em 0;
}

/* Text elements */
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;
}
ol li, ul li {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1em;
	color: #282828;
}
dt {
	font-weight: bold;
}
dd {
	margin: 0 1.5em 1.5em;
}
b, strong {
	font-weight: bold;
}
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: 1.5rem;
	line-height: 1.6;
	margin-bottom: 1.6em;
	padding: 1.6em;
	overflow: auto;
	max-width: 100%;
}
code, kbd, tt, var {
	font: 15px Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}
abbr, acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}
mark, ins {
	background: #fff9c0;
	text-decoration: none;
}
sup,
sub {
	font-size: 75%;
	height: 0;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
sup {
	bottom: 1ex;
}
sub {
	top: .5ex;
}
small {
	font-size: 75%;
}
big {
	font-size: 125%;
}
figure {
	margin: 0;
}
table {
	margin: 0 0 1.5em;
	width: 100%;
}
th {
	font-weight: bold;
}
img {
	height: auto; /* Make sure images are scaled correctly. */
	max-width: 100%; /* Adhere to container width. */
	height: auto;
	vertical-align: middle;
}
img,
object,
embed {
  max-width: 100%;
}
button,
input,
select,
textarea {
	font-size: 100%; /* Corrects font size not being inherited in all browsers */
	margin: 0; /* Addresses margins set differently in IE6/7, F3/4, S5, Chrome */
	vertical-align: baseline; /* Improves appearance and consistency in all browsers */
	*vertical-align: middle; /* Improves appearance and consistency in all browsers */
}
button,
input {
	line-height: normal; /* Addresses FF3/4 setting line-height using !important in the UA stylesheet */
}
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	display: inline-block;
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #fff;
	background:  #598fab;
	padding: 0.6em 2em 0.5em;
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: 40px;
	outline: none;
	border: none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
button:hover,
html input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	outline: none;
	background: #477e96;
}
button:focus,
html input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
button:active,
html input[type="button"]:active,
input[type="reset"]:active,
input[type="submit"]:active {
	border: none;
	box-shadow: none;
}
input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box; /* Addresses box sizing set to content-box in IE8/9 */
	padding: 0; /* Addresses excess padding in IE8/9 */
}
input[type="search"] {
	-webkit-appearance: textfield; /* Addresses appearance set to searchfield in S5, Chrome */
	-webkit-box-sizing: content-box; /* Addresses box sizing set to border-box in S5, Chrome (include -moz to future-proof) */
	-moz-box-sizing:    content-box;
	box-sizing:         content-box;
}
input[type="search"]::-webkit-search-decoration { /* Corrects inner padding displayed oddly in S5, Chrome on OSX */
	-webkit-appearance: none;
}
button::-moz-focus-inner,
input::-moz-focus-inner { /* Corrects inner padding and border displayed oddly in FF3/4 www.sitepen.com/blog/2008/05/14/the-devils-in-the-details-fixing-dojos-toolbar-buttons/ */
	border: 0;
	padding: 0;
}
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="search"],
textarea {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1em;
	color: #535456;
	border: 2px solid #282828;
	background: #fff;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus {
	color: #282828;
	outline: none;
}
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="password"],
input[type="search"] {
	padding: 10px;
}
textarea {
	overflow: auto; /* Removes default vertical scrollbar in IE6/7/8/9 */
	padding-left: 10px;
	vertical-align: top; /* Improves readability and alignment in all browsers */
	width: 98%;
}
form legend, form label {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 600;
	font-style: normal;
	font-size: 1em;
	color: #282828;
}

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

/* Text meant only for screen readers */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
}

.screen-reader-text:hover,
.screen-reader-text:active,
.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-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 */
}

/* Clearing */
/* .clear:before,
.clear:after,
[class*="content"]:before,
[class*="content"]:after,
[class*="site"]:before,
[class*="site"]:after {
	content: '';
	display: table;
} */

.clear:after,
[class*="content"]:after,
[class*="site"]:after {
	clear: both;
}


/*********************************
	Global Styles
*********************************/
p {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	line-height: 1.5;
	margin-bottom: 1.5em;
}
p.page-intro {
	color: #535456;
	font-size: 1.25em;
}
a, a:visited {
	color: #282828;
	outline: none;
	text-decoration: underline;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a:hover, a:focus, a:active {
	outline: none;
	text-decoration: none;
}
a.button {
	display: inline-block;
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #fff;
	background:  #598fab;
	padding: 0.6em 2em 0.5em;
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: 40px;
	outline: none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a.button:hover, a.button:focus, a.button:active {
	outline: none;
	background: #477e96;
}
a.button.white-button {
	background: #fff;
	color: #282828;
}
a.button.white-button:hover, a.button.white-button:focus, a.button.white-button:active {
	background: #edeeef;
}
a.button.outline-button {
	background: transparent;
	color: #282828;
	border: 2px solid #282828;
}
a.button.outline-button:hover, a.button.outline-button:focus, a.button.outline-button:active {
	background: #282828;
	color: #fff;
}
a.text-link {
	display: inline-block;
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	line-height: 1.25;
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
	outline: none;
	padding-bottom: 5px;
	border-bottom: 2px solid #282828;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a.text-link:hover, a.text-link:focus, a.text-link:active {
	border-color: transparent;
}
h1, span.h1 {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 4.5em;
	color: #282828;
	line-height: 1.1;
	margin-bottom: 0.25em;
}
span.h1 {
	display: block;
	margin-bottom: 0.25em;
}
h2, span.h2 {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 3em;
	color: #282828;
	line-height: 1.1;
	margin-bottom: 0.25em;
}
span.h2 {
	display: block;
	margin-bottom: 0.25em;
}
h3, span.h3 {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 2.375em;
	color: #282828;
	line-height: 1.1;
	margin-bottom: 0.5em;
}
span.h3 {
	display: block;
	margin-bottom: 0.5em;
}
h4, span.h4 {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 2em;
	color: #282828;
	line-height: 1.25;
	margin-bottom: 0.5em;
}
span.h4 {
	display: block;
	margin-bottom: 0.5em;
}
h5, span.h5 {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1.5em;
	color: #282828;
	line-height: 1.5;
	margin-bottom: 0.5em;
}
span.h5 {
	display: block;
	margin-bottom: 0.5em;
}
h6, span.h6 {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	line-height: 1.25;
	letter-spacing: 2px;
	text-transform: uppercase;
	margin-bottom: 0.5em;
}
span.h5 {
	display: block;
	margin-bottom: 0.5em;
}
h1 a, span.h1 a, h2 a, span.h2 a, h3 a, span.h3 a, h4 a, span.h4 a, h5 a, span.h5 a, h6 a, span.h6 a {
	color: #282828;
	text-decoration: none;
}
.two-column {
	-webkit-column-count: 2;
    -moz-column-count: 2;
    column-count: 2;
}
.three-column {
	-webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
}
.upper {
	letter-spacing: 1px;
	text-transform: uppercase;
}
.right {
	text-align: right;
}
.center {
	text-align: center;
}
.black {
	color: #282828;
}
.blackBG {
	background: #282828;
}
.gray { 
	color: #535456 !important;
}
.grayBG {
	background: #edeeef;
}
.white {
	color: #fff !important;
}
.whiteBG {
	background: #fff;
}
.blue {
	color: #598fab !important;
}
.blueBG {
	background: #598fab;
}
.darkblue {
	color: #477e96;
}
.darkblueBG {
	background: #477e96;
}
.index-wrap {
	position: relative;
	z-index: 3;
}
.flex-wrap {
	display: flex;
	flex-wrap: wrap;
}
.gap {
	gap: 30px;
}
.bigGap {
	gap: 80px;
}
.dark-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.25);
	z-index: 2;
}
.background-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

	
/*********************************
	Header Styles
*********************************/
.mobile-menu {
	position: fixed;
	top: 0;
	right: -100%;
	widtH: 50%;
	height: 100vh;
	padding: 4em;
	z-index: 99;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.mobile-menu.active {
	right: 0;
}
nav.mobile ul {
	margin: 0;
}
nav.mobile li {
	position: relative;
	list-style: none;
	display: block;
	margin-bottom: 0.25em;
}
nav.mobile li a {
	font-family: adobe-caslon-pro, serif;
	font-weight: 700;
	font-style: normal;
	font-size: 2em;
	color: #fff;
	text-decoration: none;
}
nav.mobile li a:hover, nav.mobile li.current-menu-item a {
	opacity: 0.6;
}
nav.mobile ul li.menu-button {
	margin: 2em 0 3em;
}
nav.mobile ul li.menu-button a {
	color: #fff;
	background:  #598fab;
	padding: 0.5em 2em;
	border-radius: 40px;
	font-weight: 700;
	font-family: brandon-grotesque, sans-serif;
	font-style: normal;
	font-size: 1em;
	color: #fff;
	letter-spacing: 1px;
	text-transform: uppercase;
}
nav.mobile ul li.menu-button a:hover {
	color: #fff;
	background: #477e96;
}
nav.mobile ul li.menu-item-has-children a:after {
	content: ' +';
}
nav.mobile ul li.active a:after {
	content: ' -';
}
nav.mobile ul li ul.sub-menu {
	display: none;
	margin-bottom: 1em;
	margin-left: 1em;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
nav.mobile ul li.active ul.sub-menu {
	display: block;
}
nav.mobile ul li ul.sub-menu li a:after {
	display: none;
}
nav.mobile ul li ul.sub-menu li a {
	font-family: brandon-grotesque, sans-serif;
	font-style: normal;
	font-size: 1em;
	color: #fff;
	letter-spacing: 1px;
	text-transform: uppercase;
}
.mobile-menu ul.social {
	margin-top: 3sem;
}
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	border-bottom: 2px solid #282828;
	z-index: 98;
}
.site-header a {
	text-decoration: none;
}
.header-bar {
	position: relative;
	padding: 0.35em 0;
}
.bar-left {
	display: inline-block;
	vertical-align: middle;
	width: calc(50% - 5px);
}
.bar-left h6 {
	font-size: 1em;
	margin: 0;
	display: inline-block;
	vertical-align: middle;
}
.bar-left p {
	font-size: 1em;
	margin: 0;
	display: inline-block;
	vertical-align: middle;
}
.bar-right {
	display: inline-block;
	vertical-align: middle;
	width: calc(50% - 5px);
}
.bar-right p {
	font-size: 1em;
	margin: 0 0.25em 0 0;
}
.bar-right a {
	font-size: 1.55em;
	color: #598fab;
	font-weight: 700;
	text-decoration: none;
}
.main-header {
	position: relative;
	padding: 0.5em 0 0.75em;
}
.main-header .logo {
	max-width: 245px;
	display: inline-block;
	vertical-align: middle;
}
nav.main {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 250px);
}
nav.main ul {
	margin: 0;
}
nav.main ul li {
	position: relative;
	list-style: none;
	display: inline-block;
	vertical-align: middle;
	margin-left: 2em;
}
nav.main ul li:nth-child(1) {
	margin: 0;
}
nav.main ul li.menu-button a {
	color: #fff;
	background:  #598fab;
	padding: 0.5em 2em;
	border-radius: 40px;
	font-weight: 700;
}
nav.main ul li.menu-button a:hover {
	color: #fff;
	background: #477e96;
}
nav.main ul li a {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	letter-spacing: 1px;
	text-transform: uppercase;
	padding-bottom: 2em;
}
nav.main ul li.menu-item-has-children a:after {
	content: ' +';
}
nav.main ul li.current-menu-item a {
	font-weight: 700;
}
nav.main ul li a:hover {
	color: #598fab;
}
nav.main ul li ul.sub-menu {
	max-height: 0;
	overflow: hidden;
	position: absolute;
	margin: 1em 0 0 0;
	padding: 0;
	text-align: left !important;
	z-index: 99;
	left: 50%;
	transform: translate(-50%,0);
}
nav.main ul li ul.sub-menu:before {
	content: '';
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translate(-50%,0);
	width: 0; 
	height: 0; 
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	border-bottom: 8px solid #282828;
}
nav.main ul li:hover ul.sub-menu {
	display: block;
	max-height: 1000px;
	min-width: 20em;
	background: #282828;
	padding: 1em 1.5em;
	text-align: center;
	overflow: visible;
}
nav.main ul li ul.sub-menu li {
	margin: 0;
	display: block;
	width: 100%;
	line-height: 1;
	margin: 0.5em 0;
	padding: 0;
}
nav.main ul li ul.sub-menu li a:after {
	display: none;
}
nav.main ul li ul.sub-menu li a, nav.main ul li.current-menu-item ul li a {
	color: #fff;
	font-size: 1.25em;
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	text-transform: none;
	padding: 0;
}
nav.main ul li ul.sub-menu li a:hover, nav.main ul li.current-menu-item ul li a:hover, nav.main ul li ul li.current-menu-item a {
	color: #598fab;
}
.nav-button {
	display: none;
	position: absolute;
	top: calc(50% - 20px);
	right: 2em;
	height: 40px;
	width: 40px;
	border-radius: 50%;
	cursor: pointer;
	-webkit-transition: 0.2s ease;
	-moz-transition: 0.2s ease;
	-o-transition: 0.2s ease;
	transition: 0.2s ease;
}
.nav-button .first, .nav-button .second, .nav-button .third {
	position: absolute;
	left: 50%;
	width: 50%;
	transform: translate(-50%,0);
	height: 2px;
	background: #fff;
	border-radius: 4px;
	-webkit-transition: 0.2s ease;
	-moz-transition: 0.2s ease;
	-o-transition: 0.2s ease;
	transition: 0.2s ease;
}
.nav-button .first {
	top: 15px;
}
.nav-button .second {
	bottom: 15px;
}


/*********************************
	Banner Styles
*********************************/
.page-banner {
	position: relative;
}
ul.banner-slides {
	margin: 0;
}
ul.banner-slides li.banner-slide {
	position: relative;
	list-style: none;
	padding: 8em 2em;
}
ul.banner-slides li.banner-slide h6 {
	margin-bottom: 2em;
}
ul.banner-slides li.banner-slide h1 {
	max-width: 925px;
	margin: 0 auto 0.5em;
}
ul.banner-slides .slick-track {
	display: flex !important;
}
ul.banner-slides .slick-slide {
	height: inherit !important;
}
.default-banner {
	padding: 4em 2em 2em;
}
.reverse-banner {
	padding: 4em 2em;
}
.reverse-banner h6 {
	margin-bottom: 1.5em;
}
.reverse-banner h2 {
	max-width: 950px;
	margin: 0 auto;
}
.overlay-banner {
	padding: 14em 2em;
}
.overlay-banner h6 {
	margin-bottom: 1.5em;
}
.overlay-banner h1 {
	max-width: 875px;
	margin: 0 auto;
}
.content-banner {
	position: relative;
	padding: 4em 2em 2em;
}
.content-banner h6 {
	margin-bottom: 1.5em;
}
.content-banner h1 {
	max-width: 875px;
	margin: 0 auto;
}
.content-banner p {
	font-size: 1.45em;
	max-width: 875px;
	margin: 0 auto;
}
ul.search-posts {
	margin: 0;
}
ul.search-posts li {
	position: relative;
	list-style: none;
	width: calc(33.33% - 20px);
	padding: 2em;
}


/*********************************
	Content Styles
*********************************/
.site-main {
	margin-top: 142px;
}
.site-content, .og-content, .basic-content {
	position: relative;
	padding: 6em 0 4.5em;
}
.gallery-content h6 {
	margin-bottom: 1em;
}
ul.gallery-images {
	margin: 4em 0 0;
}
ul.gallery-images li {
	position: relative;
	list-style: none;
	margin-bottom: 30px;
	cursor: pointer;
}
.image-pop {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	background: rgba(0,0,0,0.8);
	z-index: -1;
	opacity: 0;
	-webkit-transition: 0.3s ease;
	-moz-transition: 0.3s ease;
	-o-transition: 0.3s ease;
	transition: 0.3s ease;
}
.image-pop.active {
	opacity: 1;
	z-index: 999;
}
.image-pop .close .left, .image-pop .close .right {
	background: #fff;
}
.image-pop img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	max-width: 90%;
	max-height: 90%;
	border: 20px solid #fff;
}
.close {
	position: absolute;
	top: 2.5em;
	right: 2em;
	width: 20px;
	height: 20px;
	cursor: pointer;
}
.close .left, .close .right {
	position: absolute;
	top: 0;
	width: 20px;
	height: 2px;
	background: #fff;
	border-radius: 4px;
	z-index: 999;
}
.close .left {
	left: 0;
	transform: rotate(45deg);
}
.close .right {
	right: 0;
	transform: rotate(-45deg);
}
ul.posts {
	margin: 0;
}
ul.posts li.post {
	position: relative;
	list-style: none;
	width: calc(33.33% - 20px);
	padding: 15px;
}
ul.posts li.post .post-image {
	position: relative;
	display: block;
	width: 100%;
	padding-bottom: 100%;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
ul.posts li.post .post-image:hover {
	filter: brightness(65%);
}
ul.posts li.post .post-image a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
ul.posts li.post .post-content {
	padding: 2em 2em 1em;
}
.site-content.post-content {
	position: relative;
	padding: 6em 0;
}
.post-content .post-image {
	display: block;
	width: 110%;
	margin: 2em 0 2em -5%;
	padding-bottom: 65%;
}
.cats h6, .cats p {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	margin: 0;
}
#nav-below {
	margin-top: 2em;
	clear: both;
}
#nav-below a {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	line-height: 1.25;
	letter-spacing: 2px;
	text-transform: uppercase;
	text-decoration: none;
}
.nav-previous {
	float: left;
	width: 50%;
	text-align: left;
}
.nav-next {
	float: right;
	width: 50%;
	text-align: right;
}


/*********************************
	Module Styles
*********************************/
.basic-content.blueBG h1, .basic-content.blueBG h2, .basic-content.blueBG h3, .basic-content.blueBG h4, .basic-content.blueBG h5, .basic-content.blueBG h6, .basic-content.blueBG p, .basic-content.blueBG ol li, .basic-content.blueBG ul li, .basic-content.blueBG a,
.basic-content.blackBG h1, .basic-content.blackBG h2, .basic-content.blackBG h3, .basic-content.blackBG h4, .basic-content.blackBG h5, .basic-content.blackBG h6, .basic-content.blackBG p, .basic-content.blackBG ol li, .basic-content.blackBG ul li, .basic-content.blackBG a {
	color: #fff;
}
.content-boxes {
	position: relative;
	padding: 2em 0;
}
.content-boxes .module-title {
	position: relative;
	display: inline-block;
	margin: 0;
	padding: 0 1.5em 0.75em;
	z-index: 2;
}
ul.boxes {
	position: relative;
	margin: -23px 0;
	border-top: 2px solid #282828;
	width: calc(100% + 2px);
	z-index: 1;
}
ul.boxes li {
	position: relative;
	list-style: none;
	display: inline-block;
	vertical-align: middle;
	border-right: 2px solid #282828;
	border-bottom: 2px solid #282828;
	padding: 4em 2.5em;
}
ul.boxes li p {
	margin: 0;
}
.content-boxes a.button {
	position: relative;
	z-index: 2;
}
.content-boxes.grayBG a.button {
	background: #edeeef !important;
}
.content-boxes.whiteBG a.button {
	background: #fff !important;
}
.content-boxes.grayBG a.button:hover, .content-boxes.whiteBG a.button:hover {
	background: #282828 !important;
}
.image-content-accordion {
	position: relative;
	padding: 4em 0;
}
.image-content-accordion .flex-wrap {
	align-items: center;
}
.image-content-accordion.img-right .flex-wrap {
	direction: rtl;
}
.image-content-accordion .image-image {
	width: calc(50% - 40px);
	display: block;
	padding-bottom: 56.25%;
}
.image-content-accordion .content-content {
	direction: ltr;
	width: calc(50% - 40px);
	padding: 2em 0;
}
.image-content-accordion .content-content h6 {
	margin-bottom: 1.5em;
}
ul.accordion-items {
	margin: 1.5em 0 0;
	max-width: 768px;
}
ul.accordion-items li.accordion-item {
	position: relative;
	list-style: none;
	display: block;
	padding: 0.75em 1.5em;
	border-radius: 30px;
	margin-bottom: 10px;
	background: #598fab;
	cursor: pointer;
}
ul.accordion-items li.accordion-item:nth-child(2n+2) {
	background: #477e96;
}
ul.accordion-items li.accordion-item .accordion-title {
	position: relative;
	padding: 0 4em 0 0;
	margin: 0;
}
ul.accordion-items li.accordion-item .accordion-title span.indicator {
	position: absolute;
	top: 5px;
	right: 0;
	height: 18px;
	width: 18px;
	cursor: pointer;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
ul.accordion-items li.accordion-item .accordion-title span.indicator span.first {
	position: absolute;
	top: 50%;
	left: 50%;
	height: 18px;
	width: 2px;
	background: #fff;
	transform: translate(-50%,-50%);
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
ul.accordion-items li.accordion-item .accordion-title span.indicator span.second {
	position: absolute;
	top: 50%;
	left: 50%;
	height: 2px;
	width: 18px;
	background: #fff;
	transform: translate(-50%,-50%);
}
ul.accordion-items li.accordion-item .accordion-title.active span.indicator span.first {
	transform: translate(-50%,-50%) rotate(-90deg);
}
ul.accordion-items li.accordion-item .accordion-hide {
	display: none;
	padding-top: 1em;
}
.content-image {
	position: relative;
}
.content-image.img-right {
	direction: rtl;
}
.content-image .content-content {
	width: 50%;
	padding: 8em 6em;
	direction: ltr;
}
.content-image .content-content h6 {
	margin-bottom: 2em;
}
.content-image .image-image {
	width: 50%;
}
.gallery-grid {
	position: relative;
	padding: 3em 0 6em;
}
.gallery-grid h6 {
	margin-bottom: 1.5em;
}
.gallery-grid h4 {
	max-width: 500px;
	margin: 0 auto 1em;
}
ul.galleries {
	margin: 0;
}
ul.galleries li {
	position: relative;
	list-style: none;
	width: calc(33.33% - 20px);
}
ul.galleries li .gal-image {
	position: relative;
	display: block;
	width: 100%;
	padding-bottom: 100%;
	filter: brightness(65%);
	z-index: 1;
}
ul.galleries li a.button {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 90%;
	transform: translate(-50%,-50%);
	display: block;
	z-index: 2;
}
.testimonials {
	position: relative;
}
ul.tests {
	margin: 0;
}
ul.tests li.test {
	position: relative;
	padding: 8em 0;
}
ul.tests li.test .test-wrap {
	background: rgba(255,255,255,0.75);
	padding: 6em 6em 4em;
	max-width: 50%;
	margin-left: 50%;
}
ul.tests li.test .test-wrap h5 {
	margin-bottom: 1em;
}
ul.tests .slick-track {
	display: flex !important;
}
ul.tests .slick-slide {
	display: flex !important;
	align-items: flex-end;
	height: inherit !important;
}
.separating-line {
	position: relative;
	width: 100%;
	height: 2px;
	background: #282828;
}
.team-grid {
	position: relative;
	padding: 3em 0 6em;
}
.team-grid h4 {
	margin-bottom: 1em;
}
.team-grid.blueBG h4, .team-grid.blackBG h4 {
	color: #fff;
}
ul.team {
	margin: 0;
	justify-content: center;
}
ul.team li {
	position: relative;
	list-style: none;
	width: calc(33.33% - 20px);
	background: #fff;
	padding: 20px;
}
.team-grid.whiteBG ul.team li {
	background: #edeeef;
}
ul.team li .team-image {
	position: relative;
	display: block;
	padding-bottom: 100%;
	width: 100%;
	margin-bottom: 2em;
}
ul.team li h5 {
	margin: 0;
}
.repeating-blocks {
	padding: 6em 0;
}
.repeating-blocks ul.blocks {
	margin: 0;
}
.repeating-blocks ul.blocks li {
	position: relative;
	list-style: none;
	margin-bottom: 2em;
}
.repeating-blocks ul.blocks li:nth-child(2n+2) {
	direction: rtl;
}
.repeating-blocks ul.blocks li:last-child {
	margin: 0;
}
.repeating-blocks ul.blocks li .block-image {
	position: relative;
	width: 60%;
	direction: ltr;
	z-index: 1;
}
.repeating-blocks ul.blocks li .block-content {
	position: relative;
	width: 50%;
	margin-left: -10%;
	margin-top: 4em;
	margin-bottom: 4em;
	padding: 4em;
	direction: ltr;
	z-index: 2;
}
.repeating-blocks.whiteBG ul.blocks li .block-content {
	background: #edeeef !important; 
}
.repeating-blocks ul.blocks li .block-content h6 {
	margin-bottom: 1em;
}
.repeating-blocks ul.blocks li:nth-child(2n+2) .block-content {
	margin-right: -10%;
}
.repeating-blocks ul.blocks li .block-content a.button {
	margin: 0 1em 1em 0;
}
.image-carousel {
	position: relative;
	padding: 30px 0;
}
.image-carousel .slick-list {
	overflow: visible;
}
.image-carousel ul {
	position: relative;
	margin: 0;
	padding: 0 17.47%;
	z-index: 2;
}
.image-carousel ul li {
	position: relative;
	list-style: none;
	display: inline-block !important;
	vertical-align: middle;
	cursor: pointer;
}
.image-carousel ul li img {
	max-height: 500px;
	min-height: 500px;
	padding: 0 15px;
	width: auto;
	height: auto;
}
.content-accordion {
	padding: 8em 0;
}
.content-accordion ul.accordion-items {
	margin: 0;
}
.content-accordion ul.accordion-items li.accordion-item {
	background: transparent !important;
	padding: 0.75em 0 0.75em 5em;
	border-radius: 0;
	border-bottom: 2px solid #fff;
}
.content-accordion ul.accordion-items li.accordion-item:last-child {
	border: none;
}
.content-accordion ul.accordion-items li.accordion-item .count {
	position: absolute;
	top: 4px;
	left: 0;
}
.content-accordion ul.accordion-items li.accordion-item p {
	max-width: calc(100% - 60px);
}
.image-mod {
	position: relative;
}
.image-mod .image-image {
	display: block;
	width: 100%;
	padding-bottom: 50%;
}
.video-mod {
	position: relative;
	padding: 6em 0;
}
.video-container {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}
.video-container iframe, .video-container video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.jobber-work-request {
	width: 100%;
}


/*********************************
	Footer Styles
*********************************/
.sub-footer .footer-cta {
	width: 50%;
	padding: 7em 6em 4em;
}
.sub-footer .ig-feed {
	width: 50%;
	padding: 6em 6em 4em;
}
.site-footer  {
	position: relative;
}
.line-top {
	position: absolute;
	top: 3em;
	left: 0;
	width: 100%;
	height: 2px;
	background: #282828;
}
.line-bottom {
	position: absolute;
	bottom: 3em;
	left: 0;
	width: 100%;
	height: 2px;
	background: #282828;
}
.footer-wrap {
	padding: 8em 2em;
	border-left: 2px solid #282828;
	border-right: 2px solid #282828;
}
.footer-sec {
	display: inline-block;
	vertical-align: middle;
	width: calc(33.33% - 5px);
	padding: 0 2em;
}
.footer-logo .logo {
	max-width: 300px;
}
.footer-contact h4 {
	margin: 0;
}
.footer-contact a {
	text-decoration: none;
}
.footer-contact h4 a {
	color: #598fab;
}
.footer-contact h4 a:hover {
	color: #477e96;
}
.footer-contact p {
	font-size: 1.125em;
}
ul.social {
	margin: 0;
}
ul.social li {
	position: relative;
	list-style: none;
	display: inline-block;
	margin: 0 2px;
}
ul.social li img {
	max-width: 40px;
	background: #598fab;
	border-radius: 50%;
	padding: 5px;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
ul.social li:hover img {
	background: #477e96;
}
nav.footer ul {
	margin: 0;
} 
nav.footer ul li {
	position: relative;
	list-style: none;
	display: block;
	margin: 0.5em 0;
}
nav.footer ul li a {
	font-family: brandon-grotesque, sans-serif;
	font-weight: 700;
	font-style: normal;
	font-size: 1em;
	color: #282828;
	line-height: 1.25;
	letter-spacing: 1px;
	text-transform: uppercase;
	text-decoration: none;
}
nav.footer ul li a:hover {
	color: #535456f;
}
.copyright {
	position: absolute;
	bottom: 0.75em;
	left: 0;
	width: 100%;
	text-align: center;
	margin: 0;
}


/***************************************************************************************************
									Responsive Styles
***************************************************************************************************/
@media all and (max-width: 1385px) {
	.header-bar, .main-header, .image-content-accordion, .gallery-grid, .team-grid, 
	.repeating-blocks, .content-accordion, .copyright { padding-left: 2em !important; padding-right: 2em !important; }
}
@media all and (max-width: 1275px) {
	.footer-wrap { border: none; }
}
@media all and (max-width: 1205px) {
	nav.main ul li { margin-left: 1em; }
	.content-wrap { padding-left: 2em !important; padding-right: 2em !important; }
}
@media all and (max-width: 1125px) {
	nav.main ul li { margin-left: 0.5em; }
}
@media all and (max-width: 1030px) {
	nav.main, .footer-links { display: none !important; }
	.mobile-menu { width: 75%; }
	.nav-button { display: block; }
	ul.search-posts li, ul.galleries li, ul.team li, ul.posts li { width: calc(50% - 15px) !important; }
	.content-image .content-content { padding: 4em 2em; }
	ul.tests li.test { padding: 4em 2em; }
	ul.tests li.test .test-wrap { max-width: 100%; margin: 0; text-align: center; padding: 3em 3em 2em; }
	.image-carousel ul li img { max-height: 350px; min-height: 350px; }
	.sub-footer .footer-cta, .sub-footer .ig-feed { padding: 4em; }
	.footer-sec { width: 100%; text-align: center; }
	.footer-logo { padding-bottom: 2em; }
	
	.three-column { -webkit-column-count: 1; -moz-column-count: 1; column-count: 1; }
	.small-content-wrap { padding-left: 2em !important; padding-right: 2em !important; }
}
@media all and (max-width: 925px) {
	ul.boxes li { width: 50% !important; }
	.repeating-blocks { padding: 2em; }
	.repeating-blocks ul.blocks li .block-image { width: 100%; padding-bottom: 50%; margin: 0; }
	.repeating-blocks ul.blocks li .block-content { width: 100%; margin: 0 !important; }
	.content-accordion { padding: 4em 2em; }
	.accordion-intro { width: 100% !important; text-align: center !important; padding: 0 !important; }
	.content-accordion ul.accordion-items { width: 100% !important; margin-top: 4em !important; }
	
	.tiny-content-wrap { padding-left: 2em !important; padding-right: 2em !important; }
}
@media all and (max-width: 768px) {
	.bar-left, .spacer, .line-top { display: none !important; }
	.mobile-menu, ul.search-posts li, .bar-right, ul.boxes li, .image-content-accordion .image-image, .image-content-accordion .content-content,
	.content-image .content-content, .content-image .image-image, ul.galleries li, .sub-footer .footer-cta, .sub-footer .ig-feed,
	ul.team li, ul.posts li { width: 100% !important; }
	.content-boxes { padding: 2em 0 4em; }
	.image-content-accordion .flex-wrap { gap: 0; }
	.image-content-accordion .content-content { padding-bottom: 0; }
	.content-image .image-image { display: block; padding-bottom: 50%; }
	.gallery-grid, ul.tests li.test .test-wrap, .repeating-blocks ul.blocks li .block-content { padding: 2em; }
	.image-carousel ul li img { max-height: 250px; min-height: 250px; }
	.footer-wrap { padding: 4em 2em 2em; }
	.sub-footer .footer-cta, .sub-footer .ig-feed { padding: 4em 2em; text-align: center; }
	.line-bottom { bottom: 4em; }
	.copyright { position: relative; bottom: auto; padding: 0.5em 2em; }
	
	h1, span.h1 { font-size: 3em; }
	h2, span.h2 { font-size: 2.5em; }
	h3, span.h3 { font-size: 2em; }
	h4, span.h4 { font-size: 1.75em; }
	.two-column { -webkit-column-count: 1; -moz-column-count: 1; column-count: 1; }
}

