/* -------------------------------------------------------------
/
/ Theme Name: Level 10 Base Child
/ Version: 1.0
/ Description: Child theme of Level 10 Base
/ Template: level10-base
/
/ -------------------------------------------------------------*/

/* */
/* */
/* */
/* */

/*	==========================================================================
  config
  ==========================================================================	*/

:root {

/*	fonts + scaling
    --------------------------------------------------------------------------	*/

  --font-text: 'Fira Sans', var(--font-main-stack);
  --font-heading: 'Poppins', var(--font-main-stack);
  --base-font-size: 1.1rem;
  --default-heading-weight: 500;
  
  --review-max-lines: 7;
  --review-height: 14rem;
  --review-max-height: 12rem;

/*	colors
    --------------------------------------------------------------------------	*/

  --primary: #07613d;
  --primary-hover: #398969;
  --secondary: #f3c927;
  --secondary-hover: #daa523;
  --text: #6c757d;
  --dark: #2b2a33;
  --med: #c3c4c7;
  --ultralight: #f3f8f6;
  --light: #e6f0ec;
  --med: #c1d8cf;
  --ultralight-secondary: #fefae9;
  --light-secondary: #fdf7df;
  --content-border-color: #e6f0ec;
  
  /*	Use for root values that have opacity and semi-transparent backgrounds. RGB values only.
    --------------------------------------------------------------------------	*/
  --primary-opacity: rgb(7 97 71 / 93%);
  --secondary-opacity: rgba(243, 201, 39, 80%);
  --light-opacity: rgb(246 255 251 / 94%);

/*	design params
    --------------------------------------------------------------------------	*/
   
    --border-radius: 4px;
  --btn-border-radius: 4px;
  --header-menu-height: 6rem;
  --header-padding: 0.25rem 0;

} /* :root */

/*	end config
    --------------------------------------------------------------------------	*/

/* */
/* */
/* */
/* */

/*	==========================================================================
  global theme styles
  ==========================================================================	*/

/*	header menu icons
    --------------------------------------------------------------------------	*/

/* .site-header-top-row .menu > li:nth-of-type(1)::before {
  content: '\f303';
}
.site-header-top-row .menu > li:nth-of-type(2)::before {
  content: '\f075';
}
.site-header-top-row .menu > li:nth-of-type(3)::before {
  content: '\f0d6';
} */

/*	.site-header-top-row
    --------------------------------------------------------------------------	*/

.site-header-top-row {
  background: var(--primary);
  height: 3rem;
}
.site-header-top-row ul.contact-info li::before,
.site-header-top-row ul.menu li::before,
.site-header-top-row ul.menu li i.menu-icon {
  color: var(--secondary);
}
.site-header-top-row li,
.site-header-top-row li a {
  color: var(--light);
}
.site-header-top-row li a:hover {
  color: #fff;
}
.site-header-top-row ul.contact-info li {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.site-header-top-row .phone-number a {
  color: var(--secondary);
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: calc(var(--font-size) + 1px);
}

/*	.site-header-menu-row
    --------------------------------------------------------------------------	*/

.site-header-menu-row {
  width: 100%;
  padding: 0.25rem 0;
  height: var(--header-menu-height);
  background:#fff;
}
.home .site-header-menu-row.stuck .logo img {
   display: block;
}
.home.home-banner-centered-logo .site-header-menu-row .logo img {
   display: none;
}

/*	.mobile nav
    --------------------------------------------------------------------------	*/

@media(max-width: 62rem) {
 .home .site-nav-menu > ul > li a {
    font-family: var(--font-heading);
    font-weight: 500;
  }
  
  .home.home-banner-centered-logo .site-header-menu-row .logo img {
    display: block;
}
  
  .home.home-banner-centered-logo .site-header-menu-row {
    background: #fff;
}
  
  .home.home-banner-centered-logo .phone .label, .home.home-banner-centered-logo .phone a {
    color: var(--primary)!important;
}
  
  .site-header-mobile-row.sticky-header {
    background: white;
}
  
  .home-banner.home-banner-centered-logo .logo .img-wrap img {
    
    display:none;
  }
  
  .gform_wrapper.gravity-theme input:not([type=radio]):not([type=checkbox]):not([type=image]):not([type=file]) {
    line-height: 0!important;
}
}

/*	.sticky-header
    --------------------------------------------------------------------------	*/

.sticky-header {
  background: none;
  border-bottom: 1px solid var(--light);
}
.home .sticky-header {
  border: none;
}
.sticky-header.stuck {
  transition: 0.25s background;
  background: #fff;
  border-bottom: 1px solid var(--light);
}

/*	.site-btn
    --------------------------------------------------------------------------	*/

.site-btn > a {
  font-family: var(--font-heading);
  font-weight: 500;
}

/*	.site-tabs
    --------------------------------------------------------------------------	*/

.site-tabs .tab {
  padding: 0.5rem 1.2rem;
  margin: 0 0.25rem 0 0;
  position: relative;
  top: 1px;
  font-family: var(--font-heading);
  font-weight: 500;
  border-top: 1px solid var(--primary);
  border-left: 1px solid var(--primary);
  border-right: 1px solid var(--primary);
  background: var(--primary);
  color: #fff;
}
.site-tabs .tab:not(.active):hover {
  background: var(--primary-hover);
}
.site-tabs .tab.active {
  background: #fff;
  color: var(--primary);
}

/*	heading leading
    --------------------------------------------------------------------------	*/

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5 {
  line-height: 1.4;
}

/*	.site-rtt
    --------------------------------------------------------------------------	*/
    
.site-rtt {
  border-radius: var(--border-radius);
  background: var(--secondary);
  color: #000;
  right: 2rem;
}
.site-rtt:hover {
  background: var(--primary-hover);
  color: #fff;
}

/*	.site-page-title
    --------------------------------------------------------------------------	*/

.site-page-title h2 {
  color: #000;
}

/*	==========================================================================
  .site-nav-menu
  ==========================================================================	*/
  
.site-nav-menu > ul > li > a {
  font-size: calc(var(--font-size) + 1px);
  font-family: var(--font-heading);
  font-weight: 500;
}

/*	==========================================================================
  footer
  ==========================================================================	*/

footer {
    background: var(--primary);
    color: var(--med);
    padding: 3rem 0;
    border-top: 3px solid var(--med);
    background-image: linear-gradient(to right,var(--primary),var(--primary),var(--primary-opacity),var(--primary-opacity)),url(/wp-content/uploads/2023/10/footer-banner-image.webp)!important;
  background-position: bottom;
}
footer .footer-socials li a {
  color: var(--med);
}
footer .site-grid a {
  color: var(--secondary);
}
footer .site-grid h5 {
  font-size: var(--font-size);
  font-weight: 500;
}

/*	end global theme styles
    --------------------------------------------------------------------------	*/

/* */
/* */
/* */
/* */

/*	==========================================================================
  template-home.php styles
  ==========================================================================	*/

.home #header {
  background: none;
}
.home .site-header-menu-row {
}
.home.home-banner-centered-logo .site-nav-menu > ul > li > a {
  color: #fff;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.33);
}
@media ( min-width: 62rem ) {
  .home.home-banner-centered-logo .stuck .site-nav-menu > ul > li > a {
    color: var(--primary);
    text-shadow: none;
  }
}
.home.home-banner-centered-logo .site-nav-menu > ul > li > a:hover {
  color: #fff;
  background: rgba(243, 248, 246, 0.25);
}
@media ( min-width: 62rem ) {
  .home .stuck .site-nav-menu > ul > li > a:hover {
    background: var(--ultralight);
    color: var(--primary);
  }
}
.home .site-nav-menu > ul > li.active > a,
.home .site-nav-menu > ul > li.active > a:hover {
  color: #fff;
  text-shadow: none;
}
.home .site-nav-menu > ul > li.active > a:hover {
  background: none;
  text-shadow: none;
}
.home .site-content {
}
.home .site-grid {
  gap: 2rem;
}
.home h2:has(span),
.home h3:has(span) {
  color: #000;
}
.home h2 span,
.home h3 span {
  padding: 0.125rem 0.5rem;
  display: inline-block;
  margin: 0.125rem 0;
  background: var(--secondary);
}

@media(max-width: 62rem) {
  .home .site-nav-menu > ul > li.active > a:hover,
  .home .site-nav-menu > ul > li.active > a {
    background: var(--primary) !important;
  }
}

/*	.home-banner
    --------------------------------------------------------------------------	*/	
    
.home-banner.home-banner-centered-logo {
  position: relative;
  top: calc(-1 * var(--header-menu-height));
  margin-bottom: calc(-1 * var(--header-menu-height)); 
  left: 0;
  background: var(--primary);
  padding-bottom: 1rem;
}
.home-banner-spacer {
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  max-height: 100vh;
}
.home-banner.home-banner-centered-logo .img {
  aspect-ratio: 4/3;
  max-height: 100vh;
  width: 100%;
  height: auto;
  position: relative;
}
.home-banner.home-banner-centered-logo .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.home-banner.home-banner-centered-logo .img::after {
  display: none;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, #fff, rgba(255,255,255,0) 33%);
}
.home-banner.home-banner-centered-logo .text {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.home-banner.home-banner-centered-logo .text .site-container {
  position: relative;
  height: 100%;
  display: block;
  padding: 0;
  max-width: none;
  display: flex;
  flex-direction: column;
}
.home-banner.home-banner-centered-logo .headlines {
  text-align: center;
  padding: calc(var(--header-menu-height) + 3rem) var(--container-margin) 0 var(--container-margin);
  width: 100%;
 /* background: linear-gradient(to bottom,rgb(221 221 221 / 75%) 0,rgba(15,70,110,0) 100%);*/
  display: flex;
  flex-wrap: wrap;
  flex: 0;
  justify-content: center;
}

.home-banner.home-banner-centered-logo .headlines h1 {
  color: #fff;
  font-weight: 500;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.66);
  flex-basis: 100%;
}
.home-banner.home-banner-centered-logo .headlines h1 span {
  color: var(--secondary);
  display: block;
  font-size: max(var(--font-size), calc(var(--base-h1-size) - 16px));
  font-weight: 500;
}
.home-banner.home-banner-centered-logo .headlines h1 strong {
  font-weight: 700;
}
.home-banner.home-banner-centered-logo .headlines .site-btn a {
  background: var(--secondary);
  color: #000;
  font-weight: 500;
  border-color: var(--secondary);
  box-shadow: 1px 1px 3px rgba(0, 0, 0 0.66);
}
.home-banner.home-banner-centered-logo .headlines .site-btn a:hover {
  color: #fff;
  background: var(--primary);
  border-color: var(--primary);
}
.home-banner.home-banner-centered-logo .logo {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  width: 100%;
  margin: 0;
  padding: 3rem var(--container-margin) 9rem var(--container-margin);
  background: linear-gradient(to top, var(--ultralight), rgba(0,0,0,0));
}

