/*
    Theme Name: Starterpistol Child
    Author: Ramirez Creative Solutions
    Template: starterpistol
	1.1.0
*/

/************************************************
 HTML Elements
************************************************/
ul.two-column {
	-webkit-column-count: 2;
	-moz-column-count: 2;
	column-count: 2;
	-webkit-column-gap: 40px;
	column-gap: 40px;
	-moz-column-gap: 40px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.three-column .gfield_checkbox,
ul.three-column {
	-webkit-column-count: 3;
	-moz-column-count: 3;
	column-count: 3;
	-webkit-column-gap: 40px;
	column-gap: 40px;
	-moz-column-gap: 40px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.three-column .gfield_checkbox .gchoice,
.three-column .gfield_checkbox {
	display: block !important;
}

.three-column .gfield_checkbox .gchoice,
ul.two-column li,
ul.three-column li {
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
	margin: 0 0 1em 0;
}

small {
	line-height: 1.2;
}

p {
	line-height: 1.5;
}

/************************************************
 Accordion
************************************************/
.accordion {
  padding: 2em 0;
}

.accordion-item {
  clear: both;
  margin-bottom: .5em;
}

.accordion__title {
	cursor: pointer;
	font-size: 16px;
	font-weight: bold;
	padding: 1em 4em 1em 2em;
	position: relative;
}

.accordion__title span {
	background-image: url(images/plus-light.svg);
	background-repeat: no-repeat;
	cursor: pointer;
	display: inline-block;
	height: 21px;
	position: absolute;
	right: 20px;
	top: 20px;
	width: 21px;
}

.accordion__title,
.accordion__title.is-open,
.accordion__content {
	background-color: #fff;
	color: var(--copy);
}

.accordion__title.is-open span {
	background-image: url(images/minus-light.svg);
	background-repeat: no-repeat;
	cursor: pointer;
	display: inline-block;
	height: 21px;
	position: absolute;
	right: 20px;
	top: 20px;
	width: 21px;
}

.accordion__content { 
	display: none;
	overflow: hidden;
	padding: 0 2em 2em 2em; 
}

.accordion .columns {
	margin: 0 0 2em 0;
}

.accordion h2 {
	color: var(--quaternary-color);
	font-size: var(--font-2x);
}

/****************************************
 Back To Top
****************************************/
.backtotop a {
    bottom: 0;
    display: inline-block;
    position: fixed;
    right: 15px;
    z-index: 1000;
	background-color: var(--primary-color);
	padding: .5em .5em 0em .5em;
}

.backtotop a:before {
    background-image:url(images/chevron-up-solid.svg);
    content:"";
    display: inline-block;
    height: 18px;
    width: 18px;
    background-repeat: no-repeat;
    -webkit-filter: invert(100%) sepia(0%) saturate(7430%) hue-rotate(329deg) brightness(107%) contrast(107%);
    filter: invert(100%) sepia(0%) saturate(7430%) hue-rotate(329deg) brightness(107%) contrast(107%);
    text-align: center;
    z-index: 1001;
}

/****************************************
 Blogs
****************************************/
.blog-item {
    margin: 0 0 2em 0;
    padding: 0 0 1em 0;
}

a.learn-more,
.blog-item a.learn-more {
	color: #fff;
	font-weight: 600;
	text-align: right;
}

a.learn-more:after,
.blog-item a.learn-more:after,
.blog-item:hover a.learn-more:after {
	background-image: url(images/arrow-right-solid.svg);
	background-repeat: no-repeat;
	content: "";
	display: inline-block;
    height: var(--font-md);
	width: var(--font-md);
	vertical-align: middle;
}

a.learn-more:after,
.blog-item a.learn-more:after {
	-webkit-filter: invert(35%) sepia(13%) saturate(5296%) hue-rotate(330deg) brightness(99%) contrast(90%);
    filter: invert(35%) sepia(13%) saturate(5296%) hue-rotate(330deg) brightness(99%) contrast(90%);
	margin: 0 0 0 .5em;
}

a.learn-more,
.blog-item a.learn-more {
	color: var(--secondary-color);
}

.blog-item .date p.day,
.single-post .date p.day {
    font-size: var(--font-3x);
    font-weight: 600;
    line-height: .7;
}

.blog-item .date p.year,
.single-post .date p.year {
	font-size: var(--font-sm);
}

.blog-item .date {
	-ms-flex-preferred-size: 10%;
    flex-basis: 10%;
	font-size: var(--font-sm);
	text-align: center;
}

.blog-item h3 {
	margin: 0;
}

.blog-item h3 a {
	color: #000;
	font-size: var(--font-xl);
	line-height: 1.2;
}

.blog-item .content p {
	font-size: var(--font-md);
	margin: 1em 0;
} 

.blog-item .media {
	line-height: 0;
	overflow: hidden;
}

.blog-item .media a,
.blog-item img {
	width: 100%;
}

.blog-item img {
	height: 250px;
	-o-object-fit: cover;
	object-fit: cover;
	-webkit-transition: all .2s ease-in-out;
    -o-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

.blog-item:hover img {
	-webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.blog__meta {
	border-bottom: 1px solid #eee;
	margin: 0 0 .5em 0;
    padding: 0 0 1em 0;
}

.blog-item .content {
	padding: 1em 0;
}

.home .blog-item .content,
.archive .blog-item .content {
	-ms-flex-preferred-size: 80%;
    flex-basis: 80%;
}

.page-template-blog-template-page .blog-item .content,
.page-template-blog-template-page .blog-item h2 {
	margin: 0 0 1em 0;
}

.blogs--related {
	padding: 2em 0;
}

.blog-items--related h2 {
	font-size: var(--font-2x);
    text-transform: uppercase;
}

.blog-items--related {
	position: relative;
	border: none;
}

.blog-items--related .content {
    background-color: #fff;
    margin: 0 auto;
    padding: 1em 0;
    position: relative;
    width: 100%;
    z-index: 100;
}

.blog-items--related .content,
.single .blog-items--related .blog__meta {
	text-align: left;
}

.blog-items--related img {
	-o-object-fit: cover;
	object-fit: cover;
	width: 100%;
}

.blog-items--related .content h3 {
    font-size: var(--font-lg);
	font-weight: 600;
    line-height: 1.2;
}

.blog-items--related .content h3 a {
	color: var(--primary-color);
}

.blog-items--related .content h3 a:hover {
	color: var(--secondary-color);
	text-decoration: underline;
}

/****************************************
 Breadcrumbs
****************************************/
.breadcrumbs {
	margin: 0.5em 0 0 0;
	position: relative;
	text-align: left;
	text-transform: uppercase;
	z-index: 100;
}

.breadcrumbs p.inner {
    margin: 0;
}

.breadcrumbs a {
  color: var(--quaternary-color);
  margin: 0 0.5em 0 0;
}

.breadcrumbs span span span a {
  margin: 0 0.5em;
}

.breadcrumbs .breadcrumb_last,
.breadcrumbs-inner {
	color: #fff;;
}

.breadcrumbs .breadcrumb_last {
  	margin: 0 0 0 .5em ;
}

.breadcrumbs-inner {
	font-size: var(--font-sm);
	margin: 0 0 .5em 0;
}

/****************************************
 Buttons
****************************************/
button,
input[type=button],
input[type=reset],
input[type=submit] {
	border: none;
	border-radius: 0;
	background-color: var(--link-color);
	color: #fff;
	font-family: var(--font-family);
	font-size: 14px;
	line-height: 1.5;
	padding: 15px;
	white-space: pre-line;
	width: 100%;
}

button:hover,
input[type=button]:hover,
input[type=reset]:hover,
input[type=submit]:hover {
  	background-color: var(--link-hover);
}

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 {
  	background-color: var(--link-hover);
}

.woocommerce a.button,
.woocommerce .button,
a.button,
.button {
	border-radius: 30px;
	display: inline-block;
	font-size: var(--font-md);
	font-weight: 600;
	line-height: normal;
    padding: 0.75em 2em;
	text-decoration: none;
	white-space: pre-wrap;
}

.woocommerce a.button--small,
.woocommerce .button--small,
a.button--small,
.button--small {
	border-radius: 3px;
	font-size: var(--font-sm);
	padding: .5em 1em;
}

.woocommerce a.button--large,
.woocommerce .button--large,
a.button--large,
.button--large {
	font-size: var(--font-lg);
	padding: 1em 3em;
}

.woocommerce a.button--accent-color,
.woocommerce .button--accent-color,
a.button--accent-color,
.button--accent-color {
	background-color: var(--accent-color);
	color: var(--copy);
}

.woocommerce a.button--accent-color:hover,
.woocommerce .button--accent-color:hover,
a.button--accent-color:hover,
.button--accent-color:hover {
	background-color: var(--copy);
	color: #fff;
}

.woocommerce a.button--accent-color.has-arrow:after,
.woocommerce .button--accent-color.has-arrow:after,
a.button--accent-color.has-arrow:after,
.button--accent-color.has-arrow:after {
	background-image: url(images/arrow-up-right-light.svg);
	background-repeat: no-repeat;
    content: "";
	display: inline-block;
	-webkit-filter: brightness(0) saturate(100%);
    filter: brightness(0) saturate(100%);
	height: 14px;
	margin: 0 0 0 .75em;
	width: 14px;
	vertical-align: middle;
}

.woocommerce a.button--accent-color.has-arrow:hover:after,
.woocommerce .button--accent-color.has-arrow:hover:after,
a.button--accent-color.has-arrow:hover:after,
.button--accent-color.has-arrow:hover:after {
	-webkit-filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
}

.woocommerce a.button--primary-color,
.woocommerce .button--primary-color,
a.button--primary-color,
.button--primary-color {
	background-color: var(--primary-color);
	color: #fff;
}

.woocommerce a.button--primary-color:hover,
.woocommerce .button--primary-color:hover,
a.button--primary-color:hover,
.button--primary-color:hover {
	background-color: var(--copy);
	color: #fff;
}

.woocommerce a.button--secondary-color,
.woocommerce .button--secondary-color,
a.button--secondary-color,
.button--secondary-color {
	background-color: var(--secondary-color);
	color: #fff;
}

.woocommerce a.button--secondary-color:hover,
.woocommerce .button--secondary-color:hover,
a.button--secondary-color:hover,
.button--secondary-color:hover {
	background-color: var(--primary-color);
	color: #fff;
}

.woocommerce a.button--transparent,
.woocommerce .button--transparent,
a.button--transparent,
.button--transparent {
	background-color: transparent;
	border: 2px solid var(--secondary-color);
	border-radius: 30px;
	color: var(--secondary-color);
}

.woocommerce a.button--transparent:hover,
.woocommerce .button--transparent:hover,
a.button--transparent:hover,
.button--transparent:hover {
	background-color: var(--secondary-color);
	color: #fff;;
}

.woocommerce a.button--invert,
.woocommerce .button--invert,
a.button--invert,
.button--invert {
	background-color: #fff;
	color: var(--copy);
}

.woocommerce a.button--invert:hover,
.woocommerce .button--invert:hover,
a.button--invert:hover,
.button--invert:hover {
	background-color: var(--copy);
	color: #fff;;
}

/****************************************
 Colors
****************************************/
.bg-color--accent {
	background-color: var(--accent-color);
}

.bg-color--primary {
	background-color: var(--primary-color);
}

.bg-color--secondary {
	background-color: var(--secondary-color);
}

.bg-color--tertiary {
	background-color: var(--tertiary-color);
}

.bg-color--quaternary {
	background-color: var(--quaternary-color);
}

.bg-color--accent
.bg-color--primary,
.bg-color--secondary,
.bg-color--tertiary,
.bg-color--quaternary {
	color: #fff;
}


.text-primary,
.text-color--accent {
	color: var(--accent-color) !important;
}

.text-color--primary {
	color: var(--primary-color);
}

.text-color--secondary {
	color: var(--secondary-color);
}

.text-color--tertiary {
	color: var(--tertiary-color);
}

.text-color--quaternary {
	color: var(--quaternary-color);
}

.text-color--copy {
	color: var(--copy);
}

/****************************************
 Columns
****************************************/
.columns {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.columns--vertical-center {
	-webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.columns--vertical-bottom {
	-webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
}

.columns--flex-start {
	-webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.columns--flex-end {
	-webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.column-half {
	-ms-flex-preferred-size: 48%;
	flex-basis: 48%;
}

.column-thirds {
	-ms-flex-preferred-size: 32%;
	flex-basis: 32%;
}

.column-fourths {
	-ms-flex-preferred-size: 23%;
	flex-basis: 23%;
}

.column-three-fourths {
	-ms-flex-preferred-size: 74%;
	flex-basis: 74%;
}

.column-two-thirds {
	-ms-flex-preferred-size: 62%;
	flex-basis: 62%;
}

.column-ten {
	-ms-flex-preferred-size: 10%;
	flex-basis: 10%;
}

.column-ninety {
	-ms-flex-preferred-size: 90%;
	flex-basis: 90%;
}

/****************************************
 Columns-Grid
****************************************/
.columns--grid-half,
.columns--grid-thirds,
.columns--grid-fourths,
.columns--grid-fifths,
.columns--grid-six {
	display: -ms-grid;
    display: grid;
}

.columns--grid-half {
    -ms-grid-columns: (48% [col-start])[2];
    grid-template-columns: repeat(2, 48% [col-start]);
}

.columns--grid-thirds {
    -ms-grid-columns: (32% [col-start])[3];
    grid-template-columns: repeat(3, 32% [col-start]);
}

.columns--grid-fourths {
    -ms-grid-columns: (24% [col-start])[4];
    grid-template-columns: repeat(4, 24% [col-start]);
}

.columns--grid-fifths {
    -ms-grid-columns: (18% [col-start])[5];
    grid-template-columns: repeat(5, 18% [col-start]);
}

.columns--grid-six {
    -ms-grid-columns: (15% [col-start])[6];
    grid-template-columns: repeat(6, 15% [col-start]);
}

/****************************************
 Comments
****************************************/
.comment-content a {
  	word-wrap: break-word;
}

.bypostauthor {
  	display: block;
}

/****************************************
 Display
****************************************/
.is-hidden {
	display: none !important;
}

.is-visible {
    display: block !important;
}

/****************************************
 Fields & Forms
****************************************/
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,
select {
	background-color: #fff;
	border: none;
	border-radius: 5px;
	color: #000;
	font-family: var(--font-family);
	font-size: var(--base-font);
	margin: 0 0 .5em 0;
	padding: 15px;
	text-align: left;
	max-width: 100%;
}

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,
select:focus {
	color: var(--copy);
}

textarea {
  width: 100%;
}

::-webkit-input-placeholder {
    color: var(--gray);
	font-size: var(--font-xs);
}
:-ms-input-placeholder {
    color: var(--gray);
	font-size: var(--font-xs);
}
::-ms-input-placeholder {
    color: var(--gray);
	font-size: var(--font-xs);
}
::placeholder {
    color: var(--gray);
	font-size: var(--font-xs);
}

.gform_wrapper .gform_footer {
  margin: 0 !important;
  padding: 0 !important;
}

.gform_footer .gform_button {
	background-color: var(--accent-color) !important;
	border-radius: 20px;
	color: var(--copy) !important;
	font-size: var(--font-md);
	margin: 1em 0 0 0 !important;
	padding: 0.5em 3em !important;
	text-transform: capitalize !important;
	width: 100%;
}

.gform_footer .gform_button:hover, .gform_footer .gform_button:focus { 
  background-color: var(--copy) !important;
  color: #fff !important;
}

.gform_wrapper label.gfield_label, .gform_wrapper legend.gfield_label {
    font-weight: 300 !important;
    font-size: var(--font-sm) !important;
}

body .gform_wrapper .gfield_checkbox label a,
body .gform_wrapper .gfield_checkbox label {
    font-size: var(--font-xs) !important;
    color: #fff;
}

body .gform_wrapper .gfield_checkbox label a:hover {
    text-decoration: underline;
}

.home .gchoice label,
.home .gchoice label a {
	color: #fff !important;
}

.gchoice label,
.gchoice label a {
	color: var(--copy) !important;
}

.gchoice label a:hover {
	text-decoration: underline;
}

/****************************************
 Glide
****************************************/
.glide__arrows {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
	width: 100%;
    z-index: 100;
}

.glide__arrow--left,
.glide__arrow--right {
	position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: auto;
}

.glide__arrow--left:before,
.glide__arrow--right:before {
	background-repeat: no-repeat;
	content: "";
	display: inline-block;
	-webkit-filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(2%) hue-rotate(279deg) brightness(105%) contrast(101%);
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(2%) hue-rotate(279deg) brightness(105%) contrast(101%);
	height: 21px;
	width: 21px;
	vertical-align: middle;
}

.glide__arrow--left {
    left: 10px;
}

.glide__arrow--left:before {
	background-image: url(images/arrow-left-sharp-light.svg);
}

.glide__arrow--right {
    right: 10px;
}

.glide__arrow--right:before {
	background-image: url(images/arrow-right-sharp-light.svg);
}

/****************************************
 Grid
****************************************/
.grid {
	-webkit-column-count: 3;
	-moz-column-count: 3;
	column-count: 3;
	-webkit-column-fill: balance;
    -moz-column-fill: balance;
    column-fill: balance;
	gap: 2em;
}

.grid-item {
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
	margin: 0 0 2em 0;
}

.grid-item .inner,
.grid-items .inner {
	padding: 1em 0;
	line-height: 1;
}

.grid-item a,
.grid-items a {
	display: block;
}

.grid-item p,
.grid-item--image p,
.grid-item--video p {
	color: #000;
	font-size: var(--font-md);
	margin: 0;
}

.grid-item p.title,
.grid-item--image p.title,
.grid-item--video p.title {
	font-size: var(--font-sm);
  	font-weight: 600;
	margin: 0;
}
  
.grid__pagination {
	border-top: 1px solid #ccc;
	display: block;
	margin: 2em 0;
	padding: 1em 0 0 0;
	text-align: center;
}
  
.grid__pagination.hidden {
  	display: none;
}
  
.grid__pagination span.page-numbers.current {
	background-color: var(--link-color);
	color: #fff;
	display: inline-block;
	font-size: 14px;
	padding: 5px 18px;
}
  
.grid__pagination a.page-numbers {
	color: #000 !important;
	display: inline-block;
	font-size: 14px;
	padding: 5px 18px;
	position: relative;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
}
  
.grid__pagination a.page-numbers:hover, 
.grid__pagination a.page-numbers:focus {
	background-color: var(--link-hover);
	color: #fff !important;
	text-decoration: none;
}

.grid-item--image,
.grid-item--video {
	background-color: transparent;
    margin: 0 0 1em 0;
}

.grid-item--image .content,
.grid-item--video .content {
	padding: 1em 0;
}

.grid-item--image.column-thirds img {
    height: 205px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
}

/****************************************
 Hero
****************************************/
.hero {
	min-height: 400px;
}

.hero h1 {
	color: #fff;
	padding: 0 2em 0 0;
}

.hero h1 span {
	color: var(--accent-color);
}

.hero,
.hero--internal {
	background-color: #eee;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
}

.hero--internal {
  	background-position: 50% 50%;
}

.hero--internal:before {
	background-color: var(--primary-color);
	bottom: 0;
	content: "";
	display: block;
	left: 0;
	position: absolute;
	opacity: .75;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 2;
}

.hero .columns {
  	min-height: 600px;
}

.hero--internal,
.hero--internal .hero__inner,
.hero--internal .inner {
  	min-height: 300px;
}

.hero--internal .inner.columns {
	-webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.hero--internal {
	background-attachment: fixed;
}

.post-type-archive-testimonials .hero--internal .page__title {
	text-align: center;
}

.hero--internal .page__title h1 {
	color: #fff;
	font-family: var(--font-secondary);
	font-size: var(--font-3x);
	font-weight: 400;
	line-height: 1;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 10;
}

.hero--internal .inner {
	position: relative;
	z-index: 10;
}

.hero--internal p {
	color: #fff;
	font-size: var(--font-md);
}

.hero.is-desktop {
	display: block;
}

.hero.is-mobile {
	display: none;
}

.hero.is-mobile .item {
	padding: 1em 0;
}

.hero .glide__slide .content h1 {
	font-size: var(--font-4x);
    font-weight: 600;
    line-height: 1;
    margin: 0 0 .5em 0;
}

.hero .content p {
	color: #fff;
	margin: 0 0 1em 0;
}

.hero .column-half.media {
	text-align: center;
}

.hero .column-half.media img {
	height: 350px;
}

.hero.is-desktop .glide__slide:before, 
.hero.is-mobile .glide__slide:before {
    background-color: var(--secondary-color);
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    opacity: .8;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 2;
}

.home .hero.is-desktop .glide__slide,
.home .hero.is-desktop .glide__slide .inner,
.hero,
.hero .inner,
.hero .columns {
	min-height: 600px;
}

.home .hero.is-desktop .glide__slide .inner,
.hero .inner {
	position: relative;
	z-index: 10;
}

.hero ul.glide__slides {
	list-style: none;
    margin: 0;
    padding: 0;
}

.hero li.glide__slide {
	background-position: 50%;
    background-size: cover;
    background-repeat: no-repeat;
}

.hero.is-mobile .inner {
	-webkit-box-align: end;
    -ms-flex-align: end;
    align-items: end;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	position: relative;
    z-index: 10;
}

.hero.is-mobile,
.hero.is-mobile .glide__slide,
.hero.is-mobile .inner {
	min-height: 350px;
    width: 100%;
}

.hero.is-mobile .glide__slide {
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	height: 350px;
	width: 100%;
}

.page-template-blog-template-page .hero--internal h1 a {
	color: #fff;
}

.page-template-blog-template-page .hero--internal h1 a:hover {
	text-decoration: underline;
}

.hero__excerpt {
	color: #fff;
    font-size: var(--font-sm);
    position: relative;
    z-index: 10;
}

.post-type-archive-testimonials .hero--internal p {
	margin: 0;
}

/****************************************
 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;
}

/****************************************
 Layout Constrain
****************************************/
.l-constrain {
	margin-left: auto;
	margin-right: auto;
	max-width: 1400px;
	padding-left: 1em;
	padding-right: 1em;
}

.l-constrain--wide {
	margin-left: auto;
	margin-right: auto;
	max-width: 1800px;
	padding-left: 1em;
	padding-right: 1em;
}

/****************************************
 Links
****************************************/
a {
	color: var(--link-color);
	text-decoration: none;
}

a:hover, a:focus, a:active {
    color: var(--link-hover);
}

a:hover, a:active, a:focus {
    outline: 0;
}

a.is-pdf:before {
	background-image: url(images/file-pdf-solid.svg);
	background-repeat: no-repeat;
    content: "";
	display: inline-block;
	-webkit-filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
	height: 12px;
	margin: 0 .5em 0 0;
	width: 12px;
	vertical-align: middle;
}

a.disabled {
	color: #ccc;
	pointer-events: none;
}

li.has-arrow a:after {
	background-image: url(images/arrow-up-right-light.svg);
	background-repeat: no-repeat;
    content: "";
	display: inline-block;
	-webkit-filter: brightness(0) saturate(100%) invert(89%) sepia(46%) saturate(4539%) hue-rotate(350deg) brightness(99%) contrast(105%);
    filter: brightness(0) saturate(100%) invert(89%) sepia(46%) saturate(4539%) hue-rotate(350deg) brightness(99%) contrast(105%);
	height: 14px;
	margin: 0 0 0 .75em;
	width: 14px;
	vertical-align: middle;
}

li.has-arrow a:hover:after {
	-webkit-filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(59deg) brightness(103%) contrast(101%);
}

/****************************************
 Locations
****************************************/
.locations a.directions {
	font-size: var(--font-xs);
}

/****************************************
 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;
}

/****************************************
 Menus
****************************************/
.main-navigation {
	font-family: var(--font-secondary);
	font-size: var(--font-sm);
}

.main-navigation ul {
	display: block;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	background-color: #fff;
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
    float: left;
    position: absolute;
    text-align: left;
    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: 200px;
}

.main-navigation ul ul :hover > a,
.main-navigation ul ul .focus > a {
  	display: block;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
  	left: auto;
}

.main-navigation li {
	display: inline-block;
	margin: 0 0 0 2em;
	position: relative;
	vertical-align: middle;
}

.main-navigation li:first-child {
  	margin: 0;
}

.main-navigation ul.sub-menu li {
	border-bottom: 1px solid var(--quaternary-color);
	line-height: 1.2;
	margin: 0;
}

.main-navigation ul.sub-menu li:last-child {
	border: none;
}

.main-navigation ul.sub-menu li a {
	background-color: transparent;
	color: var(--primary-color);
	font-size: var(--font-sm);
	padding: 1em;
}

.main-navigation ul.sub-menu li a:hover,
.main-navigation ul.sub-menu li a:focus {
	background-color: var(--link-hover);
	color: #fff;
	text-decoration: none;
}

.home .main-navigation a {
	color: #fff;
}

.home .main-navigation a:hover,
.home .main-navigation a:focus {
  	color: #fff;
	text-decoration: underline;
}

.home .main-navigation li.current-menu-item a {
  	color: var(--accent-color);
}

.main-navigation a {
	color: var(--copy);
    display: block;
    font-weight: 400;
    text-decoration: none;
}

.main-navigation a:hover,
.main-navigation a:focus,
.main-navigation li.current-menu-item a {
  	color: var(--secondary-color);
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
  	display: block;
}

.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%;
}

.menu li.is-mobile {
	display: none;
}

/****************************************
 Message Bar
****************************************/
.message-bar {
	background-color: var(--lt-gray);
	font-size: var(--font-sm);
	padding: 1em;
	text-align: left;
}

.message-bar p {
	display: inline-block;
	margin: 0 0 0 1em;;
	padding: 0;
}

.message-bar span.address {
  	margin-right: 2em;
}

.message-bar span.phone a {
	color: var(--copy);
	text-decoration: none;
}

.message-bar span.phone a:hover {
  	color: var(--accent-color);
}

/****************************************
 Mobile Menu
****************************************/
.hamburger {
  	display: none;
}

.mobile-menu ul {
	margin: 0;
	padding: 0;
}

.mobile-menu ul li {
	border-bottom: 1px solid #0f1c59;
	display: block;
}

.mobile-menu ul li a {
	background-color: var(--primary-color);
	padding: 1em;
}

.mobile-menu ul li.menu-item-has-children ul.sub-menu li {
  	border-bottom: 1px solid #eee;
}

.mobile-menu ul li.menu-item-has-children a:after {
	background-image: url(images/plus-light.svg);
	background-repeat: no-repeat;
	content: "";
	display: inline-block;
	-webkit-filter: invert(1);
	filter: invert(1);
	float: right;
	height: 18px;
	margin: 0 0 0 .5em;
	width: 18px;
	vertical-align: middle;
}

.mobile-menu ul li.menu-item-has-children a.is-open:after {
	background-image: url(images/minus-light.svg);
}

.mobile-menu ul li.menu-item-has-children ul.sub-menu li a {
  	background-color: #fff;
}

.mobile-menu ul li.menu-item-has-children ul.sub-menu li a:hover,
.mobile-menu ul li.menu-item-has-children ul.sub-menu li a:focus {
  	background-color: #000;
	color: #fff;
}

.mobile-menu ul li.menu-item-has-children ul.sub-menu li a:after {
  	display: none;
}

/****************************************
 Owl Carousel
****************************************/
.owl-carousel button.owl-prev div {
	float: left;
}

.owl-carousel button.owl-next div {
	float: right;
}

.owl-carousel .owl-nav button.owl-prev, 
.owl-carousel .owl-nav button.owl-next,
.owl-carousel button.owl-dot {
	outline: none;
}

/****************************************
 Page
****************************************/
.page__content {
  	padding: 2em 0 4em 0;
}

.page__title h1 {
	font-size: var(--font-3x);
	font-weight: 400;
	margin: .75em 0 0 0;
	text-transform: unset;
}

.page__description {
	font-size: var(--font-lg);
	font-weight: 300;
	padding: 0 0 1em 0;
	text-align: left;
}

.page__content ul {
	font-size: var(--base-font);
    font-weight: 300;
    margin: 1em 0;
    padding: 0 0 0 1.25em;
}

.page__content h2 {
  	color: var(--primary-color);
    font-weight: 300;
}

.page__content h3 {
    color: var(--primary-color);
    font-size: var(--font-lg);
    margin: 0 0 1em 0;
}

.page__content a {
	display: inline-block;
	color: var(--link-hover);
}

.page__content a:hover {
	text-decoration: underline;
}

.page__content p {
	margin: 0 0 2em 0;
}

.page__content ul.phone-numbers,
.page__content ul.emails {
	list-style: none;
	padding: 0;
}

.page__content ul.phone-numbers,
.page__content ul.emails,
.page__content .locations {
	margin: 0 0 1em 0;
}

.page__content .locations p {
	margin: 0;
}

.single .page__content,
.page-template-blog-template-page .page__content {
    background-color: #fff;
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
	padding: 2em 0;
    position: relative;
    top: -25px;
    z-index: 170;
}

.page-template-contact .page__content {
	background-color: #fff;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    position: relative;
    z-index: 10;
}

.single .hero--internal,
.single .hero--internal .inner,
.page-template-blog-template-page .hero--internal, 
.page-template-blog-template-page .hero--internal .inner {
    min-height: 600px;
}

.single .hero--internal .page__title {
	padding: 0 0 4em 0;
}

.page-template-blog-template-page .page__content h2 {
	color: #000;
    font-size: var(--font-2x);
    font-weight: 600;
}

.single .pre-heading span,
.page-template-blog-template-page .pre-heading span {
    color: #fff;
	margin: 0 0 0 .5em;
}

.single .pre-heading label a,
.page-template-blog-template-page .pre-heading label {
	background-color: #000;
    border: 1px solid var(--accent-color);
    border-radius: 20px;
    color: var(--accent-color);
    padding: .25em 2em;
	text-transform: uppercase;
}

.single .pre-heading span,
.single .pre-heading label a,
.page-template-blog-template-page .pre-heading span,
.page-template-blog-template-page .pre-heading label {
	font-size: var(--font-sm);
	position: relative;
    z-index: 10;
}

.page-template-blog-template-page .hero--internal .breadcrumbs,
.single .hero--internal .breadcrumbs {
    border-top: 1px solid #eeeeee35;
    margin: 0 0 4em 0;
}

.page-template-blog-template-page .hero--internal .breadcrumbs {
	margin: 0 0 4em 0;
	padding: 1em 0 0 0;
}
.breadcrumbs, 
.breadcrumbs a, 
.breadcrumbs p,
.page-template-blog-template-page .breadcrumbs, 
.page-template-blog-template-page .breadcrumbs a, 
.page-template-blog-template-page .breadcrumbs p,
.single .breadcrumbs, 
.single .breadcrumbs a, 
.single .breadcrumbs p {
    font-size: var(--font-sm);
}

/****************************************
 Pip Nav
****************************************/
a.page-numbers {
	display: inline-block;
}

ul.page-numbers,
a.page-numbers {
	line-height: normal;
}

.pagination,
.pip-nav {
	grid-column: 1 / -1;
	margin: 2em auto;
    text-align: center;
	width: 100%;
}

.pip-nav ul {
	margin-left: 0;
	text-align: center;
}

.pip-nav ul li {
	display: inline-block;
	list-style: none;
	padding: 0;
}

.pip-nav ul li:before {
  	display: none;
}

.pip-nav ul li.current,
.woocommerce nav.woocommerce-pagination ul li span.current,
.pip-nav ul li a,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
a.page-numbers,
.page-numbers.current {
	font-size: var(--font-sm);
	padding: 0.5em 1.5em;
}

.pip-nav ul li.current,
.woocommerce nav.woocommerce-pagination ul li span.current,
.page-numbers.current {
	background-color: var(--primary-color);
	color: #fff;
}

.pip-nav ul li a,
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
a.page-numbers {
	color: var(--copy);
	display: inline-block;
	position: relative;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
}

.pip-nav ul li a:hover,
.pip-nav ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:hover,
a.page-numbers:hover {
	background-color: var(--secondary-color);
	color: #fff;
	text-decoration: none;
}

.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul li {
  	border: none;
}

/************************************
 Popup
************************************/
#popup-sp,
#popup-sp .inner {
	display: none;
}

#popup-sp {
	background-color: #00000075;
	bottom: 0;
	content: "";
	height: 100%;
    left: 0;
	position: absolute;
	right: 0;
    top: 0;
	width: 100%;
    z-index: 999999;
}

#popup-sp .inner {
	background-color: #eee;
	height: 500px;
    left: 50%;
	margin: 1em 0;
	max-height: 100%;
    overflow: scroll;
    padding: 2em;
	position: fixed;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
	width: 600px;
    z-index: 2147483647;
}

#popup-sp .button--close {
	background-color: #000;
    color: #fff;
    display: inline-block;
    padding: 0.5em;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 999999;
}

a#popup-sp__cta,
#popup-sp__cta a {
	display: block;
}

/****************************************
 Prefooter
****************************************/
.pre-footer {
	background-color: #f3fbff;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	font-weight: 300;
	padding: 3em 0;
} 

.pre-footer p,
.pre-footer a {
	font-size: var(--font-sm);
	margin: 0;
}

.pre-footer a:hover {
	text-decoration: underline;
}

.pre-footer .site-logo {
	display: block;
}

.pre-footer .navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pre-footer .navigation ul li {
    margin: 0 0 1em 0;
}

.pre-footer .has-logo p {
	margin: 0 0 1em 0;
}

.pre-footer li.has-arrow a:after {
	-webkit-filter: brightness(0) saturate(100%);
    filter: brightness(0) saturate(100%);
}

.pre-footer li.has-arrow a:hover:after {
	-webkit-filter: invert(25%) sepia(48%) saturate(7146%) hue-rotate(200deg) brightness(93%) contrast(101%);
    filter: invert(25%) sepia(48%) saturate(7146%) hue-rotate(200deg) brightness(93%) contrast(101%);
}

/****************************************
 Posts and Pages
****************************************/
.sticky {
  	display: block;
}

.hentry {
  	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;
}

/****************************************
 Reviews
****************************************/
.reviews-navigation {
	background-color: #f3fbff;
	padding: 1em 0;
}

.reviews-navigation .button--transparent {
	width: auto;
}

span.review__date {
    font-size: var(--font-xs);
}

/****************************************
 Sections
****************************************/
.section {
	display: block;
	padding: 4em 1em;
}

p.pre-heading,
.hero p.pre-heading,
.section .pre-heading {
	color: var(--tertiary-color);
	font-size: var(--base-font);
	font-weight: 500;
	margin: 0 0 .5em 0;
	text-transform: uppercase;
}

.single-product .pre-title a,
.product-item .pre-title a,
.section--blogs .pre-heading {
	color: var(--secondary-color);
	font-size: var(--font-xs);
    text-transform: uppercase;
}

.archive p.pre-heading {
	font-size: var(--font-sm);
	margin: 1em 0 0 0;
}

.single-product .pre-title {
	margin: 0;
}

.section h2 {
	font-size: var(--font-4x);
}

.section h3 {
	font-size: var(--font-2x);
}

.section h2,
.section h3 {
	color: var(--copy);
	font-weight: 600;
	line-height: 1;
	margin: 0;
}

.section--newsletter {
	background-color: #fff;
}

.section--quick-menu,
.section--products {
	background-color: var(--primary-color);
}

.section--quick-menu {
	padding: 1em 0 0 0;
	text-align: center;
}

.section--quick-menu li {
	display: inline-block;
	margin: 0 1.5em 0 0;
}

.section--quick-menu li:last-child {
	margin: 0;
}

.section--quick-menu li a {
	border-bottom: 1px solid var(--accent-color);
	color: #fff;
	display: inline-block;
	font-size: var(--font-xs);
	font-weight: 500;
	padding: 0 0 .5em 0;
	text-transform: uppercase;
}

.section--quick-menu li a:hover {
	border-bottom: 1px solid #fff;
}

.section--about {
	background-color: #fff;
	border-top-left-radius: 30px;
	border-top-right-radius: 30px;
	padding: 4em 0 2em 0;
	text-align: left;
}

.section--about .column-half.media img {
    height: 500px;
    -o-object-fit: cover;
    object-fit: cover;
    object-position: 50%;
    width: 100%;
}

.single .section--about {
	background-color: transparent;
}

.section--about h2 {
	margin: 0 0 .25em 0;
}

.section--about h2,
.section--about h3 {
	color: var(--primary-color);
}

.section--about h2 span,
.section--about h3 span {
	color: var(--secondary-color);
}

.section--about subtitle {
	font-weight: 500;
}

.section--about .bottom {
    border-top: 1px solid var(--copy);
    margin: 4em 0 0 0;
	padding: 1em;
}

.section--about .bottom .is-cta {
	text-align: right;
}

.single-product .section--about .bottom {
	margin: 0;
}

.section--products {
	background-image: url(../starterpistol-child/images/map-pattern-resized.svg);
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	padding: 3em 0 0 0;
	width: 100%;
}

.section--products:after,
.section--testimonials {
	background-color: var(--quaternary-color);
}

.section--products:after {
    content: "";
    display: block;
    min-height: 200px;
    width: 100%;
}

.section--products h2,
.section--products p {
	color: #fff;
}

.section--products h2 span {
	color: var(--accent-color);
}

.woocommerce li.product,
.woocommerce-shop .column-item.product-category,
.section--products .column-item.product-category {
    background-color: #fff;
    margin: 0 0 2em 0;
    padding: 2em 2em 1em 2em;
}

.woocommerce li.product,
.woocommerce-shop .column-item.product-category {
	border: 1px solid #bdbdbe;
}

.woocommerce li.product:hover,
.woocommerce-shop .column-item.product-category:hover {
	border: 1px solid var(--secondary-color);
}

.woocommerce li.product h3,
.woocommerce-shop .column-item.product-category h3,
.section--products .column-item.product-category h3 {
    border-top: 1px solid #eee;
    font-size: var(--font-lg);
    margin: 1em 0;
    padding: 1em 0 0 0;
}

.woocommerce-shop .button--secondary-color,
.section--products .button--secondary-color {
	border-radius: 0;
	font-size: var(--font-sm);
	text-align: center;
	text-transform: uppercase;
	width: 100%;
}

.woocommerce li.product .product-item h3 a {
	color: var(--primary-color);
}

.woocommerce li.product .product-item h3 a:hover {
	color: var(--secondary-color);
	text-decoration: none;
}

.woocommerce li.product p.product-item__excerpt,
.woocommerce-shop p.category-excerpt,
.section--products p.category-excerpt {
    color: #000;
    font-size: var(--font-sm);
}

.woocommerce li.product .product-item__cta,
.woocommerce-shop .product-category__cta,
.section--products .product-category__cta {
	-ms-flex-item-align: end;
    align-self: flex-end;
    width: 100%;
}

.woocommerce li.product .product-item__cta {
	border-top: 1px solid #eee;
    padding: 1em 0;
    text-align: center;
}

.woocommerce li.product .media,
.woocommerce-shop .column-item.product-category .media,
.section--products .column-item.product-category .media {
	margin: 0 auto;
    max-height: 165px;
}

.woocommerce li.product .media img,
.woocommerce-shop .column-item.product-category .media img,
.section--products .column-item.product-category .media img{
    height: 165px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
}

.woocommerce li.product .content {
	padding: 1em 0 0 0;
    width: 100%;
}

.section--cta {
    margin: 0 0 -7em 0;
	padding: 5em 0 0 0;
    position: relative;
}

.section--cta .inner {
	background-color: var(--secondary-color);
	padding: 3em;
}

.section--cta h2 span {
	color: var(--accent-color);
}

.section--cta p {
	margin: 0 0 2em 0;
}

.section--cta .column-half.media.columns {
	-ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.section--cta .column-half.media.columns img {
	height: 150px;
	margin: 0 1em 0 0;
}

.section--cta .button-group a {
	border-radius: 3px;
	margin: 0 0 1em 0;
	padding: .5em 2em;
}

.section--cta .button-group a:first-child {
	margin: 0 1em 1em 0;
}

.section--testimonials {
	padding: 0 0 3em 0;
	position: relative;
	text-align: center;
}

.section--testimonials .section__head {
	position: relative;
	z-index: 10;
}

.section--testimonials:before {
	background-image: url(../starterpistol-child/images/infinity-circle-fullwidth.png);
	background-position: 50%;
	background-repeat: no-repeat;
	bottom: 0;
	content: "";
	height: 565px;
	left: 50%;
	overflow: hidden;
	position: absolute;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 100%;
}

.section--testimonials h2 {
	color: var(--primary-color);
	margin: 0 0 .25em 0;
}

.section--testimonials h3 {
	font-size: var(--base-font);
    padding: 2em 0 0 0;
    text-transform: uppercase;
}

.section--testimonials .content p {
	margin: 2em 0;
}

.section--testimonials .glide__arrows {
    left: 50%;
    position: absolute;
	top: 100%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%;
    z-index: 100;
}

.section--testimonials .glide__arrow--left, 
.section--testimonials .glide__arrow--right {
	background-color: transparent;
	position: static;
    width: auto;
}

.section--testimonials .glide__arrow--left:before,
.section--testimonials .glide__arrow--right:before {
    -webkit-filter: brightness(0) saturate(100%) invert(14%) sepia(8%) saturate(351%) hue-rotate(149deg) brightness(99%) contrast(90%);
    filter: brightness(0) saturate(100%) invert(14%) sepia(8%) saturate(351%) hue-rotate(149deg) brightness(99%) contrast(90%);
    height: 16px;
    width: 16px;
}

.section--contact {
	background-color: var(--secondary-color);
}

.section--contact .inner {
	background-color: #fff;
	padding: 2em;
}

.section--contact .media h3 {
	color: #fff;
	margin: 0 0 1em 0;
}

.section--contact .content .directions {
	display: none;
}

.section--contact .phone-numbers {
	list-style: none;
	margin: 0 0 2em 0;
	padding: 0;
}

.section--contact .phone-numbers label {
	font-weight: 600;
}

.section--contact .ctas {
	text-align: center;
}

.section--blogs h2 {
	margin: 0 0 .25em 0;
}

.section--blogs h2 span {
	color: var(--secondary-color);
}

.section--blogs .section-head {
	margin: 0 0 2em 0;
}

.section--blogs .section-head .content p {
	text-align: right;
}

.section--secondary-form,
.section--product-details {
	background-color: var(--primary-color);
	padding: 0 0 3em 0;
}

.section--secondary-form h2,
.section--product-details h2 {
	font-weight: 300;
	margin: 0 0 1em 0;
}

.section--secondary-form:before,
.section--product-details:before {
	background-color: var(--primary-color);
	content: "";
	display: block;
	min-height: 50px;
	position: relative;
    top: -3em;
	width: 100%;
}

.section--secondary-form h2,
.section--product-details h2,
.section--product-details h3,
.section--product-details ul,
.section--product-details li,
.section--product-details p {
	color: #fff;
}

.section--product-details ul,
.section--product-details .content {
	margin: 0 0 2em 0;
}

.section--product-details ul {
	list-style: none;
    padding: 0;
}

.section--product-details li {
    border-bottom: 1px solid var(--secondary-color);
    padding: 1em 0;
}

.section--product-details .content.is-features ul {
	list-style: disc;
	list-style-position: inside;
}

.section--product-details .content.is-features li {
	border-bottom: none;
	padding: 0;
}

.section--secondary-form {
	position: relative;
}

.section--secondary-form:after {
	background-image: url(images/seamless-bg-pattern.png);
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.section--secondary-form h2,
.section--secondary-form .inner {
	position: relative;
	z-index: 10;
}

.section--secondary-form h2 {
    font-size: var(--font-xl);
    font-weight: 600;
    margin: 0 auto 1em auto;
    width: 80%;
}

.section--secondary-form .inner {
	background-color: #fff;
	padding: 4em 2em;
}

.section--secondary-form .gform_wrapper .gfield_checkbox label {
	color: var(--copy);
	display: inline-block;
}

.section--reviews-grid .grid-item {
	border: 1px solid var(--copy);
	border-radius: 30px;
	padding: 2em;
}

.section--reviews-grid .grid-item .fallback-letter {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: var(--base-font);
    height: 50px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 0 1em 0;
    width: 50px;
}

.section--reviews-grid .grid-item .fallback-letter.has-image {
	background-repeat: no-repeat;
	background-size: cover;
}

.section--reviews-grid .grid-item:nth-child(even) .fallback-letter {
	background-color: var(--primary-color);
	color: #fff;
}

.section--reviews-grid .grid-item:nth-child(odd) .fallback-letter {
	background-color: var(--secondary-color);
	color: #fff;
}

.section--reviews-grid .grid__pagination {
	border-top: 1px solid #eee;
    margin: 2em 0 0 0;
    padding: 2em 0 0 0;
    text-align: center;
}

.section--reviews-grid .review__meta {
	margin: 2em 0 0 0;
}

.section--reviews-grid .review__meta .content {
	padding: 0 1em;
}

.section--reviews-grid .review__meta .columns {
	-webkit-box-pack: normal;
    -ms-flex-pack: normal;
    justify-content: normal;
}

.section--reviews-grid .review__author {
	font-weight: 600;
}

.section--reviews-grid .review__type {
	font-size: var(--font-xs);
}

.section--reviews-grid .inner {
	font-size: var(--font-sm);
	margin: 1em 0 0 0;
}

.section--reviews-grid .grid-item h2 {
    font-size: var(--base-font);
    line-height: 1.2;
}

.section--related h2 {
	font-size: var(--font-2x);
}

.section--related p.related-link {
    margin: 0 0 1em 0;
}

.section--related p.related-link a {
    color: var(--link-hover);
	font-size: var(--font-md);
}

.section--related p.related-link a:hover {
    text-decoration: underline;
}

/****************************************
 Single
****************************************/
.single .nav-links {
  border-bottom: 1px solid var(--lt-gray);
  border-top: 1px solid var(--lt-gray);
  overflow: hidden;
  padding: 2em 0;
}

.single .nav-previous:before,
.single .nav-next:before {
  display: block;
}

.single .nav-previous:before {
  content: "\276E \00a0 Previous Post";
  text-align: left;
}

.single .nav-next:before {
  content: "Next Post \00a0 \276F";
  text-align: right;
}

.single-product h1 {
    border-bottom: 1px solid var(--copy);
    color: var(--primary-color);
    font-size: var(--font-2x);
    font-weight: 600;
    line-height: 1.3;
    margin: 0;
    padding: 0 0 .25em 0;
}

.single-product .product-item__cta {
	border-top: 1px solid var(--copy);
	padding: 1em 0 0 0;
}

.single-product .product-item__cta .button {
	border-radius: 0;
	text-align: center;
}

.single-product .product__head {
	background-color: #fff;
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    position: relative;
    z-index: 10;
}

.single-product .product__head .media,
.single-product .product__head .content {
	padding: 2em 0;
}

.single-product .product__head .media img {
    height: 350px;
    -o-object-fit: contain;
    object-fit: contain;
    width: 100%;
}

.single-product .short-description {
	font-size: var(--font-md);
	margin: 2em 0;
}

.single-product a.gallery-item.fancybox.image {
    border: 1px solid var(--copy);
}

.single-product a.gallery-item.fancybox.image:hover {
    border: 1px solid var(--secondary-color);
}

/****************************************
 Site Footer
****************************************/
.site-footer {
	background-color: #f3fbff;
	color: var(--copy);
	font-size: var(--font-xs);
	padding: .5em 0;
	text-align: center;
	width: 100%;
}

/****************************************
 Site
****************************************/
.site-branding {
	display: block;
	margin: 0;
	position: relative;
	width: 100%;
}

.site-menu {
    background-color: transparent;
    display: inline-block;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    min-height: auto;
    line-height: 1;
}

.site-menu--mobile {
	-webkit-animation: slideInLeft .7s;
    animation: slideInLeft .7s;
	background-color: var(--primary-color);
	box-shadow: 0 0 0 100000px rgb(0 0 0 / 90%);
	display: none;
	left: 0;
	max-height: calc(100% - 50px);
	min-height: 100%;
	overflow-y: auto;
	padding: 0;
	position: fixed;
	text-align: left;
	top: 0;
	width: 50%;
	z-index: 99999999;
}
/* 
.site-menu--mobile:before {
	background: transparent;
    content: "";
	height: 100%;
	left: 0;
    position: fixed;
    top: 0;
    width: 100%; 
    z-index: 99999998;
} */

.site-menu--mobile a {
	color: #fff;
	display: block;
}

.site-menu--mobile a:hover {
	background-color: #000;
	color: #fff;
}

.site-menu--mobile ul.sub-menu {
	background-color: #fff;
	display: none;
}

.site-menu--mobile ul.sub-menu li a {
	color: var(--primary-color);
	padding: 1em;
}

.site-menu--mobile ul.sub-menu li a:hover,
.site-menu--mobile ul.sub-menu li a:focus {
	background-color: var(--gray);
	color: #000;
}

.site-menu__close {
	background-color: var(--primary-color);
	border-bottom: 1px solid #0f1c59;
	padding: 1em;
	text-align: right;
}

.site-menu__close .fas.fa-times-circle {
	color: #fff;
	font-size: var(--font-xl);
}

.site-name {
	background-color: #faf9f5;
	display: inline-block;
	line-height: normal;
	overflow: hidden;
	padding: 0.75em 1em;
	text-align: left;
}

.site-logo img,
.site-logo--secondary img {
	-o-object-fit: contain;
	object-fit: contain;
	text-align: center;
}

.site-logo a {
	color: var(--copy);
	font-size: var(--font-lg);
	font-weight: 700;
	text-decoration: none;
	display: block;
}

.site-logo--secondary {
	display: inline-block;
	-ms-flex-preferred-size: 20%;
	flex-basis: 20%;
	padding: .25em;
	text-align: center;
}

.site-logo--secondary img {
	height: 75px;
}

.site-logo img {
    padding-top:4px;
	height: 72px;
	max-height: 100%;
	text-align: left;
	width: auto;
	display: block;
}

.site-title h1 {
	color: #000;
	font-family: var(--font-family);
	font-size: var(--font-lg);
	font-weight: 400;
	line-height: 1;
	margin: 0;
}

.site-title p {
	margin: 0;
}

.site-logo,
.site-description {
	display: inline-block;
	-ms-flex-preferred-size: 50%;
	flex-basis: 50%;
}

.site-logo {
	overflow: hidden;
}

.site-description {
	text-align: right;
}

.site-description p {
	color: #fff;
	font-family: var(--font-secondary);
	font-size: var(--font-2x);
	font-weight: 400;
	margin: 0;
}

/****************************************
 Site Header
****************************************/
.site-header.is-desktop.columns {
	display: flex;	    
    position: sticky;
    top: 0;
    z-index: 1000;
	background-color: #fff;
}

.site-header.is-mobile.columns {
	display: none;
}

.site-header {
	border-bottom: 1px solid var(--copy);
	width: 100%;
}

.home .site-header {
	background-color: var(--primary-color) !important;
	border: none;
}

.site-header.is-desktop .column-fourths.has-contact.columns,
.site-header.columns {
	-ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.site-header a.site-contact {
	background-color: var(--accent-color);
	display: inline-block;
	min-height: 77px;
	padding: .5em 2em;
}

.site-header a.site-contact label,
.site-header a.site-contact {
	color: #000;
}

.site-header a.site-contact:hover {
	background-color: var(--secondary-color);
}

.site-header a.site-contact:hover label,
.site-header a.site-contact:hover p {
	color: #fff;
	cursor: pointer;
}

.site-header a.site-contact label {
	font-size: var(--font-xs);
    text-transform: uppercase;
}

.site-header .phone {
	font-size: var(--font-lg);
	font-weight: 600;
	margin: 0;
}

.site-header .has-logo {
	margin: 0 auto 0 0;
	padding: 0 0 0 1em;
	overflow: hidden;
}

.site-header .has-navigation {
	text-align: center;
}

.site-header .has-contact {
	margin: 0 0 0 auto;
}

.site-header .column-fourths {
	-ms-flex-preferred-size: 25%;
    flex-basis: 25%;
}

.site-header .column-half {
	-ms-flex-preferred-size: 50%;
    flex-basis: 50%;
}

/****************************************
 Site Search
****************************************/
.site-search,
.site-search .bt-search-field,
.site-search .input-group-btn {
	display: inline-block;
}

.site-search__icon {
	line-height: 0;
	margin: 0 2em;
}

.site-search .fa-search {
	color: var(--copy);
    vertical-align: super;
}

.home .site-search .fa-search {
	color: #fff;
}

.site-search__icon,
.site-search__icon:hover {
	color: #fff;
	display: block;
}

.site-search,
.site-search__box {
	margin: 0 1em;
}

.site-search__box {
	background-color: #eee;
    box-shadow: 0px 4px 8px #00000035;
    display: none;
    margin: 0 1em;
    padding: 2em;
    position: absolute;
    right: 160px;
    top: 77px;
    z-index: 100000;
}

.site-search__box .button--accent-color {
	line-height: 1.3;
    padding: 15px;
}

.site-search__box .button--accent-color:after {
	display: none;
}

.search-no-results .site-search__box-internal {
	display: none;
}

.site-search__box-internal {
	border-bottom: 1px solid #eee;
	padding: 2em 0;
}

.search-results article h2 {
	border-bottom: none;
    display: list-item;
    font-size: var(--font-lg);
    list-style-position: inside;
    list-style-type: none;
	margin: 1em 0 0 0;
}

.search-results article {
	border-bottom: 1px solid #eee;
	margin: 0 0 2em 0;
}

.search-results article .entry-summary {
	margin: 0 0 2em 0;
}

.search-results article .entry-summary p {
	color: var(--copy);
	margin: 0;
}

.search-results .input-group,
.site-search__box .input-group,
.search-no-results .search-form .input-group {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.site-search__box .input-group input.form-control.bt-search-field,
.search-results .search-form .input-group input.form-control.bt-search-field,
.search-no-results .search-form .input-group input.form-control.bt-search-field {
	background-color: #fff;
    border: none;
	border-bottom-right-radius: 0;
	border-top-right-radius: 0;
	-ms-flex-preferred-size: 90%;
    flex-basis: 90%;
	margin: 0;
	padding: 0 1em;
	width: 100%;
}

.site-search__box .input-group .input-group-btn .btn.btn-default,
.search-results .search-form .input-group .input-group-btn .btn.btn-default,
.search-no-results .search-form .input-group .input-group-btn .btn.btn-default {
	min-height: 53px;
}

.site-search__box .input-group .input-group-btn .button {
	border-radius: 0;
}

/****************************************
 Slider
****************************************/
.aps-slider-wrapper-class a.adl-featured-img-link {
  	margin: 0 !important;
}

.slide{
     position: relative;
     z-index: 1;
}

.slider-content{
     position: absolute;
     top: 20px;
     left: 20px;
     z-index: 100;
}

#slider__home {
	margin-bottom: 0 !important;
	position: relative;
}

#slider__home .sa_hover_container:before {
	background-color: #000;
	bottom: 0;
	content: "";
	display: block;
	left: 0;
	position: absolute;
	opacity: .4;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 2;
}

#slider__home h1 {
  	z-index: 10;
}

#slider__home .inner {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	min-height: 400px;
}

#slider__home .inner h1 {
	color: #fff;
	font-size: var(--font-4x);
	font-weight: 600;
}

.owl-carousel .owl-nav button.owl-prev,
.owl-carousel .owl-nav button.owl-next,
#slider__home .owl-dots {
  	z-index: 10;
}

.owl-carousel .owl-dots button {
  	width: auto;
}

#slider__home .owl-dots {
  	bottom: 20px !important;
}

