/*
Theme Name: Junk It Today
Theme URI: http://www.viscodesign.com/
Author: Visco Design
Author URI: http://www.viscodesign.com/
Description: Custom theme design and build by Visco Design
Version: 1.0.0
License: Copyright Visco Design
License URI: http://www.viscodesign.com/
Text Domain: junkittoday

Junk It Today is based on Underscores http://underscores.me/, (C) 2012-2015 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.com/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
	## Posts and pages
	## Asides
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
html {
	font-family: sans-serif;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust:     100%;
}

body {
	margin: 0;
}

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

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-appearance: textfield;
	box-sizing: content-box;
}

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: #404040;
	font-family: sans-serif;
	font-size: 1em;
	line-height: 1.5;
}

h1 {
	font: 100 normal 3em/1.2 'Roboto', Helvetica, sans-serif;
	color: #888;
	margin: 0 0 0.75em;
}
h2 {
	font: 700 normal 1.75em/1.1 'Roboto', Helvetica, sans-serif;
	color: rgb(4,3,3);
	margin: 0 0 0.75em;
	text-transform: uppercase;
}
h3 {
	font: 900 normal 1.2em/1.1 'Roboto', Helvetica, sans-serif;
	color: rgb(201,36,32);
	margin: 0 0 0.5em;
}
h4 {
	font: 100 normal 1em/1.1 'Roboto', Helvetica, sans-serif;
	color: rgb(130,138,149);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 0.25em;
}
h5 {
	font: 400 normal 1em/1 'Roboto', Helvetica, sans-serif;
	color: #777;
	text-transform: uppercase;
	margin: 0;	
}
h6 {
	font: 700 normal 1em/1.1 'Roboto', Helvetica, sans-serif;
	color: #777;
	margin: 0 0 0.5em;
}

p, ul, ol {
	font: 400 normal 1em/1.65 'Roboto', Helvetica, sans-serif;
	color: #111;
	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 1em;
	padding-left: 1.5em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

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

dt {
	font-weight: bold;
}

dd {
	margin: 0 1.5em 1.5em;
}

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

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

/*--------------------------------------------------------------
# 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: space-between;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-ms-flex: 0 0 100%;
	-webkit-flex: 0 0 100%;
	flex: 0 0 100%;
	margin: 0;
	padding: 0;
}

/* Layout
--------------------------------------------------------------*/
.site-content {
	margin: 0;
	padding: 0;
}
#primary {
	width: 100%;
	margin: 0;
	padding: 0;
	min-height: 500px;
}
.site-main {
	max-width: 900px;
	margin: 0 auto;
	padding: 1em;
}
#secondary {
	width: 100%;
	margin: 0;
	padding: 0;
	background: rgb(241,244,243);
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	font: 700 normal 1em/1 'Roboto', Helvetica, sans-serif;
	color: #fff;
	padding: 0.75em 1em;
	border: none;
	background: rgb(201,36,32);
	transition: all 0.5s ease;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background: rgb(4,3,3);
}

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"],
textarea {
	-webkit-appearance: none;
	-webkit-border-radius: 0;
	color: #666;
	border: 1px solid #ddd;
}

select {
	border: 1px solid #ddd;
}

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

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"] {
	padding: 8px;
}

textarea {
	padding-left: 3px;
	width: 100%;
}

/* Custom Forms */
.search-submit .fa {
	color: #fff;
}

/* Ninja Forms */
.ninja-forms-form-wrap {
	margin: 2em 0;
	padding: 0;
	border: 1px solid #ddd;
}
.ninja-forms-form-title {
	margin: 0;
	padding: 15px 30px;
	border-bottom: 1px solid #ddd;
	background: rgb(241,244,243);
}
.ninja-forms-response-msg p {
	margin: 0;
	padding: 15px 30px;
	color: #fff;
	border-bottom: 1px solid #ddd;
	background: rgb(4,3,3);	
}
.ninja-forms-form-wrap form {
	margin: 0;
	padding: 15px 30px;
	border-bottom: 1px solid #ddd;
}
.ninja-forms-required-items {
	margin: 0 0 1em;
	color: #aaa;
}
.ninja-forms-field-description {
	clear: both;
}
.booking-name-wrap,
.booking-email-wrap,
.booking-day-wrap,
.booking-time-wrap {
	float: left;
	width: 50%;
	padding-right: 20px;
}
.booking-services-wrap li,
.booking-day-wrap li,
.booking-time-wrap li {
	width: 100%;
	display: block;
}
#ninja_forms_field_8_div_wrap {
	clear: left;
}

