@charset "UTF-8";
/* -----------------------------------------------------------------------------
imarketsolutions.com 
Stylesheet: Home.css
Created: 8/28/2013
Author:  Jess Klein
Updated: 12/13/2020
Version: 2.0.4
Organization:	iMarket Solutions
----------------------------------------------------------------------------- */
html {
  font-size: 62.5%;
  /* Sets up the Base 10 stuff */
}

#masthead,
#fixed-masthead {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -moz-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}

#promotions-secondary li a, #main-container > .width-limiter, #main-content-wrap > .width-limiter,
#top-content-wrap > .width-limiter, .footer-main-inner, #home-main-content > .width-limiter {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  align-items: stretch;
  -webkit-align-content: stretch;
  -moz-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
}

.affiliate-container, #page-heading .heading-container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -moz-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0;
}

*, *:before, *:after {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  background: transparent none repeat left top;
}

fieldset, a img {
  border: 0 solid transparent;
}

html, body {
  height: 100%;
}

body {
  font: 62.5%/1.8em Arial, 'Helvetica Neue', Helvetica, sans-serif;
  background-color: #FFF;
  text-align: left;
  min-width: 320px;
}

body.active-navigation {
  overflow: hidden;
}

body.mceContentBody {
  min-width: 0;
  background-color: #FFF;
}

#container-all {
  overflow: hidden;
  position: relative;
}

.width-limiter {
  max-width: 1250px;
  margin: 0 auto;
  width: calc(100% - 40px);
}

/*----- LAYOUTS - UNIVERSAL RESET ----- */
@media all and (max-width: 800px) {
  /*prevent automatic landscape orientation zoom on iOS devices */
  html {
    -webkit-text-size-adjust: 100%;
  }
}

@media all and (max-width: 570px) {
  .width-limiter {
    width: calc(100% - 30px);
  }
}

#access_key, .access_key {
  text-align: center;
}

#accessibility {
  position: absolute;
  left: -999em;
}

html {
  font-size: 62.5%;
}

body {
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  color: #222;
  line-height: 1.3;
  text-align: left;
}

@media all and (max-width: 1024px) {
  body {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 800px) {
  body {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media all and (max-width: 570px) {
  body {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  line-height: 1.15;
  margin: 1.2em 0 0.7em;
}

.h1, .h2, .h3, .h4, .h5, .h6 {
  display: block;
}

h1, .h1 {
  font-family: "Roboto", sans-serif;
  font-size: 45px;
  font-size: 4.5rem;
  color: #29377E;
  font-weight: 700;
  line-height: 56px;
  font-style: normal;
  text-transform: none;
}

@media all and (max-width: 1024px) {
  h1, .h1 {
    font-size: 40px;
    font-size: 4rem;
    line-height: 50px;
  }
}

@media all and (max-width: 800px) {
  h1, .h1 {
    font-size: 35px;
    font-size: 3.5rem;
    line-height: 45px;
  }
}

@media all and (max-width: 570px) {
  h1, .h1 {
    font-size: 30px;
    font-size: 3rem;
    line-height: 40px;
  }
}

h2, .h2 {
  font-family: "Roboto", sans-serif;
  font-size: 34px;
  font-size: 3.4rem;
  color: #29377E;
  font-weight: 700;
  line-height: 36px;
  font-style: normal;
  text-transform: none;
}

@media all and (max-width: 1024px) {
  h2, .h2 {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  h2, .h2 {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  h2, .h2 {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

h3, .h3 {
  font-family: "Roboto", sans-serif;
  font-size: 25px;
  font-size: 2.5rem;
  color: #29377E;
  font-weight: 700;
  line-height: 28px;
  font-style: normal;
  text-transform: none;
}

@media all and (max-width: 1024px) {
  h3, .h3 {
    font-size: 28px;
    font-size: 2.8rem;
  }
}

@media all and (max-width: 800px) {
  h3, .h3 {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

@media all and (max-width: 570px) {
  h3, .h3 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

h4, .h4 {
  font-family: "Roboto", sans-serif;
  font-size: 24px;
  font-size: 2.4rem;
}

@media all and (max-width: 1024px) {
  h4, .h4 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  h4, .h4 {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  h4, .h4 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

h5, .h5 {
  font-family: "Roboto", sans-serif;
  font-size: 20px;
  font-size: 2rem;
}

@media all and (max-width: 1024px) {
  h5, .h5 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

@media all and (max-width: 800px) {
  h5, .h5 {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 570px) {
  h5, .h5 {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

h6, .h6 {
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
}

@media all and (max-width: 1024px) {
  h6, .h6 {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 800px) {
  h6, .h6 {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media all and (max-width: 570px) {
  h6, .h6 {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

#home-top-content h1:first-of-type {
  margin-top: 0;
}

p, li {
  font-size: 18px;
  font-size: 1.8rem;
  color: #222;
  line-height: 1.5;
  margin-bottom: 1.3em;
  box-sizing: border-box;
}

@media all and (max-width: 570px) {
  p, li {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

li {
  margin-bottom: .5em;
}

span,
blockquote {
  font-size: 18px;
  font-size: 1.8rem;
}

@media all and (max-width: 570px) {
  span,
  blockquote {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

address {
  font-size: 12px;
  font-size: 1.2rem;
  font-style: normal;
  margin-bottom: 1.5em;
}

blockquote {
  margin: 0 .6em;
}

iframe {
  border: none;
  position: relative;
  z-index: 1;
}

blockquote p {
  margin-bottom: 0.75em;
}

blockquote .source {
  font-size: 1.2em;
}

ul, ol {
  padding: 0 0 1.8em 3.6em;
  color: #222;
}

ul ul, ul ol, ol ul, ol ol {
  padding-bottom: 0;
}

li li, li p {
  font-size: 14px;
  font-size: 1.4rem;
}

dl {
  padding: 0 0 1.8em 0;
}

dt {
  font-size: 13px;
  font-size: 1.3rem;
  font-weight: 700;
}

dd {
  font-size: 13px;
  font-size: 1.3rem;
  padding: 0 0 1.5em 3.6em;
}

dd ul, dd ol {
  padding-left: 0;
}

dd * {
  font-size: 14px;
  font-size: 1.4rem;
}

.publication_name {
  font-style: italic;
}

.footnote {
  font-size: 13px;
  font-size: 1.3rem;
}

#access_key, .access_key {
  text-align: center;
}

strong {
  font-weight: 700;
}

input[type="text"],
textarea,
select {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 400;
}

p, li, span {
  font-family: "Roboto", sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.5;
}

@media all and (max-width: 1024px) {
  p, li, span {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 800px) {
  p, li, span {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media all and (max-width: 570px) {
  p, li, span {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

small {
  font-family: "Roboto", sans-serif;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 400;
}

a {
  font-size: 18px;
  font-size: 1.8rem;
  color: #0086b6;
  font-weight: 400;
  -webkit-transition: all 0.2s ease;
  -o-transition: all 0.2s ease;
  transition: all 0.2s ease;
}

@media all and (max-width: 1024px) {
  a {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 800px) {
  a {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media all and (max-width: 570px) {
  a {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

a:link, a:visited {
  color: #0086b6;
  text-decoration: underline;
}

a:hover, a:active {
  color: #C31921;
  text-decoration: none;
}

#home-top-content li,
#home-main-content li,
#top-content li,
#main-content li {
  margin-bottom: .5em;
}

.slick-dots li {
  font-size: 1px;
}

form label {
  font-family: "Roboto", sans-serif;
}

form input[type="text"],
form textarea,
form option {
  font-family: "Roboto", sans-serif;
  color: #222;
}

form input[type="submit"],
form button {
  font-family: "Roboto", sans-serif;
  font-size: 17px;
  font-size: 1.7rem;
  color: #fff;
  font-weight: 700;
  text-align: center;
  font-style: normal;
  text-transform: none;
  text-shadow: none;
}

form input[type="submit"]:hover, form input[type="submit"]:active,
form button:hover,
form button:active {
  color: #fff;
}

form .submit {
  text-align: center;
}

form fieldset input[type="text"],
form fieldset textarea,
form fieldset select,
#top-content form fieldset ul li input[type="text"],
#top-content form fieldset ul li textarea,
#top-content form fieldset ul li select,
#main-content form fieldset ul li input[type="text"],
#main-content form fieldset ul li textarea,
#main-content form fieldset ul li select {
  font-family: "Roboto", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  color: #222;
}

input[type="submit"],
button,
#top-content form fieldset ul li input[type="submit"],
#main-content form fieldset ul li input[type="submit"],
#top-content form fieldset ul li button,
#main-content form fieldset ul li button {
  font-family: "Roboto", sans-serif;
  font-size: 21px;
  font-size: 2.1rem;
  color: #fff;
  font-weight: 700;
}

input[type="submit"]:hover, input[type="submit"]:active,
button:hover,
button:active,
#top-content form fieldset ul li input[type="submit"]:hover,
#top-content form fieldset ul li input[type="submit"]:active,
#main-content form fieldset ul li input[type="submit"]:hover,
#main-content form fieldset ul li input[type="submit"]:active,
#top-content form fieldset ul li button:hover,
#top-content form fieldset ul li button:active,
#main-content form fieldset ul li button:hover,
#main-content form fieldset ul li button:active {
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.5);
}

#top-content ul li label,
#top-content ul li p.label-heading,
#main-content ul li label,
#main-content ul li p.label-heading,
#top-content ul li span.wrapper label,
#main-content ul li span.wrapper label,
#top-content ul li span.note,
#main-content ul li span.note {
  font-size: 16px;
  font-size: 1.6rem;
}

.phone-number {
  font-family: "Roboto", sans-serif;
  font-size: 48px;
  font-size: 4.8rem;
  font-weight: 700;
  text-align: right;
  font-style: normal;
  white-space: nowrap;
  margin: 0;
}

@media all and (max-width: 1024px) {
  .phone-number {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  .phone-number {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  .phone-number {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.phone-number a {
  font-size: 48px;
  font-size: 4.8rem;
  font-weight: 700;
  font-style: normal;
  text-decoration: none;
}

@media all and (max-width: 1024px) {
  .phone-number a {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  .phone-number a {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  .phone-number a {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.phone-number a:link, .phone-number a:visited {
  color: #C31921;
  text-decoration: none;
}

.phone-number a:hover, .phone-number a:active {
  color: #C31921;
}

#contact .widget-heading,
.sidebar-right #mini-form .widget-heading {
  font-size: 43px;
  font-size: 4.3rem;
  color: #fff;
  text-align: left;
  margin-top: 0;
}

@media all and (max-width: 1024px) {
  #contact .widget-heading,
  .sidebar-right #mini-form .widget-heading {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  #contact .widget-heading,
  .sidebar-right #mini-form .widget-heading {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  #contact .widget-heading,
  .sidebar-right #mini-form .widget-heading {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

#mini-form label,
#mini-form .label-heading {
  font-size: 18px;
  font-size: 1.8rem;
  color: #fff;
  font-weight: 400;
  text-align: left;
}

@media all and (max-width: 1024px) {
  #mini-form label,
  #mini-form .label-heading {
    font-size: 17px;
    font-size: 1.7rem;
  }
}

@media all and (max-width: 800px) {
  #mini-form label,
  #mini-form .label-heading {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media all and (max-width: 570px) {
  #mini-form label,
  #mini-form .label-heading {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

a {
  color: #0086b6;
}

a a {
  color: #0086b6;
}

a a:visited {
  color: #0086b6;
}

a a:hover {
  color: #C31921;
}

a a:active {
  color: #C31921;
}

a:link, a:visited {
  text-decoration: underline;
}

caption {
  font-size: 12px;
  font-size: 1.2rem;
  color: #222;
  line-height: 1.5;
  text-align: center;
  font-style: italic;
}

td, th {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
}

th {
  font-weight: 700;
}

tfoot td {
  line-height: 1.5;
}

tfoot li {
  font-size: 10px;
  font-size: 1rem;
}

.tagline {
  font-size: 15px;
  font-size: 1.5rem;
  color: #222;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}

.phone-container {
  text-align: center;
}

.phone-text {
  font-size: 16px;
  font-size: 1.6rem;
}

#masthead .phone-number,
#fixed-masthead .phone-number {
  font-size: 45px;
  font-size: 4.5rem;
  font-weight: 700;
}

#masthead .phone-number a:link, #masthead .phone-number a:visited,
#fixed-masthead .phone-number a:link,
#fixed-masthead .phone-number a:visited {
  color: #29377E;
}

#masthead .phone-number a:hover, #masthead .phone-number a:active,
#fixed-masthead .phone-number a:hover,
#fixed-masthead .phone-number a:active {
  color: #C31921;
}

#masthead .financing,
#fixed-masthead .financing {
  font-size: 15px;
  font-size: 1.5rem;
  text-align: center;
}

#masthead .financing a,
#fixed-masthead .financing a {
  color: #0086b6;
}

#masthead .financing a:visited,
#fixed-masthead .financing a:visited {
  color: #0086b6;
}

#masthead .financing a:hover,
#fixed-masthead .financing a:hover {
  color: #C31921;
}

#masthead .financing a:active,
#fixed-masthead .financing a:active {
  color: #C31921;
}

@media all and (max-width: 800px) {
  .js #toggle-navigation a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #C31921;
    font-weight: 700;
    text-transform: uppercase;
  }
  .js .active-navigation #toggle-navigation a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
  }
  #primary-navigation li,
  #primary-navigation li a,
  #primary-navigation li a span {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
  }
  #primary-navigation li,
  #primary-navigation li a:link,
  #primary-navigation li a:visited {
    color: #fff;
  }
  #primary-navigation li a:hover,
  #primary-navigation li a:active,
  #primary-navigation li.active > a,
  #primary-navigation ul li.nav-level-1 ul li a:hover,
  #primary-navigation ul li.nav-level-1 ul li a:active {
    color: #fff;
  }
  #primary-navigation li.current > a:link,
  #primary-navigation li.current > a:visited,
  #primary-navigation li.current > a:hover,
  #primary-navigation li.current > a:active {
    color: #C31921;
  }
  span.nav-expand {
    color: #fff;
  }
}

@media all and (min-width: 801px) {
  #primary-navigation li.nav-level-1 > a {
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
    font-weight: 400;
  }
  #primary-navigation li.nav-level-1 a > span {
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 700;
  }
  #primary-navigation li.nav-level-2 a,
  #primary-navigation li.nav-level-3 a,
  #primary-navigation li.nav-level-2 a span,
  #primary-navigation li.nav-level-3 a span {
    font-size: 14px;
    font-size: 1.4rem;
    color: #fff;
    font-weight: 700;
  }
}

#footer-navigation ul {
  text-align: left;
}

#footer-navigation ul li a:link, #footer-navigation ul li a:visited {
  color: #29377E;
  text-decoration: none;
}

#footer-navigation ul li a:hover, #footer-navigation ul li a:active {
  color: #29377E;
  text-decoration: underline;
}

#footer-navigation ul li span {
  font-size: 16px;
  font-size: 1.6rem;
}

#footer-navigation ul li::after {
  color: #fff;
}

@media all and (max-width: 800px) {
  #footer-navigation ul {
    text-align: center;
  }
}

#hero .hero-title {
  font-size: 60px;
  font-size: 6rem;
  color: #29377E;
  font-weight: 700;
  line-height: 1;
  text-align: left;
  font-style: normal;
  text-shadow: none;
  margin-top: 0;
  margin-bottom: 15px;
}

@media all and (max-width: 1024px) {
  #hero .hero-title {
    font-size: 40px;
    font-size: 4rem;
    line-height: 50px;
  }
}

@media all and (max-width: 800px) {
  #hero .hero-title {
    font-size: 35px;
    font-size: 3.5rem;
    line-height: 45px;
  }
}

@media all and (max-width: 570px) {
  #hero .hero-title {
    font-size: 30px;
    font-size: 3rem;
    line-height: 40px;
  }
}

#hero h4 {
  margin: 15px 0;
}

#page-heading h1 {
  font-size: 60px;
  font-size: 6rem;
  color: #fff;
  font-weight: 700;
  text-shadow: 1px 2px 10px rgba(0, 0, 0, 0.71);
  margin: 0;
  width: 100%;
}

@media all and (max-width: 1024px) {
  #page-heading h1 {
    font-size: 40px;
    font-size: 4rem;
    line-height: 50px;
  }
}

@media all and (max-width: 800px) {
  #page-heading h1 {
    font-size: 35px;
    font-size: 3.5rem;
    line-height: 45px;
  }
}

@media all and (max-width: 570px) {
  #page-heading h1 {
    font-size: 30px;
    font-size: 3rem;
    line-height: 40px;
  }
}

.phone-number {
  font-size: 60px;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  margin: 0;
}

.phone-number a:link, .phone-number a:visited {
  color: #29377E;
  text-decoration: none;
}

@media all and (max-width: 1024px) {
  .phone-number {
    font-size: 46px;
    font-size: 4.6rem;
  }
}

@media all and (max-width: 800px) {
  .phone-number {
    font-size: 40px;
    font-size: 4rem;
  }
}

@media all and (max-width: 570px) {
  .phone-number {
    font-size: 36px;
    font-size: 3.6rem;
  }
}

#masthead .phone-number {
  text-align: right;
}

@media all and (max-width: 800px) {
  #masthead .phone-number a:link, #masthead .phone-number a:visited {
    font-size: 24px;
    font-size: 2.4rem;
    color: #fff;
  }
}

#footer-main .tagline {
  font-size: 36px;
  font-size: 3.6rem;
  margin-bottom: 45px;
}

@media all and (max-width: 1024px) {
  #footer-main .tagline {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  #footer-main .tagline {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  #footer-main .tagline {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

#footer-main .phone-number {
  font-size: 24px;
  font-size: 2.4rem;
  text-align: center;
  text-decoration: none;
  margin-bottom: 20px;
}

@media all and (max-width: 1024px) {
  #footer-main .phone-number {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #footer-main .phone-number {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #footer-main .phone-number {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#footer-main .phone-number a {
  font-size: 24px;
  font-size: 2.4rem;
  text-align: center;
  text-decoration: none;
}

@media all and (max-width: 1024px) {
  #footer-main .phone-number a {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #footer-main .phone-number a {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #footer-main .phone-number a {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#footer-main .phone-number a:link, #footer-main .phone-number a:visited {
  color: #fff;
}

#footer-main .phone-number a:hover, #footer-main .phone-number a:active {
  text-decoration: none;
}