.home-banner.home-banner-centered-logo .logo .img-wrap {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.home-banner.home-banner-centered-logo .logo .img-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: auto;
  margin-left: auto;
  margin-right: auto;
}

/*	.home-banner-grid
  --------------------------------------------------------------------------	*/

.home-banner-grid {
  background: var(--ultralight);
  padding: 0;
}
.home-banner-grid .site-container {
}
.home-banner-grid .site-grid {
  grid-template-columns: repeat(4, 4fr);
  gap: 1rem;
  overflow: hidden;
  position: relative;
  z-index: 2;
  top: -6rem;
}
.home-banner-grid .grid-item {
  border-radius: var(--border-radius);
  position: relative;
  overflow: hidden;
  transition: .5s ease;
}
.home-banner-grid .grid-item:first-child {
  padding: 2rem;
  background: var(--primary);
  display: flex;
  align-items: center;
}
.home-banner-grid .grid-item .card {
  width: 100%;
  height: 100%;
  padding: 2rem 1rem 2rem 2rem;
  background: var(--primary);
  transition: .5s ease;
}
.home-banner-grid .grid-item .card::before {
}
.home-banner-grid .grid-item h2 {
  color: #fff;
  margin: 0;
}
.home-banner-grid .grid-item h2 em {
  color: var(--secondary);
  font-style: normal;
}
.home-banner-grid .grid-item .card h3 {
  color: #fff;
}
.home-banner-grid .grid-item .card i.fa-light {
  color: var(--secondary);
  font-size: 2.5rem;
  margin: 0 0 1rem 0;
}
.home-banner-grid .grid-item .card .site-btn.btn-outline a {
  border-color: var(--secondary);
  color: var(--secondary);
  background: none;
  padding: 0.5rem 1rem;
}
.home-banner-grid .grid-item .card .site-btn.btn-outline a:hover {
  background: var(--secondary);
  color: #000;
}
  
/*	.home-tabs
  --------------------------------------------------------------------------	*/

.home-tabs {
  padding: 0 0 6rem 0;
  background: var(--ultralight);
}

@media ( max-width: 62rem ) {
  .home-tabs {
    padding-top: 2rem;
  }
}

.home-tabs .site-tabs {
  margin: 3rem 0 0 0;
}
.home-tabs .tab-contents {
  border-top: 1px solid var(--primary);
  background: #fff;
  padding: 2rem;
  border-radius: 0 var(--border-radius) var(--border-radius) var(--border-radius);
}

/*	.home-service-hero + .home-quick-links
  --------------------------------------------------------------------------	*/

.home-service-hero {
  width: 100%;
  position: relative;
  background: var(--ultralight);
}
.home-service-hero .img {
  width: 100%;
  height: auto;
  aspect-ratio: 3/2;
  max-height: calc(100vh - var(--header-menu-height-stuck));
  max-width: 120rem;
  margin: 0 auto;
}
.home-service-hero .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
@media(min-width:120rem) {
  .home-service-hero .img {
    overflow: hidden;
    border-radius: var(--border-radius);
  }
}
.home-quick-links {
  position: absolute;
  left: var(--container-margin);
  bottom: 2rem;
  width: auto;
  background: rgba(242, 202, 39, 0.85);
  backdrop-filter: blur(4px);
  border-radius: var(--border-radius);
  padding: 2rem;
}
.home-quick-links h6 {
  color: var(--primary);
  font-weight: 500;
  border-radius: var(--border-radius);
  padding: 0.5rem 1rem;
  background: var(--primary);
  color: #fff;
  display: inline-flex;
  text-transform: uppercase;
  align-items: center;
}
.home-quick-links h6::before {
  font-family: 'Font Awesome 6 Pro';
  content: '\f245';
  font-weight: 600;
  margin: 0 0.5rem 0 0;
}
.home-quick-links .site-grid {
  gap: 0;
}
.home-quick-links a {
  display: flex;
  border-radius: var(--border-radius);
  justify-content: space-between;
  align-items: center;
  text-decoration: none !important;
  font-family: var(--font-heading);
  font-weight: 400;
  padding: 0.5rem 1rem;
  color: #000;
  transition: 0.5s background, 0.5s color;
}
.home-quick-links a::after {
  font-family: 'Font Awesome 6 Pro';
  content: '\f105';
  color: #000;
  font-weight: 600;
  position: relative;
  transition: 0.5s left;
  left: 0;
}
.home-quick-links a:hover {
  background: var(--primary);
  color: #fff;
}
.home-quick-links a:hover::after {
  color: #fff;
  left: 0.25rem;
}

/*	.home-services
  --------------------------------------------------------------------------	*/

.home-services {
  padding: 6rem 0;
  background: var(--ultralight);
}
.home-services .site-grid {
  margin: 3rem 0 0 0;
  gap: 1rem;
}
.home-services .grid-item {
  background: #fff;
  border-radius: var(--border-radius);
  border: 1px solid var(--med);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.home-services .grid-item .img {
  aspect-ratio: 3/2;
  width: 100%;
  height: auto;
  border-bottom: 1px solid var(--med);
}
.home-services .grid-item .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.home-services .grid-item .text {
  padding: 2rem;
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: space-between;
}
.home-services .grid-item .text-contents {
  margin: 0 0 1rem 0;
}

/*	.home-identity
  --------------------------------------------------------------------------	*/

.home-identity {
  padding: 6rem 0;
}
.home-identity .site-grid {
  margin: 3rem 0 0 0;
}
.home-identity .site-grid .grid-item {
  position: relative;
}
.home-identity .site-grid img {
  border-radius: var(--border-radius);
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right;
}
.home-identity .grid-item:last-child {
  position: relative;
}
.home-identity .grid-item:last-child p {
  position: absolute;
  margin: 0;
  left: 0;
  bottom: 0;
  padding: 0.5rem 1.5rem;
  font-family: var(--font-heading);
  font-weight: 500;
  color: var(--primary);
  background: #fff;
  border-radius: 0 var(--border-radius) 0 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
}
.home-identity .grid-item:last-child p::before {
  display: inline-block;
  margin: 0 0.5rem 0 0;
  font-family: "Font Awesome 6 Pro";
  content: '\f083';
  font-size: calc(var(--font-size) + 5px);
}

/*	.home-reviews-hero
  --------------------------------------------------------------------------	*/

.home-reviews-hero {
  width: 100%;
  position: relative;
}
.home-reviews-hero .img {
  width: 100%;
  height: auto;
  aspect-ratio: 3/2;
  max-height: calc(100vh - var(--header-menu-height-stuck));
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto;
}
.home-reviews-hero .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: bottom;
}
@media(min-width:120rem) {
  .home-reviews-hero .img {
    overflow: hidden;
    border-radius: var(--border-radius);
  }
}
.home-reviews-hero .img::after {
  display: none;
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  height: 50%;
  width: 100%;
  background: linear-gradient(to bottom, rgba(0,0,0,0), var(--ultralight));
}
   
/*	.home-reviews
  --------------------------------------------------------------------------	*/
  
.home-reviews {
  background: var(--ultralight);
  padding: 6rem 0;
}
.home-reviews .site-grid {
  margin: 3rem 0;
  gap: 1rem;
  grid-template-columns: repeat( auto-fit,minmax(22rem,1fr) );
}
@media (min-width: 1360px) {
  .home-reviews .site-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
}
.home-reviews .grid-item,
.template-reviews .grid-item,
.site-grid.reviews-grid .grid-item {
  border-radius: var(--border-radius);
  background: #fff;
  padding: 2rem;
  border: 1px solid var(--light);
}
.home-reviews .grid-item .review-meta,
aside .widget-reviews .review-meta,
.template-reviews .grid-item .review-meta,
.site-grid.reviews-grid .grid-item .review-meta {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  align-items: center;
  justify-content: flex-start;
}
.home-reviews .grid-item .img,
aside .widget-reviews .img,
.template-reviews .grid-item .img,
.site-grid.reviews-grid .grid-item .img {
  width: 5rem;
  height: 5rem;
  border-radius: var(--border-radius);
  display: block;
  background: var(--med);
}
aside .widget-reviews .img {
  width: 4rem;
  height: 4rem;
}
.home-reviews .grid-item .stars::after,
aside .widget-reviews .stars::after,
.template-reviews .grid-item .stars::after,
.site-grid.reviews-grid .grid-item .stars::after,
.template-reviews .review-modal .stars::after,
.site-grid.reviews-grid .review-modal .stars::after {
  position: relative;
  width: auto;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  font-family: 'Font Awesome 6 Pro';
  color: var(--secondary);
  font-weight: 900;
  font-size: 1.3rem;
  content: '\f005\f005\f005\f005\f005';
    background: -webkit-linear-gradient(var(--secondary), #ff9c44);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
aside .widget-reviews .stars::after {
  font-size: 1.2rem;
}
.home-reviews h5 {
  text-wrap: balance;
  text-transform: capitalize;
}
.home-reviews .grid-item hr,
aside .widget-reviews hr,
.template-reviews .review-modal hr,
.template-reviews .grid-item hr,
.site-grid.reviews-grid .review-modal hr,
.site-grid.reviews-grid .grid-item hr {
  margin: 1rem 0;
}
.home-reviews p.name,
aside .widget-reviews p.name,
.template-reviews p.name,
.site-grid.reviews-grid p.name {
  font-weight: 500;
  font-family: var(--font-heading);
  color: #000;
  margin: 0 0 0.5rem 0;
}
aside .widget-reviews p.name {
  margin: 0 0 0.25rem 0;
}
.home-reviews .site-btn {
  width: 100%;
  text-align: center;
}

/*	.home-recent-posts
  --------------------------------------------------------------------------	*/

.home-recent-posts {
  padding: 6rem 0;
}
.home-recent-posts #l10-post-widget {
  margin: 3rem 0 0 0;
}
.home #l10-post-widget .tabs .tab {
  padding: 0.5rem 1.5rem;
  margin: 0 0.25rem 0 0;
  position: inherit;
  top: 1px;
  font-family: var(--font-heading);
  font-size: var(--font-size); /* override plugin, match .home-tabs */
  line-height: inherit; /* override plugin, match .home-tabs */
  font-weight: 500;
  border-top: 1px solid var(--primary);
  border-left: 1px solid var(--primary);
  border-right: 1px solid var(--primary);
  background: var(--primary);
  color: #fff;
}
/*.home #l10-post-widget .tabs .tab i {
  display: none; 
}*/