/* Quick Quote */
#quick-quote-success h1 {
	display: inline-block;
	font-size: 2em;
	color: #aaa;
}
#quick-quote-success .transaction-icon {
	float: left;
	display: inline-block;
	margin-right: 15px;
	vertical-align: middle;
	width: 35px;
}


/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
a {
	color: rgb(201,36,32);
}
a:visited {
	color: rgb(201,36,32);
}
a:focus,
a:hover,
a:active {
	color: rgb(201,36,32);
	outline: 0;
}

/* Styled Links */
a.btn {
	display: inline-block;
	font-size: 1.25em;
	font-weight: 400;
	text-align: center;
	color: #fff;
	margin: 0 auto;
	padding: 0.5em 0.75em;
	text-decoration: none;
	background-color: rgb(201,36,32);
	transition: all 0.5s ease;
}
.more::after {
	font-family: FontAwesome;
	content: "\f105";
	margin-left: 8px;
	color: inherit;
	opacity: 0.5;
}
.less::before {
	font-family: FontAwesome;
	content: "\f104";
	margin-right: 8px;
	color: inherit;
	opacity: 0.5;
}
.btn .fa {
	margin-left: 8px;
}
a.btn.small {
	font-size: 75%;
}
a.btn.large {
	font-size: 125%;
}
a.btn.white {
	color: rgb(25,97,169);
	background-color: #fff;
}
a.btn.black {
	background-color: rgb(0,0,0);
}
a.btn.red {
	color: #fff;
	background-color: rgb(201,36,32);
}
a.btn.yellow {
	color: #fff;
	background-color: rgb(250,188,60);
}
a.btn.transparent {
	color: rgb(201,36,32);
	padding: 11px 19px;
	border: 1px solid #ccc;
	background: none;
}
a.btn.transparent.white {
	color: #fff;
	border: 1px solid #fff;
	background: none;
}
a.btn:hover {
	color: #fff;
	background-color: rgb(4,3,3);
	border-color: rgb(4,3,3);
}

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
	display: none;
	margin: 0;
	padding: 0;
}

/* Primary Menu */
#primary-menu {
	display: inline-block;
	list-style: none;
	margin: 0;
	padding: 0 10px;
	text-align: left;
	background: rgb(4,3,3);
}
#primary-menu li {
	display: inline-block;
	padding: 10px 0;
}
#primary-menu li a {
	display: block;
	color: #fff;
	font: 700 normal 1.25em/1 'Roboto Condensed', Helvetica, sans-serif;
	padding: 10px;
	text-decoration: none;
	text-transform: uppercase;
}
#primary-menu li.menu-item-has-children > a {
	padding: 10px 5px 10px 10px;
}
#primary-menu li.menu-item-has-children > a::after {
	float: right;
	content: "\f107";
	font-family: 'FontAwesome';
	text-decoration: none;
	color: rgba(255,255,255,0.5);
	font-size: 20px;
	padding-left: 8px;
	border: none;
	vertical-align: baseline;
}
/*
#primary-menu li.menu-item-has-children:hover::after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin-left: -12px;
	border: 12px solid rgb(4,3,3);
	border-bottom-color: rgb(241,244,243);
	z-index: 9999;
}
*/
#primary-menu li:hover > a {
	color: rgb(201,36,32);
}

/* Submenu */
#primary-menu ul {
	display: none;
}
#primary-menu li:hover ul {
	display: block;
	position: absolute;
	top: 60px;
	left: auto;
	margin: 0 0 0 -10px;
	padding: 0 0 10px;
	z-index: 9999;
	background: rgb(4,3,3);
}
#primary-menu ul li {
	float: none;
	display: block;
	margin: 0;
	padding: 0;
}
#primary-menu ul li a {
	color: #fff;
	line-height: 1;
	padding: 10px 40px 10px 20px;
}
#primary-menu ul li:hover a {
	color: #555;
}
#primary-menu li.menu-item-booknow a {
	color: #fff;
	margin-left: 5px;
	background: rgb(201,36,32);
}

/* Current Page */
#primary-menu .current_page_item > a,
#primary-menu .current-menu-item > a,
#primary-menu .current_page_ancestor > a {
	color: rgb(201,36,32);
}

