/*!
Theme Name: Fast-Fix Core
Theme URI: http://underscores.me/
Author: Mike Staples
Author URI: http://drawn2design.net
Description: New FastFix Theme
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: ff-core
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

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

fastfix-core is based on Underscores https://underscores.me/, (C) 2012-2017 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 https://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
--------------------------------------------------------------*/

@font-face {
  font-family: 'ff-icons';
  src: url('fonts/ff-icons.eot?37184338');
  src: url('fonts/ff-icons.eot?37184338#iefix') format('embedded-opentype'),
       url('fonts/ff-icons.woff2?37184338') format('woff2'),
       url('fonts/ff-icons.woff?37184338') format('woff'),
       url('fonts/ff-icons.ttf?37184338') format('truetype'),
       url('fonts/ff-icons.svg?37184338#ff-icons') format('svg');
  font-weight: normal;
  font-style: normal;
}
/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */
/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */
/*
@media screen and (-webkit-min-device-pixel-ratio:0) {
  @font-face {
    font-family: 'ff-icons';
    src: url('../font/ff-icons.svg?37184338#ff-icons') format('svg');
  }
}
*/
[class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: "ff-icons";
  font-style: normal;
  font-weight: normal;
  speak: never;

  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  /* opacity: .8; */

  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;

  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;

  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: .2em;

  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */

  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}

.icon-phone:before { content: '\e817'; } /* '' */
.icon-x:before { content: '\e818'; } /* '' */
.icon-mobile-phone:before { content: '\e819'; } /* '' */
.icon-envelope-o:before { content: '\f003'; } /* '' */
.icon-twitter:before { content: '\f099'; } /* '' */
.icon-facebook:before { content: '\f09a'; } /* '' */
.icon-angle-left:before { content: '\f104'; } /* '' */
.icon-angle-right:before { content: '\f105'; } /* '' */
.icon-angle-up:before { content: '\f106'; } /* '' */
.icon-angle-down:before { content: '\f107'; } /* '' */
.icon-instagram:before { content: '\f16d'; } /* '' */
.icon-google:before { content: '\f1a0'; } /* '' */
.icon-fax:before { content: '\f1ac'; } /* '' */
.icon-diamond:before { content: '\f219'; } /* '' */
.icon-pinterest-p:before { content: '\f231'; } /* '' */

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
/* normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
	line-height: 1.15; /* 1 */
	-webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
	margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

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

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
	box-sizing: content-box; /* 1 */
	height: 0; /* 1 */
	overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
	border-bottom: none; /* 1 */
	text-decoration: underline; /* 2 */
	text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

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

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
	font-family: inherit; /* 1 */
	font-size: 100%; /* 1 */
	line-height: 1.15; /* 1 */
	margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

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

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */

legend {
	box-sizing: border-box; /* 1 */
	color: inherit; /* 2 */
	display: table; /* 1 */
	max-width: 100%; /* 1 */
	padding: 0; /* 3 */
	white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
	box-sizing: border-box; /* 1 */
	padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

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

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
	-webkit-appearance: textfield; /* 1 */
	outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
	display: none;
}

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

h1, h2, h3, h4, h5, h6 {
	clear: both;
}

p {
	margin-bottom: 1.5em;
}

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 {
	/* Inherit box-sizing to make it easier to change the property for components that leverage other behavior; see https://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
	box-sizing: inherit;
}

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

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

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

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

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

dt {
	font-weight: bold;
}

dd {
	margin: 0 1.5em 1.5em;
}

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

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

table {
	margin: 0 0 1.5em;
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
td, th {
	border: 0;
}

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

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

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

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

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

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}

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

a:visited {
	/*color: purple;*/
	color: royalblue;
}

a:hover, a:focus, a:active {
	/*color: midnightblue;*/
	color: royalblue;
}

a:focus {
	outline: thin dotted;
}

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

/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
.main-navigation {
	font-family: 'Montserrat', sans-serif;
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	clear: both;
	display: block;
	float: right;
}

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

.main-navigation ul ul {
	padding-top: 10px;
	padding-bottom: 10px;
	border-top: 2px solid #e3b65b;
	background: #232323;
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
}

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

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

.main-navigation ul ul a {
	/*width: 240px;*/
	white-space: nowrap;
}

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

.main-navigation li {
	float: left;
	position: relative;
}

.main-navigation a {
	padding: 0.75em 1.5em;
	display: block;
	color: #fff;
	text-decoration: none;
	position: relative;
	-moz-transition: color .3s ease-in-out;
  -webkit-transition: color .3s ease-in-out;
  transition: color .3s ease-in-out;
}
.main-navigation a:hover, .main-navigation a:focus {
	color: #e3b65b;
}