.home #l10-post-widget .tabs .tab:not(.active):hover {
  background: var(--primary-hover);
}
.home #l10-post-widget .tabs .tab.active {
  color: var(--primary);
  background: #fff;
  position: relative;
}
.home #l10-post-widget .tabs .tab.active::after {
  display: block;
  height: 1px;
  width: 100%;
  position: absolute;
  bottom: 1px;
  left: 0;
  content: '';
}
.home #l10-post-widget .posts {
  border-top: 1px solid var(--primary);
  border-radius: 0 var(--border-radius) var(--border-radius) var(--border-radius);
}
.home #l10-post-widget .site-btn a {
  text-decoration: none;
  background: #fff;
  border-color: var(--primary);
  color: var(--primary);
}
.home #l10-post-widget .site-btn a:hover {
  background: var(--primary);
  color: #fff;
}

/* don's note: plugin css is outdated */

.home #l10-post-widget .posts ul.post-categories {
  padding: 0; 
}
.home #l10-post-widget .posts .post-list {
  padding: 1rem;
}
.home #l10-post-widget .posts ul.post-categories {
  display: flex;
  gap: 0.5rem;
}
.home #l10-post-widget .posts ul.post-categories li {
  border: none;
}
.home #l10-post-widget hr {
  margin: 0.5rem 0;
}
.home #l10-post-widget .posts ul li a i.fa-angle-right {
  padding: 0;
  font-size: var(--font-size);
  transition: 0.25s color;
  position: inherit;
  display: none;
}
.home #l10-post-widget .posts ul li a:hover i.fa-angle-right {
  color: #fff;
  left: 0;
}
     
/*	.home-service-areas
  --------------------------------------------------------------------------	*/

.home-service-areas {
  background: var(--ultralight);
  padding: 6rem 0 0 0;
}
.home-service-areas h3 {
  margin: 0 0 3rem 0;
}
.home-service-areas iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 2/1;
  margin: 3rem 0 0 0;
}

/* .home-map
  --------------------------------------------------------------------------	*/
/* .home-map iframe {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 2/1;
  margin: 3rem 0 0 0;
} */

.home-map {
  padding: 3rem 0 3rem;
  background: var(--light)
}

.home-map .text {
  background: var(--ultralight);
  padding: 6rem 3rem 6rem 5vw;
  border-radius: 0 var(--border-radius)var(--border-radius)0
}

.home-map ul {
  margin-bottom: 2rem
}

.home-map .map {
  background: #fff;
  position: relative;
  border-radius: var(--border-radius)0 0 var(--border-radius);
  box-shadow: var(--box-shadow);
  overflow: hidden
}

@media ( max-width: 48rem ) {
  .home-map .site-grid .map {
    min-height: 400px;
  }
  
  .home-map .map h3.headline-align-left {
    left: 1rem;
}
  
  .home-map .map h3.headline-align-right {
    right: 1rem;
}
}

.home-map .map iframe {
  width: 100%;
  height: 125%;
  position: relative;
  top: -5rem
}

.home-map ul.angles {
  margin: 0 0 1rem;
  padding: 0
}

.home-map ul.angles li {
  margin: 0 0 .5rem
}

.home-map ul.angles li::before {
  content: '\f105';
  display: inline-block;
  font-family: 'font awesome 6 pro';
  color: var(--secondary);
  margin: 0 .5rem 0 0;
  font-weight: 600
}

.home-map ul.angles li a {
  text-decoration: none;
}

/*	.home-footer
  --------------------------------------------------------------------------	*/

.home footer {
  margin: 0;
}

/*	end template-home.php
    --------------------------------------------------------------------------	*/

/*	==========================================================================
  posts
  ==========================================================================	*/

.site-featured-img .date {
  font-family: var(--font-heading);
  font-weight: 500;
  color: #000;
  background: var(--secondary);
}

/*	==========================================================================
  sidebar
  ==========================================================================	*/
  
/*	#l10-post-widget 
    --------------------------------------------------------------------------	*/

#sidebar #l10-post-widget .posts ul li a.title {
  font-family: var(--font-text);
}
#sidebar #l10-post-widget .tabs {
  gap: 0.25rem;
}
#sidebar #l10-post-widget .tabs .tab,
#sidebar #l10-post-widget .tabs .tab:last-child {
  font-family: var(--font-heading);
  font-size: var(--font-size);
  font-weight: 500;
  color: #fff;
  background: var(--primary);
  border-top: 1px solid var(--primary);
  border-left: 1px solid var(--primary);
  border-right: 1px solid var(--primary);
  position: inherit;
  flex: 1;
}
#sidebar #l10-post-widget .tabs .tab.active {
  background: #fff;
  color: var(--primary);
  position: relative;
}
#l10-post-widget .tabs .tab::after {
  display: none; /* bug fix */
}
#sidebar #l10-post-widget .tabs .tab.active::after {
  display: block;
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  background: #fff;
  width: 100%;
  height: 1px;
}
#sidebar #l10-post-widget .posts {
  border-top: 1px solid var(--primary);
}
    
/* */
/* */
/* */
/* */

/*	==========================================================================
  media queries
  ==========================================================================	*/

@media(max-width:75rem) {
  br:not(.address-br, h3.h4.headline-align-right br, h3.h4.headline-align-left br) {
    display: none;
  }
  .home h2 span, .home h3 span {
    display: inline;
  }
  .home-banner-grid .site-grid {
    grid-template-columns: repeat(2, 2fr);
  }
  .home-identity .site-grid {
    grid-template-columns: repeat(1, 1fr);
  }
  .home-identity .site-grid .img {
    aspect-ratio: 4/3;
  }
}
@media(max-width:62rem) {
  .home .site-header-menu-row .logo img {
    display: block;
  }
  .home-banner .logo {
    display: none;
  }
  .home-banner .headlines {
    background: linear-gradient(to bottom,rgba(255,255,255,.75) 0,rgba(255,255,255,0) 100%);
  }
  .menu-header-menu-container {
    display: none;
  }
  .site-header-top-row ul {
    margin: 0 auto;
  }
  
  .before-you-go-content.site-grid .site-form {
    display: none;
}
  
  footer {
    background-position: center;
    background-size: cover;
}
}

@media(max-width:1110px) {
  .before-you-go-content.site-grid h3.headline {
    font-size: 2rem!important;
}
}
@media ( max-width: 62rem ) {
  .home-banner-container.home-banner-hero-slideshow .sidebar-form-header h5 {
    color: var(--primary);
  }
  
  .home-banner-container.home-banner-hero-slideshow .sidebar-form-header {
    background: transparent;
  }
}
@media(max-width:48rem) {
  .home-quick-links {
    position: relative;
    top: 0;
    left: 0;
    background: var(--secondary);
  }
  
  .carousel-slide-content .site-btn a {
    background: var(--secondary);
    color: var(--primary);
}
}
@media(max-width:36rem) {
  .site-header-top-row ul.contact-info {
    flex-direction: column;
    align-items: center;
  }
  
  .home #l10-post-widget .tabs .tab {
    line-height: 1.45rem;
}

.site-grid.reviews-grid { 
    grid-template-columns: repeat( auto-fit,minmax(19rem,1fr) )!important;
}

.site-grid.site-grid--2x1 { 
    grid-template-columns: repeat(auto-fit,minmax(20rem,1fr))!important;
}
  
  header.header-1 .site-header-top-row ul.contact-info li.address {
    display: none;
  }
  .home-banner .text {
    position: relative;
  }
  .home-banner .headlines {
    background: var(--primary);
    padding: 3rem 0;
  }
  .home-banner .headlines h1 {
    text-shadow: none;
  }
  .home-banner-grid {
    padding:3rem 0;
  }
  .home-banner-grid .site-grid {
    grid-template-columns: repeat(1, 1fr);
    top: 0;
  }
  .home-banner-grid .grid-item:first-child {
    padding: 0;
    background: none;
  }
  .home-banner-grid .grid-item h2 {
    color: #000;
    margin: 0 0 1.5rem 0;
  }
  .home-banner-grid .grid-item h2 em {
    background: var(--secondary);
    color: #000;
  }
  
  .home #l10-post-widget .posts .post-list {
    padding: 0;
}