/* Footer Menu */
.footer-navigation ul {
	margin: 0 auto;
	padding: 0;
	list-style-type: none;
}
.footer-navigation li {
	display: inline-block;
}
.footer-navigation li a {
	display: block;
	color: rgb(4,3,3);
	font: 700 normal 1.5em/1 'Roboto Condensed', Helvetica, sans-serif;
	padding: 10px 8px;
	text-decoration: none;
	text-transform: uppercase;
	transition: all 0.5s ease;
}
.footer-navigation li a:hover {
	color: #aaa;
}
.footer-navigation li.menu-item-booknow a {
	color: #fff;
	margin-left: 8px;
	padding: 10px 16px;
	background: rgb(201,36,32);
	transition: all 0.5s ease;
}
.footer-navigation li.menu-item-booknow a:hover {
	color: rgba(255,255,255,0.5);
}

/*--------------------------------------------------------------
# Social Media Lists
--------------------------------------------------------------*/
.social-links {
	display: inline-block;
	list-style-type: none;
	margin: 0 auto;
	padding: 0;
	line-height: 1;
}
.social-links li {
	float: left;
	display: inline-block;
	margin: 0;
	padding: 0;
}
.social-links li:last-of-type {
	margin: 0;
}
.social-links .fa {
	display: inline-block;
	width: 40px;
	height: 40px;
	padding: 12px;
	font-size: 16px;
	line-height: 16px;
	color: rgb(201,36,32);
	text-align: center;
	transition: all 0.5s ease;
}
.social-links .fa:hover {
	color: #555;
}

/* Footer */
.footer-contact .social-links {
	margin: 10px 0 0;
}


/*--------------------------------------------------------------
## Numeric Pagination
--------------------------------------------------------------*/
.pagination {
	margin: 0.5em 0;
	padding: 1em 0;
}
.pagination .fa {
	margin: 0;
	padding: 0;
}
.pagination a {
	float: left;
	color: #bbb;
	font-weight: 700;
	margin: 0;
	padding: 0.25em 0.8125em;
	text-decoration: none;
	border-left: 1px solid #ddd;
	background: #fff;
	transition: all 0.5s ease;
}
.pagination a:hover,
.pagination a.next:hover,
.pagination a.prev:hover {
	color: #fff;
	background: rgb(246,157,175);
}
.pagination a.prev {
	color: #fff;
	background: #bbb;
	border-left: none;
	transition: all 0.5s ease;
}
.pagination a.next {
	color: #fff;
	background: #bbb;
	border-left: none;
	transition: all 0.5s ease;
}
.pagination .dots {
	float: left;
	color: #aaa;
	margin: 0;
	padding: 0.25em 0.8125em;
	border-left: 1px solid #ddd;
}
.pagination .current {
	float: left;
	color: #fff;
	background: rgb(246,157,175);
	margin: 0;
	padding: 0.25em 0.8125em;
	border-left: 1px solid #ddd;
}

/*--------------------------------------------------------------
## Posts/Comments Navigation
--------------------------------------------------------------*/
.site-main .comment-navigation,
.site-main .post-navigation {
	margin: 0;
	overflow: hidden;
	padding: 0;
	border-radius: 5px;
	border: 1px solid #ddd;
}
.nav-links {
	width: 100%;
	display: inline-block;
	margin: 0;
}
.nav-previous,
.nav-next {
	width: 50%;
	max-width: 50%;
	padding: 1.5em;
}
.nav-previous a,
.nav-next a {
	font-size: 1em;
	font-weight: 400;
	color: #777;
}
.nav-previous::before {
	content: '\f104';
	font-family: FontAwesome;
	color: rgb(34,34,34);
	margin-right: 1em;
}
.nav-previous a:hover,
.nav-next a:hover {
	color: rgb(34,34,34);
}
.nav-next::after {
	content: '\f105';
	font-family: FontAwesome;
	color: rgb(34,34,34);
	margin-left: 1em;
}
.comment-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	border-right: 1px solid #ddd;
}
.comment-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	text-align: right;
}

/*--------------------------------------------------------------
## Back To Top
--------------------------------------------------------------*/
.back-to-top {
	position: fixed;
	bottom: 0;
	right: 0;
	width: 80px;
	height: 80px;
	display: none;
}
.back-to-top a {
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 30px;
	line-height: 1;
	padding: 25px;
	vertical-align: middle;
	background: rgb(201,36,32);
	transition: all 0.5s ease;
}
.back-to-top .fa {
	vertical-align: middle;
}
.back-to-top a:hover {
	background: rgb(4,3,3);
}

/*--------------------------------------------------------------
# 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;
}
.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}
/* Do not show the outline on the skip link target. */
#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,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
	content: "";
	display: table;
	table-layout: fixed;
}
.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
	clear: both;
}