.widget-heading {
  font-size: 36px;
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
  margin-top: 0;
}

@media all and (max-width: 1024px) {
  .widget-heading {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  .widget-heading {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  .widget-heading {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.sidebar-right .widget-heading {
  font-size: 34px;
  font-size: 3.4rem;
  color: #29377E;
  font-weight: 700;
  text-align: center;
  text-shadow: none;
}

@media all and (max-width: 1024px) {
  .sidebar-right .widget-heading {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  .sidebar-right .widget-heading {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  .sidebar-right .widget-heading {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.sidebar-right .widget-heading.alt {
  font-size: 34px;
  font-size: 3.4rem;
  color: #fff;
  font-weight: 700;
  text-align: center;
  text-shadow: 0 3px 6px rgba(0, 0, 0, 0.56);
}

@media all and (max-width: 1024px) {
  .sidebar-right .widget-heading.alt {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  .sidebar-right .widget-heading.alt {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  .sidebar-right .widget-heading.alt {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.sidebar-right .widget-subheading {
  color: #fff;
  font-weight: 700;
  font-style: italic;
}

#footer-main .widget-heading {
  font-size: 24px;
  font-size: 2.4rem;
  color: #fff;
  font-weight: 700;
  text-align: center;
  text-shadow: none;
  margin-top: 0;
}

@media all and (max-width: 1024px) {
  #footer-main .widget-heading {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #footer-main .widget-heading {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #footer-main .widget-heading {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#footer-main .title {
  font-size: 36px;
  font-size: 3.6rem;
  color: #fff;
  font-weight: 700;
  text-align: center;
}

@media all and (max-width: 1024px) {
  #footer-main .title {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  #footer-main .title {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  #footer-main .title {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

.view-all {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 2.5;
  text-align: center;
  text-transform: uppercase;
}

.view-all a {
  text-decoration: none;
}

.view-all a:link, .view-all a:visited {
  color: #fff;
}

.view-all a:hover, .view-all a:active {
  color: #fff;
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.5);
}

.view-all a::after {
  font-size: 8px;
  font-size: 0.8rem;
  font-weight: 400;
  line-height: 1;
  font-style: normal;
}

.cta-button {
  font-size: 20px;
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
}

.cta-button a {
  font-size: 15px;
  font-size: 1.5rem;
  color: #fff;
  font-weight: 800;
  text-decoration: none;
}

.cta-button a span {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.2;
}

.cta-button a:hover, .cta-button a:active {
  text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.5);
}

#breadcrumbs-container span {
  font-size: 16px;
  font-size: 1.6rem;
}

.affiliations {
  text-align: center;
}

.affiliations li {
  text-align: center;
}

.affiliations li a {
  color: #000;
  text-decoration: none;
}

.affiliations li span.visible {
  font-size: 11px;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
}

#testimonials-secondary .widget-heading,
#testimonials-secondary .secondary-tools-heading {
  color: #fff;
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.56);
}

#testimonials-secondary .widget-heading,
#testimonials-secondary .widget-heading.alt {
  margin-bottom: 30px;
}

#testimonials-secondary .testimonial p {
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.5;
}

.nn-agg {
  text-align: center;
}

.nn-agg-rating {
  font-size: 20px;
  font-size: 2rem;
  color: #0086b6;
  font-weight: 700;
}

.nn-reviews {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
}

.nn-reviews a {
  color: #C31921;
}

.nn-reviews a:visited {
  color: #C31921;
}

.nn-reviews a:hover {
  color: #0086b6;
}

.nn-reviews a:active {
  color: #0086b6;
}

.nn-review-outer-cont,
.ims-recoomend-me-checkins div.nn-review-header h3,
.ims-recoomend-me-checkins div.nn-samap-header h3,
.ims-recoomend-me-checkins .nn-samap-near {
  font-size: 16px;
  font-size: 1.6rem;
}

.testimonial .read-more {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}

.source-info .source {
  font-size: 15px;
  font-size: 1.5rem;
}

.source-info .source .rating_output {
  font-size: 14px;
  font-size: 1.4rem;
  font-style: italic;
}

.source-image {
  font-size: 10px;
  font-size: 1rem;
}

#promotions-secondary li a .title {
  font-size: 36px;
  font-size: 3.6rem;
  color: #C31921;
  font-weight: 700;
  line-height: 1.1;
  font-style: normal;
}

@media all and (max-width: 1024px) {
  #promotions-secondary li a .title {
    font-size: 32px;
    font-size: 3.2rem;
  }
}

@media all and (max-width: 800px) {
  #promotions-secondary li a .title {
    font-size: 30px;
    font-size: 3rem;
  }
}

@media all and (max-width: 570px) {
  #promotions-secondary li a .title {
    font-size: 25px;
    font-size: 2.5rem;
  }
}

#promotions-secondary li a .teaser {
  font-size: 24px;
  font-size: 2.4rem;
  color: #222;
  font-weight: 700;
  line-height: 1.1;
  font-style: italic;
}

@media all and (max-width: 1024px) {
  #promotions-secondary li a .teaser {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #promotions-secondary li a .teaser {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #promotions-secondary li a .teaser {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#promotions-secondary li a:hover .title, #promotions-secondary li a:active .title {
  color: #fff;
}

#promotions-secondary li a:hover .teaser, #promotions-secondary li a:active .teaser {
  color: #fff;
}

.content-left #promotions-secondary .widget-heading {
  text-shadow: none;
}

#promotions .promotions-item,
#promotions .promotions-item .view-all,
.promotions-item-details-wrapper {
  text-align: center;
}

#promotions .promotions-item h2 a {
  text-decoration: none;
}

.promotions-item-details-wrapper h1 {
  font-size: 26px;
  font-size: 2.6rem;
}

@media all and (max-width: 1024px) {
  .promotions-item-details-wrapper h1 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  .promotions-item-details-wrapper h1 {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  .promotions-item-details-wrapper h1 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

.promotions-item-details-wrapper p {
  font-size: 18px;
  font-size: 1.8rem;
}

.promotions-item-details-wrapper p.promotions-content {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
}

.promotions-item-details-wrapper p.coupon-footer {
  font-size: 16px;
  font-size: 1.6rem;
}

#service-area-search p.search {
  font-size: 24px;
  font-size: 2.4rem;
  color: #fff;
  font-weight: 700;
  text-align: center;
}

@media all and (max-width: 1024px) {
  #service-area-search p.search {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #service-area-search p.search {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #service-area-search p.search {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#service-area-search form,
#service-area-secondary .map {
  text-align: center;
}

#service-area-list .service-cities li,
#service-area-towns-list .service-cities li {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: left;
}

#service-area-list .service-cities li a,
#service-area-towns-list .service-cities li a {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: left;
}

#service-area-list .service-cities li a:link, #service-area-list .service-cities li a:visited,
#service-area-towns-list .service-cities li a:link,
#service-area-towns-list .service-cities li a:visited {
  color: #C31921;
  text-decoration: underline;
}

#service-area-list .service-cities li a:hover, #service-area-list .service-cities li a:active,
#service-area-towns-list .service-cities li a:hover,
#service-area-towns-list .service-cities li a:active {
  color: #29377E;
  text-decoration: none;
}

.ims-recoomend-me-checkins h2 {
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
}

@media all and (max-width: 1024px) {
  .ims-recoomend-me-checkins h2 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  .ims-recoomend-me-checkins h2 {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  .ims-recoomend-me-checkins h2 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

#zips-secondary p {
  text-align: center;
}

#newsletter-signup {
  text-align: center;
}

#newsletter-signup .left {
  text-align: right;
}

#newsletter-signup .right {
  text-align: left;
}

#newsletter-signup p {
  font-size: 24px;
  font-size: 2.4rem;
  color: #fff;
  font-weight: 700;
}

@media all and (max-width: 1024px) {
  #newsletter-signup p {
    font-size: 22px;
    font-size: 2.2rem;
  }
}

@media all and (max-width: 800px) {
  #newsletter-signup p {
    font-size: 20px;
    font-size: 2rem;
  }
}

@media all and (max-width: 570px) {
  #newsletter-signup p {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

@media all and (max-width: 800px) {
  #newsletter-signup .left,
  #newsletter-signup .right {
    text-align: center;
  }
}

.staff-member-container .department-name,
.staff-member.without-bio,
.staff-member.preview {
  text-align: center;
}

@media all and (max-width: 570px) {
  .staff-member {
    text-align: center;
  }
  .staff-member.details {
    text-align: left;
  }
}

#wp-blog .navigation a {
  font-size: 15px;
  font-size: 1.5rem;
}

#footer-main {
  text-align: center;
}

#footer-main p {
  color: #fff;
}

#footer-main .financing a:link, #footer-main .financing a:visited {
  color: #fff;
}

#footer-main .financing a:hover, #footer-main .financing a:active {
  text-decoration: none;
}

#payments {
  text-align: center;
}

#footer-main .address span,
#footer-main .license,
#footer-main .copyright {
  font-size: 15px;
  font-size: 1.5rem;
}

#footer-main .address .extra-address {
  display: inline-block;
  margin-top: 15px;
}

.copyright span {
  font-size: 15px;
  font-size: 1.5rem;
}

#footer-navigation ul li,
#footer-navigation ul li a:link,
#footer-navigation ul li a:visited,
#footer-navigation ul li::after {
  font-size: 16px;
  font-size: 1.6rem;
  color: #29377E;
}

.imarket-link {
  font-size: 15px;
  font-size: 1.5rem;
  text-align: right;
}

.imarket-link a {
  font-size: 15px;
  font-size: 1.5rem;
  color: #29377E;
  text-decoration: underline;
}

.imarket-link a:hover, .imarket-link a:active {
  text-decoration: none;
}

@media all and (max-width: 800px) {
  .imarket-link {
    text-align: center;
  }
}

body {
  min-width: 320px;
}

.full-width,
.width-limiter {
  max-width: 1250px;
  width: calc(100% - 40px);
  margin: 0 auto;
  box-sizing: border-box;
}

@media all and (max-width: 1250px) {
  .full-width,
  .width-limiter {
    max-width: calc(100% - 40px);
  }
}

@media all and (max-width: 570px) {
  .full-width,
  .width-limiter {
    max-width: calc(100% - 30px);
  }
}

.hide {
  display: none;
}

fieldset.onecol ul,
fieldset.twocol ul,
fieldset.threecol ul,
ul.twocol,
ul.threecol {
  overflow: hidden;
  padding: 0 0 0 1.5em;
}