.home-banner.home-banner-centered-logo {
    padding-bottom: 5rem;
}

.home-banner.home-banner-centered-logo .logo {
    background: transparent;
}
}

/*	==========================================================================
  Random improvements and modifications to tighten the theme up.
  ==========================================================================	*/

.blog.single .meta {
  justify-content: space-between;
  gap: .2rem;
}

.meta .page-views {
  display: flex;
  align-items: center;
}

@media ( max-width: 48rem ) {
  .meta .page-views {
    align-items: end;
  }
}

.meta .page-views i {
  font-weight: 700;
  font-size: calc(var(--font-size) - 1px);
  color: var(--primary);
}

.meta .page-views > span {
  display: flex;
  align-items: center;
  gap: .2rem
}

.home #l10-post-widget .post-list ul > li {
  position: relative;
}

.home #l10-post-widget .meta .page-views,
.blog.index article .meta .page-views {
  position: absolute;
  top: 20px;
  right: 20px;
  color: #fff;
  text-shadow: 1px 1px 0px #0000003b;
}

.home #l10-post-widget .meta .page-views i,
.blog.index article .meta .page-views i,
.meta .pinned-post i {
  color: #fff;
  text-shadow: 1px 1px 0px #0000003b;
}

.home #l10-post-widget .site-featured-img.no-image + .text .meta .page-views,
.home #l10-post-widget .site-featured-img.no-image + .text .meta .page-views i,
.blog.index article .site-featured-img.no-image + .text .meta .page-views,
.blog.index article .site-featured-img.no-image + .text .meta .page-views i {
  color: var(--primary)
}

#l10-post-widget .posts ul li .text .date {
  display: none;
}

#l10-post-widget .posts ul li .text:hover {
    background: var(--ultralight);
    transition: .5s ease;
}

#l10-post-widget .posts ul li .text {
    transition: .5s ease;
}

input:not(.before-after-slider .slider):focus-within {
    background: var(--ultralight);
}

textarea:focus-within {
    background: var(--ultralight)!important;
}

#sidebar .map iframe { 
    border-radius: var(--border-radius)!important;
    height: 14rem;
}

.review-stars select {
    border: 1px solid var(--med)!important;
    outline: 0!important;
    border-radius: var(--border-radius);
    height: 2.1rem;
}

#sidebar #l10-post-widget .tab {
    transition: .25s ease;
}

.home.home-banner-centered-logo .phone .label,
.home.home-banner-centered-logo .phone a {
    color: #fff;
}

.phone .label > span {
    font-weight: 500;
}

.home-banner-grid .grid-item .card:hover {
    background: var(--primary-hover)!important;
    transition: .5s ease;
}

.home-banner-grid .grid-item:hover {
    background: var(--primary-hover);
    transition: .5s ease;
}

@media ( max-width: 36rem ) {
  .home-banner-grid .grid-item:first-child:hover {
    background: none;
    transition: none;
  }
}

.sub-menu i.menu-icon {
    font-weight: 600;
    margin-right: .5rem;
    font-size: 1.1rem;
    color: var(--med);
}

.label {
    font-size: 1.05rem;
  font-family: var(--font-heading);
  margin-bottom: -4px;
}

.number {
    font-size: 1.4rem;
    font-weight: 600;
  font-family: var(--font-text);
}

#sidebar #l10-post-widget .tabs .tab.active i {
    color: var(--primary);
}

#l10-post-widget .tabs .tab i {
    font-weight: 600;
    color: var(--light);
}

.home .stuck .number-outer {
    color: var(--primary);
}

.home .stuck .label {
    color: var(--primary);
}

.home #l10-post-widget .tabs .tab.active i {
    color: var(--primary);
}

/*	==========================================================================
  Page specific. Lining up sidebar with the bottom of the entry content.
  ==========================================================================	*/

.page-template-templatestemplate-reviews-php aside#sidebar {
    margin-bottom: 2.35rem;
}

@media(max-width:1445px) {
  .page-template-templatestemplate-reviews-php aside#sidebar {
    margin-bottom: 0.7rem;
}
}

/*	==========================================================================
  EXPERIMENTAL CODE FOR BUTTON
  ==========================================================================	*/

.site-btn.icon-right i {
    display: none;
}

/*	==========================================================================
  HOME BANNER STYLES
  ==========================================================================	*/
  
/* Static Home Banner */

@media ( max-width: 62rem ) {
  .home-banner-hero-static {
    margin-bottom: 2rem;
  }
}

.home-banner-hero-static .home-banner {
    position: relative;
    padding: 24rem 0;
    overflow: hidden;
    background: var(--light)
}

.home-banner-hero-static .home-banner .img {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: calc(100% - 1rem);
    background: var(--med);
    object-fit: cover;
    object-position: bottom;
    border-radius: 0 0 0 var(--border-radius);
    box-shadow: var(--box-shadow);
    aspect-ratio: 2/1;
}

.home-banner-hero-static .home-banner .img-outer::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #00000080;
  width: 100%;
  height: calc(100% - 1rem);
}

@media ( max-width: 62rem ) {
  .home-banner-hero-static .home-banner .img-outer {
    position: relative;
  }
  .home-banner-hero-static .home-banner .img-outer::after {
    height: calc(100% - .5rem);
  }
}

.home-banner-hero-static .home-banner .text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2
}

@media (max-width: 62rem) {
  .home-banner-hero-static .home-banner {
    padding: 0;
  }
  .home-banner-hero-static .home-banner .img {
    position: relative;
    height: auto;
  }
  
  .home-banner-hero-static .home-banner .img:after {
    content: none;
  }
  
  .home-banner-hero-static .home-banner .text {
    position: relative;
    padding: 5% 0;
    margin-bottom: 5%;
    background: var(--med);
  }
  
  .home-banner-hero-static + .home-banner-grid .site-grid {
    top: auto;
  }
  
  .before-you-go-content.site-grid .site-btn a {
    background: var(--primary-hover);
}
}