/*--------------------------------------------------------------
# Sidebars
--------------------------------------------------------------*/
#secondary .widget {
	margin: 0;
	padding: 2em;
	border-bottom: 1px solid #fff;
}
#secondary .widget p:last-of-type {
	margin: 0;
}
#secondary .widget ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
	border: 1px solid #ddd;
}
#secondary .widget li {
	margin: 0;
	padding: 1em;
	border-bottom: 1px solid #ddd;
	transition: all 0.5s ease;
}
#secondary .widget li:hover {
	background: #ddd;
}
#secondary .widget li:last-of-type {
	border: none;
}
#secondary .widget select {
	max-width: 100%;
}
#secondary .widget input {
	width: calc(100% - 100px);
	max-width: 250px;
}

#booking-help {
	margin: 0;
	padding: 2em;
	background: rgb(201,36,32);
}
#booking-help * {
	color: #fff;
}
#booking-help h2 {
	line-height: 1;
}
#booking-help a {
	padding: 20px 0 20px 10px;
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
	text-decoration: none;
	vertical-align: middle;
}
#booking-help .fa {
	display: inline-block;
	padding: 15px;
	font-size: 30px;
	line-height: 1;
	vertical-align: middle;
	width: 60px;
	height: 60px;
	border-radius: 100%;
	border: 1px solid rgba(255,255,255,0.25);
}
#got-questions {
	margin: 0;
	padding: 2em;
	background: #222;
}
#got-questions h2,
#got-questions a {
	color: #fff;
}
#got-questions p {
	color: #aaa;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/

/*--------------------------------------------------------------
## Header
--------------------------------------------------------------*/

/* Site Header */
.site-header {
	width: 100%;
	margin: 0;
	padding: 0;
	background: linear-gradient( to bottom, rgb(4,3,3) 50px, rgb(241,244,243) 50px); 
}
#site-navigation {
	flex: 0 1 75%;
	order: 1;
	margin: 0 auto 0 0;
}

/* Header Phone */
#header-phone {
	flex: 1 1 auto;
	order: 3;
	margin: 0;
	padding: 0;
	text-align: center;
	line-height: 1;
	background: rgb(201,36,32);
}
#header-phone .fa {
	font-size: 75%;
	margin-right: 5px;
}
#header-phone a {
	display: block;
	color: #fff;
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
	padding: 15px;
	text-decoration: none;
}

/* Header Social */
#header-social {
	flex: 0 1 auto;
	order: 2;
	margin: 0;
	padding: 0;
	line-height: 0;
	background: rgb(4,3,3);
}
#header-social .social-links .fa {
	display: inline-block;
	width: 50px;
	height: 50px;
	padding: 15px;
	font-size: 20px;
	line-height: 1;
	color: #fff;
	text-align: center;
	transition: all 0.5s ease;
}
#header-social .social-links .fa-facebook {
	background: #3b5998;
}
#header-social .social-links .fa-twitter {
	background: #55acee;
}
#header-social .social-links .fa:hover {
	color: rgba(255,255,255,0.5);
}

/* Header Quick Links */
#header-quick-links {
	flex: 1 1 100%;
	order: 4;
	margin: 0;
	padding: 10px;
	line-height: 1;
	text-align: center;
}
#header-quick-links ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
#header-quick-links ul li {
	display: inline-block;
}
#header-quick-links ul li a {
	font-size: 19px;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	margin: 0;
	padding: 10px 15px;
	background: rgb(201,36,32);
	transition: all 0.5s ease;
}
#header-quick-links ul li a:hover {
	color: rgb(201,36,32);
	background: #fff;
}

/* Header Tagline */
#site-tagline {
	flex: 0 1 100%;
	order: 5;
	text-align: center;
	margin: 0;
	padding: 15px;
}
.tagline h3 {
	font-size: 1em;
	font-weight: 300;
	line-height: 1;
	margin: 0;
}
.tagline h3 span {
	color: rgb(201,36,32);
	font-weight: 900;
}

/*--------------------------------------------------------------
## Front Page
--------------------------------------------------------------*/

/*--------------------------------------------------------------
## Front Page
--------------------------------------------------------------*/