fieldset.twocol ul li,
ul.twocol li {
  float: left;
  width: 50%;
}

fieldset.threecol ul li,
ul.threecol li {
  float: left;
  width: 33%;
}

#page-not-found #top-content p {
  font-size: 2em;
}

@media all and (max-width: 800px) {
  #page-not-found #top-content p {
    font-size: 1.7em;
  }
}

.star-rating,
.star-rating span:hover,
.star-rating span:active,
.star-rating span:focus,
.star-rating .current-rating {
  background-image: url("/assets/templates/main/images/star.png");
  background-position: left -1000px;
  background-repeat: repeat-x;
}

.star-rating {
  position: relative;
  width: 125px;
  height: 25px;
  overflow: hidden;
  list-style: none;
  margin: 0;
  padding: 0;
  background-position: left top;
}

.star-rating li {
  display: inline;
  min-height: 0;
  padding-bottom: 0;
}

.vertical .star-rating li {
  display: inline;
  min-height: 0;
  padding-bottom: 0;
}

#main-content form fieldset ul li.current-rating {
  list-style: none outside none;
  padding: 0;
}

.star-rating span,
.star-rating .current-rating {
  position: absolute;
  top: 0;
  left: 0;
  text-indent: -1000em;
  height: 25px;
  line-height: 25px;
  outline: none;
  overflow: hidden;
  border: none;
}

.star-rating span:hover,
.star-rating span:active,
.star-rating span:focus {
  background-position: left bottom;
}

.star-rating span.one-star {
  width: 20%;
  z-index: 6;
}

.star-rating span.two-stars {
  width: 40%;
  z-index: 5;
}

.star-rating span.three-stars {
  width: 60%;
  z-index: 4;
}

.star-rating span.four-stars {
  width: 80%;
  z-index: 3;
}

.star-rating span.five-stars {
  width: 100%;
  z-index: 2;
}

.star-rating .current-rating {
  z-index: 1;
  background-position: left center;
}

/* for an inline rater */
.inline-rating {
  display: -moz-inline-block;
  display: -moz-inline-box;
  display: inline-block;
  vertical-align: middle;
}

/* smaller star */
.small-star {
  margin-right: 10px;
  position: absolute;
  width: 50px;
}

.small-star,
.small-star span:hover,
.small-star span:active,
.small-star span:focus,
.small-star .current-rating {
  background-image: url("/assets/templates/main/images/star_small.png");
  line-height: 10px;
  height: 10px;
}

#top-content ul,
#main-content ul {
  list-style-type: disc;
  padding-left: 40px;
}

#top-content ul li,
#main-content ul li {
  margin-bottom: 5px;
}

/* --- IMAGES --------------------------------------------------------------- */
a img {
  border: 0;
}

p.last {
  margin-top: 3em;
}

.image-left, .image-right, .image-center {
  font-size: 1.2em;
  line-height: 0;
}

.image-left, .image-right {
  max-width: 50%;
}

.image-left {
  float: left;
  margin: 0;
  padding: 0 2em 0.75em 0;
}

.image-right {
  float: right;
  margin: 0;
  padding: 0 0 0.75em 2em;
}

.image-center {
  max-width: 100%;
  margin: 0 auto 1.8em;
  text-align: center;
}

.image-left img, .image-right img, .image-center img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

.caption {
  font-size: 1.3em;
  line-height: 1.6364em;
  text-align: center;
}

.landing-page-hero-image {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 270px;
  /* Desired height of the image */
  position: relative;
  width: 100%;
}

.custom-featured-image {
  width: auto;
  max-width: 50%;
}

.custom-featured-image > img {
  width: auto;
  max-width: 100%;
  height: auto;
}

/*----- LAYOUTS - IMAGES ----- */
@media all and (max-width: 570px) {
  .image-left, .image-right {
    float: none;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 0 10px;
  }
  .custom-featured-image {
    max-width: 90%;
  }
}

.inline-block {
  display: inline-block;
}

.block {
  display: block;
}

.margin-0 {
  margin: 0;
}

.margin-auto {
  margin: auto;
}

.vertical-top {
  vertical-align: top;
}

.vertical-middle {
  vertical-align: middle;
}

.vertical-bottom {
  vertical-align: bottom;
}

.bold {
  font-weight: bold;
}

.normal {
  font-weight: normal;
}

.italic {
  font-style: italic;
}

.no-italic {
  font-style: normal;
}

.clear {
  clear: both;
}

.clear-left {
  clear: left;
}

.clear-right {
  clear: right;
}

.hide {
  display: none;
}

.show {
  display: block;
}

.align-center {
  text-align: center;
}

.align-right {
  text-align: right;
}

.align-left {
  text-align: left;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.font-15 {
  font-size: 15px;
}

.font-16 {
  font-size: 16px;
}

.font-17 {
  font-size: 17px;
}

.font-18 {
  font-size: 18px;
}

.font-19 {
  font-size: 19px;
}

.font-20 {
  font-size: 20px;
}

.font-21 {
  font-size: 21px;
}

.font-22 {
  font-size: 22px;
}

.font-23 {
  font-size: 23px;
}

[class*="font-"] {
  line-height: 1.2;
}

/* Honeypot Validation */
li.company_name_required {
  display: none;
}

/*Checkmark Bullets */
ul.checkmarks li {
  list-style-image: url("/assets/templates/main/images/bullets/bullet-checkmark.png");
}

ul.twocol.checkmarks,
ul.threecol.checkmarks {
  padding: 0 0 0 2.5em;
}

body.no-scroll {
  overflow: hidden;
}

#site-modal.ims-lightbox {
  /* make a brand color */
  background-color: #fff;
}

#site-modal .popup-inner {
  padding: 0 20px;
}

/* imsLightbox Modal Forms */
.ims-lightbox {
  background-color: #fff;
  position: fixed;
  left: 0%;
  top: 45px;
  width: 100%;
  height: calc(100% - 45px);
  z-index: 1001;
  overflow: visible;
  box-shadow: 0 1px 12px 20000px rgba(0, 0, 0, 0.25);
  border-radius: 0px;
  padding: 60px 0 30px;
}

.ims-lightbox .popup-inner {
  height: 100%;
  overflow-y: scroll;
}

.ims-lightbox .secondary-tools-outer {
  border: none;
  padding: 0;
  margin: 0;
}

.ims-lightbox .close-popup {
  background-color: #0079bd;
  border-radius: 50%;
  height: 45px;
  width: 45px;
  display: inline-block;
  text-align: center;
  font-weight: bold;
  cursor: pointer;
  background-image: url(/assets/templates/main/images/icons/icon-close.svg);
  background-repeat: no-repeat;
  background-position: center;
  color: transparent;
  background-size: 22px;
  transition: 0.3s;
  position: absolute;
  top: 15px;
  right: 20px;
  box-shadow: 1px 1px 1px #000;
}

@media all and (min-width: 571px) {
  .ims-lightbox {
    width: 80%;
    left: 10%;
    border-radius: 10px;
    top: 55px;
  }
}

@media all and (min-width: 801px) {
  .ims-lightbox {
    width: 85%;
    left: 7.5%;
    height: 75%;
    top: 12.5%;
  }
  .ims-lightbox .close-popup {
    top: -20px;
  }
}

@media all and (min-width: 1025px) {
  .ims-lightbox {
    width: 70%;
    left: 15%;
  }
}

@media all and (min-width: 1251px) {
  .ims-lightbox {
    width: 60%;
    left: 20%;
  }
}

/* --- RECAPTCHA ------------------------------------------------------------------------ */
.ims-grecaptcha-badge .ims-rc-anchor-invisible-text span {
  font-size: 11px;
}

.ims-grecaptcha-badge .ims-rc-anchor-invisible .ims-rc-anchor-pt span,
.ims-grecaptcha-badge .ims-rc-anchor-invisible .ims-rc-anchor-pt a {
  font-size: 7px;
}

@media all and (min-width: 800px) and (max-width: 1025px) {
  #container-footer .ims-grecaptcha-badge,
  #container-footer .ims-rc-anchor-invisible {
    width: 250px;
  }
  #container-footer .ims-rc-anchor-invisible-text {
    white-space: normal;
    line-height: 11px;
    text-align: left;
    padding-left: 10px;
    padding-top: 2px;
  }
}

.ims-grid-one, .ims-col-one {
  width: 8.3333%;
}

.ims-grid-two, .ims-grid-1-6, .ims-col-two, .ims-col-1-6 {
  width: 16.6666%;
}

.ims-grid-three, .ims-grid-1-4, .ims-col-three, .ims-col-1-4 {
  width: 25%;
}

.ims-grid-four, .ims-grid-1-3, .ims-col-four, .ims-col-1-3 {
  width: 33.3333%;
}

.ims-grid-five, .ims-col-five {
  width: 41.6666%;
}

.ims-grid-six, .ims-grid-1-2, .ims-col-six, .ims-col-1-2 {
  width: 50%;
}

.ims-grid-seven, .ims-col-seven {
  width: 58.3333%;
}

.ims-grid-eight, .ims-grid-2-3, .ims-col-eight, .ims-col-2-3 {
  width: 66.6666%;
}

.ims-grid-nine, .ims-grid-3-4, .ims-col-nine, .ims-col-3-4 {
  width: 75%;
}

.ims-grid-ten, .ims-grid-5-6, .ims-col-ten, .ims-col-5-6 {
  width: 83.3333%;
}

.ims-grid-eleven, .ims-col-eleven {
  width: 91.6666%;
}

.ims-grid-twelve, .ims-grid-1, .ims-col-twelve, .ims-col-1 {
  width: 100%;
}

[class*='ims-grid-'] {
  display: inline-block;
  margin-right: -3px;
  vertical-align: top;
}

[class*='ims-col-'] {
  display: block;
  margin: 0 auto;
}

/* Grid gutter values */
[class*='ims-grid-'] {
  padding-right: 15px;
}

[class*='ims-grid-']:last-of-type {
  padding-right: 0;
}

.ims-grid-force-pad:last-of-type {
  padding-right: 15px;
}

.ims-pad-grid {
  padding: 15px 0 15px 15px;
}

.ims-pad-grid [class*='ims-grid-']:last-of-type {
  padding-right: 15px;
}