@media (max-width: 62rem) {
  .home-banner-hero-static .home-banner .text {
    margin-bottom: 0;
  }
  
  .home-banner-hero-static .home-banner .site-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.home-banner-hero-static .home-banner .site-container {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-content: center;
    position: relative
}

.home-banner-hero-static .home-banner .text-headlines {
    position: relative;
    left: -5vw;
    background: linear-gradient(to bottom right,#1f2f5b,#1f2f5ba1);
    width: calc((50% + 5vw) - 1rem);
    display: inline-block;
    padding: 3rem 0 3rem 5vw;
    border-radius: 0 var(--border-radius)var(--border-radius)0;
    box-shadow: var(--box-shadow)
}

.home-banner-hero-static .home-banner .banner-text {
    color: #fff;
    font-weight: 400;
    margin: 0 0 1rem;
    line-height: 2.75rem;
    text-shadow: 1px 1px 0 rgba(33,33,33,.66);
    width: 100%;
}

.home-banner-hero-static .home-banner .banner-text span {
    font-size: 2.5rem;
    font-weight: 700
}

.home-banner-hero-static .home-banner p {
    color: #fff;
    margin: 0 0 2rem;
    line-height: 2rem;
    font-weight: 400;
    text-shadow: 1px 1px 0 rgba(33,33,33,.66)
}

.home-banner-hero-static .home-banner .buttons {
    display: flex
}

.home-banner-hero-static .home-banner .site-btn {
    display: flex;
    justify-content: center;
    margin: 1rem 1rem 0 0
}

.home-banner-hero-static .home-banner .site-btn.empty {
    border-color: #fff;
    opacity: .66
}

.home-banner-hero-static .home-banner .site-btn a {
    width: 100%;
    text-align: center;
    padding: .6rem 1.6rem;
    display: flex;
    text-align: center;
    align-items: center;
}

.home-banner-hero-static .home-banner .site-btn i {
    margin: 0 10px 0 0;
}

.home-banner-hero-static .home-banner .site-btn.empty a {
    color: #fff
}

.home-banner-hero-static .home-banner .site-btn:hover {
    opacity: 1
}

.home-banner .site-grid {
  grid-template-columns: repeat(2,2fr);
}

.home-banner .grid-item {
  display: flex;
  align-content: flex-start;
  flex-wrap: wrap;
}

.home-banner .left {
  padding: 0;
}

.home-banner .right {
  justify-content: flex-end;
}

.home-banner .right .form-wrapper {
    max-width: 42rem;
    background: #3a3a3aab;
    padding: 1rem;
    width: 23rem;
  border-radius: var(--border-radius);
}

@media ( max-width: 62rem ) {
  .home-banner .right .form-wrapper {
    max-width: 100%;
    width: 100%;
  }
}

.home-banner .form h3 {
    color: #fff;
    margin: -1rem 0 1rem -1rem;
    padding: 0.5rem 1rem;
    text-align: center;
    background: var(--primary);
    width: calc(100% + 2rem);
    border-radius: var(--border-radius)var(--border-radius)0 0;
    font-size: 1.4rem;
}

.home-banner .form h3 i {
    margin: 0 10px 0 0;
    font-size: 133%;
    color: #fff
}

.home-banner .gform_wrapper.gravity-theme .gfield_label {
    display: none
}

.home-banner .gform_wrapper.gravity-theme .gform_fields {
    gap: .5rem
}

.home-banner .gform_wrapper.gravity-theme .gfield input.large,.home-banner .gform_wrapper.gravity-theme .gfield textarea {
    border-radius: var(--border-radius);
    font-family: var(--font-main-stack);
    font-size: 1rem;
    border: 1px solid var(--primary);
    background: #fff;
    padding: 10px 15px;
    transition: .5s all;
    resize: none;
    outline: none
}

.home-banner .gform_wrapper.gravity-theme .gfield input.large:focus,.home-banner .gform_wrapper.gravity-theme .gfield textarea.small:focus {
    background: #fff;
    border: 1px solid #55b3e3;
    outline: none
}

.home-banner .gform_wrapper.gravity-theme .gfield input.large::placeholder,.home-banner .gform_wrapper.gravity-theme .gfield textarea::placeholder {
    font-family: var(--font-heading);
    font-size: .9rem;
    color: var(--primary);
    opacity: .66
}

.home-banner .gform_wrapper.gravity-theme .gform_footer {
    margin: 0;
    padding: 0
}

.home-banner .gform_wrapper.gravity-theme .gform_footer input {
    font-family: var(--font-heading);
    font-size: 1rem;
    color: #fff;
    border: none;
    -webkit-appearance: none;
    border-radius: var(--border-radius);
    background: var(--primary);
    margin: 0;
    cursor: pointer;
    transition: .5s all;
    font-size: 1.2rem;
}

.home-banner .gform_wrapper.gravity-theme .gform_footer input:hover {
    background: var(--primary-hover)
}

.home-banner .captcha-disclaimer {
    margin: 0 0 1rem;
    font-size: .75rem;
    opacity: .9;
    color: #ebebeb;
    line-height: .9rem
}

.home-banner .captcha-disclaimer a {
    color: var(--secondary);
    text-decoration: underline
}

.home-banner-container {
  position: relative;
}

/* Slideshow */
@keyframes tonext {
  75% {
    left: 0;
  }
  95% {
    left: 100%;
  }
  98% {
    left: 100%;
  }
  99% {
    left: 0;
  }
}

@keyframes tostart {
  75% {
    left: 0;
  }
  95% {
    left: -300%;
  }
  98% {
    left: -300%;
  }
  99% {
    left: 0;
  }
}

@keyframes snap {
  96% {
    scroll-snap-align: center;
  }
  97% {
    scroll-snap-align: none;
  }
  99% {
    scroll-snap-align: none;
  }
  100% {
    scroll-snap-align: center;
  }
}

@keyframes fill {
  0% {
    width: 0%;
  }
  100% {
    width: 100%;
  }
}

@media ( min-width: 62rem ) {
  .home-banner-hero-slideshow .form-wrapper {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 2rem;
    z-index: 3;
    background: var(--secondary-opacity);
    border-radius: var(--border-radius);
  }
  
}

.carousel * {
  scrollbar-color: transparent transparent; /* thumb and track color */
  scrollbar-width: 0px;
}

.carousel *::-webkit-scrollbar {
  width: 0;
}

.carousel *::-webkit-scrollbar-track {
  background: transparent;
}

.carousel *::-webkit-scrollbar-thumb {
  background: transparent;
  border: none;
}

.carousel * {
  -ms-overflow-style: none;
}

.carousel {
  position: relative;
  padding-top: 50%;
  overflow: hidden;
  margin-bottom: 1rem;
}

.carousel-viewport {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  overflow-x: scroll;
  counter-reset: item;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  overflow: hidden;
}

.carousel-slide {
  position: relative;
  display: flex;
  align-items: center;
  flex: 0 0 100%;
  width: 100%;
  counter-increment: item;
  background: var(--primary);
  scroll-snap-align: start;
}

.carousel-slide::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #00000080;
  width: 100%;
  height: 100%;
}

@media (max-width: 48rem) {
  .carousel-slide::after {
    content: none;
  }
}

.carousel[data-carousel-animation="fade"] .carousel-slide {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: opacity 1s ease-in-out;
}

.carousel[data-carousel-animation="fade"]:not(.loaded) .carousel-slide:first-child,
.carousel[data-carousel-animation="fade"] .carousel-slide.active {
  opacity: 1;
  position: relative;
}

.carousel-slide-content .site-btn a {
  text-decoration: none;
}

.carousel-slide-content hr {
  margin: 1rem 0;
  background: var(--primary);
  height: 3px;
  width: 100px
}

@media ( max-width: 48rem ) {
  .carousel-slide-content hr {
    background: var(--secondary);
  }
}

.carousel-controls {
  right: 2rem;
  bottom: 2rem;
  position: absolute;
  display: flex;
  z-index: 4;
}

@media ( max-width: 48rem ) {
  .carousel-controls {
    display: none;
  }
}

.carousel-prev i,
.carousel-next i {
  width: 3.5rem;
  height: 3.5rem;
  font-size: 1.5rem;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 0 0.5rem;
  transition: .5s all;
  cursor: pointer;
  transition: background .5s ease-in-out;
}

.carousel-prev:hover i,
.carousel-next:hover i {
  background-color: var(--primary-hover);
}

/* .carousel-image {
  width: 100%;
  height: 100%;
} */

.carousel .carousel-img {
  position: relative;
  width: 100%;
  height: calc(100vw * .56);
  background: var(--ultralight);
  background-size: cover;
  background-position: 50%;
  object-fit: cover;
}

@media ( max-width: 640px ) {
  span#input_3_5_3_container {
    margin-bottom: 1rem;
  }
    span#input_3_5_6_container {
    margin-bottom: 0;
  }
}

@media ( max-width: 62rem ) {
  .carousel .carousel-img {
    max-height: calc(100vh - var(--header-top-height) - var(--header-menu-height) - 5px);
  }
  
  .before-you-go-modal>.inner {
    height: calc(100% - 19rem)!important;
    padding: 0rem!important;
  }
  
  .before-you-go-modal .content {
    padding: 2rem;
    text-align: center;
  }
  
  .before-you-go-content.site-grid {
    gap: 0!important;
  }
}

.carousel-slide-content {
  padding-left: 2rem;
  z-index: 2;
  font-size: 2rem;
  color: #fff;
  position: absolute;
  max-width: 50%;
}

@media ( max-width: 62rem ) {
  .carousel-slide-content {
    max-width: 100%;
  }
}

@media ( min-width: 62rem ) and ( max-width: 1920px ) {
  .carousel-slide-content {
    margin-left: 1%;
  }
  .home-banner-hero-slideshow .form-wrapper { 
    margin-right: 1%;
  }
}

@media ( min-width: 1921px ) {
  .carousel-slide-content {
    margin-left: 4%;
  }
  .home-banner-hero-slideshow .form-wrapper { 
    margin-right: 4%;
  }
}

.home-banner-hero-static h1,
.home-banner-hero-slideshow .carousel-slide-content h2 {
  text-transform: capitalize
}

/* @media ( max-width: 48rem ) {
  .carousel-slide-content {
    position: relative;
    padding: 2rem;
    max-width: 50%;
  }
} */

.home-banner-gauge {
  position: absolute;
  bottom: 0;
  width: 100%;
  background: var(--med);
}

.home-banner-gauge .gauge {
  position: relative;
  width: 0;
  height: 0.3rem;
  background: var(--secondary);
  animation-name: none;
  animation-timing-function: linear;
  animation-duration: 8s;
  animation-iteration-count: infinite;
  transition: opacity 0.5s ease-in-out;
}

.carousel-viewport.ready ~ .home-banner-gauge .gauge {
  animation-name: fill;
}

.carousel[data-pause-on-hover="true"]:hover .home-banner-gauge .gauge {
  animation-play-state: paused;
}

.home:not(.home-banner-hero-static) .home-banner-grid .site-grid {
  top: auto;
  padding-bottom: 6rem;
}

.entry-content h1, .entry-content h2, .entry-content h3, 
.entry-content h4, .entry-content h5, .entry-content h6 {
  text-wrap: balance;
}

.entry-content h1, main#content h1, h1+h2 {
  text-transform: capitalize;
}

.entry-content p strong, .entry-content p b, main#content p strong, main#content p b {
  font-weight: 500;
}

/* Reviews */
.review-content:not(.show-all) .inner {
    width: 100%;
    height: var(--review-height);
    max-height: var(--review-max-height);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -ms-box-orient: vertical;
    box-orient: vertical;
    -webkit-line-clamp: var(--review-max-lines);
    -moz-line-clamp: var(--review-max-lines);
    -ms-line-clamp: var(--review-max-lines);
    line-clamp: var(--review-max-lines);
    overflow: hidden;
}

.review-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.3);
    z-index: 999999;
    display: none
}

.review-modal>.inner { 
    background: #fff; 
    height: calc(100% - 10rem);
    width: calc(100% - 11rem);
    max-width: 75rem;
    margin: auto; 
    border-radius: var(--border-radius); 
    display: flex; 
    flex-direction: column; 
    padding: 3rem; 
    gap: .5rem; 
}

@media ( max-width: 62rem ) {
  .review-modal>.inner { 
    width: calc(100% - 3rem); 
  }
}

.review-modal .inner .review-modal-content {
    flex: 1 1;
    overflow: auto
}

.review-modal .inner .review-modal-footer {
    flex-shrink: 1
}

.review-read-more {
  display: none;
}

.review-read-more a {
    background: none !important;
    border: none !important;
    color: var(--primary) !important;
    padding: 0;
    margin-top: 2rem
}

.review-read-more a:before {
    content: unset
}

.template-reviews main .grid-item, 
.site-grid.reviews-grid .grid-item {
    display: flex;
    flex-direction: column;
    transition: transform .5s ease;
}

.template-reviews main .grid-item .review-content,
.site-grid.reviews-grid .grid-item .review-content {
    flex: 1
}

@media(max-width: 48rem) {
  .carousel {
    padding-top:0;
    margin-bottom: 1rem
  }

  .carousel-viewport {
    position: relative;
    /* height: 100vh */
  }

  .carousel-slide {
    flex-direction: column
  }

  .carousel-image {
    position: relative
  }

  .carousel-slide-content {
    position: relative;
    padding: 2rem;
    max-width: 100%;
  }
}

/* Header top cta */
.site-header-top-row li.cta {
  background: var(--primary-hover);
  position: relative;
  display: flex;
  padding: 0;
  transition: .5s all;
  align-items: center;
 /* border-top-left-radius: var(--border-radius);*/
  /*border-bottom-left-radius: var(--border-radius);*/
  border-left: 4px solid #fff;
}