/* Slider
--------------------------------------------------------------*/
#home_slider {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}
#home_slider .gallery-slider {
	margin: 0 auto;
}
.slider-overlay {
	position: absolute;
	top: 0;
	left: 0;
  	width: 100%;
  	height: 100%;
  	background-color: rgba(0,0,0,0.5);
	z-index: 999;
}
.slider-cta {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
  	width: 70%;
  	max-width: 900px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	z-index: 9999;
}
.slider-branding {
	width: 100%;
	margin: 0 auto 20px;
}
.slider-logo {
	max-width: 200px;
}
.slide-title {
	color: #fff;
	font-size: 4vw;
	font-weight: 700;
	line-height: 1.05;
	letter-spacing: 0;
	text-shadow: 0 2px 3px rgba(0,0,0,0.85);
}
.slider-cta .btn {
	box-shadow: 0 2px 3px rgba(0,0,0,0.5);
}

.home .site-main {
	padding: 0 0 25px;
}

/* Hero Image
--------------------------------------------------------------*/
#front_hero {
	position: relative;
	width: 100%;
}
#front_hero .entry-thumbnail {
	padding-bottom: 55%;
	z-index: 99;
}
.hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
  	width: 100%;
  	height: 100%;
  	background-color: rgba(0,0,0,0.5);
	z-index: 999;
}
#front_hero .cta-block {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
  	width: 90%;
  	max-width: 900px;
	margin: 0 auto;
	padding: 25px;
	text-align: center;
	z-index: 9999;
}
.hero-branding {
	width: 100%;
	margin: 0 auto 15px
}
.hero-logo {
	max-width: 200px;
}
h1.hero-title {
	margin: 0 auto 0.5em;
	color: #fff;
	font-size: 4vw;
	font-weight: 700;
	text-shadow: 0 1px 4px rgba(0,0,0,0.85);
}
#front_hero .cta-block .btn {
	margin: 5px auto;
	padding: 10px;
}
.front .entry-content {
	margin: 0 auto;
}
.front .entry-content img {
	width: 250px;
}

/* CTA Blocks 
#home-hero {
	width: 100%;
	margin: 0;
	padding: 2em 5%;
	background: #fff;
	text-align: center;
}
.site-branding {
	width: 100%;
	margin: 0;
	padding: 0;
}
h1.site-title {
	margin: 0;
}
.site-logo {
	width: 100%;
	max-width: 300px;
	margin: 0;
}
.header-image {
	width: 100%;
	margin: 0;
	padding: 0;
}
*/

#home-free-quote {
	width: 100%;
	margin: 0;
	padding: 2em;
	text-align: center;
	background: rgb(201,36,32);
}
#home-free-quote h1 {
	font-size: 5vw;
	font-weight: 300;
	margin: 0 auto;
	color: #fff;
}
#home-free-quote img {
	vertical-align: middle;
	max-width: 250px;
	margin-top: 1em;
}

#home-services {
	width: 100%;
	margin: 0;
	padding: 3em 10%;
	text-align: center;
	background: rgb(241,244,243);
}
#home-services .widget {
	-ms-flex: 0 1 30%;
	-webkit-flex: 0 1 30%;
	flex: 0 1 30%;
	max-width: 30%;
	margin: 0;
	padding: 0.5em;
}
#home-services .widget h2 {
	font-size: 0.8125em;
	margin: 0;
}
#home-services .widget h2 a {
	color: rgb(4,3,3);
	text-decoration: none;
	transition: color 0.5s ease;
}
#home-services .widget h2 a:hover {
	color: rgb(201,36,32);
}
#home-services .service-icon {
	width: 100%;
	max-width: 80px;
	height: auto;
}
#home-intro {
	position: relative;
	width: 100%;
	min-height: 300px;
	margin: 0;
	padding: 3em 10% 300px 10%;
	background-image: url('images/john-hughes.jpg');
	background-repeat: no-repeat;
	background-position: 75% 100%;
	background-size: 300px 300px;
}
#home-intro .welcome-text {
	text-align: center;
}
#home-intro h1 {
	font-size: 6vw;
}
#home-intro .owner {
	position: absolute;
	right: 0;
	bottom: 25px;
	text-align: right;
	padding-right: calc(275px + 10%);
}
#home-intro .owner p {
	font-weight: 700;
	margin: 0;
}
#home-intro .owner span {
	font-size: 75%;
	font-weight: 400;
	color: #999;
	text-transform: uppercase;
	margin-left: 8px;
}
#home-reviews {
	width: 100%;
	margin: 0;
	padding: 3em 10%;
	text-align: center;
	background: rgb(4,3,3);
}
#home-reviews h1 {
	font-weight: 100;
	color: #fff;
}
.review-content p {
	color: #fff;
}
.review-cta {
	color: #fff;
}

/*--------------------------------------------------------------
## Pages
--------------------------------------------------------------*/
#page-thumb {
	position: relative;
	width: 100%;
	height: 0;
	margin: 0;
	padding-top: 25%;
	overflow: hidden;
}
#page-thumb img {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: auto;
	margin: 0;
}