.menu-primary-menu-container > ul > li:first-child > a, 
.menu-primary-menu-container > ul > li:last-child > a {
	background: #e3b65b;
	color: #000;
	-moz-transition: color .3s ease-in-out;
  -webkit-transition: color .3s ease-in-out;
  transition: color .3s ease-in-out;
}
.menu-primary-menu-container > ul > li:first-child > a:hover, 
.menu-primary-menu-container > ul > li:last-child > a:hover, 
.menu-primary-menu-container > ul > li:first-child > a:focus, 
.menu-primary-menu-container > ul > li:last-child > a:focus {
	color: #fff;
}
.menu-primary-menu-container > ul > li.menu-item-has-children > a {
	padding-right: 2.5em;
}
.menu-primary-menu-container > ul > li.menu-item-has-children > a:after {
	font-family: 'ff-icons';
	content: "\f107";
	font-size: 1rem;
	display: block;
	right: 1em;
	top: 8px;
	position: absolute;
}
.sub-menu li {
	width: 100%;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

@media screen and (min-width: 1020px) {
	.menu-toggle {
		display: none;
	}
	.main-navigation ul {
		display: block;
	}
}

.site-main .comment-navigation, .site-main
.posts-navigation, .site-main
.post-navigation {
	margin: 0 0 1.5em;
	overflow: hidden;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	float: left;
	width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	float: right;
	text-align: right;
	width: 50%;
}

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

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	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;
}

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

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

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
.sticky {
	display: block;
}

.post,
.type-page {
	margin: 0 0 1.5em;
}



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

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

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

/*--------------------------------------------------------------
## 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,
.infinite-scroll.neverending .site-footer {
	/* Theme Footer (when set to scrolling) */
	display: none;
}

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

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

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

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

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

/***** site specific *****/
body {
	background: #fff;
	/*background:#e6ecf2;*/
	/*overflow-x: hidden;*/
}
body, p {
	margin-top: 0;
	color: #222;
  font-family: 'Muli', sans-serif;
	font-size: 1.05em;
}

/* Style links */
a {
	color: #1e73be;
}

a:hover {
	color: #639dd3;
}

/* Style headings */
h1 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 44px;
	font-weight: 400;
}

h2 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 1.5em;
	font-weight: 700;
}

h3 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 1.3em;
	font-weight: 700;
}

h4 {
	color: #222;
	font-size: 22px;
	font-weight: 400;
}