.site-header-top-row li.cta a i {
  transition: .5s all;
}

/*.site-header-top-row li.cta:hover {
  background: var(--secondary);
}*/

/*.site-header-top-row li.cta:hover a i {
  color: var(--light);
}*/

.site-header-top-row li.cta::after {
  width: 50vw;
  height: 100%;
  position: absolute;
  top: 0;
  left: 100%;
  background: var(--primary-hover);
  transition: .5s all;
  content: '';
  display: block
}

/*.site-header-top-row li.cta:hover::after {
  background: var(--secondary);
}*/

.site-header-top-row li.cta a {
  padding: 10px 0 10px 2rem
}

.site-grid.site-grid--2x1,
.site-grid.site-grid--3x1 {
  gap: 2rem; 
  grid-template-columns: repeat(auto-fit,minmax(15.5rem,1fr));
}

.site-grid.site-grid--2x1 > div,
.site-grid.site-grid--3x1 > div {
  background: var(--ultralight);
  border-radius: var(--border-radius);
  border: 1px solid var(--content-border-color);
}

/* Before After Slider */
.before-after-slider {
  width: 100%;
  height: 600px;
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
  margin-top: 2rem;
}

.before-after-slider .before::before, .before-after-slider .after::before {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--ultralight);
    letter-spacing: .5px;
    line-height: 1;
    padding: .5rem 1rem;
    background: var(--primary-opacity);
    border-radius: var(--border-radius);
    box-shadow: var(--box-shadow);
    position: absolute;
    top: 1rem;
    z-index: 3;
}

.before-after-slider .before::before {
  content: 'Before';
  left: 1rem
}

.before-after-slider .after::before {
  content: 'After';
  right: 1rem;
}

.before-after-slider .image {
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
}

.before-after-slider .image img {
  height: 100%;
  width: 100%;
  object-fit: cover
}

.before-after-slider input.slider:focus-within {
    border: none!important;
}

.before-after-slider .image.before {
  width: 100%;
  z-index: 2;
  clip-path: polygon(0 0,50% 0,50% 100%,0% 100%)
}

.before-after-slider .image.after {
  width: 100%;
  z-index: 1
}

.before-after-slider .slider {
  width: 100%;
  height: 100%;
  outline: none;
  background-color: initial;
  position: absolute;
  margin: 0;
  cursor: pointer;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  transition: .25s all ease-in-out;
  -moz-transition: .25s all ease-in-out;
  -webkit-transition: .25s all ease-in-out;
  z-index: 4
}

.before-after-slider .slider::-moz-range-thumb {
  position: relative;
  width: 10px;
  height: 100vh;
  left: 3px;
  background-color: #fff;
  cursor: pointer
}

.before-after-slider .slider::-webkit-slider-thumb {
  position: relative;
  width: 10px;
  height: 100vh;
  left: 3px;
  background-color: var(--primary);
  cursor: pointer;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none
}

.before-after-slider .slider-button {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  -moz-broder-radius: 50%;
  -webkit-border-radius: 50%;
  background-color: var(--primary);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  /* cursor: ew-resize; */
  z-index: 4;
  pointer-events: none;
}

@media ( min-width: 1920px ) {
  .before-after-slider .slider-button { 
    margin-left: -.2rem;
  }
}

.before-after-slider .slider-button:before,
.before-after-slider .slider-button:after {
  font-family: 'font awesome 6 pro';
  color: var(--ultralight);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(50%, -50%);
}

.before-after-slider .slider-button:before {
  left: 0;
  content: "\f053"
}

.before-after-slider .slider-button:after {
  right: 0;
  content: "\f054"
}

@media ( max-width: 1920px ) {
  .before-after-slider .slider-button:after {
    right: -3px;
  }
}

/*	==========================================================================
  staff-container
  ==========================================================================	*/
.staff-container.site-grid {
    margin-top: 2rem;
}
.staff-container .grid-item {
    margin: calc(var(--team-img-size) * .5)0 0;
    display: flex;
    flex-direction: column;
    border-radius: var(--border-radius);
    background: var(--ultralight);
    border: 1px solid var(--content-border-color);
}
.staff-container .grid-item.hide {
  display: none;
}
.staff-container .grid-item .img {
    width: var(--team-img-size);
    height: var(--team-img-size);
    margin-top: calc(var(--team-img-size) * -.5);
    border: 1px solid var(--content-border-color);
    background: var(--light);
    margin-left: 2rem;
    border-radius: var(--border-radius);
    background-size: cover;
    background-position: 50%;
  transition: transform .5s ease;
}

.staff-container .grid-item:hover .img {
    transform: translateY(-0.5rem);
    transition: transform .5s ease;
}
.staff-container .grid-item .text {
  padding: 2rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.staff-container h5 {
    margin: 0 0 .5rem;
    color: var(--primary);
    /* text-transform: uppercase; */
    font-family: var(--font-heading);
}
.staff-container h5 i {
  margin: 0 0.5rem 0 0;
}
.staff-container h6 {
  color: var(--darkmode-text);
}
.staff-container .grid-item h6 {
  margin: 0 0 1rem 0;
}
.staff-container .grid-item ul {
  margin: 0 0 1rem 0
}
.staff-container .grid-item ul li {
}
.staff-container .grid-item ul li i {
  color: var(--secondary);
  margin: 0 0.5rem 0 0;
}
.staff-container .grid-item .site-btn {
  margin-top: auto;
}
.staff-container .team-bio {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vw;
  z-index: 100;

}
.staff-container .team-bio-flexbox {
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(37, 37, 41, 0.66);
  display: flex;
  justify-content: center;
  align-items: center;
}
.staff-container .team-bio-text {
  background: var(--ultralight);
  padding: 3rem;
  width: 75vw;
  height: auto;
  max-height: 75vh;
  overflow: scroll;
  position: relative;
  -ms-overflow-style: none;
  scrollbar-width: none;
  border-radius: var(--border-radius);
  color: var(--darkmode-text);
}
.staff-container .team-bio-text::-webkit-scrollbar {
  display: none;
}
.staff-container .team-bio-text .team-img-container {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.staff-container .team-bio-text .team-bio-name {
  display: block;
}
.staff-container .team-bio-text .img {
  width: var(--team-img-size);
  height: var(--team-img-size);
  background: var(--ultralight);
  border-radius: var(--border-radius);
  margin: 0 2rem 0 0;
  background-size: cover;
  background-position: center;
}
.staff-container .window-close {
  color: var(--primary);
  border-radius: 0 calc(var(--border-radius) - 2px) 0 calc(var(--border-radius) - 2px);
  width: 4rem;
  height: 4rem;
  top: 1px;
  right: 1px;
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.staff-container .window-close:hover {
  background: var(--light);
}
.staff-container .window-close i {
  font-size: 2.5rem;
}

/* Before You Go Modal */
.before-you-go-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.3);
  z-index: 999999;
  display: none
}

.before-you-go-modal > .inner {
  background: var(--primary);
 /* background-image: url(/wp-content/uploads/2023/08/home-banner-image.webp);*/
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  height: calc(100% - 30rem);
  width: calc(100% - 7rem);
  max-width: 66rem;
  margin: auto;
  border-radius: var(--border-radius); 
  display: flex;
  flex-direction: column;
  padding: 3rem;
  gap: .5rem;
  position: relative;
  justify-content: center;
  align-items: center;
  min-height:30rem;
}

.before-you-go-modal > .inner:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--border-radius);
}

.before-you-go-modal.has-image > .inner:before {
  background: rgb(0 0 0 / 49%);
}

.before-you-go-modal > .inner .close-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 2rem;
  color: var(--ultralight);
  cursor: pointer;
  z-index: 2;
}

.before-you-go-content {
  height: 100%;
  align-items: center;
  z-index: 1;
}

.before-you-go-modal .gform_title {
  display: none !important;
}

.before-you-go-modal .headline,
.before-you-go-modal .subheadline,
.before-you-go-modal .text {
  color: #fff;
  text-shadow: 1px 1px 0 rgba(33,33,33,.66);
  width: 100%;
}

/* .before-you-go-modal .before-you-go-content .site-form .gform_footer {
  padding: 0;
  margin: 0;
} */

@media ( max-width: 62rem ) {
  .before-you-go-modal > .inner {
    width: calc(100% - 3rem); 
  }
}

.before-you-go-modal .inner .before-you-go-modal-content {
  flex: 1 1;
  overflow: auto
}

.before-you-go-modal .inner .before-you-go-modal-footer {
  flex-shrink: 1
}

.menu-header-menu-container {
    height: 100%;
}

.carousel h2 span, .carousel h3 span {
  padding: .125rem 0;
  background: 0 0;
}

.carousel-slide-content p {
    font-size: 1.3rem;
}

.contact-box {
    background: var(--ultralight);
    padding: 2rem;
    border-radius: var(--border-radius);
  border: 1px solid var(--content-border-color);
}

span#input_1_7_6_container {
    margin-bottom: 0;
}

.carousel-slide-content h2 {
    font-size: 2.5rem;
    color: #fff!important;
    line-height: 2.75rem;
}

.carousel .site-btn {
    margin-top: 1rem;
}

.entry-content img:not(.cta-outer img), main#content img:not(.cta-outer img) {
    border-radius: var(--border-radius);
    width: 100%;
}

.before-you-go-content.site-grid h4.subheadline {
    font-size: 1.2rem;
    color: var(--secondary);
  text-wrap: balance;
}

.before-you-go-content.site-grid p.text {
    text-wrap: balance;
}

.before-you-go-content.site-grid h3.headline {
    font-size: 2.5rem;
    color: #fff;
  text-wrap: balance;
}