/* Services */
#services .services-widget {
	-ms-flex: 0 1 100%;
	-webkit-flex: 0 1 100%;
	flex: 0 1 100%;
	position: relative;
	margin: 0 0 1em;
	padding: 1em 1em 4em;
	border: 1px solid #ddd;
	text-align: left;
}
#services .services-widget a.service-icon {
	display: inline-block;
	float: left;
	vertical-align: middle;
}
#services .services-widget a.service-icon img {
	max-width: 75px;
	vertical-align: middle;
}
#services .services-widget h2 {
	display: inline-block;
	font-size: 1.5em;
	margin: 1em auto 1em 1em;
	vertical-align: middle;
}
#services .services-widget h2 a {
	text-decoration: none;
}
#services .services-widget .large-btn {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	margin: 1em 0 0;
	padding: 1em;
	color: #fff;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
	text-decoration: none;
    background-size: 100% 200%;
    background-image: linear-gradient(to bottom, rgb(201,36,32) 50%, rgb(4,3,3) 50%);
    transition: background-position 0.5s ease;
	transition: all 0.5s ease;
}
#services .services-widget .large-btn:hover {
    background-position: 0 100%;
}

/* Contact */
.contact-info {
	list-style: none;
	margin: 0 auto 25px;
	padding: 0;
}
.contact-info li .fa {
	margin-right: 15px;
}

/*--------------------------------------------------------------
## Posts
--------------------------------------------------------------*/

.sticky {
	display: block;
}

.hentry {
	margin: 0 0 1.5em;
}

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

.single .byline,
.group-blog .byline {
	display: inline;
}

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

/*--------------------------------------------------------------
## Promotions
--------------------------------------------------------------*/
#promotions article {
	margin: 0 auto 25px;
	padding: 25px;
	background: url('images/scissors.png') rgb(241,244,243) bottom right no-repeat;
	border: 3px dashed #aaa;
}
#promotions article .entry-thumbnail {
	float: left;
	max-width: 200px;
	margin: 1.5em 25px 0 0;
}
#promotions article .entry-thumbnail a {
	vertical-align: middle;
}
#promotions article .entry-meta {
	color: #888;
	font-size: 14px;
	text-transform: uppercase;
}

/*--------------------------------------------------------------
## Reviews
--------------------------------------------------------------*/
ul.star-rating {
	display: inline-block;
	margin: 10px auto;
	text-align: center;
}
ul.star-rating li {
	line-height: 1;
}
ul.star-rating li .fa {
	color: rgb(201,36,32);
}

/* Review Archives */
.archive article.review {
	width: 48%;
	margin: 0 2% 1em 0;
	padding: 2em;
	border: 1px solid #ddd;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.archive article.review::before {
	content: '\f10d';
	font-family: FontAwesome;
	color: rgb(201,36,32);
}
.archive article.review .reviewer {
	color: rgb(4,3,3);
	font-weight: 900;
}
.archive article.review h5 {
	display: inline-block;
	margin: 15px 0;
}
.archive article.review div.field_type-star_rating {
	display: inline-block;
	float: right;
	line-height: 1;
}

/* Single Testimonials */
.review-single-rating {
}

/*--------------------------------------------------------------
## FAQs
--------------------------------------------------------------*/
#faqs {
	max-width: 800px;
	margin: 2em 0 1em;
	padding: 0;
	border: 1px solid #ddd;
}
#faqs .faq-item {
	margin: 0;
	padding: 1em;
	border-top: 1px solid #ddd;
	transition: all 0.5s ease;
}
#faqs .faq-item:hover {
	background: #eee;
}
#faqs .faq-item:first-of-type {
	border-top: none;
}
#faqs h3 {
	margin: 0;
	font-size: 1em;
	cursor: pointer;
}
#faqs h3 a {
	color: #333;
	text-decoration: none;
}
#faqs h3::before {
	content: '\f105';
	font-family: FontAwesome;
	font-size: 75%;
	color: rgb(201,36,32);
	margin-right: 0.75em;
}
#faqs h3.ui-state-active a {
	color: #333;
}
#faqs h3.ui-state-active::before {
	content: '\f107';
}
#faqs h3:first-of-type {
	border: none;
}
#faqs h3:focus,
#faqs h3:active {
	outline: none;
}
#faqs .faq-answer {
	display: none;
	padding: 1em 0 0;
}