/*----- LAYOUTS - GRID & COLUMN LAYOUT ----- */
@media all and (max-width: 570px) {
  [class*='ims-grid-'] {
    width: 100%;
    padding-right: 0;
  }
  .ims-grid-force-pad:last-of-type {
    padding-right: 0;
  }
  .ims-pad-grid [class*='ims-grid-'] {
    padding-right: 15px;
  }
  [class*='ims-col-'] {
    width: 100%;
  }
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.inline-flex {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

/* FD = Flex Direction */
.fd-column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.fd-column-reverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}

.fd-row {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}

.fd-row-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

/* FW = Flex Wrap */
.fw-wrap {
  -webkit-box-flex: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

/* JC = Justify Content */
.jc-flex-start {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.jc-flex-end {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.jc-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.jc-space-around {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.jc-space-between {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.jc-space-evenly {
  -webkit-box-pack: space-evenly;
  -ms-flex-pack: space-evenly;
  justify-content: space-evenly;
}

/* AC = Align Content */
.ac-flex-start {
  -ms-flex-line-pack: start;
  align-content: flex-start;
}

.ac-flex-end {
  -ms-flex-line-pack: end;
  align-content: flex-end;
}

.ac-center {
  -ms-flex-line-pack: center;
  align-content: center;
}

.ac-space-around {
  -ms-flex-line-pack: distribute;
  align-content: space-around;
}

.ac-space-between {
  -ms-flex-line-pack: justify;
  align-content: space-between;
}

.ac-space-evenly {
  -ms-flex-line-pack: space-evenly;
  align-content: space-evenly;
}

/* AI = Align Items */
.ai-flex-start {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.ai-flex-end {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.ai-center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.ai-baseline {
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}

.ai-stretch {
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
}

/* AS = Align Self */
.as-flex-start {
  -ms-flex-item-align: start;
  align-self: flex-start;
}

.as-flex-end {
  -ms-flex-item-align: end;
  align-self: flex-end;
}

.as-center {
  -ms-flex-item-align: center;
  -ms-grid-row-align: center;
  align-self: center;
}

.as-baseline {
  -ms-flex-item-align: baseline;
  align-self: baseline;
}

.as-stretch {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
}

.as-auto {
  -ms-flex-item-align: auto;
  -ms-grid-row-align: auto;
  align-self: auto;
}

/* Flex Grow/Shrink/Basis */
.flex-1 {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.flex-2 {
  -webkit-box-flex: 2;
  -ms-flex: 2;
  flex: 2;
}

.flex-3 {
  -webkit-box-flex: 3;
  -ms-flex: 3;
  flex: 3;
}

.flex-4 {
  -webkit-box-flex: 4;
  -ms-flex: 4;
  flex: 4;
}

#affiliates {
  background-color: #e3e3e3;
  position: relative;
  padding: 50px 0;
}

.affiliate-container {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

@media all and (max-width: 1024px) {
  .affiliate-container {
    -webkit-flex-flow: wrap;
    -moz-flex-flow: wrap;
    -ms-flex-flow: wrap;
    flex-flow: wrap;
  }
}

#main-content .affiliations {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.affiliations li,
.affiliate-container li {
  display: inline-block;
  margin-right: -3px;
  max-width: 245px;
  padding: 12px;
  margin-bottom: 0;
  vertical-align: middle;
}

.affiliations li a,
.affiliate-container li a {
  display: block;
}

.affiliations li a:hover,
.affiliations li a:active,
.affiliate-container li a:hover,
.affiliate-container li a:active {
  opacity: 0.8;
}

.affiliations li img,
.affiliate-container li img {
  border: medium none;
  display: block;
  max-width: 100%;
  height: auto;
}

.affiliations li span,
.affiliate-container li span {
  left: -999em;
  position: absolute;
}

.affiliations li span.visible,
.affiliate-container li span.visible {
  display: block;
  left: auto;
  padding: 5px;
  position: static;
}

@media all and (max-width: 1024px) {
  .affiliations li,
  .affiliate-container li {
    max-width: 50%;
  }
}

.view-all {
  margin-bottom: 0;
}

.view-all a {
  padding: 8px 30px;
  border-radius: 4px;
  border: 1px solid #C31921;
  background-color: #C31921;
  transition: 0.2s;
}

.view-all a:hover, .view-all a:active {
  background-color: #29377E;
  border: 1px solid #fff;
}

.cta-button {
  display: inline-block;
}

.cta-button a {
  display: block;
  margin: 0;
  padding: 0 20px;
  border-radius: 10px;
  border: 1px solid #fff;
  background-color: #C31921;
  transition: 0.2s;
}

.cta-button a:hover, .cta-button a:active {
  background-color: #29377E;
  border: 1px solid #fff;
}

.cta-button a span {
  display: inline-block;
  vertical-align: middle;
  padding: 16px 0;
}

.populate {
  color: #6d6d6d;
}

.populate:focus {
  color: #000;
}

form fieldset input[type="text"],
form fieldset textarea,
form fieldset select {
  border: 1px solid #e3e3e3;
  border-radius: 5px;
  padding: 13px 10px 14px;
  background-color: #fff;
  height: auto;
  box-sizing: border-box;
}

form fieldset select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  background-image: url("/assets/templates/quickstart/images/icons/select-arrows.png");
  background-repeat: no-repeat;
  background-position: 98% 50%;
  padding: 10px 25px 10px 10px;
}

form fieldset ul, form fieldset ol {
  list-style-type: none;
  padding: 0;
}

label,
input[type="radio"],
input[type="checkbox"],
input[type="submit"],
button {
  cursor: pointer;
}

label,
input[type="submit"],
button {
  border: none;
  -webkit-appearance: none;
}

/*this keeps iphones from zooming in on form fields */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
  select:focus, textarea:focus, input:focus {
    font-size: 16px;
  }
}

input[type="submit"],
button {
  background-color: #C31921;
  border: 1px solid #fff;
  border-radius: 5px;
  padding: 10px 40px 11px 40px;
}

input[type="submit"]:hover, input[type="submit"]:active,
button:hover,
button:active {
  background-color: #29377E;
  border: 1px solid #fff;
}

input.error,
select.error,
textarea.error {
  border: 1px solid red !important;
}

#error-container,
.error-container {
  background: #ffa0a0;
  /* Old browsers */
  background: -moz-linear-gradient(top, #ffa0a0 0%, #f9c2c2 100%);
  /* FF3.6+ */
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ffa0a0), color-stop(100%, #f9c2c2));
  /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(top, #ffa0a0 0%, #f9c2c2 100%);
  /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(top, #ffa0a0 0%, #f9c2c2 100%);
  /* Opera 11.10+ */
  background: -ms-linear-gradient(top, #ffa0a0 0%, #f9c2c2 100%);
  /* IE10+ */
  background: linear-gradient(to bottom, #ffa0a0 0%, #f9c2c2 100%);
  /* W3C */
  border-top: 10px solid #D60000;
  color: #353535;
  text-shadow: 0 1px 0 #fff;
}

.confirmation-container {
  background: #abeaab;
  /* Old browsers */
  background: -moz-linear-gradient(top, #abeaab 0%, #bfffbf 100%);
  /* FF3.6+ */
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #abeaab), color-stop(100%, #bfffbf));
  /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(top, #abeaab 0%, #bfffbf 100%);
  /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(top, #abeaab 0%, #bfffbf 100%);
  /* Opera 11.10+ */
  background: -ms-linear-gradient(top, #abeaab 0%, #bfffbf 100%);
  /* IE10+ */
  background: linear-gradient(to bottom, #abeaab 0%, #bfffbf 100%);
  /* W3C */
  border-top: 10px solid #008000;
  color: #343434;
  text-shadow: 0 1px 0 #fff;
}

#error-container {
  border-radius: 0 0 7px 7px !important;
  box-shadow: 0 1px 3px #000000 !important;
  color: #353535 !important;
  height: 50%;
  margin-bottom: 1.8em !important;
  padding: 1.8em 18px 2.5em !important;
  position: fixed;
  right: 0 !important;
  top: 0 !important;
  z-index: 3000 !important;
  right: 5% !important;
  width: 30% !important;
}

#error-container h2,
#error-container h3 {
  background-image: none;
  background-repeat: repeat;
  background-attachment: scroll;
  background-position: 0 0;
  background-color: transparent !important;
  border: medium none !important;
  color: #e51937 !important;
  font-family: Arial,"Helvetica Neue",Helvetica,sans-serif !important;
  font-size: 24px !important;
  font-style: normal !important;
  font-weight: bold !important;
  margin: 0 !important;
  padding: 0 25px 0 0 !important;
  position: relative !important;
  text-shadow: none;
  text-transform: capitalize;
  top: 0 !important;
  width: 100% !important;
}

#error-container ul {
  display: block !important;
  height: 80% !important;
  padding: 0 !important;
  margin: 10px !important;
  overflow-x: hidden !important;
  overflow-y: scroll !important;
  text-align: left !important;
}

#error-container li {
  color: #000000 !important;
  min-height: 0 !important;
  list-style-image: none !important;
  font-weight: normal !important;
  padding: 1px 0 !important;
}

#error-container li:before {
  color: #565656 !important;
  content: "\00BB" !important;
  /* » */
  font-size: 1.3em !important;
  font-style: normal !important;
  font-weight: normal !important;
  line-height: 1em !important;
  padding: 0 5px 0 0 !important;
  text-shadow: none !important;
}

@media all and (max-width: 1025px) {
  #error-container {
    width: 40% !important;
    right: 2.5% !important;
  }
}

@media all and (max-width: 800px) {
  #error-container {
    border-radius: 0 0 0 7px !important;
    width: 50% !important;
    right: 0 !important;
  }
}

@media all and (max-width: 570px) {
  #error-container {
    border-radius: 0 !important;
    height: 75% !important;
    width: 100% !important;
  }
}

input.close-modal-popup {
  background-image: none;
  background-repeat: repeat;
  background-attachment: scroll;
  background-position: 0 0;
  background-color: #BC1010;
  border: none !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 1px #999 !important;
  color: #FFFFFF !important;
  cursor: pointer !important;
  font-size: 18px !important;
  height: 30px !important;
  margin: 1px 5px !important;
  padding: 0 0 0 1px !important;
  position: absolute !important;
  right: 3px !important;
  top: 3px !important;
  width: 30px !important;
  -webkit-appearance: none;
  z-index: 100;
}

input.close-modal-popup:hover,
input.close-modal-popup:active {
  background-color: #676767 !important;
  box-shadow: none !important;
}

#ie-message {
  background-color: #EFEFEF;
  border: 1px solid #bababa;
  padding: 5px;
  margin: 10px 30px 0;
  text-align: center;
  display: none;
}

#ie-message .h2, #ie-message .h3 {
  font-family: Arial, Helvetica, sans-serif;
  color: #d92027;
  margin: 0 0 10px;
}

#ie-message p {
  margin: 0 0 5px;
}

body.oldIE #ie-message {
  display: block !important;
}

fieldset.onecol ul,
fieldset.twocol ul,
fieldset.threecol ul,
ul.twocol,
ul.threecol {
  overflow: hidden;
  padding: 0 0 0 1.5em;
}

fieldset.twocol ul li,
ul.twocol li {
  float: left;
  width: 50%;
}

fieldset.threecol ul li,
ul.threecol li {
  float: left;
  width: 33%;
}

/* --- MINI FORM ------------------------------------------------------------ */
.sidebar-right #mini-form .widget-heading {
  margin: 15px 0 10px 0;
}

.sidebar-right #mini-form .submit {
  margin: 23px 0 5px 0;
}

#mini-form {
  background-color: #29377E;
  border-radius: 10px;
  padding-bottom: 5px;
  padding-right: 30px;
  padding-left: 30px;
  padding-top: 5px;
  margin-bottom: 0;
  margin-top: 0;
}

@media all and (min-width: 801px) and (max-width: 1024px), (max-width: 570px) {
  #mini-form {
    padding-right: 10px;
    padding-left: 10px;
  }
}

@media all and (max-width: 800px) {
  #mini-form {
    margin: 20px auto;
  }
}

#mini-form label {
  display: block;
  text-align: left;
}

#mini-form fieldset,
#mini-form ul,
#mini-form li {
  display: block;
  width: auto;
}

#mini-form ul {
  margin: 0;
}

#mini-form li {
  padding: 5px 0;
  margin: 0;
}

#mini-form input[type="text"],
#mini-form textarea,
#mini-form select {
  width: 100%;
  background-color: #fff;
}

#mini-form textarea {
  max-height: 100px;
}

#mini-form button,
#mini-form input[type="submit"] {
  position: static;
  margin: 0 auto;
}

#mini-form ul.submit {
  text-align: center;
}

#mini-form li.structured_particle_required,
.secondary-tools form ul li.structured_particle_required {
  position: absolute;
  display: none;
  visibility: hidden;
}

a {
  transition: all 0.1s;
  outline: none;
}

#newsletter-signup {
  background-color: #29377E;
  border-bottom: none;
  margin: 0;
  padding: 30px 0;
}

@media all and (max-width: 800px) {
  #newsletter-signup .left,
  #newsletter-signup .right {
    width: 100%;
  }
}

#newsletter-signup .left {
  padding: 0 30px;
}

#newsletter-signup p {
  margin: 0;
}

#newsletter-signup > .width-limiter {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -moz-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}

@media all and (max-width: 800px) {
  #newsletter-signup > .width-limiter {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

#newsletter-signup form {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
  -webkit-align-content: center;
  -moz-align-content: center;
  -ms-flex-line-pack: center;
  align-content: center;
}

@media all and (max-width: 800px) {
  #newsletter-signup form {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
  }
}

#newsletter-signup form fieldset:last-of-type {
  margin-left: -10px;
}

#newsletter-signup form li {
  margin: 0;
}

#newsletter-signup form input[type="submit"],
#newsletter-signup form button {
  padding: 13px 20px;
}

#payments {
  padding: 0;
}

#payments li {
  background-image: none;
  background-repeat: repeat;
  background-attachment: scroll;
  background-position: 0 0;
  background-color: transparent;
  display: inline-block;
  list-style-type: none;
  padding: 0;
}

#payments li img {
  max-width: 45px;
  height: auto;
  padding: 0 5px;
}

#payments li span {
  position: absolute;
  left: -999em;
}

#promotions-secondary li a {
  background-color: #fff;
  border: 3px dashed #C31921;
  min-height: 150px;
  transition: 0.2s;
  width: 100%;
}

#promotions-secondary li a:hover, #promotions-secondary li a:active {
  background-color: #C31921;
}

#top-content #promotions-secondary ul,
#main-content #promotions-secondary ul {
  padding: 0;
}

#promotions-secondary .image {
  width: 100px;
  background-color: #C31921;
  background-image: url("/assets/templates/quickstart/images/promotions-icon.png");
  background-repeat: no-repeat;
  background-position: center;
}

@media all and (min-width: 801px) and (max-width: 1024px), (max-width: 570px) {
  #promotions-secondary .image {
    width: 60px;
  }
}

#promotions-secondary .content {
  width: calc(100% - 100px);
  padding: 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: column nowrap;
  -moz-flex-flow: column nowrap;
  -ms-flex-flow: column nowrap;
  flex-flow: column nowrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  align-items: stretch;
  -webkit-align-content: stretch;
  -moz-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
}

@media all and (min-width: 801px) and (max-width: 1024px), (max-width: 570px) {
  #promotions-secondary .content {
    width: calc(100% - 60px);
  }
}

.content-left #promotions-secondary {
  padding: 20px 125px;
}

/* Slick Resets */
#promotions-secondary button:focus,
#promotions-secondary .slick-slider div:focus,
#promotions-secondary .slick-slider a:focus {
  outline: none !important;
}

#promotions-secondary button::-moz-focus-inner {
  border: 0;
}

#promotions-secondary {
  position: relative;
  z-index: 0;
}

/* ------- CONTENT ------- */
#rotating-promo-content,
#promotions-secondary .slick-arrows-container {
  /* width: 500px; */
  max-width: 100%;
  margin: auto;
}

#rotating-promo-content {
  padding: 20px 0;
}

/* Hide view all links not in view to prevent clickable invisible links */
#promotions-secondary .slick-slide .view-all {
  visibility: hidden;
}

#promotions-secondary .slick-slide.slick-current .view-all {
  visibility: visible;
}

/* ------- DOTS ------- */
#promotions-secondary ul.slick-dots {
  margin: auto auto 20px auto;
  text-align: center;
}

#promotions-secondary .slick-dots li {
  border: none;
  background-color: transparent;
  background-image: none;
  display: inline-block;
  padding: 0 5px;
}

/* ------- ARROWS ------- */
#promotions-secondary .slick-arrows-container {
  overflow: hidden;
}

#promotions-secondary .slick-arrows-container .slick-arrow {
  background-color: transparent;
  font-size: 15px;
  font-weight: bold;
  padding: 0;
}

#promotions-secondary .slick-arrows-container .slick-arrow:hover,
#promotions-secondary .slick-arrows-container .slick-arrow:active {
  color: #aaa;
}

#promotions-secondary .slick-arrows-container .slick-prev {
  float: left;
}

#promotions-secondary .slick-arrows-container .slick-next {
  float: right;
}

#promotions-secondary .slick-arrows-container .slick-prev::before {
  content: "\00ab  ";
}

#promotions-secondary .slick-arrows-container .slick-next::after {
  content: "  \00bb";
}

#promotions-secondary .secondary-tools .slick-track {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
}

#promotions-secondary .secondary-tools .slick-list li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  height: auto;
}

#promotions-secondary .secondary-tools li:first-of-type {
  margin-left: 0;
}

#promotions-secondary .secondary-tools li:last-of-type {
  margin-right: 0;
}

@media all and (min-width: 571px) and (max-width: 800px) {
  #promotions-secondary .secondary-tools ul.promotions {
    width: 83%;
    margin: 0 auto;
  }
}

@media all and (min-width: 801px) {
  #promotions-secondary .secondary-tools .slick-track {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
  }
  #promotions-secondary .secondary-tools .slick-list li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    height: auto;
  }
  #promotions-secondary .secondary-tools li:first-of-type {
    margin-left: 0px;
  }
  #promotions-secondary .secondary-tools li:last-of-type {
    margin-right: 0px;
  }
}

@media all and (min-width: 1025px) {
  #promotions-secondary .secondary-tools li:first-of-type {
    margin-left: 0px;
  }
  #promotions-secondary .secondary-tools li:last-of-type {
    margin-right: 0px;
  }
}

#promotions .promotions-item-details-wrapper {
  border: medium none;
  padding: 0;
}