/****************************************
 Slider
****************************************/
.sa_owl_theme .owl-nav {
    left: 50%;
	position: absolute;
    top: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 100%;
}

.sa_owl_theme .owl-nav .owl-prev{
    float: left;
}

.sa_owl_theme .owl-nav .owl-next {
    float: right;
}

.aps-slider-wrapper-class a.adl-featured-img-link {
  margin: 0 !important;
}

.slide {
  position: relative;
  z-index: 1;
}

.slider-content {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 100;
}

#slider__home {
  margin-bottom: 0 !important;
  position: relative;
}

#slider__home .sa_hover_container:before {
  content: "";
  display: block;
  height: 100%;
  left: 0;
  opacity: 0.45;
  position: absolute;
  top: 0;
  width: 100%;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 1) 0%,
    rgba(255, 255, 255, 0) 72%
  );
}

#slider__home h1 {
  z-index: 10;
}

#slider__home .inner {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  min-height: 600px;
  position: relative;
  z-index: 100;
}

#slider__home a {
  display: inline-block;
  font-size: var(--font-lg);
  line-height: 0.5;
  margin: 2em 0 0 0;
  padding: 1em 2em;
  text-transform: uppercase;
  background-color: var(--primary-color);
  color: white;
}

#slider__home a:hover {
  background-color: var(--accent-color);
  color: var(--background-color);
}