/*--------------------------------------------------------------
## Archives
--------------------------------------------------------------*/
#archives {
	-ms-flex-pack: start;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;	
}
article.archive {
	-ms-flex: 0 0 100%;
	-webkit-flex: 0 0 100%;
	flex: 0 0 100%;
	margin: 0;
	padding: 0;
	border: 1px solid #ddd;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,0.2);	
}
article.archive h3 {
	min-height: 50px;
	font-size: 1.25em;
	line-height: 1.1;
	padding: 0.75em 1em;
}
article.archive h3 a {
	color: rgb(4,3,3);
	font-weight: 300;
	text-decoration: none;
}
article.archive h3 a:hover {
	color: rgb(169,172,169);
}
article.archive .entry-thumbnail {
	position: relative;
	width: 100%;
	height: 0;
	margin: 0;
	padding-top: 55%;
	overflow: hidden;
	opacity: 1;
	transition: all 0.5s ease;
}
article.archive:hover .entry-thumbnail {
	opacity: 0.75;
}
article.archive .entry-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
}
article.archive .entry-content {
	color: #888;
	margin: 0;
	padding: 1em 1em;
}
article.archive .entry-content a {
	float: right;
}

/*--------------------------------------------------------------
## Footer
--------------------------------------------------------------*/
.site-footer {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
}

/* Footer CTAs */
#footer-ctas .widget {
	-ms-flex: 0 1 100%;
	-webkit-flex: 0 1 100%;
	flex: 0 1 100%;
	text-align: center;
	margin: 0;
	padding: 2em;
	transition: all 0.75s ease;
}
#footer-ctas .widget:hover {
	box-shadow: inset 0 0 50px rgba(0,0,0,0.5);
}
#footer-ctas .widget img {
	max-width: 125px;
}
#footer-quick-quote {
	background: rgb(241,244,243);
}
#footer-quick-quote h1 {
	color: rgb(4,3,3);
}
#footer-book-now {
	background: rgb(201,36,32);
}
#footer-book-now h1,
#footer-book-now p {
	color: #fff;
}

/* Footer Widgets */
#footer-widget-area {
	width: 100%;
	margin: 0;
	padding: 2em;
}
#footer-widget-area .widget {
	width: 100%;
	margin: 0;
	padding: 1em;
}
.footer-contact ul {
	margin: 1em auto;
}
.footer-contact ul li {
	display: inline-block;
}
.footer-contact a {
	font-weight: 700;
	color: rgb(4,3,3);
	text-decoration: none;
}
.footer-contact a:hover {
	color: #555;
}
.footer-contact .fa:not(.fa-search) {
	color: rgb(201,36,32);
	margin-right: 0.5em;
}
.footer-logo {
	max-width: 10em;
}
.footer-social .fa {
	font-size: 1.25em;
}
.footer-social .fa:hover {
	color: rgb(4,3,3);
}
#footer-search {
	margin-top: 1em;
}
.footer-tagline {
	margin: 25px auto 0;
}
.footer-tagline h3 {
	margin: 0 auto 10px;
	font-size: 1.25em;
}
.footer-tagline p {
	max-width: 800px;
	color: rgb(153,153,153);
}

.site-info {
	font-size: 1em;
	margin: 0;
	padding: 2em;
	background: rgb(241,244,243);
}
.site-info p {
	margin: 0;
	color: #777;
	line-height: 1;
}
.webdev {
	font-size: 75%;
	color: #bbb;
}
.webdev a {
	color: #bbb;
	font-weight: 400;
}

/*--------------------------------------------------------------
## Asides
--------------------------------------------------------------*/
.blog .format-aside .entry-title,
.archive .format-aside .entry-title {
	display: none;
}

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

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

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

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

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