#promotions .promotions-item {
  border: 1px dashed #787878;
  border-radius: 3px;
  margin: 2%;
  padding: 10px 10px 20px;
  position: relative;
  vertical-align: top;
}

#promotions .promotions-item h2 {
  margin: 0;
}

#promotions .promotions-item .view-all {
  display: block;
  padding: 0 6px;
  width: 100%;
}

/*-------- PROMOTIONS - Individual (Coupons) -------------------------------- */
.promotions-item-details-wrapper {
  border: 3px dashed #000;
  margin: 0 auto;
  width: 90%;
}

.promotional-item-details {
  padding: 10px;
}

.promotions-item-details-wrapper img.promotion-logo {
  display: block;
  margin: 10px auto;
  max-width: 300px;
  width: 100%;
}

#btn-print-coupon {
  max-width: 300px;
  margin: 10px auto;
  display: block;
}

.no-webp #testimonials-secondary {
  background-image: url("/assets/templates/quickstart/images/bg-reviews.jpg");
}

.webp #testimonials-secondary {
  background-image: url("/assets/templates/quickstart/images/bg-reviews.webp");
}

#testimonials-secondary {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  text-align: center;
  padding: 20px 30px 35px 30px;
  border-radius: 10px;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}

@media all and (min-width: 801px) and (max-width: 1024px), (max-width: 570px) {
  #testimonials-secondary {
    padding: 20px 0px 35px 0px;
  }
}

#testimonials-secondary .testimonial {
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  border: 1px solid #cccccc;
  background-color: rgba(255, 255, 255, 0.9);
  padding: 25px;
  margin-bottom: 20px;
  text-align: left;
}

@media all and (max-width: 400px) {
  #testimonials-secondary .testimonial {
    padding: 20px 10px;
  }
}

/*-------- REVIEWS - Landing Page ------------------------------------------- */
/* Default reviews page */
#reviews #top-content .testimonial,
#reviews #main-content .testimonial {
  margin: 50px auto;
}

#reviews #top-content .testimonial blockquote .quote,
#reviews #main-content .testimonial blockquote .quote {
  background-color: #ebebeb;
  padding: 25px;
  border-radius: 10px;
  width: 580px;
  max-width: 95%;
  position: relative;
  margin-bottom: 15px;
}

#reviews #top-content .testimonial blockquote .quote p,
#reviews #main-content .testimonial blockquote .quote p {
  font-size: 18px;
  font-size: 1.8rem;
  font-style: italic;
}

#reviews #top-content .testimonial blockquote .quote p:last-child,
#reviews #main-content .testimonial blockquote .quote p:last-child {
  margin-bottom: 0;
}

#reviews #top-content .testimonial blockquote .quote p:first-child::before,
#reviews #main-content .testimonial blockquote .quote p:first-child::before {
  content: '\201c';
}

#reviews #top-content .testimonial blockquote .quote p:last-child::after,
#reviews #main-content .testimonial blockquote .quote p:last-child::after {
  content: '\201d';
}

#reviews #top-content .testimonial blockquote p.source,
#reviews #main-content .testimonial blockquote p.source {
  font-size: 15px;
  font-size: 1.5rem;
  color: #666;
}

#reviews #top-content .testimonial blockquote .quote:after,
#reviews #main-content .testimonial blockquote .quote:after {
  content: " ";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 7.5px 0 7.5px;
  border-color: #ebebeb transparent transparent transparent;
  bottom: -9px;
  position: absolute;
}

#reviews #top-content .testimonial:nth-child(odd) blockquote .quote:after,
#reviews #main-content .testimonial:nth-child(odd) blockquote .quote:after {
  left: 20px;
}

#reviews #top-content .testimonial:nth-child(even) blockquote .quote:after,
#reviews #main-content .testimonial:nth-child(even) blockquote .quote:after {
  right: 20px;
}

#reviews #top-content .testimonial:nth-child(odd) blockquote .quote,
#reviews #main-content .testimonial:nth-child(odd) blockquote .quote {
  float: left;
}

#reviews #top-content .testimonial:nth-child(even) blockquote .quote,
#reviews #main-content .testimonial:nth-child(even) blockquote .quote {
  float: right;
}

#reviews #top-content .testimonial:nth-child(odd) blockquote p.source,
#reviews #main-content .testimonial:nth-child(odd) blockquote p.source {
  text-align: left;
  clear: left;
}

#reviews #top-content .testimonial:nth-child(even) blockquote p.source,
#reviews #main-content .testimonial:nth-child(even) blockquote p.source {
  text-align: right;
  clear: right;
}

/* --- REVIEWS -------------------------------------------------------------- */
/* --- LAYOUTS/ANIMATION  --------------------------------------------------- */
@media all and (max-width: 800px) {
  #reviews #top-content .testimonial,
  #reviews #main-content .testimonial {
    margin: 30px auto;
  }
  #reviews #top-content .testimonial blockquote .quote p,
  #reviews #main-content .testimonial blockquote .quote p {
    font-size: 1.6em;
  }
  #reviews #top-content .testimonial blockquote p.source,
  #reviews #main-content .testimonial blockquote p.source {
    font-size: 1.4em;
  }
}

/* End default reviews page */
#nn-reviews {
  margin: 5px 0 15px 0;
}

.nn-agg-container img {
  display: none;
}

.nn-agg-container::before {
  content: "";
  display: block;
  position: relative;
  background-image: url("/assets/templates/quickstart/images/recme-stars.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  height: 26px;
  width: 185px;
  margin: 0 auto 5px auto;
}

.nn-agg-rating {
  display: inline-block;
  vertical-align: middle;
}

.nn-agg-rating::after {
  content: " Average Star Rating!";
  display: inline-block;
  position: relative;
}

.nn-reviews {
  margin: 7px 0;
}

/*#testimonials-popup .popup-inner{
  padding-right: 35px;
  padding-left: 35px;
}
#testimonials-popup-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  border-bottom: 2px solid #dbdbdb;
  margin-bottom: 36px;
}
#testimonials-popup h2 {
  margin-top: 0px;
  margin-bottom: 12px;
}
.popup-header-left .review-star-rating {
  margin-bottom: 20px;
}
.popup-header-left .review-star-rating > div {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  width: auto;
}
.popup-header-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}
.popup-header-right p {
  text-align: right;
}
.testimonial .read-more {
  font-size: 1.8rem;
  font-weight: bold;
  text-decoration: underline;
  cursor: pointer;
}
@media all and (max-width: 570px) {
  .testimonial .read-more.popup-link {
    display: none;
  }
}

@media all and (min-width: 571px) {
  .testimonial .read-more.no-popup-link {
    display: none;
  }
}

// --- TESTIMONIALS PAGE ---------------------------------------------------- //
.testimonials .testimonial {
  margin-bottom: 45px;
  box-shadow: 0px 0px 3px #f1f1f1;
  background-color: #f1f1f1;
  padding: 20px;
}
#testimonials-secondary .review-star-rating {
  margin-bottom: 20px;
  position: relative;
  display: inline-block;
  background-color: rgba(0,0,0,.18);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  padding: 10px;
  border-radius: 10px;
  color: #fff;
}
#testimonials-secondary .review-star-rating a {
  color: #fff;
}
#reviews .review-star-rating {
  margin-bottom: 40px;
  position: relative;
}
body#reviews .review-star-rating::after {
  content: '';
  position: absolute;
  width: calc(100% - 250px);
  height: 1px;
  background-color: #c5c5c5;
  right: 0px;
  bottom: 50%;
}
i.star {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-review-star.png);
  width: 30px;
  height: 30px;
  background-repeat: no-repeat;
  display: inline-block;
  background-size: contain;
}
i.icon-recommended {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-recommended.png);
  width: 20px;
  height: 16px;
  background-repeat: no-repeat;
  display: inline-block;
  background-size: contain;
}
.review-star-rating > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 220px;
}
.review-star-rating span {
  font-size: 3.3rem;
  line-height: 1.1;
  font-weight: 700;
  margin-right: 10px;
}
.review-star-rating a {
  margin-left: 5px;
}
#reviews .review-star-rating a {
  text-decoration: none;
}
#testimonials-secondary .review-star-rating > div {
  margin: 5px auto 5px;
}
#testimonials-secondary blockquote {
  margin: 0px;
}
#testimonials-secondary .secondary-tools {
  text-align: center;
}
#testimonials-secondary .testimonial {
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  background-color: #fff;
  margin-bottom: 20px;
  padding: 25px;
}
.testimonial .source-info {
  min-height: 70px;
}
.testimonial .source-info .source {
  color: #555;
}
.testimonial .source-info .rating_output {
  font-style: italic;
  font-size: 1.4em;
  color: #555;  
}
.testimonial .source-image {
  position: relative;
  display: inline-block;
  float: left;
  margin-right: 20px;
}
.testimonial .source-image img {
  border-radius: 50%;
  width: 62px;
  height: 62px;
}
.review-source {
  border-radius: 50%;
  background-color: #fff;
  height: 25px;
  width: 25px;
  position: absolute;
  right: 0px;
  bottom: 0px;
  text-indent: -9999px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto 18px;
  box-shadow: 0px 0px 3px #9c9c9c;
}
.review-source.source-Facebook {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-facebook.png);
}
.review-source.source-Google {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-google.png);
}
.review-source.source-BBB {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-bbb.png);
}
.review-source.source-no-source {
  display: none;
}
.testimonial .quote p:before {
  content:open-quote;
}
.testimonial .quote p:after {
  content:close-quote;
}
#testimonial_pagination {
  text-align: center;
}
#testimonial_pagination a {
  background-color: #ebebeb;
  padding: 3px 10px;
  margin: 0px 5px;
  color: #005aa1;
  text-decoration: none;
  font-size: 15px;
  transition: 0.3s;
}
#testimonial_pagination a.current,
#testimonial_pagination a:hover,
#testimonial_pagination a:active {
  background-color: #005aa1;
  color: #ebebeb;
}
#testimonial_pagination .pagination-spacer {
  padding: 3px 5px;
  vertical-align: super;
}*/
#service-area-list {
  position: relative;
  background-color: #e4e4e4;
}

.webp #service-area-list::after {
  background-image: url("/assets/templates/quickstart/images/bg-service-area.webp");
}

.no-webp #service-area-list::after {
  background-image: url("/assets/templates/quickstart/images/bg-service-area.jpg");
}

#service-area-list::after {
  position: absolute;
  display: block;
  content: '';
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

@media all and (max-width: 800px) {
  #service-area-list::after {
    height: 250px;
    width: 100%;
  }
}

#service-area-list .sa-city-wrapper {
  width: 50%;
  padding: 95px 20px 80px 20px;
}

#service-area-list .sa-city-wrapper ul {
  list-style-type: none;
}

@media all and (max-width: 800px) {
  #service-area-list .sa-city-wrapper {
    width: 100%;
    padding-top: 300px;
  }
}

#service-areas #service-area-towns-list ul {
  padding: 0;
}

#service-area-list .service-cities li::before {
  position: relative;
  display: inline-block;
  content: '';
  height: 17px;
  width: 13px;
  margin-right: 5px;
  background-image: url("/assets/templates/quickstart/images/icon-pin.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

#service-area-secondary .map {
  position: relative;
}

#service-area-secondary .map img {
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

#service-area-secondary .map::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("/assets/templates/quickstart/images/map-overlay.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 80%;
}

#service-area-search {
  background-color: #C31921;
  padding: 5px;
}

#service-areas #service-area-search {
  text-align: center;
  background-color: transparent;
  margin-bottom: 0;
  margin-top: 60px;
}

#service-areas #service-area-towns-list {
  background-color: transparent;
  border-radius: 0;
}

#service-area-search p.search {
  margin-bottom: 10px;
  margin-top: 20px;
  padding: 0 15px;
}

#service-area-search form ul li {
  margin-bottom: 0;
}

#service-area-list {
  border-bottom: none;
  padding: 0 20px;
}

#service-area-list h2.service-towns {
  display: none;
}

#service-area-list .service-cities {
  -webkit-columns: 2;
  -moz-columns: 2;
  columns: 2;
  padding: 0;
}

@media all and (min-width: 801px) and (max-width: 1024px), (max-width: 450px) {
  #service-area-list .service-cities {
    -webkit-columns: 1;
    -moz-columns: 1;
    columns: 1;
  }
}

#service-area-list .service-cities li {
  margin-bottom: 0;
}

#service-areas #top-content .content-spacer {
  padding-left: 0;
  padding-right: 0;
}

#service-areas #top-content {
  margin-bottom: 0;
}

#service-areas #service-area-towns-list {
  padding: 0;
  margin-bottom: 0;
}

#service-area-list .secondary-tools ul li a:link, #service-area-list .secondary-tools ul li a:visited {
  display: inline-block;
}

#service-areas #main-content #service-area-towns-list ul li:not(.view-all) {
  width: 25%;
  margin: 0 -3px 5px 0;
  padding: 6px;
  display: inline-block;
  vertical-align: top;
}

@media all and (max-width: 700px) {
  #service-areas #main-content #service-area-towns-list ul li:not(.view-all) {
    width: 33%;
  }
}

@media all and (max-width: 430px) {
  #service-areas #main-content #service-area-towns-list ul li:not(.view-all) {
    width: 50%;
  }
}

#secondary-navigation-outer li,
.service-area-links li {
  margin-bottom: 5px;
  padding: 0;
}

.ims-recoomend-me-checkins {
  border-bottom: 5px solid #fff;
  margin: 20px 0;
  padding: 20px;
}

.nn-samap-header img.nn-samap-ci-image {
  height: auto;
  max-height: none;
  max-width: 100%;
}

ul.slick-dots {
  text-align: center;
}

ul.slick-dots li {
  display: inline;
  padding: 8px;
}

ul.slick-dots li button {
  background-color: #29377E;
  border: 1px solid #fff;
  font-size: 1px;
  color: transparent;
  line-height: 1px;
  display: inline-block;
  height: 25px;
  width: 25px;
  border-radius: 50%;
  padding: 0;
}

ul.slick-dots li button:hover,
ul.slick-dots li.slick-active button {
  background-color: #fff;
  border: 1px solid #29377E;
}

.social-networking {
  margin: 0;
  text-align: center;
}

.social-networking ul {
  padding: 0;
}

.social-networking li {
  display: inline-block;
  margin-left: 5px;
  padding: 0;
}

.social-networking li:first-of-type {
  margin-left: 0;
}