.main-header {
	width: 100%;
	padding: 12px 30px 10px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	background: #232323;
}
/*.home .main-header {
	position: absolute;
	z-index: 100;
	background: rgba(0,0,0,1);
	background: -moz-linear-gradient(top, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
	background: -webkit-gradient(left top, left bottom, color-stop(0%, rgba(0,0,0,1)), color-stop(100%, rgba(0,0,0,0)));
	background: -webkit-linear-gradient(top, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
	background: -o-linear-gradient(top, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
	background: -ms-linear-gradient(top, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
	background: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#000000', GradientType=0 );
}*/
.site-branding {
	padding-right: 30px;
}
.site-header-nav {
	flex-grow: 1;
	position: relative;
}
.hdr-social {
	/*right: 0;
	top: -42px;
	position: absolute;*/
	padding-bottom: 6px;
	/*text-align: right;*/
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.hdr-social a {
	margin: 0 3px;
	color: #e3b65b;
	font-size: 21px;
	text-decoration: none;
	-moz-transition: color .3s ease-in-out;
  -webkit-transition: color .3s ease-in-out;
  transition: color .3s ease-in-out;
}
.hdr-social a.hdr-call {
	margin-right: 15px;
	font-size: 1rem;
	font-weight: 700;
}
.hdr-social a.hdr-call span {
	font-size: 1.25rem;
	vertical-align: middle;
}
.hdr-social a:hover {
	color: #fff;
}
.hdr-social a:last-child {
	margin-right: 0;
}
@media screen and (max-width: 1019px) { /*58.75em = 940px @ base pixel size 16px*/
	.site-branding {
		position: absolute;
		top: 20px;
	}
	.hdr-social {
    top: -70px;
	}
	.site-header-nav {
		padding: 40px 0 5px;
		width: 100%;
		order: 3;
		z-index: 10;
	}
	.main-navigation button.open-icon {
		right: 0;
		/*top: -32px;*/
		margin-top: -30px;
		position: absolute;
		background: transparent;
		border: none;
	}
	.main-navigation button.open-icon:hover, .main-navigation button.open-icon:active, .main-navigation button.open-icon:focus {
		border-color: #232323  #232323  #232323;
		outline: none;
	}
	.open-icon {
	    display: block;
	    float: right;
	    width: 35px;
	    height: 25px;
	    position: relative;
	    margin: 8px 0 0 0;
	    cursor: pointer;
	    position: relative;  
	}
	.open-icon span {
	    height: 1px;
	    width: 100%;
	    position: absolute;
	    left: 0;
	    top: 0;
	    background: #e3b65b;
	    -moz-transition: all 0.3s ease-in-out;
	    -webkit-transition: all 0.3s ease-in-out;
	    transition: all 0.3s ease-in-out;
	}
	.open-icon .menu_label {
	    opacity: 0;
	}
	.open-icon span:nth-child(1) {
	    top: 0px;
	    transform: rotate(0deg);
	    -moz-transform: rotate(0deg);
	    -webkit-transform: rotate(0deg);
	    -ms-transform: rotate(0deg);
	}
	.open-icon span:nth-child(2) {
	    width: 100%;
	    left: 0;
	}
	.open-icon span:nth-child(3) {
	    top: 20px;
	    transform: rotate(0deg);
	    -moz-transform: rotate(0deg);
	    -webkit-transform: rotate(0deg);
	    -ms-transform: rotate(0deg);
	}
	.open-icon span:nth-child(2) {
	    top: 8px;
	}
	.open-icon span:nth-child(3) {
	    top: 16px;
	}
	.main-navigation.toggled .open-icon span:nth-child(1) {
	    top: 10px;
	    transform: rotate(45deg);
	    -moz-transform: rotate(45deg);
	    -webkit-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	}
	.main-navigation.toggled .open-icon span:nth-child(2) {
	    width: 0;
	    left: 50%;
	}
	.main-navigation.toggled .open-icon span:nth-child(3) {
	    top: 10px;
	    transform: rotate(-45deg);
	    -moz-transform: rotate(-45deg);
	    -webkit-transform: rotate(-45deg);
	    -ms-transform: rotate(-45deg);
	}
	.main-navigation {
		margin-top: 40px;
		height: auto;
		max-height: 0px;
		float: none;
		display: block;
		overflow: hidden;
		-moz-transition: max-height 0.75s ease-in-out;
    -webkit-transition: max-height 0.75s ease-in-out;
    transition: max-height 0.75s ease-in-out;
	}
	.main-navigation.toggled {
		max-height: 1500px;
		-moz-transition: max-height 0.75s ease-in-out;
    -webkit-transition: max-height 0.75s ease-in-out;
    transition: max-height 0.75s ease-in-out;
	}
	.menu-primary-menu-container {
		margin-top: 20px;
		background: #232323;
		/*background: rgba(35,35,35,.9);*/
	}
	.home .menu-primary-menu-container {
		padding-bottom: 10px;
	}
	.main-navigation ul {
		width: 100%;
		margin: 0 auto;
		float: none;
		display: block;
	}
	.main-navigation ul li {
		width: 100%;
		padding: 0px;
		text-align: center;
		display: block;
		border-top: 1px solid #444;
		float: none;
	}
	.main-navigation ul > li:first-child {
		display: block;
	}
	.menu-primary-menu-container > ul > li:first-child > a, .menu-primary-menu-container > ul > li:last-child > a {
    background: transparent;
    color: #fff;
  }
  .menu-primary-menu-container > ul > li:first-child > a:hover, .menu-primary-menu-container > ul > li:last-child > a:hover {
    color: #e3b65b;
  }

.main-navigation ul ul {
	border-top: none;
	font-weight: 400;
	box-shadow: none;
}
.main-navigation ul ul li {
	border-top: none;
}
	/*.main-navigation ul > li:last-child {
		border-bottom: 1px solid #3c4865;
	}*/
	.main-navigation ul li a {
		padding: 15px;
		display: block;
	}
	.main-navigation div > ul > li.current-menu-item > a {
		color: #e3b65b;
		border-bottom: none;
	}
	.main-navigation div > ul > li.menu-item-has-children {
		position: relative;
	}
	.main-navigation div > ul > li.menu-item-has-children > a {
		padding-left: 50px;
		padding-right: 0;
		margin-right: 50px;
	}
	.main-navigation div > ul > li.menu-item-has-children > a:after {
		content: none;
	}
	.main-navigation div > ul > li.menu-item-has-children a.subbed-btn {
		padding: 0;
		margin-right: 0;
		width: 20px;
		height: 34px;
		color: #bbb;
		/*border: 1px solid #ccc;
		border-radius: 10px;*/
		display: block;
		top: 11px;
		right: 10px;
		position: absolute !important;
		-moz-transition: all .2s ease-in-out;
	  -webkit-transition: all .2s ease-in-out;
	  transition: all .2s ease-in-out;
	}
	.main-navigation div > ul > li.menu-item-has-children a.subbed-btn:hover {
		color: #e3b65b;
		/*border-color: #4c8dc4;*/
	}
	.main-navigation div > ul > li.menu-item-has-children > a.subbed-btn:after {
		font-family: 'ff-icons';
		font-size: 1.2rem;
		line-height: 1;
		content: '\f107';
		width: 20px;
		height: 20px;
		display: block;
		top: 4px;
		right: 0;
		position: absolute;
	}
	.main-navigation div > ul > li.menu-item-has-children > a.subbed-btn.subbed-open {
		border-color: #4c8dc4;
	}
	.main-navigation div > ul > li.menu-item-has-children > a.subbed-btn.subbed-open:after {
		color: #e3b65b;
		content: '\f106';
	}
	.main-navigation .sub-menu {
		padding-top: 0;
		padding-bottom: 0;
	}
	.main-navigation ul ul {
		left: auto;
		height: auto;
		max-height: 0;
		overflow: hidden;
		float: none;
		position: relative;
		-moz-transition: max-height 0.75s ease-in-out;
    -webkit-transition: max-height 0.75s ease-in-out;
    transition: max-height 0.75s ease-in-out;
	}
	.main-navigation ul li:hover > ul,
	.main-navigation ul li.focus > ul {
		left: inherit;
		position: inherit;
	}
	.main-navigation .sub-open ul.sub-menu {
		max-height: 1000px;
		-moz-transition: max-height 0.75s ease-in-out;
    -webkit-transition: max-height 0.75s ease-in-out;
    transition: max-height 0.75s ease-in-out;
	}
}
@media screen and (max-width: 500px) {
	.site-header-nav {
		padding: 10px 0 5px;
	}
	.hdr-social {
		flex-wrap: wrap;
	}
	.hdr-social a.hdr-call {
		margin-right: 0;
		width: 100%;
		text-align: right;
	}
}

/*** home video ***/
.video-banner {
	background: #000;
	position: relative;
}
.video-banner video {
  width: 100%;
  opacity: 0.4;
  margin-bottom: 0;
  display: block;
  height: auto;
  -webkit-transform: scale(1);
  transform: scale(1);
  background-color: black;
}
.banner-content-wrapper {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
}
.banner-content {
	padding: 0 30px;
	width: 100%;
	max-width: 1300px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.banner-content h1 {
	margin: 0;
	padding: 0 30px;
	font-family: 'Montserrat', sans-serif;
	font-size: 3rem;
	font-weight: 900;
	line-height: 1.2;
	color: #fff;
	text-align: center;
	text-shadow: 1px 1px 2px rgba(0,0,0,.7);
}
.header-locations-tag {
	padding: 25px 0 20px;
}
.header-locations-tag h3 {
	margin: 0 auto;
	padding: 8px 30px;
	font-family: 'Montserrat', sans-serif;
	font-size: 0.9rem;
	font-weight: 600;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
	color: #000;
	background: #e6ecf2;
	border-radius: 6px;
}
.locations-bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.header-location-map {
	padding: 25px 30px 0;
	max-width: 40%;
}
.header-location-map img {
	border-radius: 8px;
}
/*.home-location {
	width: calc(50% - 16px);
	margin: 8px;
}*/
.home-location {
	width: 100%;
	margin: 25px auto 15px;
}
.home-location a {
	opacity: 1;
	-moz-transition: opacity .3s ease-in-out;
  -webkit-transition: opacity .3s ease-in-out;
  transition: opacity .3s ease-in-out;
}
.home-location a:hover {
	opacity: .8;
}
.home-location img {
	border-radius: 6px;
}
@media (max-width: 999px) {
	.banner-content h1 {
		padding-top: 12%;
		font-size: 2.4rem;
	}
}
@media (max-width: 810px) {
	.banner-content h1 {
		padding-top: 140px;
	}
}
@media (max-width: 767px) {
	.banner-content h1 {
		font-size: 2rem;
	}
	.video-banner {
		overflow: hidden;
	}
	.video-banner video {
    height: 600px;
    -webkit-transform: scale(2);
    transform: scale(2);
	}
	.header-location-map {
		max-width: 60%;
	}
	.locations-bar {
		justify-content: center;
	}
	.home-location {
		margin: 8px;
	}
}
@media (max-width: 500px) {
	.header-location-map {
		max-width: 90%;
	}
	.home-location {
		max-width: 80%;
		margin: 8px;
	}
}
@media (max-width: 500px) {
	.header-location-map {
		max-width: 100%;
	}
}

/*** crumby nav ***/
.crumb-wrapper {
	width: 100%;
  display: block;
	background: #e3b65b;
  position: relative;
}
.crumb-wrap {
  margin: 0 auto;
  max-width: 1200px;
  padding: 15px 30px;
  overflow: hidden;
}
.crumby_nav {
    list-style:none;
    padding: 0 15px 0 3px;
    margin: 0;
    font: 400 0.9rem 'Montserrat', sans-serif;
    text-transform: uppercase;
    color: #000;
    float: left;
    overflow:hidden;
}
.crumby_nav li {
    display:inline-block;
    vertical-align:middle;
}
.crumby_nav .separator {
	font-family: 'ff-icons';
    margin-top: -2px;
    padding: 0 15px;
    font-size: 18px;
    color: #000;
    display: inline-block;
}
.crumby_nav li a {
    color: #000;
    font-weight: 600;
    text-decoration: none;
    -moz-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
.crumby_nav li a:hover, .crumby_nav li a:focus {
    color: #000;
    text-decoration: underline;
}
.crumby_nav strong {
    font-weight: 400;
}

@media (min-width: 1260px) {
	.main-header {
		padding: 12px 55px 10px;
	}
}

/***** gutenberg specific *****/
.wp-block-button {
	padding: 40px 0;
}
.wp-block-button.aligncenter {
	text-align: center;
}
.wp-block-button.aligncenter a {
	margin: 0 auto;
}
.wp-block-button .wp-element-button,
.wp-block-button .wp-block-button__link {
	padding: 25px 50px !important;
	font: 600 0.8em/1 'Montserrat', sans-serif !important;
	color: #000 !important;
	text-decoration: none;
	display: inline-block;
	background: #fff !important;
	border: 1px solid #e3b65b;
	border-radius: 0px !important;
	-moz-transition: background .3s ease-in-out;
  -webkit-transition: background .3s ease-in-out;
  transition: background .3s ease-in-out;
}
.wp-block-button .wp-element-button:hover,
.wp-block-button .wp-block-button__link:hover {
	background: #e3b65b !important;
}

/***** site content *****/
.site-content {
	margin: 0 auto;
	padding: 30px;
	max-width: 1300px;
	min-height: 380px;
}
.home .site-content {
	padding-top: 0;
	max-width: none;
}
.site-content .alignwide {
	margin-left: auto;
	margin-right: auto;
	max-width: 1300px;
}
.site-content .alignfull {
	margin-left: -30px;
	width: calc(100% + 60px);
}
/*.home .site-content .entry-content {
	margin-top: -100px;
	position: relative;
  z-index: 2;
}
@media (max-width: 999px) {
	.home .site-content .entry-content {
		margin-top: 0;
	}
}*/

.site-content h1 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 44px;
	font-weight: 400;
}

.site-content h2 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 1.5em;
	font-weight: 700;
}

.site-content h3 {
	font-family: 'Montserrat', sans-serif;
	color: #222;
	font-size: 1.3em;
	font-weight: 700;
}

.site-content h4 {
	color: #222;
	font-size: 22px;
	font-weight: 400;
}

.entry-header .entry-title {
	padding-bottom: 20px;
	margin-bottom: 0;
	font-family: 'Montserrat', sans-serif; /* font family of the post title */
  border-bottom: 1px solid #666;
}
.article-content {
	display: flex;
	flex-direction: column;
}
.has-post-thumbnail .article-content, 
.locations .article-content  {
	flex-direction: row;
}
.has-post-thumbnail .article-content .entry-thumbnail, 
.locations .article-content .entry-thumbnail {
	margin: 1.5em 0 0;
	padding: 30px 40px 15px 15px;
	width: 38%;
	max-width: 430px;
}
.has-post-thumbnail .article-content .entry-thumbnail .post-thumbnail, 
.locations .article-content .entry-thumbnail .post-thumbnail {
	margin-right: 30px;
	font-size: 0;
	line-height: 0;
	position: relative;
}
.has-post-thumbnail .article-content .entry-thumbnail .post-thumbnail img,
.locations .article-content .entry-thumbnail .post-thumbnail img {
	position: relative;
	z-index: 1;
}
.has-post-thumbnail .article-content .post-thumbnail:before, 
.locations .article-content .post-thumbnail:before {
  content: '';
  height: 50%;
  width: 50%;
  background-color: #e3b65b;
  display: block;
  top: -15px;
  left: -15px;
  position: absolute;
  z-index: 0;
}
.has-post-thumbnail .article-content .post-thumbnail:after, 
.locations .article-content .post-thumbnail:after {
  content: '';
  height: 30%;
  width: 30%;
  background-color: #e3b65b;
  display: block;
  bottom: -15px;
  right: -15px;
  position: absolute;
  z-index: 0;
}
.has-post-thumbnail .article-content .entry-content, 
.locations .article-content .entry-content {
	width: 62%;
}

.additional-services {
	padding-top: 30px;
	display: none;
}
.additional-services ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
}
.additional-services ul li span {
	margin: 0 0 8px 0;
	display: flex;
	align-items: center;
	font-size: 1.2rem;
}
.additional-services ul li a {
	color: #222;
	text-decoration: none;
}
.additional-services ul li a span {
	display: flex;
	align-items: center;
}
.additional-services img {
	width: 30px;
	height: auto;
}
.additional-services .additional-icon {
	width: 30px;
}
.additional-services .additional-text {
	padding: 5px 10px;
	margin-left: 8px;
	display: block;
	line-height: 1;
	border-left: 3px solid #e3b65b;
}
.additional-services ul li a span.additional-text {
	text-decoration: underline;
	flex-grow: 1;
}