.before-you-go-content.site-grid .site-form {
    background: #00000061;
    padding: 2rem 3rem 1rem 3rem;
    border-radius: var(--border-radius);
    width: 80%;
    place-self: center;
    justify-self: center;
}

h3.form-popup {
    color: #fff;
    font-size: 1.4rem;
    text-align: center;
    margin-bottom: 0;
  text-wrap: balance;
}

.before-you-go-content.site-grid .content .site-btn {
    margin-top: 1rem;
}

div#input_4_8 {
    display: flex;
    gap: 1rem;
}

fieldset#field_4_8 {
    background: #fff;
    padding: 1rem;
    border-radius: var(--border-radius);
    border: 1px solid var(--med);
}

div.wp-caption {
    background: var(--ultralight);
    padding: 0 0 1rem 0;
    border-radius: 0 0 var(--border-radius) var(--border-radius);
  width: 100%!important;
}

p.wp-caption-text {
    padding: 0rem 1rem;
    font-size: 0.8rem;
    font-style: italic;
}

div.wp-caption img {
    border-radius: var(--border-radius) var(--border-radius) 0 0!important;
}

.home-banner-hero-slideshow span.space {
  width: .6rem;
}

.site-nav-menu .top-cta {
  display: none;
  padding: 0 1rem;
}

@media ( max-width: 62rem ) {
  .site-nav-menu .top-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 1rem;
  }
  
  .site-nav-menu .top-cta .site-btn {
    width: 100%;
  }
  
  .site-nav-menu .top-cta .site-btn > a {
    display: flex;
  }
}

.site-nav-menu #header-menu-mobile {
  padding-top: 0;
}
@media ( min-width: 62rem ) {
  .site-nav-menu #header-menu-mobile {
    display: none;
  }
}

#header-menu-mobile.icon-direction-left a {
  flex-direction: row-reverse;
  justify-content: start;
  gap: 1rem;
  padding-left: 0;
}

#header-menu-mobile a {
  color: #d3d3d3;
}

#header-menu-mobile a i {
  font-weight: 700;
  color: var(--secondary);
}

@media ( max-width: 640px ) {
  .gform_wrapper.gravity-theme .ginput_complex span:last-child {
    margin-bottom: 0 !important;
  } 
  .gform_wrapper.gravity-theme .ginput_complex span {
    margin-bottom: 1rem !important;
  }
}

.meta .pinned-post {
  position: absolute;
  top: 20px;
  left: 20px;
}

@media ( max-width: 768px ) {
  .home #l10-post-widget .posts ul,
  .home #l10-post-widget .posts .post-list[data-columns] ul {
    grid-template-columns: 1fr;
  }
}

/* @media (min-width: 62rem) and (max-width: 1360px) {
.site-nav-menu>ul>li.grid-menu.active>.cta-menu-container { 
    width: 118%;
  }
} */

.menu-cta .site-btn {
  margin: 0 0.5rem;
}

hr.short {
    width: 8rem;
    background: var(--secondary);
    height: 2px;
    margin: 2rem 0;
}

.entry-content h1, main#content h1 {
    font-weight: 700;
    font-size: 2.1rem;
}

@media ( max-width: 62rem ) {
  .entry-content h1, main#content h1 {
    font-size: 1.7rem;
  }
}

.home-map .map h3.headline-align-right br {
    display: block;
}

.home-map .map h3.headline-align-left br {
    display: block;
}

.entry-content iframe:not(.map iframe), main#content iframe:not(.map iframe) { 
  width: 100%;
  border-radius: var(--border-radius);
  margin-top: 1rem;
  margin-bottom: 1rem;
}

p + h4 {
  margin-top: 2rem;
}

@keyframes scale {
  100% {
    transform: scale(1);
  }
}

@keyframes fade-in {
  100% {
    opacity: 1;
    filter: blur(0);
  }
}

.carousel[data-slide-animation="fade"]:not(.loaded) .carousel-slide:first-child h2 > span,
.carousel[data-slide-animation="fade"]:not(.loaded) .carousel-slide:first-child p {
	animation-name: none !important;
	opacity: 1;
	filter: none;
}

.carousel[data-slide-animation="fade"] .carousel-slide.active h2 > span {
  animation-name: fade-in;
}

.carousel[data-slide-animation="fade"] .carousel-slide-content p {
  opacity: 0;
  animation-delay: 0.2s;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(0.11, 0, 0.5, 0);
  filter: blur(2px);
}

.carousel[data-slide-animation="fade"] .carousel-slide.active p {
  animation-name: fade-in;
}

.carousel-slide-content h2 > span {
  animation-name: none;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(0.11, 0, 0.5, 0);
  opacity: 0;
  filter: blur(2px);
}

.carousel-slide-content h2 > span:nth-child(1) {
  animation-delay: 1s;
}

.carousel-slide-content h2 > span:nth-child(2) {
  animation-delay: 1.1s;
}

.carousel-slide-content h2 > span:nth-child(3) {
  animation-delay: 1.2s;
}

.carousel-slide-content h2 > span:nth-child(4) {
  animation-delay: 1.3s;
}

.carousel-slide-content h2 > span:nth-child(5) {
  animation-delay: 1.4s;
}

.carousel-slide-content h2 > span:nth-child(6) {
  animation-delay: 1.5s;
}

.carousel-slide-content h2 > span:nth-child(7) {
  animation-delay: 1.6s;
}

.carousel-slide-content h2 > span:nth-child(8) {
  animation-delay: 1.7s;
}

.carousel-slide-content h2 > span:nth-child(9) {
  animation-delay: 1.8s;
}

.carousel-slide-content h2 > span:nth-child(10) {
  animation-delay: 1.9s;
}

.carousel-slide-content h2 > span:nth-child(11) {
  animation-delay: 2s;
}

.carousel-slide-content h2 > span:nth-child(12) {
  animation-delay: 2.1s;
}

.carousel-slide-content h2 > span:nth-child(13) {
  animation-delay: 2.2s;
}

.carousel-slide-content h2 > span:nth-child(14) {
  animation-delay: 2.3s;
}

.carousel-slide-content h2 > span:nth-child(15) {
  animation-delay: 2.4s;
}

.carousel-slide-content h2 > span:nth-child(16) {
  animation-delay: 2.5s;
}

.carousel-slide-content h2 > span:nth-child(17) {
  animation-delay: 2.6s;
}

.carousel-slide-content h2 > span:nth-child(18) {
  animation-delay: 2.7s;
}

.carousel-slide-content h2 > span:nth-child(19) {
  animation-delay: 2.8s;
}

.carousel-slide-content h2 > span:nth-child(20) {
  animation-delay: 2.9s;
}

.carousel-slide-content h2 > span:nth-child(21) {
  animation-delay: 3s;
}

.carousel-slide-content h2 > span:nth-child(22) {
  animation-delay: 3.1s;
}

.carousel-slide-content h2 > span:nth-child(23) {
  animation-delay: 3.2s;
}

.carousel-slide-content h2 > span:nth-child(24) {
  animation-delay: 3.3s;
}

.carousel-slide-content h2 > span:nth-child(25) {
  animation-delay: 3.4s;
}

.carousel-slide-content h2 > span:nth-child(26) {
  animation-delay: 3.5s;
}

.carousel-slide-content h2 > span:nth-child(27) {
  animation-delay: 3.6s;
}

.carousel-slide-content h2 > span:nth-child(28) {
  animation-delay: 3.7s;
}

.carousel-slide-content h2 > span:nth-child(29) {
  animation-delay: 3.8s;
}

.carousel-slide-content h2 > span:nth-child(30) {
  animation-delay: 3.9s;
}

.carousel-slide-content h2 > span:nth-child(31) {
  animation-delay: 4s;
}

.carousel-slide-content h2 > span:nth-child(32) {
  animation-delay: 4.1s;
}

.carousel-slide-content h2 > span:nth-child(33) {
  animation-delay: 4.2s;
}

.carousel-slide-content h2 > span:nth-child(34) {
  animation-delay: 4.3s;
}

.carousel-slide-content h2 > span:nth-child(35) {
  animation-delay: 4.4s;
}

.carousel-slide-content h2 > span:nth-child(36) {
  animation-delay: 4.5s;
}

.carousel-slide-content h2 > span:nth-child(37) {
  animation-delay: 4.6s;
}

.carousel-slide-content h2 > span:nth-child(38) {
  animation-delay: 4.7s;
}

.carousel-slide-content h2 > span:nth-child(39) {
  animation-delay: 4.8s;
}

.carousel-slide-content h2 > span:nth-child(40) {
  animation-delay: 4.9s;
}

.carousel-slide-content h2 > span:nth-child(41) {
  animation-delay: 5s;
}

.carousel-slide-content h2 > span:nth-child(42) {
  animation-delay: 5.1s;
}

.carousel-slide-content h2 > span:nth-child(43) {
  animation-delay: 5.2s;
}

.carousel-slide-content h2 > span:nth-child(44) {
  animation-delay: 5.3s;
}

.carousel-slide-content h2 > span:nth-child(45) {
  animation-delay: 5.4s;
}

.carousel-slide-content h2 > span:nth-child(46) {
  animation-delay: 5.5s;
}

.carousel-slide-content h2 > span:nth-child(47) {
  animation-delay: 5.6s;
}

.carousel-slide-content h2 > span:nth-child(48) {
  animation-delay: 5.7s;
}

.carousel-slide-content h2 > span:nth-child(49) {
  animation-delay: 5.8s;
}

.carousel-slide-content h2 > span:nth-child(50) {
  animation-delay: 5.9s;
}

.home-map.column-full .site-grid {
  grid-template-columns: repeat( 1, 1fr );
}

.home-map.column-full .site-grid .map {
  min-height: 600px;
  max-height: 34rem;
}

.home-map.layout-map-only {
  padding: 0;
}

.mini-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 2rem;
  background: var(--ultralight);
  border-radius: var(--border-radius);
  border: 1px solid var(--content-border-color);
}