/*--------------------------------------------------------------
## 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) {

#footer-ctas .widget {
	-ms-flex: 0 1 50%;
	-webkit-flex: 0 1 50%;
	flex: 0 1 50%;
	max-width: 50%;
}

}

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

.site-main {
	padding: 1.5em;
}
#footer-widget-area {
	padding: 1.5em;
}
#home-free-quote h1 {
	font-size: 3.5vw;
}
#home-free-quote img {
	margin-top: 0;
	margin-left: 0.5em;
}
#home-services .widget h2 {
	font-size: 1em;
}
#home-intro {
	min-height: 325px;
	padding: 3em 10%;
	background-position: 90% 100%;
}
#home-intro .welcome-text > *:not(.owner) {
	padding-right: 300px;
}
#home-intro .welcome-text h1 {
	padding-right: 0;
}
#home-intro .owner br {
	display: none;
}
#services .services-widget {
	-ms-flex: 0 1 48%;
	-webkit-flex: 0 1 48%;
	flex: 0 1 48%;
	max-width: 48%;
	text-align: center;
}
#services .services-widget a.service-icon {
	float: none;
	display: block;
	vertical-align: middle;
}
#services .services-widget a.service-icon img {
	max-width: 100px;
}
#services .services-widget h2 {
	font-size: 1.5em;
	margin: 0 auto;
}
article.archive {
	-ms-flex: 0 1 50%;
	-webkit-flex: 0 1 50%;
	flex: 0 1 50%;
	max-width: calc(50% - 1em);
	margin: 0 1em 1em 0;
	padding: 0;
}
.site-info br {
	display: none;
}

}

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

#header-quick-links {
	flex: 0 1 60%;
	order: 3;
}
#site-tagline {
	flex: 0 1 40%;
	text-align: right;
}

}

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

#header-quick-links {
	flex: 1 1 auto;
	order: 3;
}
#header-social .social-links .fa {
	width: 60px;
	height: 60px;
	padding: 20px;
	font-size: 20px;
}
#header-phone a {
	padding: 20px;
}
#site-tagline {
	flex: 0 1 100%;
	padding: 20px;
	text-align: center;
}
#site-tagline h3 {
	font-size: 1.25em;
	line-height: 1;
}
#site-tagline br {
	display: none;
}
.site-branding {
	float: right;
	width: 30%;
}
.header-image {
	float: left;
	width: 70%;
}
.site-main {
	padding: 2em;
}
#primary:not(.full-width) {
	-ms-flex: 0 1 65%;
	-webkit-flex: 0 1 65%;
	flex: 0 1 65%;
	max-width: 65%;
}
#secondary {
	-ms-flex: 0 1 35%;
	-webkit-flex: 0 1 35%;
	flex: 0 1 35%;
	max-width: 35%;
}
#footer-widget-area {
	padding: 2em;
}
#home-free-quote h1,
#home-intro h1 {
	font-size: 3vw;
}
#home-free-quote img {
	max-width: 350px;
}
#home-services .widget {
	-ms-flex: 0 1 15%;
	-webkit-flex: 0 1 15%;
	flex: 0 1 15%;
	max-width: 15%;
}
#home-intro .welcome-text h1 {
	padding-right: 300px;
}
.review-content {
	float: right;
	width: 75%;
}
.review-cta {
	float: left;
	width: 25%;
	margin-top: 75px;
}
.site-info {
	text-align: left;
	padding: 2em 3em;
}
.site-info br {
	display: none;
}
.webdev {
	float: right;
	margin-right: 80px;
}

}

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

.main-navigation {
	display: inline-block;
}
.site-header {
	background: linear-gradient( to bottom, rgb(4,3,3) 60px, rgb(241,244,243) 60px); 
}
#site-navigation {
	flex: 1 1 auto;
	order: 1;
}
#header-phone {
	flex: 0 1 auto;
	order: 3;
}
#header-quick-links {
	flex: 0 1 40%;
}
#site-tagline {
	flex: 0 1 60%;
}

}

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

.site-main {
	padding: 2.5em;
}
#primary:not(.full-width) {
	-ms-flex: 0 1 70%;
	-webkit-flex: 0 1 70%;
	flex: 0 1 70%;
	max-width: 70%;
}
#secondary {
	-ms-flex: 0 1 30%;
	-webkit-flex: 0 1 30%;
	flex: 0 1 30%;
	max-width: 30%;
}
#home-free-quote,
#footer-widget-area {
	padding: 2em 3em;
}
#services .services-widget {
	-ms-flex: 0 1 32%;
	-webkit-flex: 0 1 32%;
	flex: 0 1 32%;
	max-width: 32%;
}

}

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

.site-main {
	padding: 3em;
}
#primary:not(.full-width) {
	-ms-flex: 0 1 75%;
	-webkit-flex: 0 1 75%;
	flex: 0 1 75%;
	max-width: 75%;
}
#secondary {
	-ms-flex: 0 1 25%;
	-webkit-flex: 0 1 25%;
	flex: 0 1 25%;
	max-width: 25%;
}
#home-free-quote,
#footer-widget-area {
	padding: 2em 4em;
}

}

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

#site-navigation {
	flex: 1 1 auto;
	order: 1;
}
#header-quick-links {
	flex: 1 1 auto;
	order: 2;
}
#site-tagline {
	flex: 1 1 auto;
}
#header-social {
	order: 3;
}
#header-phone {
	order: 4;
}

}