.desktop-only, .mobile-only {
	display: none;
}
@media (min-width: 768px) {
	.desktop-only {
		display: block;
	}
}
@media (max-width: 767px) {
	.mobile-only {
		display: block;
	}
}


.wp-block-table th,
.wp-block-table td {
	border: none !important;
}
.lined-table {
	max-width: 600px;
	text-align: left;
}

.lined-table tbody>tr>td, 
.lined-table tbody>tr>th, 
.lined-table tfoot>tr>td, 
.lined-table tfoot>tr>th, 
.lined-table thead>tr>td, 
.lined-table thead>tr>th {
    border-top: 1px solid #ccc !important;
    font-size: 16px;
    line-height: 1.42857143;
    padding: 12px 8px;
    vertical-align: top;
}

.section-wrapper {
	width: 100%;
	display: flex;
	justify-content: center;
}
.section-wrap {
	width: 100%;
	padding-top: 10px;
}

.services-block-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.service-block {
	width: calc(33.333% - 16px);
	margin: 8px;
	position: relative;
	background-size: cover;
	background-position: center;
}
.service-block-ratio {
	padding-top: 80%;
}
.service-block a {
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	position: absolute;
	display: flex;
	flex-direction: column;
	justify-content: center;
	font-family: 'Montserat', sans-serif;
	font-size: 0.85rem;
	font-weight: 600;
	text-align: center;
	align-items: center;
	color: #e3b65b;
	text-decoration: none;
	background: rgba(0,0,0,.1);
	-moz-transition: background .3s ease-in-out;
  -webkit-transition: background .3s ease-in-out;
  transition: background .3s ease-in-out;
}
.service-block a:hover {
	background: rgba(0,0,0,.4);
}
.service-block a span {
	display: block;
}
.service-block-name {
	padding: 50% 10px 3px;
	color: #fff;
	font-size: 1.25rem;
	line-height: 1.2;
	font-weight: 700;
}