.site-grid.site-grid--3x1.mini-cta-grid {
    margin-top: 2rem;
}

.mini-cta i {
  font-size: 3rem;
  color: var(--primary);
  display: block;
  font-weight: 900;
}

.mini-cta hr {
  margin: 1rem 0;
}

.mini-cta h3 {
  padding: 0;
  margin: 0 0 1rem 0;
}

.mini-cta .site-btn {
  padding: 0;
  margin: 0;
}

.home.home-banner-centered-logo .site-header-menu-row.stuck .logo img {
    display: block;
}

@media ( min-width: 62rem ) {
  .home.home-banner-centered-logo .stuck .phone .label {
      color: var(--primary);
  }
}

h1.entry-title.h4 {
    font-size: 1.5rem!important;
    font-weight: 500!important;
}

.site-grid.reviews-grid {
  grid-template-columns: repeat( auto-fit,minmax(22rem,1fr) )
}

.gchoice {
    background: var(--light);
    padding: 0 .5rem;
    border: 1px solid var(--light);
    border-radius: var(--border-radius);
}

hr.highlight {
    margin: 2rem 0;
}

.home .site-nav-menu>ul>li.active>a {
    color: white!important;
}

.site-grid.reviews-grid .grid-item:hover {
    transition: transform .5s ease;
    transform: translateY(-.5rem);
}

.icon-cta-box:hover .icon-cta-box--icon {
    background: var(--primary-hover);
    transition: background .5s ease;
}

.mini-cta:hover .icon {
    transform: translateY(-.5rem);
    transition: transform .5s ease;
}

.mini-cta .icon {
    transition: transform .5s ease;
}

h3.h4.headline-align-left span {
    border-radius: 0 var(--border-radius) var(--border-radius)var(--border-radius);
}

h3.h4.headline-align-left span:first-child {
    border-radius: var(--border-radius) var(--border-radius) 0 0;
}

h3.h4.headline-align-right span {
    border-radius: var(--border-radius) 0px var(--border-radius) var(--border-radius);
}

h3.h4.headline-align-right span:first-child {
    border-radius: var(--border-radius) var(--border-radius) 0px 0px;
}

aside .sidebar-container .widget-area h3 {
    font-size: 1.3rem;
}

.image-card .image-card--image {
  position: relative;
  overflow: hidden;
}
.image-card .image-card--image::before {
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
  content: "";
  display: block;
  height: 100%;
  left: -75%;
  position: absolute;
  top: 0;
  transform: skewX(-25deg);
  width: 50%;
  z-index: 2;
}
.image-card:hover .image-card--image::before, .image-card:focus .image-card--image::before {
  -webkit-animation: shine 0.85s;
          animation: shine 0.85s;
}

.image-card.single.horizontal .image-card--content {
  justify-content: center;
}

@media (min-width: 62rem) {
  .image-card.single.horizontal {
    display: grid;
    grid-template-columns: 20% 80%;
  }
  .image-card.single.horizontal.image-right {
    grid-template-columns: 80% 20%;
  }
  .image-card.single.horizontal.image-right .image-card--image {
    order: 1;
  }
  .image-card.single.horizontal .image-card--image {
    height: 100%;
    width: 100%;
    max-height: 100%;
  }
  .image-card.single.horizontal .image-card--image img {
    object-fit: cover;
    height: 100%;
    width: 100%;
    max-height: 100%;
    border-radius: var(--border-radius) 0px 0px var(--border-radius)!important;
  }
}

@-webkit-keyframes shine {
  100% {
    left: 125%;
  }
}
@keyframes shine {
  100% {
    left: 125%;
  }
}

.icon-cta-box + .icon-cta-box { 
    margin-top: 3rem; 
}
.icon-cta-box + div + .icon-cta-box {
    margin-top: 3rem;
}

.icon-cta-box h2 {
    font-weight: 500!important;
}

.cta--content h3 {
    max-width: 43rem!important;
}

.highlight-box+p,
.icon-cta-box+p {
    margin-top: 2rem;
}

.site-accordion .title { 
    text-transform: capitalize; 
}

h5.review-title {
    font-weight: 500!important;
}

#momnt-widget-branded-container {
  display: none !important;
}

.badge-cta {
  background: var(--ultralight);
  display: grid;
  grid-template-columns: 20% 70%;
  align-items: center;
  gap: 2rem;
  padding: 2rem;
  margin-top: 2rem;
  border-radius: var(--border-radius);
  border: 1px solid var(--content-border-color);
}

.badge-cta.no-image {
  grid-template-columns: 1fr;
}

.badge-cta .badge-image {
  text-align: center;
}

.badge-cta .badge-image img {
  max-width: 10rem;
}

@media (max-width: 62rem) {
  .badge-cta {
    display: block;
  }
  .badge-cta .badge-image {
    margin-bottom: 2rem;
  }
}

.badge-cta+p {
    margin-top: 2rem;
}

.entry-content div+.site-btn:not(.site-btn.review-read-more) {
    margin-top: 2rem!important;
}

.cta-outer .site-btn a {
    background: var(--secondary);
    color: #000;
    border: none;
}

.entry-content .site-btn.icon-right a {
    background: var(--secondary);
    color: black;
    border: none;
}

.entry-content ul.x li::marker, main#content ul.x li::marker {
    content: "✖";
    color: var(--primary);
}

@media ( max-width: 48rem ) {
  .site-breadcrumbs nav::before {
    content: none;
  }
}

.page-id-75 .cta-outer, .page-id-75 hr.cta_hr {
    display: none;
}

.blog.index .site-grid .site-featured-img { 
    border-radius: 0;
} 

.blog.index .site-grid .site-featured-img img { 
    border-radius: 0!important;
} 

div#l10-post-widget .site-featured-img {
    border-radius: 0;
}

@media ( max-width: 48rem ) {
  .home-banner.home-banner-centered-logo .headlines {
    background: none;
  }
  .home-banner.home-banner-centered-logo .img img {
    display: none;
  }
  
  .home-banner.home-banner-centered-logo .headlines .site-btn a:hover {
    background: var(--secondary-hover);
    border-color: var(--secondary-hover);
    color: #000;
  }
}

.single-service-areas .map, .single-service-areas .map iframe { 
    max-height: 30rem;
}

.no-full {
  position: relative !important;
}

@media ( min-width: 62rem ) {
  ul.yes-full {
    position: inherit;
  }
  ul.yes-full .cta-menu-container {
    margin-top: -1rem;
  }
}

.left--image .image-card--image,
.right--image .image-card--image {
    height: 100%;
    min-height: 100%;
}

.left--image,
.right--image {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 20rem;
}

.right--image .image-card--image {
    order: 1;
}

@media (max-width: 48rem) {
    .left--image,
    .right--image {
        display: block;
        
    }
    .right--image .image-card--image {
        order: 0;
    }
}

.image-card.single.left--image img {
    height: 100%;
}
.image-card.single.right--image img {
    height: 100%;
}
.image-card.single.left--image img { 
    height: 100%; 
    border-radius: var(--border-radius) 0 0 var(--border-radius) !important;
}

.image-card.single.left--image img {
    height: 100%;
    border-radius: var(--border-radius) 0 0 var(--border-radius) !important;
}
@media ( max-width: 48rem ) {
  .image-card.single.left--image img { 
      border-radius: var(--border-radius) var(--border-radius) 0px 0px!important;
  }
}

.image-card.single.right--image img { 
    height: 100%; 
    border-radius: 0px var(--border-radius) var(--border-radius) 0px;
}

@media ( max-width: 48rem ) {
  .image-card.single.right--image img { 
      border-radius: var(--border-radius) var(--border-radius) 0px 0px!important;
  }
}

.entry-content ul.bullet li::marker, main#content ul.bullet li::marker {
    content: "•";
}

.home-banner.home-banner-centered-logo .text {
    background: #0000004f;
}

.home-banner.home-banner-centered-logo .logo .img-wrap img {
    filter: drop-shadow(-2px 2px 22px white);
	padding: 2rem;
}

a.return-to-top{
    -webkit-animation: 2s ease 0s normal forwards 1 fadein2;
    animation: 2s ease 0s normal forwards 1 fadein2;
}

@keyframes fadein2{
    0% { opacity:0; }
    66% { opacity:0; }
    100% { opacity:1; }
}

@-webkit-keyframes fadein2{
    0% { opacity:0; }
    66% { opacity:0; }
    100% { opacity:1; }
}

:target:not(div):before{
    -webkit-animation: 2s ease 0s normal forwards 1 fadein;
    animation: 2s ease 0s normal forwards 1 fadein;
}

@keyframes fadein{
    0% { opacity:0; }
    66% { opacity:1; }
    100% { opacity:0; }
}

@-webkit-keyframes fadein{
    0% { opacity:0; }
    66% { opacity:1; }
    100% { opacity:0; }
}

a.return-to-top {
    color: var(--secondary);
    font-size: .9rem;
    text-decoration: underline;
    position: relative;
    bottom: -1rem;
	display: block;
	z-index:99;
}

a.return-to-top:before {
    content: "↑ ";
}

a.return-to-top:after {
    font-size: 1rem;
}

.entry-content ul.x li::marker, main#content ul.x li::marker { 
    content: "✗"; 
    font-size: 1.4rem; 
    color: var(--secondary); 
    font-weight: 700; 
}

/* .home #l10-post-widget .post-list ul>li {
  position: relative
}

.home #l10-post-widget .site-featured-img + .text > .meta .page-views {
  position: absolute;
  top: 20px;
  right: 20px;
  color: #fff
}

.home #l10-post-widget .site-featured-img + .text > .meta .page-views i {
  color: #fff
} */

/*	end media queries
    --------------------------------------------------------------------------	*/

/* */
/* */
/* */
/* */

/*	end file
    --------------------------------------------------------------------------	*/