.social-networking li a {
  display: block;
  text-indent: -9999em;
  font-size: 1px;
  color: transparent;
  height: 45px;
  width: 45px;
  position: relative;
  background-color: #29377E;
  border-radius: 50%;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto 25px;
  transition: 0.2s;
}

.social-networking li.btn-facebook a {
  background-image: url("/assets/templates/main/images/social/btn-facebook.svg");
}

.social-networking li.btn-x a {
  background-image: url("/assets/templates/main/images/social/btn-x.svg");
  background-size: auto 20px;
}

.social-networking li.btn-youtube a {
  background-image: url("/assets/templates/main/images/social/btn-youtube.svg");
}

.social-networking li.btn-instagram a {
  background-image: url("/assets/templates/main/images/social/btn-instagram.svg");
}

.social-networking li.btn-pinterest a {
  background-image: url("/assets/templates/main/images/social/btn-pinterest.svg");
  background-size: auto 20px;
}

.social-networking li.btn-angies-list a {
  background-image: url("/assets/templates/main/images/social/btn-angies-list.svg");
}

.social-networking li.btn-houzz a {
  background-image: url("/assets/templates/main/images/social/btn-houzz.svg");
}

.social-networking li.btn-linkedin a {
  background-image: url("/assets/templates/main/images/social/btn-linkedin.svg");
}

.social-networking li.btn-google-maps a {
  background-image: url("/assets/templates/main/images/social/btn-google-maps.svg");
  background-size: auto 20px;
}

.social-networking li.btn-google-my-business a {
  background-image: url("/assets/templates/main/images/social/btn-google-my-business.svg");
}

.social-networking li.btn-yelp a {
  background-image: url("/assets/templates/main/images/social/btn-yelp.svg");
}

.social-networking li.btn-flickr a {
  background-image: url("/assets/templates/main/images/social/btn-flickr.svg");
}

.social-networking li a:hover,
.social-networking li a:active {
  background-color: #222;
  color: transparent;
}

#container-banner {
  position: relative;
  z-index: 0;
}

#banner {
  height: 100%;
}

#banner .banner-slide {
  width: 100%;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  width: 100%;
}

@media all and (max-width: 800px) {
  #banner .banner-slide {
    min-height: 250px;
  }
}

#banner .banner-slide a {
  display: block;
  /*height:100%;*/
  text-decoration: none;
  /*width:100%;*/
}

#banner .banner-slide img {
  display: block;
  width: 100%;
  height: auto;
}

.banner-text {
  background-color: rgba(0, 0, 0, 0.5);
  bottom: 0;
  display: block;
  left: 0;
  padding: 10px;
  position: absolute;
  width: 100%;
}

.banner-text span {
  color: #FFF;
  display: block;
  line-height: 1.1em;
  margin: 0;
}

.banner-text span.banner-text-title {
  font-size: 3em;
}

.banner-text span.banner-text-description {
  font-size: 1.6em;
}

#masthead,
#fixed-masthead {
  overflow: hidden;
  position: relative;
}

@media all and (max-width: 800px) {
  #masthead,
  #fixed-masthead {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

#masthead .financing,
#fixed-masthead .financing {
  margin-top: 10px;
  margin-bottom: 0;
}

@media all and (max-width: 800px) {
  #masthead {
    margin-top: 50px;
    padding-bottom: 10px;
  }
}

#container-fixed-masthead {
  position: fixed;
  top: -300px;
  left: 0;
  width: 100%;
  background-color: #fff;
  box-shadow: 0 3px 5px 0 rgba(0, 0, 0, 0.2);
  transition: top 0.6s, left 0.3s;
  z-index: 1000;
}

@media all and (max-width: 800px) {
  #container-fixed-masthead {
    display: none;
  }
}

#fixed-masthead {
  padding: 10px 0;
}

.ims-is-scrolled #container-fixed-masthead {
  top: 0;
}

#masthead {
  transition: height 0.3s ease;
  min-height: 140px;
}

.logo {
  max-width: 350px;
  position: relative;
}

.logo img {
  width: 100%;
  height: auto;
  display: block;
}

.tagline {
  margin: 0 0 0.6em;
}

.phone-container {
  padding: 0 20px;
}

@media all and (max-width: 800px) {
  .phone-container {
    padding: 20px;
  }
}

.phone-text {
  margin: 0;
}

.phone-number {
  margin: 0;
  white-space: nowrap;
}

.phone-number,
.phone-number span,
.phone-number a,
.phone-number span.gc-cs-link {
  color: #00cc0d;
  text-decoration: none;
}

.logo,
.phone-container,
.tagline {
  transition: all 0.3s ease;
}

@media all and (max-width: 800px) {
  #masthead .phone-number {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1440;
    padding: 0 20px;
    background-color: #C31921;
    vertical-align: middle;
    height: 45px;
  }
}

@media all and (max-width: 800px) {
  #masthead .phone-number a {
    vertical-align: middle;
  }
}

@media all and (max-width: 570px) {
  .logo-container,
  .tagline2,
  .phone-container {
    display: block;
    float: none;
    margin: 0 auto;
    max-width: 450px;
    width: 100%;
  }
}

/*----------------------------------------------------------------------------*/
/* --- BEGIN PRIMARY NAVIGATION (MOBILE/TABLET) ----------------------------- */
@media all and (max-width: 800px) {
  #toggle-navigation {
    transition: all 0.4s ease;
  }
  #container-primary-navigation,
  .ims-push-content {
    transition: left 0.3s ease;
  }
  #primary-navigation {
    background-image: none;
    background-repeat: repeat;
    background-attachment: scroll;
    background-position: 0 0;
    background-color: rgba(255, 255, 255, 0.98);
    box-shadow: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    height: 100%;
    width: 100%;
    max-width: 100%;
    padding: 45px 0 20px;
    overflow-x: hidden;
    overflow-y: scroll;
  }
  #primary-navigation > ul {
    display: block;
    padding: 0;
    height: auto;
    list-style-type: none;
    position: relative;
    width: 100%;
    /*border-bottom: 1px solid rgba(0,0,0,0.3);*/
  }
  #primary-navigation > ul::after {
    content: '';
    position: absolute;
    width: calc(100% - 30px);
    height: 1px;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    background-color: #EDEDED;
  }
  #primary-navigation ul li {
    position: relative;
  }
  #primary-navigation .phone-number {
    text-align: center;
    margin-top: 25px;
  }
  #primary-navigation .phone-number svg {
    max-width: 30px;
    vertical-align: middle;
  }
  /* --- PRIMARY NAVIGATION (MOBILE/TABLET) --------------------------------- */
  /* --- NAV ITEM COLORS & FONT SIZES --------------------------------------- */
  /* ----- Static ----- */
  /* All Nav Items */
  #primary-navigation li,
  #primary-navigation li a:link,
  #primary-navigation li a:visited {
    color: #222;
  }
  /* ----- Rollovers ----- */
  /* All Nav Items */
  #primary-navigation li a:hover,
  #primary-navigation li a:active,
  #primary-navigation li.active > a,
  #primary-navigation ul li.nav-level-1 ul li a:hover,
  #primary-navigation ul li.nav-level-1 ul li a:active {
    color: #222;
  }
  /* ----- You Are Here ----- */
  /* All Nav Items */
  #primary-navigation li.current > a:link,
  #primary-navigation li.current > a:visited,
  #primary-navigation li.current > a:hover,
  #primary-navigation li.current > a:active {
    color: #222;
  }
  /* ----- Nav Font Sizes ----- */
  /* Top Level */
  #primary-navigation ul li.nav-level-1 {
    font-size: 1.8em;
    line-height: 1.1em;
  }
  /* Secondary */
  #primary-navigation ul li.nav-level-1 > ul > li {
    font-size: 1em;
    line-height: 1.1em;
  }
  /* Tertiary/Third Level & Beyond */
  #primary-navigation ul li.nav-level-1 > ul > li li {
    font-size: 1em;
    line-height: 1.1em;
  }
  /* --- PRIMARY NAVIGATION (MOBILE/TABLET) --------------------------------- */
  /* --- TOP-LEVEL ---------------------------------------------------------- */
  #primary-navigation ul li.nav-level-1 {
    /*border-bottom: 1px solid rgba(0,0,0,0.3);*/
    min-height: 40px;
    height: auto;
    line-height: 1.1em;
    overflow: hidden;
    padding: 0;
    position: relative;
    text-align: left;
    font-weight: 700;
  }
  #primary-navigation ul li.nav-level-1::after {
    content: '';
    position: absolute;
    width: calc(100% - 30px);
    height: 1px;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    background-color: #EDEDED;
  }
  #primary-navigation ul li.nav-level-1:first-child::after {
    content: '';
  }
  #primary-navigation ul li.nav-level-1:last-child::after {
    display: none;
  }
  #primary-navigation ul li.nav-level-1 > a {
    display: block;
    padding: 15px 19% 15px 25px;
    text-decoration: underline;
    text-transform: uppercase;
    position: relative;
  }
  #primary-navigation ul li.nav-level-1.active-submenu > a::after {
    content: '';
    position: absolute;
    width: calc(100% - 30px);
    height: 1px;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    background-color: #EDEDED;
  }
  /* --- PRIMARY NAVIGATION (MOBILE/TABLET) --------------------------------- */
  /* --- NAV ITEMS ---------------------------------------------------------- */
  /* ----- All Dropdown Nav Items ----- */
  #primary-navigation ul li.nav-level-1 ul {
    list-style-type: none;
    margin: 0;
    max-height: 0;
  }
  #primary-navigation ul li.nav-level-1 li {
    overflow: hidden;
    text-align: left;
  }
  #primary-navigation ul li.nav-level-1 li a {
    display: block;
    padding: 10px 50px 10px 30px;
    position: relative;
  }
  #primary-navigation ul li.nav-level-1 ul > li:not(.last):not(.nav-level-3) > a::after {
    content: '';
    position: absolute;
    width: calc(100% - 30px);
    height: 1px;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    background-color: #EDEDED;
  }
  /* ----- 3rd Level Nav Items (tertiary service pages) & beyond ------------ */
  #primary-navigation ul li.nav-level-1 > ul > li ul {
    border-left: none;
    margin: 0;
  }
  #primary-navigation ul li.nav-level-1 > ul > li ul li a {
    padding: 8px 50px 8px 0;
    font-weight: 400;
  }
  #primary-navigation ul li.nav-level-1 > ul > li > ul ul {
    margin: 0 0 0 2%;
  }
  /* Active Navigation */
  #primary-navigation ul li.nav-level-1 ul.active {
    max-height: none;
  }
  #primary-navigation ul li.nav-level-1 > ul.active {
    padding-bottom: 8px;
    padding-left: 20px;
  }
  /* --- PRIMARY NAVIGATION (MOBILE/TABLET) --------------------------------- */
  /* --- NAVIGATION 'SHOW/HIDE' LINK ---------------------------------------- */
  #toggle-navigation {
    height: 0;
    width: 0;
  }
  .no-js #toggle-navigation {
    display: none;
  }
  .js #toggle-navigation {
    background-image: none;
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-position: 0 center;
    background-color: #29377E;
    background-size: auto 30px;
    border-radius: 0;
    cursor: pointer;
    font-size: 2em;
    font-weight: 700;
    height: 45px;
    text-transform: uppercase;
    left: 0;
    margin: 0 auto;
    min-width: 100px;
    overflow: hidden;
    padding: 0;
    position: fixed;
    text-align: left;
    top: 0;
    z-index: 1950;
    transition: background 0.4s linear;
  }
  .js #toggle-navigation a {
    position: relative;
    color: #fff;
    display: block;
    height: 100%;
    line-height: 45px;
    padding: 0 5px 0 40px;
    text-align: left;
    text-decoration: none;
    width: 100%;
  }
  .js #toggle-navigation a::before,
  .js #toggle-navigation a::after,
  .js #toggle-navigation::before {
    content: '';
    position: absolute;
    width: 24px;
    height: 4px;
    background-color: #fff;
    left: 10px;
    border-radius: 4px;
    -ms-transition-property: transform;
    -webkit-transition-property: transform;
    transition-property: transform;
    -ms-transition-duration: .3s;
    -webkit-transition-duration: .3s;
    transition-duration: .3s;
    -ms-transition-timing-function: ease-out;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
  }
  .js #toggle-navigation a::before {
    top: 13px;
    transform-origin: center left;
  }
  .js #toggle-navigation a::after {
    bottom: 14px;
    transform-origin: center left;
  }
  .js #toggle-navigation::before {
    top: 20px;
  }
  .js .active-navigation #toggle-navigation {
    background-image: none;
    background-repeat: repeat;
    background-attachment: scroll;
    background-position: 0 0;
    background-color: #29377E;
    border-radius: 0;
    height: 45px;
    position: fixed;
    top: 0;
    left: 0;
    width: auto;
  }
  .js .active-navigation #toggle-navigation a::before {
    transform: rotate(45deg);
  }
  .js .active-navigation #toggle-navigation a::after {
    transform: rotate(-45deg);
    bottom: 11px;
  }
  .js .active-navigation #toggle-navigation a {
    display: inline-block;
    background-color: #29377E;
    color: #fff;
    width: auto;
    min-width: 100px;
    height: 45px;
    line-height: 47px;
    padding: 0 5px 0 32px;
    text-align: left;
  }
  /* ------ Show/Hide Navigation (slide-out) ------ */
  #container-primary-navigation {
    height: 100%;
    left: -100%;
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 900;
  }
  #container-primary-navigation .nav-logo {
    display: inline-block;
    padding: 20px 10px 20px 10px;
    margin: 0 auto;
  }
  #container-primary-navigation .nav-logo a {
    display: inline-block;
  }
  #container-primary-navigation .nav-logo img {
    max-width: 100%;
    height: 100%;
  }
  .active-navigation #container-primary-navigation {
    left: 0;
  }
  #container-masthead,
  #container-content,
  #container-footer,
  .ims-push-content {
    position: relative;
    left: 0;
  }
  .active-navigation #container-masthead.ims-push-content,
  .active-navigation .ims-push-content,
  .active-navigation #container-fixed-masthead {
    left: 0;
  }
  .active-navigation #container-masthead {
    box-shadow: none;
  }
  /* Hide Apex Chat when nav is active */
  .active-navigation #apexchat_invitation_container_minimized_wrapper,
  .active-navigation #apexchat_invitation_container_wrapper {
    display: none !important;
  }
  /* --- PRIMARY NAVIGATION (MOBILE/TABLET) --------------------------------- */
  /* --- EXPAND NAVIGATION BUTTONS ------------------------------------------ */
  div.expand-nav {
    cursor: pointer;
    display: block;
    height: 44px;
    margin: 0;
    padding: 4px;
    position: absolute;
    right: 20px;
    top: 5px;
    width: 44px;
    z-index: 900;
    transition: all 0.4s;
  }
  div.expand-nav > span.nav-expand {
    transition: all 0.4s ease-in-out;
  }
  div.expand-nav.active span.nav-expand {
    background-color: #29377E;
  }
  li.nav-level-1 li div.expand-nav {
    height: 34px;
    padding: 5px;
    width: 34px;
  }
  span.nav-expand {
    background-color: #EDEDED;
    border-radius: 5px;
    display: inline-block;
    height: 30px;
    margin: 2px;
    text-align: center;
    vertical-align: top;
    padding: 0;
    width: 30px;
    position: relative;
  }
  li.nav-level-1 li span.nav-expand {
    height: 25px;
    position: relative;
    margin: 0;
    width: 25px;
  }
  span.nav-expand:after,
  span.nav-expand:before {
    content: '';
    position: absolute;
    width: 12px;
    height: 4px;
    background-color: #29377E;
    border-radius: 4px;
    top: 50%;
    transition: all 0.4s;
  }
  span.nav-expand:before {
    position: relative;
    display: block;
  }
  li.nav-level-2 span.nav-expand:after,
  li.nav-level-2 span.nav-expand:before {
    content: '';
    position: absolute;
    width: 10px;
    height: 4px;
    background-color: #222;
    border-radius: 4px;
    top: 50%;
  }
  li.nav-level-2 span.nav-expand:after {
    right: 4px;
  }
  li.nav-level-2 span.nav-expand:before {
    left: 4px;
  }
  span.nav-expand:after {
    transform: rotate(-45deg) translateY(-50%);
    right: 5px;
  }
  span.nav-expand:before {
    transform: rotate(45deg) translateY(-50%);
    left: 4px;
  }
  div.expand-nav.active > span.nav-expand::before {
    transform: rotate(-45deg);
    top: 14px;
    left: 6px;
    background-color: #fff;
  }
  div.expand-nav.active > span.nav-expand::after {
    transform: rotate(45deg);
    top: 14px;
    right: 6px;
    background-color: #fff;
  }
  li.nav-level-2 div.expand-nav.active > span.nav-expand::before {
    top: 10px;
    left: 4.5px;
  }
  li.nav-level-2 div.expand-nav.active > span.nav-expand::after {
    top: 10px;
    right: 5px;
  }
  .mobile-nav-buttons {
    text-align: center;
    margin-top: 36px;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }
  .mobile-nav-buttons .cta-phone {
    margin-bottom: 31px;
  }
  .mobile-nav-buttons .cta-button.cta-phone a img {
    margin-right: 10px;
    margin-bottom: -10px;
  }
}