.section-services-footer {
	margin: 0 auto;
	padding: 20px 30px 0;
  max-width: 1300px;
  display: flex;
  flex-wrap: wrap;
}
.section-services-footer .service-block {
    width: calc(11.111% - 2px);
    margin: 1px;
}
.section-services-footer .service-block a {
  background: rgba(0,0,0,0);
}
.section-services-footer .service-block span:not(.service-block-name) {
    display: none;
}
.section-services-footer .service-block span.service-block-name {
    padding: 0 10px;
    bottom: 10px;
    position: absolute;
    font-size: 0.7rem;
    font-weight: 400;
    text-transform: uppercase;
}
/*.service-block-name {
    padding: 35% 10px 10px;
    color: #fff;
    font-size: 1.25rem;
    line-height: 1.2;
    font-weight: 900;
}*/
@media (max-width: 999px) {
	.section-services-footer .service-block span.service-block-name {
		display: none;
	}
}
@media (max-width: 900px) {
	.service-block {
    width: calc(50% - 16px);
	}
}
@media (max-width: 767px) {
	.service-block {
    width: calc(100% - 16px);
	}
}
@media (max-width: 550px) {
	.section-services-footer .service-block {
    width: calc(20% - 2px);
    margin: 1px;
	}
}
.editor-block-wrap {
	text-align: left;
}