.owl-carousel .owl-nav button.owl-prev,
.owl-carousel .owl-nav button.owl-next,
#slider__home .owl-dots {
  z-index: 10;
}

.owl-carousel .owl-dots button {
  width: auto;
}

#slider__home .owl-dots {
  bottom: 20px !important;
}

#slider__reviews .sap_slider_container {
  margin: 0 auto !important;
  width: 80%;
}

#slider__reviews .sap_slider_container p {
  font-size: var(--font-xl);
  line-height: 1.5;
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot span {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: transparent !important;
  border: 1px solid var(--lt-gray) !important;
  border-style: solid !important;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  padding: 5px;
  position: relative;
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot span {
  border: 1px solid #fff !important;
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot span:before {
  color: var(--lt-gray);
  content: "\2022";
  font-size: 20px;
  display: inline-block;
  left: 50%;
  position: absolute;
  top: 4%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot span:before {
  color: #fff;
  top: 0;
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot.active span {
  border: 1px solid var(--accent-color) !important;
}

.section--testimonials .sap_owl_theme .owl-dots .owl-dot.active span:before {
  color: var(--accent-color);
}

.sap_owl_theme .owl-nav .owl-prev div,
.sap_owl_theme .owl-nav .owl-next div {
  background-color: transparent !important;
  -webkit-filter: invert(93%) sepia(0%) saturate(211%) hue-rotate(164deg)
    brightness(97%) contrast(75%);
  filter: invert(93%) sepia(0%) saturate(211%) hue-rotate(164deg)
    brightness(97%) contrast(75%);
}

.sap_owl_theme .owl-nav .owl-prev div:hover,
.sap_owl_theme .owl-nav .owl-next div:hover {
  -webkit-filter: invert(15%) sepia(29%) saturate(2965%) hue-rotate(313deg)
    brightness(92%) contrast(85%);
  filter: invert(15%) sepia(29%) saturate(2965%) hue-rotate(313deg)
    brightness(92%) contrast(85%);
}

/****************************************
 Social Media
****************************************/
.share-buttons .inner {
	background-color: var(--primary-color);
    border-radius: 30px;
    display: inline-block;
    padding: .5em 1em;
    text-align: center;
}

.share-buttons h3 {
    color: #fff;
	font-size: var(--font-xs);
    display: inline-block;
    margin: 0 1em 0 0;
	text-transform: uppercase;
}

.share-buttons .a2a_kit a {
    background-color: transparent;
    border: 1px solid #bacbc2 !important;
    border-radius: 50%;
    filter: none;
    line-height: 0;
	margin: 0 .25em 0 0;
    padding: .25em;
}

.share-buttons .a2a_kit a:hover {
    background-color: #bacbc2 !important;
    border: 1px solid #bacbc2 !important;
    border-radius: 50%;
    line-height: 0;
    padding: .25em;
}

.share-buttons .a2a_kit a:hover .a2a_svg svg {
	fill: #32434f;
	-webkit-filter: brightness(0) saturate(100%) invert(21%) sepia(11%) saturate(1502%) hue-rotate(162deg) brightness(91%) contrast(82%);
    filter: brightness(0) saturate(100%) invert(21%) sepia(11%) saturate(1502%) hue-rotate(162deg) brightness(91%) contrast(82%);
}

span[class*="socicon-"]:before {
    -webkit-filter: brightness(0) saturate(100%);
    filter: brightness(0) saturate(100%);
    height: 18px;
    width: 18px;
}

span[class*="socicon-"]:hover:before {
	-webkit-filter: brightness(0) saturate(100%) invert(13%) sepia(31%) saturate(5598%) hue-rotate(212deg) brightness(87%) contrast(111%);
    filter: brightness(0) saturate(100%) invert(13%) sepia(31%) saturate(5598%) hue-rotate(212deg) brightness(87%) contrast(111%);
}

/****************************************
 Tabs
****************************************/
.tabbed-content.is-desktop {
	display: block !important;
}

ul.tabs {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

ul.tabs .column-half {
	-ms-flex-preferred-size: 50%;
    flex-basis: 50%;
}

ul.tabs li.tab__main-title {
	background-color: var(--primary-color);
	cursor: pointer;
	padding: .5em;
	position: relative;
	text-align: center;
}

ul.tabs li.tab__main-title.current {
	background: var(--accent-color);
    color: #fff;
	overflow: hidden;
	position: relative;
}

ul.tabs li.tab__main-title.current:hover:before {
	display: none;
}

ul.tabs li.tab__main-title.current h3 {
	position: relative;
    z-index: 10;
}

.tab-item {
	display: none;
	padding: 2em 0;
}

.tab-item.current {
	display: inherit;
}

/****************************************
 Testimonials
****************************************/
.testimonials {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.testimonial__item {
	background-color: #fff;
	border: 3px solid transparent;
	-ms-flex-preferred-size: 32%;
	flex-basis: 32%;
	margin: 0;
	position: relative;
}

.testimonial__item:nth-child(odd) {
	border: 3px solid var(--secondary-color);
}

.testimonial__item:nth-child(even) {
	border: 3px solid var(--tertiary-color);
}

.testimonial__item .inner {
	padding: 2em;
	position: relative;
	text-align: left;
}

.testimonial__item:hover {
	border: 3px solid var(--accent-color);
}

.testimonial__item a {
	display: block;
	text-decoration: none;
}

.testimonial-info {
	font-size: var(--font-xs);
}

span.star:before {
    background-image: url(images/star-sharp-solid.svg);
    background-repeat: no-repeat;
    content: "";
    display: inline-block;
    -webkit-filter: brightness(0) saturate(100%) invert(92%) sepia(36%) saturate(2203%) hue-rotate(360deg) brightness(106%) contrast(100%);
    filter: brightness(0) saturate(100%) invert(92%) sepia(36%) saturate(2203%) hue-rotate(360deg) brightness(106%) contrast(100%);
    height: 18px;
    width: 18px;
    vertical-align: middle;
}

p.rating {
	margin: 0;
}

/****************************************
 Widgets
****************************************/
.widget {
  	margin: 0 0 1.5em;
  	/* Make sure select elements fit in widgets. */
}
.widget select {
  	max-width: 100%;
}

/**************************************
 Woocommerce
**************************************/
.woocommerce .productz {
	list-style: none;
	margin: 2em 0;
	padding: 0;
}

.woocommerce .product a.button.product_type_simple {
	display: none;
}

.woocommerce li.product .pre-title {
	line-height: 1;
	margin: .25em 0;
}

.woocommerce li.product h3 {
	border: none;
	margin: 0 0 1em 0;
	padding: 0;
}

/**************************************
 Youtube / Vimeo Videos
**************************************/
.embed-responsive {
	display: block;
	height: 0;
	overflow: hidden;
	padding: 0;
	position: relative;
}

.embed-responsive-16by9 {
    padding-bottom: 56.25%;
}

.vimeo,
.youtube {
	cursor: pointer;
	position: relative;
}

.vimeo:before,
.youtube:before {
	background-color: var(--copy);
	bottom: 0;
	content: "";
	display: block;
	left: 0;
	opacity: .70;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 10;
}

.vimeo.has-video:before,
.youtube.has-video:before {
	display: none;
}

.vimeo img,
.youtube img {
	left: 0;
    height: 100%;
    margin-top: 0;
	-o-object-fit: cover;
    object-fit: cover;
    width: 100%;
}

.vimeo .play-button,
.youtube .play-button {
    background-color: #ff0000;
	border-radius: 6px;
    box-shadow: 0 0 30px rgba( 0,0,0,0.6 );
	height: 50px;
    opacity: 0.8;
	width: 75px;
	z-index: 100;
}

.vimeo .play-button:before,
.youtube .play-button:before {
	background-image: url(images/play-solid.svg);
	background-repeat: no-repeat;
	content: "";
	display: inline-block;
	-webkit-filter: brightness(0) saturate(100%) invert(100%) sepia(2%) saturate(697%) hue-rotate(247deg) brightness(119%) contrast(100%);
    filter: brightness(0) saturate(100%) invert(100%) sepia(2%) saturate(697%) hue-rotate(247deg) brightness(119%) contrast(100%);
	height: 25px;
    width: 18px;
}

.vimeo img,
.vimeo .play-button,
.youtube img,
.youtube .play-button {
    cursor: pointer;
}

.vimeo img,
.vimeo iframe,
.vimeo .play-button,
.vimeo .play-button:before,
.youtube img,
.youtube iframe,
.youtube .play-button,
.youtube .play-button:before {
    position: absolute;
}

.vimeo .play-button,
.vimeo .play-button:before,
.youtube .play-button,
.youtube .play-button:before {
	left: 50%;
    top: 50%;
    transform: translate3d( -50%, -50%, 0 );
}

.vimeo iframe,
.youtube iframe {
    height: 100%;
    left: 0;
    top: 0;
	width: 100%;
}

/****************************************
 Media Queries
****************************************/
@media only screen and (max-width: 1350px) {

}

@media only screen and (max-width: 1250px) {
	.site-header.is-desktop.columns {
		display: none;
	}
	
	.site-header.is-mobile .column-half {
		min-height: 60px;
	}

	.site-header.is-mobile.columns {
		display: -webkit-box;
    	display: -ms-flexbox;
    	display: flex;
    	-ms-flex-wrap: wrap;
        flex-wrap: wrap;
		 position: sticky;
		top: 0;
		z-index: 9999;
		background: #fff; /* optional but recommended */
	}
	
	.site-header.is-mobile .has-contact {
		background-color: var(--accent-color);
		display: block;
		line-height: 60px;
		text-align: center;
		width: 100%;
	}
	
	.site-header.is-mobile .site-contact {
		color: #000;
		display: block;
		min-height: auto;
		padding: 0;
	}
	
	.site-header.is-mobile .site-contact:hover {
		text-decoration: underline;
	}
	
	.column-half.navigation,
	.site-menu {
		display: none;
	}
	
	.section--quick-menu .site-menu, 
	.pre-footer .site-menu {
		display: block;
	}

	.hamburger {
		display: inline-block;
		margin: 0 auto 0 0;
	}

	.hamburger .fas.fa-bars {
		color: #000;
		font-size: var(--font-xl);
	}

	.home .hamburger .fas.fa-bars {
		color: #fff;
	}
	
	.site-header .column-fourths {
		-ms-flex-preferred-size: 48%;
		flex-basis: 48%;
	}
	
	.site-search__box {
		box-shadow: none;
		margin: 0;
		position: static;
		width: 100%;
	}
	
	.section--quick-menu ul#quick-menu {
		margin: 0 0 1em 0;
    	padding: 0;
	}
	
	.section--quick-menu ul#quick-menu li {
		margin: 0 1.5em 1em 0;
	}
	
	.menu li.is-mobile {
		display: block;
	}
}

@media only screen and (max-width: 1200px) {
	
}

@media only screen and (max-width: 1100px) {
	.product-item__cta.columns.columns--grid-half {
		-ms-grid-columns: (100% [col-start])[1];
		grid-template-columns: repeat(1, 100% [col-start]);
	}

	.single-product .product-item__cta .button,
	.woocommerce li.product .product-item .product-item__cta a {
		margin: 0 0 1em 0;
	}
}

@media only screen and (max-width: 1000px) {
	.section--cta {
		padding: 1em 0 0 0;
	}
	
	.section--cta .column-half.media.columns {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	
	.section--cta .column-half.media.columns img {
		margin: 0 auto 15px auto;
		display: block;
	}
	
	.columns--grid-fourths {
		-ms-grid-columns: (32% [col-start])[3];
		grid-template-columns: repeat(3, 32% [col-start]);
	}
}

@media only screen and (max-width: 950px) {
	.youtube .play-button {
		height: 35px;
		width: 50px;
	}
	
	.youtube .play-button:before {
		border-width: 9px 0px 8px 16px;
	}
	
	.section--reviews-grid .grid {
		-webkit-column-count: 2;
		-moz-column-count: 2;
		column-count: 2;
	}
}

@media only screen and (max-width: 900px) {
	#popup-sp .inner {
		min-height: 400px;
		overflow: scroll;
		width: 90%;
	}
}

@media only screen and (max-width: 850px) {
 
}

@media only screen and (max-width: 800px) {
	.hero .column-half.media,
	.hero .column-half.media img {
		display: none;
	}
	
	.hero .column-half {
		-ms-flex-preferred-size: 100%;
		flex-basis: 100%;
	}
}

@media only screen and (max-width: 750px) {
	.hero--internal .hero__content .column-thirds,
	.hero--internal .hero__content .column-two-thirds,
	body[class*="page-template-"] .column-two-thirds.content,
	body[class*="page-template-"] .column-thirds.sidebar,
	.site-header.is-mobile .column-half,
	.column-half {
		-ms-flex-preferred-size: 100%;
		flex-basis: 100%;
	}

	.column-thirds,
	.column-fourths {
		-ms-flex-preferred-size: 48%;
		flex-basis: 48%;
	}
	
	.columns--grid-thirds,
	.columns--grid-fourths,
	.columns--grid-fifths,
	.columns--grid-sixths {
		display: -ms-grid;
		display: grid;
		-ms-grid-columns: (48% [col-start])[2];
		grid-template-columns: repeat(2, 48% [col-start]);
	}
	
	.column-half,
	.column-thirds,
	.column-fourths,
	.columns--grid-thirds,
	.columns--grid-fourths,
	.columns--grid-fifths,
	.columns--grid-sixths {
		margin: 0 0 1em 0;
	}
	
	.section--product-details .columns--grid-half,
	.woocommerce .product__head .columns--grid-half {
		-ms-grid-columns: (100% [col-start])[1];
		grid-template-columns: repeat(1, 100% [col-start]);
	}

	.site-footer__widgets {
		display: block;
		margin: 0 0 2em 0;
	}
	
	a.page-numbers,
	span.page-numbers.current {
		display: none;
	}
	
	a.prev.page-numbers,
	a.next.page-numbers {
		display: inline-block;
	}
	
	.hero.is-desktop {
		display: none;
	}
	
	.hero.is-mobile {
		display: block;
		padding: 0;
	}
	
	.glide__slide .content {
		margin: 0 0 1em 0;
		position: relative;
		text-align: center;
		width: 100%;
		z-index: 10;
	}
	
	.glide__slide .content h1,
	.glide__slide .content h1 span,
	.glide__slide .content p {
		color: #fff;
		margin: 0;
	}
	
	.hero.is-mobile .glide__slide .content h1 {
		font-size: var(--font-xl);
		padding: 0;
	}
	
	.hero.is-mobile .inner {
		padding: 2em;
	}
	
	.glide__slide .content p {
		margin: 0 0 1em 0;
	}
	
	.three-column .gfield_checkbox,
	ul.three-column {
		-webkit-column-gap: 1em;
		-moz-column-gap: 1em;
		column-gap: 1em;
		-webkit-column-count: 2;
		-moz-column-count: 2;
		column-count: 2;
	}
	
	.site-header.is-mobile .column-half {
		line-height: unset;
        min-height: auto;
    }
	
	.site-header.is-mobile .column-half.has-logo {
		padding: .5em 1em;
	}
	
	.site-header.is-mobile .site-logo img {
		padding-top: 0;
	}
	
	.section--quick-menu .site-menu, 
	.pre-footer .site-menu {
		display: block;
	}
	
	.section--testimonials .glide__slide .content p {
		color: var(--copy);
		margin: 2em 0 0 0;
	}
	
	.section h2 {
		font-size: var(--font-2x);
	}
	
	.section--about {
		padding: 2em 0;
	}
	
	.section--about .bottom .is-cta {
		text-align: left;
	}
	
	.page__title h1 {
		font-size: var(--font-2x);
	}
	
	.section--about .column-half.media img {
		height: 350px;
	}

}

@media only screen and (max-width: 700px) {
	.single .nav-previous:before,
	.single .nav-next:before {
		display: none;
	}

	.single .nav-previous,
	.single .nav-next {
		font-size: 0;
	}

	.single .nav-previous a:before,
	.single .nav-next a:before {
		display: block;
		font-size: var(--font-md);
	}

	.single .nav-previous a:before {
		content: "\276E \00a0 Previous Post";
		text-align: left;
	}

	.single .nav-next a:before {
		content: "Next Post \00a0 \276F";
		text-align: right;
	}
}

@media only screen and (max-width: 650px) {
	.section--reviews-grid .grid {
		-webkit-column-count: 1;
		-moz-column-count: 1;
		column-count: 1;
	}
}

@media only screen and (max-width: 600px) {
	.site-menu--mobile {
		width: 100%;
	} 
	
	.section--cta .column-half.media.columns {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
}

@media only screen and (max-width: 550px) {
	.three-column .gfield_checkbox,
	ul.three-column {
		-webkit-column-gap: 1em;
		-moz-column-gap: 1em;
		column-gap: 1em;
		-webkit-column-count: 1;
		-moz-column-count: 1;
		column-count: 1;
	}
	
	.section--contact .ctas a,
	.section--cta .button-group a:first-child,
	.section--cta .button-group a {
		margin: 0 0 1em 0;
		text-align: center;
		width: 100%;
	}
	
	.section--contact .ctas.columns--grid-half {
		-ms-grid-columns: (100% [col-start]) [1];
		grid-template-columns: repeat(1, 100% [col-start]);
	}
	
	.section--quick-menu ul#quick-menu li {
        display: block;
		margin: 0 0 1em 0;
    }
}

@media only screen and (max-width: 500px) {
	.column-thirds,
	.column-fourths {
		-ms-flex-preferred-size: 100%;
		flex-basis: 100%;
	}
	
	.columns--grid-half,
	.columns--grid-thirds,
	.columns--grid-fourths,
	.columns--grid-fifths {
		display: -ms-grid;
		display: grid;
		-ms-grid-columns: (100% [col-start])[1];
		grid-template-columns: repeat(1, 100% [col-start]);
	}
}

@media only screen and (max-width: 450px) {
  
}

@media only screen and (max-width: 400px) {
	.alignleft,
	.alignright,
	.aligncenter {
		display: block;
		float: none;
		margin: 0 auto 1em auto;
	}
}

@media only screen and (max-width: 350px) {
  
}