/* @media all and (max-width: 800px) */
/* --- PRIMARY NAVIGATION (MOBILE/TABLET) ----------------------------------- */
/* --- MOBILE OVERRIDES ----------------------------------------------------- */
@media all and (max-width: 570px) {
  .js #toggle-navigation {
    background-size: auto 36px;
    top: 0;
    height: 45px;
  }
  .js #toggle-navigation a {
    line-height: 45px;
  }
}

/* --- END PRIMARY NAVIGATION (MOBILE/TABLET) ------------------------------- */
/*--------------------------------------------------------------------------- */
/*--------------------------------------------------------------------------- */
/* --- BEGIN PRIMARY NAVIGATION (DESKTOP) ----------------------------------- */
@media all and (min-width: 801px) {
  #primary-navigation li.docid-1 {
    display: none;
  }
  .mobile-nav-buttons {
    display: none;
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- SET UP --------------------------------------------------------------- */
  #container-primary-navigation .nav-logo,
  #container-primary-navigation .phone-number {
    display: none;
  }
  /* no toggle nav button for any desktop view */
  .js #toggle-navigation,
  .js #toggle-navigation a {
    font-size: 0;
    height: 0;
    width: 0;
  }
  /* Base CSS for #container-primary-navigation */
  #container-primary-navigation {
    background-color: #C31921;
  }
  /* Base CSS for #primary-navigation */
  #primary-navigation {
    clear: both;
    margin: 0 auto;
    padding: 0;
    position: relative;
    text-align: center;
    z-index: 800;
  }
  /* Base nav ul CSS */
  #primary-navigation ul {
    display: block;
    list-style: none;
    margin: 0 auto;
    padding: 0;
  }
  /* Base CSS for all nav items */
  #primary-navigation li {
    margin-bottom: 0;
  }
  #primary-navigation ul li,
  #primary-navigation ul li a {
    text-decoration: none;
    cursor: pointer;
  }
  #primary-navigation a {
    display: block;
    position: relative;
    transition: all 0.2s;
  }
  #primary-navigation a span {
    position: relative;
    line-height: 1.1em;
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- TOP-LEVEL ------------------------------------------------------------ */
  /*-- TOP-LEVEL UL -----------------------*/
  #primary-navigation > ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    /* Space items evenly */
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  /*-- TOP-LEVEL LI -----------------------*/
  #primary-navigation .nav-level-1 {
    position: relative;
  }
  /*-- TOP-LEVEL A -----------------------*/
  #primary-navigation .nav-level-1 > a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    /* Vertically-Center spans within links */
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    /* Set preferred height of link */
    height: 50px;
    /* Set up font styles here */
    font-weight: bold;
    padding: 0 15px;
  }
  /*-- TOP LEVEL LINK COLORS -----------------------*/
  /* Default */
  #primary-navigation .nav-level-1 > a:link,
  #primary-navigation .nav-level-1 > a:visited {
    color: #fff;
  }
  /* Hover */
  #primary-navigation .nav-level-1 > a:hover,
  #primary-navigation .nav-level-1 > a:active {
    background-color: #29377E;
  }
  /* Current/Active */
  #primary-navigation .nav-level-1.current > a:link,
  #primary-navigation .nav-level-1.current > a:visited,
  #primary-navigation .nav-level-1.current > a:hover,
  #primary-navigation .nav-level-1.current > a:active,
  #service-areas #primary-navigation #nav-21 > a,
  #city-landing-page #primary-navigation #nav-21 > a,
  #wp-blog #primary-navigation #nav-21 > a {
    background-color: #29377E;
  }
  /*-- DROPDOWN ICONS -----------------------*/
  /**** Arrow on the right ****/
  /* Add padding to make room for icon */
  #primary-navigation .nav-level-1:not(.contains-0) > a {
    padding-right: 25px;
    /* Adjust as needed */
  }
  /* Add icon */
  .nav-level-1:not(.contains-0) > a > span::before {
    content: '';
    background-image: url("/assets/templates/main/images/nav/icon-dropdown.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    position: absolute;
    top: 0;
    height: 100%;
    width: 7px;
    right: -14px;
  }
  /**** Arrow below ****/
  /*.nav-level-1:not(.contains-0) > a::before {
  content: '';
  background-image: url("/assets/templates/main/images/nav/icon-dropdown.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  position: absolute;
  height: 6px;
  width: 100%;
  bottom: 4px;
  left: 0;
}*/
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- 2ND-LEVEL ------------------------------------------------------------ */
  /*-- 2ND-LEVEL UL -----------------------*/
  #primary-navigation .nav-level-1 > ul {
    display: none;
    position: absolute;
    background-color: #C31921;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.7);
    text-align: left;
    /*top: 50px;*/
    /* Just in case top position is wonky */
    width: 300px;
  }
  /* Show dropdown ul on hover */
  #primary-navigation .nav-level-1.active > ul {
    display: block;
  }
  /* Postion dropdown ul based on position of parent */
  #primary-navigation .nav-level-1.center-position > ul {
    left: -75px;
  }
  #primary-navigation .nav-level-1.right-position > ul {
    left: auto;
    right: 0;
  }
  /*-- 2ND-LEVEL FLEXBOX UL -----------------------*/
  /* Target Desired Nav Items for Flexbox
  #primary-navigation #nav-8.active > ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }*/
  /* Set up Menu Widths */
  /*#primary-navigation #nav-8 > ul {
    width: 700px;*/
  /* 3-4 Columns */
  /*}*/
  /*#primary-navigation #nav-11 > ul {*/
  /*width: 520px;*/
  /* 2 Columns */
  /*}*/
  /*-- 2ND-LEVEL FLEXBOX LI -----------------------*/
  /* Set Up Column Widths */
  /* 2 Columns */
  /*#nav-11 li.nav-level-2 {
  -ms-flex-preferred-size: 50%;
  flex-basis: 50%;
}*/
  /* 3 Columns 
  #nav-8 li.nav-level-2 {
    -ms-flex-preferred-size: 33.3333%;
    flex-basis: 33.3333%;
  }*/
  /* 4 Columns */
  /*#nav-12 li.nav-level-2 {
  -ms-flex-preferred-size: 25%;
  flex-basis: 25%;
}*/
  /* Column Background Colors 
  #nav-8 li.nav-level-2:nth-child(odd) {
    background-color: #005972;
  }

  #nav-8 li.nav-level-2:nth-child(even) {
    background-color: #049aa2;
  }*/
  /*-- STYLE 2ND-LEVEL FLEXBOX COLUMN TITLES -----------------------*/
  /*#nav-8 .nav-level-2 > a {
    border-bottom: 4px solid #49becc;
    padding-top: 8px;*/
  /* Standardize top padding */
  /*padding-bottom: 4px;*/
  /* Standardize bottom padding */
  /*font-weight: bold;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.7);
  }*/
  /*-- 2ND-LEVEL A -----------------------*/
  .nav-level-2 a {
    padding: 4px 10px;
  }
  /*.nav-level-2:first-child a {
  padding-top: 8px;
}

  .nav-level-2:last-child a {
  padding-bottom: 8px;
}*/
  /*-- 2ND LEVEL LINK COLORS -----------------------*/
  /* Default */
  #primary-navigation .nav-level-2 a:link,
  #primary-navigation .nav-level-2 a:visited {
    color: #fff;
  }
  /* Hover */
  #primary-navigation .nav-level-2 a:hover,
  #primary-navigation .nav-level-2 a:active {
    background-color: #29377E;
  }
  /* Current/Active */
  #primary-navigation .nav-level-2.current > a:link,
  #primary-navigation .nav-level-2.current > a:visited,
  #primary-navigation .nav-level-2.current > a:hover,
  #primary-navigation .nav-level-2.current > a:active,
  #service-areas #primary-navigation #nav-119 > a,
  #city-landing-page #primary-navigation #nav-119 > a,
  #wp-blog #primary-navigation #nav-88 > a {
    background-color: #29377E;
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- 3RD-LEVEL ------------------------------------------------------------ */
  /*-- 3RD LEVEL LINK COLORS -----------------------*/
  /* Default */
  #primary-navigation .nav-level-3 a:link,
  #primary-navigation .nav-level-3 a:visited {
    color: #fff;
  }
  /* Hover */
  #primary-navigation .nav-level-3 a:hover,
  #primary-navigation .nav-level-3 a:active {
    background-color: #29377E;
  }
  /* Current/Active */
  #primary-navigation .nav-level-3.current > a:link,
  #primary-navigation .nav-level-3.current > a:visited,
  #primary-navigation .nav-level-3.current > a:hover,
  #primary-navigation .nav-level-3.current > a:active {
    background-color: #29377E;
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- DROPDOWNS - CONTAINERS ----------------------------------------------- */
  #primary-navigation ul li.nav-level-1 > ul {
    transition: box-shadow ease 0.3s, max-height ease 0.3s;
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- EXPAND NAVIGATION BUTTONS (repurposed as close megadropdown) --------- */
  /* no close button for no-touch devices */
  .no-touchevents div.expand-nav,
  .no-touchevents div.expand-nav span.nav-expand {
    display: none;
  }
  .nav-level-1.active > div.expand-nav {
    background-image: none;
    background-repeat: repeat;
    background-attachment: scroll;
    background-position: 0 0;
    background-color: #DADADA;
    border-radius: 30px;
    box-shadow: 1px 2px 2px #000000;
    color: #000000;
    height: 40px;
    position: absolute;
    left: 280px;
    top: 41px;
    width: 40px;
    z-index: 900;
  }
  /* Standard Button Position */
  .nav-level-1.active.center-position > div.expand-nav {
    left: 210px;
  }
  /* Left-aligned, 3-4-column menu */
  #primary-navigation #nav-8 > div.expand-nav {
    left: 680px;
    /* Nav width - 20px */
  }
  /* Left-aligned, 2-column menu */
  /*#primary-navigation #nav-11 > div.expand-nav {*/
  /*left: 500px; */
  /* Nav width - 20px */
  /*}*/
  /*#primary-navigation #nav-11.center-position > div.expand-nav {*/
  /*left: 423px;*/
  /* Custom Adjustment. Not sure what the math is here... */
  /*}*/
  /*#primary-navigation #nav-12 > div.expand-nav {*/
  /*right: -20px;*/
  /* This one needs to be right-aligned */
  /*}*/
  .nav-level-1.active.right-position > div.expand-nav {
    left: auto;
    right: -25px;
  }
  .nav-level-1.active > div.expand-nav:hover,
  .nav-level-1.active > div.expand-nav:active {
    background-image: none;
    background-repeat: repeat;
    background-attachment: scroll;
    background-position: 0 0;
    background-color: #333333;
    color: #DADADA;
  }
  .nav-level-1.active > div.expand-nav span.nav-expand {
    display: block;
    height: 40px;
    line-height: 40px;
  }
  .nav-level-1.active > div.expand-nav span.nav-expand:after {
    content: 'X';
  }
  /* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
  /* --- DROPDOWNS - NAV ITEMS ------------------------------------------------ */
}

/* @media all and (min-width: 801px) */
/* --- PRIMARY NAVIGATION (DESKTOP) ----------------------------------------- */
/* --- TWO-LINE TEXT -------------------------------------------------------- */
/* Two-Line Text */
/* --- END PRIMARY NAVIGATION (DESKTOP) ------------------------------------- */
/*----------------------------------------------------------------------------*/
.automatic-page-image {
  max-height: 594px;
  min-height: 594px;
}

.automatic-page-image {
  position: absolute;
  height: 100%;
  width: 100%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

#container-banner {
  position: relative;
}