.split-boxed {
	padding: 10px 0;
}
.split-boxed-content {
	display: flex;
	background: #fff;
}
.split-boxed-text, .split-boxed-image {
	width: 50%;
}
.split-boxed-text {
	padding: 15px 0 30px 30px;
}
.split-boxed-text h2 {
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.2;
}
.split-boxed-text h3 {
	font-weight: 500;
	line-height: 1.2;
}
.split-boxed-text .wp-block-button {
	padding: 15px 0;
}
.split-boxed-image {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.family-jeweler {
	padding-top: 1rem;
}
.family-jeweler h3 {
	margin: 0;
	font-size: clamp(1.5rem, 1.031rem + 1.5vw, 2.25rem);
	font-weight: 800;
	line-height: 1.1;
}
.family-jeweler h2 {
	margin: 0.25em 0 0.65em;
	font-size: clamp(2.25rem, 1.781rem + 1.5vw, 3rem);
	font-weight: 400;
	line-height: 1.1;
}
.family-jeweler .wp-block-column {
	margin: 1rem;
}
.family-jeweler .wp-block-column img {
	margin-top: 8px;
}

/*** reviews page ***/
.google-places-reviews, .yelp-business {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
[id*=gpr_widget] div.gpr-review-content>p {
  font-size: inherit !important;
}
.gpr-minimal-light-style a {
  color: #005699 !important;
}
.yelp-business a.name, [id*=gpr_widget] .gpr-business-name>a, [id*=gpr_widget] .gpr-business-name>a:visited {
  font-size: inherit !important;
}
.reviews-box {
  padding: 0 15px 15px;
  box-shadow: 0 2px 2px rgba(0,0,0,.2), 0 1px 5px rgba(0,0,0,.2);
  margin-bottom: 40px;
  background: #fff;
  position: relative;
}
.reviews-box h2 {
  margin: 0 -15px 30px;
  padding: 15px !important;
  font-size: 1rem;
  text-transform: uppercase;
  background: #232323;
  color: #fff;
  border-bottom: 2px solid #ccc;
}
.reviews-box span.gpr-rating-time {
  color: #666 !important;
}
/*** showcase ***/
.embed-responsive {
  position: relative;
  display: block;
  height: 0;
  padding: 0;
  overflow: hidden;
}
.showcase .embed-responsive, .showcase iframe {
  width: 100%;
  min-height: 1450px;
  border: none;
}
/***** coupons *****/
.coupons_page {
  margin-bottom: 0;
}
.coupons_wrap {
  text-align: center;
}
.coupons_wrap ul {
  margin: 0 auto;
  padding: 0;
  list-style-type: none;
}
.coupons_wrap ul li {
  margin: 2%;
  width: 45%;
  vertical-align: top;
  display: inline-block;
}
.coupon_outline {
  padding: 10px 20px;
  border: 4px dashed #333;
  cursor: pointer;
  background: #fff;
}
.coupon_outline .fast-fix-small {
  display: none;
}
.coupon_outline h3 {
  margin: -14px -24px 0;
  padding: 10px;
  background: #333;
  color: #fff;
}
.coupon_outline p {
	margin: 0;
  padding: 20px 0 0;
  font-size: 1.0em;
  line-height: 1.4em;
  color: #000;
}
.coupon_outline p.coupon_disclaimer {
  padding: 20px 10px;
  font-size: 0.7em;
  line-height: 1.2em;
}
.coupon_outline p.coupon_expire {
  padding: 0 10px 2px;
  font-size: 0.6em;
  line-height: 1.2em;
}
@media (max-width: 940px) {
  .coupons_wrap ul li {
      width: 85%;
  }
}
@media (max-width: 500px) {
  .coupons_wrap ul li {
      margin: 2% 0;
      width: 100%;
  }
}

/***** locations listing and content page *****/
.locations-listing-wrapper {
	padding-bottom: 30px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
.locations-listing-wrapper article {
	margin: 30px 0;
	width: 40%;
}
.locations-listing-wrapper h2 {
	margin: 20px 0 0 0;
	padding: 0px;
	line-height: 1.2;
}
.locations-listing-wrapper .article-content .entry-content {
	width: 100%;
}
.locations-listing-wrapper .locations-info {
	padding-left: 20px;
	border-left: 3px solid #e3b65b;
}
.locations-listing-wrapper .locations-info .wp-block-button {
	padding: 0 0 10px 0;
}
.locations-listing-wrapper .locations-info .wp-block-button a {
	padding: 15px 30px;
	font-size: 0.8rem;
	text-transform: uppercase;
}
.locations-info {
    position: relative;
}
.locations-info span, .locations-social span {
    width: 30px;
    text-align: center;
    position: relative;
    display: inline-block;
}
.locations-info .icon-mobile {
    font-size: 26px;
}
.locations-info .icon-mobile:before {
    left: 9px;
    bottom: -7px;
    position: absolute;
}
.location_in_mall {
	padding-bottom: 1.5rem;
}
.location_in_mall img {
	max-width: 562px;
	width: 100%;
}

.locations-social {
	padding-top: 0;
	font-size: 1.25rem;
}
.locations-social a {
	display: inline-block;
}
.locations-social a:first-of-type {
	margin-left: -5px;
}
/*.locations-social {
    padding: 10px 0;
    font-size: 1.25rem;
    text-align: left;
}
.locations-social a {
    margin: 0;
    padding: 0;*/
    /*color: #fff;
    background: #3b5998;
    text-decoration: none;*/
    /*border-bottom: inherit;
    display: inline-block;
}*/
/*.locations-social a.location-twitter {
    background: #00aced;
}
.locations-social a.location-pinterest {
    background: #c92228;
}
.locations-social a.location-instagram {
    background: #d93175;
}
.locations-social a.location-google {
    background: #007b1e;
}*/               
.location-map {
	padding: 50px 0 30px;
}
.location iframe {
	width: 100%;
}
.locations-map-org {
	height: 400px;
	box-shadow: 0px 1px 3px rgba(0,0,0,.1);
	/*border: 3px solid #fff;*/
}

.fastfix-divider {
	padding: 0 28%;
	text-align: center;
}
.fastfix-cta {
	padding: 40px 0 50px;
	display: flex;
	align-items: center;
	background: rgb(255,255,255);
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 50%, rgba(216,224,232,1) 50%, rgba(216,224,232,1) 100%);
}
.home .fastfix-cta {
	padding: 40px 0 30px;
}
.fastfix-cta-wrap {
	margin: 0 auto;
	padding: 50px 60px;
	max-width: 800px;
	background: #000;
	text-align: center;
}
.fastfix-cta-wrap h3,
.fastfix-cta-wrap p {
	color: #fff;
}
.fastfix-cta-wrap h3 {
	margin: 0 0 24px;
	font-size: 30px;
	line-height: 1.1;
}
.fastfix-cta-wrap p {
	margin-top: 0;
}
.fastfix-cta-wrap a {
	font-size: clamp(1.875rem, 1.172rem + 2.25vw, 3rem);
	font-weight: 700;
	color: #e3b65b;
	text-decoration: none;
	-moz-transition: color .3s ease-in-out;
  -webkit-transition: color .3s ease-in-out;
  transition: color .3s ease-in-out;
}
.fastfix-cta-wrap a:hover {
	color: #fff;
}
.fastfix-cta-wrap a span {
	margin-right: -10px;
	font-size: clamp(1.375rem, 0.672rem + 2.25vw, 2.5rem);
}

/***** footer area *****/
.footer {
	background: #e7edf1;
}
.home .footer {
	padding-top: 20px;
}
.section-footer {
	margin: 0 auto;
	padding: 30px;
	max-width: 1300px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.footer-col {
	padding-bottom: 15px;
	width: 22%;
}
.footer-logo {
	padding: 30px 0 15px;
}
.footer .widget-title {
	font-size: 1.1rem;
	text-transform: uppercase;
	font-weight: 600;
}
.footer-col ul.menu {
    margin: 0;
    padding: 0;
    list-style-type: none;
    font-size: 0.9rem;
}
.footer-col ul.menu li a {
    padding: 3px 0;
    color: #222;
    text-decoration: none;
    display: block;
}
.footer-col ul.menu li a:hover {
    color: #7b641b;
    text-decoration: underline;
}
.footer-contact-extra a {
	padding: 3px 0;
	color: #222;
	text-decoration: none;
	display: block;
}
.footer-contact-extra a:hover {
	color: #7b641b;
	text-decoration: underline;
}
.footer-contact-extra .ftr-call {
	margin-left: -3px;
	font-size: 0.875em;
	font-weight: 800;
}
.footer-contact-extra .ftr-call span {
	font-size: 1.125em;
	vertical-align: middle;
}
.footer-social {
	padding-top: 20px;
	font-size: 1.25rem;
}
.footer-social h2 {
	margin-bottom: 10px;
}
.footer-social a {
	display: inline-block;
}
.footer-social a:first-of-type {
	margin-left: -5px;
}
#menu-contact li a {
	padding-left: 25px;
	position: relative;
}
#menu-contact li a:before {
	content: '\f219';
	font-family: 'ff-icons';
	display: block;
	left: 0;
	top: 2px;
	position: absolute;
}

.site-footer-info {
	margin: 0 auto;
	padding: 50px 30px;
	max-width: 1300px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}
.site-footer {
	background: #e3b65b;
	font-size: 0.9rem;
}
.site-footer a {
	color: #222;
	text-decoration: none;
}
.site-footer-links a {
	font-weight: 600;
	text-decoration: underline;
}
/* to top */
.to-top {
  right: 10px;
  bottom: -60px;
  position: fixed;
  -moz-transition: bottom .5s ease-in-out;
  -webkit-transition: bottom .5s ease-in-out;
  transition: bottom .5s ease-in-out;
  z-index: 100;
}
.top-show {
  bottom: 92px;
}
.to-top a {
  width: 36px;
  height: 36px;
  font-size: 36px;
  line-height: 30px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: rgba(0,0,0,.75);    
  -moz-transition: background 0.3s ease-in-out;
  -webkit-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
  display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 2px;
  outline: none;
}
.to-top a:hover {
  background: rgba(0,0,0,1);
}
.to-top a span {
  display: inline-block;
  margin-top: -6px;
}

@media (max-width: 900px) {
	.footer-col {
		width: 48%;
	}
	.footer-col {
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: center;
	}
	.footer-col ul.menu li a {
		margin: 0 auto;
		display: inline-block;
	}
	.site-footer-info {
		flex-direction: column;
		text-align: center;
	}
}
@media (max-width: 767px) {
	.split-boxed-content {
		flex-direction: column;
	}
	.split-boxed-text, .split-boxed-image {
		width: 100%;
	}
	.split-boxed-text {
		padding: 15px 15px 0;
	}
	.split-boxed-text .wp-block-button {
    text-align: center;
	}
	.locations-listing-wrapper article {
		width: 80%;
	}
	.has-post-thumbnail .article-content, 
	.locations .article-content {
		flex-direction: column;
	}
	.has-post-thumbnail .article-content .entry-thumbnail,
	.locations .article-content .entry-thumbnail {
    margin: 1.5em 0 0;
    padding: 30px 70px 15px 15px;
    width: 100%;
    max-width: 430px;
	}
	.has-post-thumbnail .article-content .entry-content, 
	.locations .article-content .entry-content {
    width: 100%;
	}
}
@media (max-width: 600px) {
	.footer-col {
		width: 100%;
	}
}
@media (max-width: 550px) {
	body {
		font-size: 14px;
	}
	.banner-content {
		padding: 0 15px;
	}
	.site-content {
		padding: 30px 15px;
	}
	.video-banner video {
    -webkit-transform: scale(3);
    transform: scale(3);
	}
	.locations-listing-wrapper article {
		width: 100%;
	}
	.site-content .alignfull {
		margin-left: -15px;
		margin-right: -15px;
		width: auto;
	}
}
.section-sms {
	font-size: 1rem;
	background: #d8e0e8;
}
.section-sms h3 {
	margin: 0px 0px 10px;
}
.section-sms-inner {
	margin: 0 auto;
	padding: 30px;
	max-width: 1300px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}
.section-sms-left-col {
	width: 22%;
}
.section-sms-left-col img {
	width: 80px;
}
.hide-this {
	height: 0px;
	overflow: hidden;
}
.section-sms-right-col {
	width: 74%;
}
.sms-inputs-wrap {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.sms-inputs-wrap .sms-col-3 {
	width: 30.5% !important;
}
.sms-inputs-wrap .sms-col-3 input {
	padding: 10px;
	width: 100%;
	max-width: 100% !important;
}
.sms-inputs-wrap .sms-col-3 label {
	font-weight: bold;
	padding: 0 0 0 10px;
}
.sms-inputs-wrap .wpcf7-not-valid-tip {
	padding: 0 0 0 10px;
	font-size: 0.875rem;
}
.sms-checkbox-wrap {
	margin: 1rem 0;
	width: 100% !important;
	position: relative;
}
.sms-checkbox-wrap .wpcf7-form-control-wrap {
	left: -14px;
	top: 0;
	position: absolute;
}
.sms-checkbox-wrap .wpcf7-list-item-label {
	visibility: hidden;
}
.sms-checkbox-wrap .sms-text {
	padding: 0 0 0 30px;
}
.sms-button-wrap {
	padding: 8px 0 0 30px;
}
.sms-button-wrap input {
	padding: 15px 30px;
	background: #000;
	font-size: 0.875rem;
	color: #fff;
	text-transform: uppercase;
	border: none;
}
#sms-optin .last {
	visibility: hidden;
	pointer-events: none;
}
@media (max-width: 1020px) {
	.section-sms-left-col,
	.section-sms-right-col {
		width: 100%;
	}
}
@media (max-width: 740px) {
	.sms-inputs-wrap {
		flex-direction: column;
	}
	.sms-inputs-wrap .sms-col-3 {
		width: 100% !important;
	}
}