#page-heading {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.28);
}

#page-heading .heading-container {
  box-shadow: inset 2px 3px 0 rgba(0, 0, 0, 0.1);
  position: relative;
  height: 100%;
}

@media all and (max-width: 800px) {
  #page-heading .heading-container {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

.full-width-layout #page-heading .heading-container h1,
.exclude-sidebar #page-heading .heading-container h1 {
  max-width: 800px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media all and (max-width: 800px) {
  #main-container > .width-limiter {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

#home-main-content,
#main-content {
  padding-bottom: 100px;
}

@media all and (max-width: 800px) {
  #home-main-content,
  #main-content {
    padding-bottom: 50px;
  }
}

#content,
#container-content,
#sidebar-content-top,
#sidebar-content-bottom {
  position: relative;
}

#sidebar-content-top {
  margin-bottom: 45px;
}

#top-content-wrap,
#main-content-wrap {
  overflow: hidden;
  position: relative;
}

#main-content-wrap > .width-limiter,
#top-content-wrap > .width-limiter {
  position: relative;
  z-index: 10;
}

@media all and (max-width: 800px) {
  #main-content-wrap > .width-limiter,
  #top-content-wrap > .width-limiter {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

.content-left {
  width: calc(100% - 510px);
  padding-right: 45px;
  box-sizing: border-box;
}

@media all and (min-width: 801px) and (max-width: 1024px) {
  .content-left {
    width: calc(100% - 350px);
  }
}

@media all and (max-width: 800px) {
  .content-left {
    width: 100%;
    padding-right: 0;
  }
}

.sidebar-content {
  width: 510px;
}

@media all and (min-width: 801px) and (max-width: 1024px) {
  .sidebar-content {
    width: 350px;
  }
}

@media all and (max-width: 800px) {
  .sidebar-content {
    width: 100%;
  }
}

@media all and (min-width: 801px) {
  .content-left {
    display: inline-block;
    max-width: 100%;
  }
  .no-top-content #top-content-wrap > .width-limiter {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .full-width-layout .content-left,
  .exclude-sidebar .content-left,
  .exclude-top-sidebar #top-content-wrap .content-left,
  .single-sidebar #top-content-wrap .content-left,
  .exclude-bottom-sidebar #main-content-wrap .content-left {
    display: block;
    width: 100%;
  }
  .full-width-layout .sidebar-right,
  .exclude-sidebar .sidebar-right {
    display: none;
  }
}

#top-content-wrap #breadcrumbs-container {
  padding: 25px 0 5px;
  font-size: 16px;
  font-weight: bold;
  text-transform: uppercase;
}

#top-content-wrap #breadcrumbs-container + h1 {
  margin-top: 10px;
}

#service-areas #top-content-wrap .content-left #service-calls-map .service-call-info-window p,
#service-areas #top-content-wrap .content-left #service-calls-map .service-call-info-window strong,
#service-areas #top-content-wrap .content-left #service-calls-map label {
  color: #000;
}

.has-landing-page-image #top-content-wrap .content-left a:link,
.has-landing-page-image #top-content-wrap .content-left a:visited {
  text-decoration: underline;
}

.has-landing-page-image #top-content-wrap .content-left a:hover,
.has-landing-page-image #top-content-wrap .content-left a:active {
  color: rgba(255, 255, 255, 0.7);
}

.no-main-content.exclude-bottom-sidebar #main-content-wrap > .width-limiter,
.no-main-content.full-width-layout #main-content-wrap > .width-limiter {
  padding-top: 0;
  padding-bottom: 0;
}

.no-landing-page-image:not(.no-main-content) #top-content-wrap > .width-limiter {
  padding-bottom: 0;
}

.no-landing-page-image.full-width-layout #main-content-wrap > .width-limiter {
  padding-top: 0;
}

.exclude-top-sidebar #top-content-wrap .content-left {
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.exclude-bottom-sidebar #main-content-wrap .content-left .content-spacer > *:not(.image-left):not(.image-center):not(.image-right):not(img),
.full-width-layout .content-left .content-spacer > *:not(.image-left):not(.image-center):not(.image-right):not(img),
.exclude-sidebar .content-left .content-spacer > *:not(.image-left):not(.image-center):not(.image-right):not(img) {
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.sidebar-right {
  background-color: transparent;
  width: 510px;
}

@media all and (min-width: 801px) and (max-width: 1024px) {
  .sidebar-right {
    width: 350px;
  }
}

@media all and (max-width: 800px) {
  .sidebar-right {
    width: 100%;
  }
}

@media all and (min-width: 801px) {
  .sidebar-right {
    display: inline-block;
    max-width: 100%;
  }
}

.secondary-tools-outer {
  margin: 45px 0;
  background-color: #e4e4e4;
  border-radius: 10px;
  padding: 40px 30px;
}

.secondary-tools-outer:first-of-type {
  margin-top: 0;
}

.secondary-tools-outer:last-child {
  border: medium none;
  margin-top: 0;
}

.secondary-tools .secondary-tools-heading {
  display: block;
  font-size: 2.3em;
  line-height: 1em;
  font-weight: normal;
  margin: 0 0 0.4em;
}

.secondary-tools ul {
  list-style-type: none;
  padding: 10px 0;
}

.secondary-tools li {
  font-weight: bold;
  padding: 6px 0;
}

.secondary-tools ul li a:link,
.secondary-tools ul li a:visited {
  text-decoration: none;
}

.secondary-tools form {
  margin: 0 0 15px;
}

.secondary-tools form ul {
  list-style-type: none;
  padding: 0;
}

.secondary-tools form fieldset,
.secondary-tools form ul,
.secondary-tools form ul li {
  display: inline-block;
  text-align: center;
  vertical-align: middle;
}

.secondary-tools form fieldset textarea {
  resize: vertical;
}

.secondary-tools form input[type="submit"],
.secondary-tools form button {
  position: relative;
  margin-left: -10px;
}

#container-footer {
  background-color: #C31921;
}

#footer-main {
  padding: 70px 0 25px 0;
}

@media all and (max-width: 800px) {
  #footer-main {
    padding: 25px 0;
  }
  #footer-main .width-limiter {
    max-width: calc(100% - 30px);
  }
}

.footer-main-inner {
  margin-bottom: 20px;
}

@media all and (max-width: 800px) {
  .footer-main-inner {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

.footer-main-inner .left,
.footer-main-inner .center,
.footer-main-inner .right {
  width: 33%;
}

@media all and (max-width: 800px) {
  .footer-main-inner .left,
  .footer-main-inner .center,
  .footer-main-inner .right {
    width: 100%;
  }
}

#footer-bottom {
  background-color: #fff;
  padding: 40px 0 50px 0;
}

#footer-bottom > .width-limiter {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-content: stretch;
  -moz-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  align-items: stretch;
}

@media all and (max-width: 800px) {
  #footer-bottom > .width-limiter {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

#footer-bottom > .width-limiter > div {
  width: 50%;
}

@media all and (max-width: 800px) {
  #footer-bottom > .width-limiter > div {
    width: 100%;
  }
}

#footer-navigation ul {
  list-style-type: none;
  padding: 0;
}

#footer-navigation ul li {
  display: inline-block;
  padding: 0;
  margin: 0;
}

#footer-navigation ul li a {
  display: inline-block;
  padding: 0 5px;
}

#footer-navigation ul li::after {
  content: '\002F';
  display: inline-block;
  position: relative;
  padding: 0 5px;
}

#footer-navigation ul li:last-of-type::after {
  display: none;
}

.imarket-link {
  margin: 0;
}

.imarket-link a {
  position: relative;
  background-color: transparent;
  background-image: url("/assets/templates/main/images/logo-imarket.png");
  background-repeat: no-repeat;
  background-position: 0 50%;
  padding-left: 30px;
  margin: 0 auto;
}

#container-banner {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  min-height: 594px;
  width: 100%;
}

@media all and (max-width: 800px) {
  #container-banner {
    min-height: 250px;
  }
}

#hero .width-limiter {
  height: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  -moz-flex-flow: row nowrap;
  -ms-flex-flow: row nowrap;
  flex-flow: row nowrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-align-content: flex-start;
  -moz-align-content: flex-start;
  -ms-flex-line-pack: start;
  align-content: flex-start;
  -webkit-box-align: start;
  -ms-flex-align: start;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  align-items: flex-start;
}

.hero-content {
  width: 100%;
  max-width: 616px;
  box-shadow: 0 0 25px rgba(0, 0, 0, 0.25);
  background-color: rgba(255, 255, 255, 0.8);
  padding: 50px;
  margin: 75px 0;
}

@media all and (max-width: 800px) {
  .hero-content {
    padding: 50px 25px;
  }
}

#hero .hero-title {
  padding: 0;
}

#contact {
  position: relative;
  background-color: #29377E;
  border-radius: 0;
  margin-top: -75px;
  margin-bottom: 40px;
}

@media all and (max-width: 800px) {
  #contact {
    margin-top: 0;
  }
}

#contact fieldset ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-flow: row wrap;
  -moz-flex-flow: row wrap;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-content: stretch;
  -moz-align-content: stretch;
  -ms-flex-line-pack: stretch;
  align-content: stretch;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  -moz-align-items: stretch;
  align-items: stretch;
}

#contact fieldset ul li {
  width: 100%;
  margin-bottom: 5px;
}

#contact fieldset ul li:last-of-type {
  width: 100%;
}

#contact .widget-heading {
  margin-bottom: 10px;
  margin-top: 0;
}

#home-top-content {
  padding: 45px 0;
}

@media all and (max-width: 800px) {
  #home-top-content {
    padding: 45px 20px 25px 20px;
  }
}

#affiliates {
  margin: 0;
  padding: 50px 0;
}

#home-main-content {
  padding: 85px 0 100px 0;
}

@media all and (max-width: 800px) {
  #home-main-content {
    padding: 25px 0 45px 0;
  }
}

#home-main-content > .width-limiter {
  position: relative;
}

@media all and (max-width: 800px) {
  #home-main-content > .width-limiter {
    -webkit-flex-flow: column nowrap;
    -moz-flex-flow: column nowrap;
    -ms-flex-flow: column nowrap;
    flex-flow: column nowrap;
  }
}

#qmEditor ul li,
#qmEditor ul li a.qmButton,
#qmEditor ul li span {
  font-size: 13px;
}


.carousel {
  width: 100%;
  max-width: 600px;
  margin: 40px auto;
  overflow: hidden;
  position: relative;
  background: rgba(255,255,255,0.9);
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  touch-action: pan-y;
}

.carousel-track {
  display: flex;
  transition: transform 0.5s ease-in-out;
  will-change: transform;
}

.carousel-slide {
  min-width: 100%;
  box-sizing: border-box;
  padding: 40px 20px 0px;
  text-align: center;
}

.quote {
  font-size: 1em;
  font-style: italic;
  color: #333;
}

.source {
  margin-top: 10px;
  font-weight: bold;
  color: #555;
}

.carousel-dots {
  text-align: center;
  padding: 10px 0;
  background: #f9f9f9;
}

.dot {
  display: inline-block;
  height: 12px;
  width: 12px;
  margin: 0 5px;
  background-color: #177BBE;
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.dot.active {
  background-color: #C31921;
}

@media (max-width: 500px) {
  .quote {
    font-size: 1em;
  }

  .carousel-slide {
    padding: 30px 10px;
  }
}
/*# sourceMappingURL=home.css.map */

/* Birdeye Star Rating Box */
.review-star-rating .star-rating-inner {
  position: relative;
  display: inline-block;
  background-color: #29377E;
  -webkit-box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
  box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
  padding: 20px;
  border-radius: 0px;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 265px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 25px;
  justify-content: center;
}
.review-star-rating span.avg-star-rating {
  font-size: 45px;
  font-weight: 700;
  margin-right: 7px;
  color: #fff;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.review-star-rating i.star {
  width: 40px;
  height: 35px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.review-star-rating a {
  font-size: 18px;
  margin-left: 8px;
  color: #fff;
  text-decoration: underline;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.review-star-rating a:hover,
.review-star-rating a:active {
  text-decoration: none;
}
/* Birdeye Reviews Inner */
.testimonial.be-review .source-info {
  min-height: 70px;
}
.testimonial.be-review .source-info .source {
  font-size: 15px;
}
.testimonial.be-review .source-info .rating_output {
  font-style: italic;
  font-size: 14px;  
}
.testimonial.be-review .source-info .source,
.testimonial.be-review .source-info .rating_output {
  /*These colors need to be the same to account for facebook reviews. */
  color: #555;
}

.testimonial.be-review .source-image {
  position: relative;
  display: inline-block;
  float: left;
  margin-right: 20px;
}
.testimonial.be-review .source-image img {
  border-radius: 50%;
  width: 62px;
  max-width: 62px;
  height: 62px;
}
.testimonial.be-review .review-source {
  border-radius: 50%;
  background-color: #fff;
  height: 25px;
  width: 25px;
  position: absolute;
  right: 0px;
  bottom: 0px;
  text-indent: -9999px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: auto 18px;
  -webkit-box-shadow: 0px 0px 3px #9c9c9c;
  box-shadow: 0px 0px 3px #9c9c9c;
}
.review-source.source-Facebook {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-facebook.svg);
}
.review-source.source-Google {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-google.svg);
}
.review-source.source-BBB {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-bbb.svg);
}
i.star {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-review-star.svg);
  width: 20px;
  height: 20px;
  background-repeat: no-repeat;
  display: inline-block;
  background-size: contain;
}
i.icon-recommended {
  background-image: url(/assets/templates/main/images/icons/reviewv3-icon-recommended.svg);
  width: 20px;
  height: 16px;
  background-repeat: no-repeat;
  display: inline-block;
  background-size: contain;
}
.review-source.source-no-source {
  display: none;
}
.testimonial.be-review blockquote {
  margin: 0;
}
.testimonial.be-review .read-more {
  font-size: 18px;
  font-weight: bold;
  text-decoration: underline;
  cursor: pointer;
  color: #29377E;
  display: block;
  margin-bottom: 20px;
}
.testimonial.be-review .read-more:hover,
.testimonial.be-review .read-more:active {
  color: #29377E;
}
@media all and (max-width: 570px) {
  .testimonial.be-review .read-more.popup-link {
    display: none;
  }
}
@media all and (min-width: 571px) {
  .testimonial.be-review .read-more.no-popup-link {
    display: none;
  }
}