/*
Theme Name: Transom Corporation
Theme URI: http://cdevision.com/
Author: cdeVision
Author URI: http://cdevision.com/
Description: Custom theme for Transom Corporation
Version: 5.5
License: No copy or resale
License URI: http://cdevision.com/
Text Domain: Transom Corporation
Tags: 
*/
/*	
    --------------------------------------------------
    CSS RESET 
	--------------------------------------------------
*/
/*
  1. Use a more-intuitive box-sizing model.
*/
*, *::before, *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/*
  2. Remove default margin
*/
* {
  margin: 0;
  padding: 0;
  font: inherit;
}

/*
  3. Allow percentage-based heights in the application
*/
html, body {
  height: 100%;
}

/*
  Typographic tweaks!
  4. Add accessible line-height
  5. Improve text rendering
*/
body {
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/*
  Added
*/
/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/*
  6. Improve media defaults
*/
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/*
  7. Remove built-in form typography styles - Used * above instead

input, button, textarea, select {
  font: inherit;
}
*/
/*
  8. Avoid text overflows
*/
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/* Improved heading in supported browsers */
h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

/* improve readability with max-width on paragraphs and lists */
/* prevent orphans in supported browsers */
p,
li {
  text-wrap: pretty;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
*::before,
*::after {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/*	
    --------------------------------------------------
    Body
	--------------------------------------------------
*/
body {
  background: #FFF;
  font-size: 18px;
  line-height: 1.6;
  color: #333;
  font-family: "Roboto", sans-serif;
  font-weight: normal;
  padding: 0;
  margin: 0;
}

#skipnav {
  display: none;
}

html {
  scroll-behavior: smooth;
}

/*	
    --------------------------------------------------
   	Grid
	-------------------------------------------------- 
*/
.container {
  max-width: 1230px;
  margin: 0 auto;
}

.main-content-inner {
  display: grid;
  max-width: 100%;
  grid-template-columns: minmax(20px, 1fr) minmax(50px, 410px) minmax(50px, 410px) minmax(50px, 410px) minmax(20px, 1fr);
}

.fullscreen {
  grid-column: 1/6;
}

.fullwidth {
  grid-column: 2/5;
}

.twothirds {
  grid-column: 3/5;
}

.columns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
}

.col {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0px;
}

.col.sidebar {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 600px;
          flex: 0 0 600px;
}

@media (max-width: 1270px) {
  .container {
    max-width: 100%;
    padding: 0 20px;
  }
  .wsidebar .container {
    padding: 0;
  }
  .col.sidebar {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
}
@media (max-width: 1023px) {
  .main-content-inner {
    grid-template-columns: 20px minmax(50px, 1fr) minmax(50px, 1fr) minmax(50px, 1fr) 20px;
  }
  .columns {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .columns.four {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
  }
  .columns.revmob {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
@media (max-width: 850px) {
  .col.sidebar {
    max-width: 100%;
    width: 100%;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 100%;
            flex: 1 1 100%;
  }
}
/* small Mobile */
@media (max-width: 650px) {
  .columns,
.columns.four {
    display: block;
    margin-right: 0;
    margin-left: 0;
    padding: 0;
    gap: 0;
  }
  .columns .col,
.col.sidebar {
    max-width: 100% !important;
    width: 100% !important;
    margin-right: 0;
    margin-left: 0;
    padding: 0;
  }
  .col.sidebar {
    margin-top: 50px;
  }
}
/*	
  ----------------------------------------------------------------
  Base - Typography and other classes - included into TinyMCE
	----------------------------------------------------------------
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #333;
  margin: 20px 0 6px 0;
  padding: 0;
  font-family: "Montserrat", sans-serif;
  font-weight: 900;
  font-style: normal;
  text-transform: uppercase;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
  color: #333;
  text-decoration: none !important;
  font-weight: 900;
}
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover {
  color: #F51800;
  text-decoration: underline !important;
  font-weight: 900 !important;
}

h1.center,
h2.center,
h3.center,
h4.center,
h5.center,
h6.center {
  text-align: center;
}

h1,
.h1 {
  font-size: 45px;
  line-height: 55px;
  color: #333;
  font-weight: 900;
  margin: 20px 0 6px 0;
}

h2,
.h2 {
  font-size: 36px;
  line-height: 46px;
  color: #333;
  font-weight: 900;
  margin: 20px 0 6px 0;
}

h3,
.h3 {
  font-size: 30px;
  line-height: 40px;
  color: #333;
  font-weight: 900;
  margin: 20px 0 6px 0;
}

h4,
.h4 {
  font-size: 24px;
  line-height: 34px;
  color: #333;
  font-weight: 900;
  margin: 20px 0 6px 0;
}

h5,
h6 {
  font-size: 24px;
  line-height: 34px;
  color: #333;
  font-weight: 900;
  margin: 20px 0 6px 0;
}

/* Mobile */
@media (max-width: 767px) {
  h1,
.h1 {
    font-size: 39px;
    line-height: 49px;
  }
  h2,
.h2 {
    font-size: 30px;
    line-height: 40px;
  }
  h3,
.h3 {
    font-size: 24px;
    line-height: 34px;
  }
  h4,
.h4 {
    font-size: 20px;
    line-height: 30px;
  }
  h5,
h6 {
    font-size: 20px;
    line-height: 30px;
  }
  h1 br,
h2 br,
h3 br,
h4 br,
h5 br,
h6 br {
    display: none;
  }
}
p {
  font-size: 18px;
  line-height: 1.6;
  color: #333;
  font-family: "Roboto", sans-serif;
  font-weight: normal;
  font-weight: normal;
  margin: 0 0 24px 0;
}

p.smallmargin {
  margin: 0 0 10px 0;
}

p img {
  margin: 0;
}

em,
i {
  font-style: italic;
  line-height: inherit;
}

strong,
b {
  font-weight: bold;
  line-height: inherit;
}

small {
  font-size: 60%;
  line-height: inherit;
}

ul {
  margin: 0 0 24px 26px;
  padding: 0;
}

ul li {
  margin: 0 0 10px 0;
  padding: 0;
  list-style: url(images/bullet.png); /* Also change .white-text Helper Class in _misc.scss */
}

ul ul {
  margin: 10px 0 10px 60px;
  padding: 0;
}

ol {
  margin: 0 0 24px 20px;
  padding: 0;
}

ol li {
  margin: 0 0 12px 0;
  padding: 0 0 0 4px;
}

ol ol {
  margin: 10px 0 10px 60px;
  padding: 0;
}

blockquote {
  padding: 0;
  margin: 0;
  border: none;
  font-size: 16px;
  line-height: 22px;
}

blockquote p {
  padding: 0 0 0 45px;
  margin: 0 0 16px;
  font-size: 16px;
  line-height: 22px;
  border: none;
}

p.wp-caption-text {
  font-size: 12px !important;
  line-height: 20px !important;
  text-align: center !important;
  padding: 0 20px 0 20px;
  color: #666;
  font-style: normal;
  margin: 0;
}

.gallery-caption {
  font-size: 14px !important;
  line-height: 22px !important;
  text-align: center !important;
  padding: 10px 20px 0 20px;
  color: #666;
  font-style: normal;
  margin: 0;
}

/*	--------------------------------------------------
	Links
	-------------------------------------------------- */
a {
  color: #F51800;
  line-height: inherit;
  word-wrap: break-word;
  font-weight: bold;
  text-decoration: none;
}

a:visited {
  color: inherit;
  text-decoration: inherit;
}

a:focus {
  color: inherit;
  outline: none;
  text-decoration: inherit;
}

a:visited {
  line-height: inherit;
  color: #F51800;
}

a:hover {
  color: #F51800;
  font-weight: bold;
  text-decoration: underline;
}

a.box {
  display: inline-block;
  margin: 0;
  padding: 10px 12px;
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  line-height: 26px;
  color: #FFF;
  text-decoration: none;
  font-style: normal !important;
  font-weight: 600 !important;
  position: relative;
  background: #010101;
  text-transform: uppercase;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  border-radius: 6px;
}

a.box:visited {
  color: #FFF;
  text-decoration: inherit;
  font-weight: inherit;
}

a.box:after {
  font-size: 16px;
  content: "\f054";
  padding-left: 6px;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
  display: inline-block;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

a.box.back:before {
  font-size: 16px;
  content: "\f054";
  padding-right: 6px;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
  display: inline-block;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

a.box.back:after {
  display: none;
}

a.box.rev,
.compare a.box {
  padding: 0;
  color: #FFF;
  background: none;
}

a.box.rev:visited,
.compare a.box:visited {
  color: #FFF;
}

a.box.white {
  color: #FFF;
}

a.box.white:visited {
  color: #FFF;
}

a.box.pdf:after {
  font-size: 18px;
  padding-left: 8px;
  content: "\f1c1";
}

a.box.view_more::after {
  content: "\f078";
}

a.box:hover {
  color: #FFF;
  text-decoration: inherit;
  font-weight: inherit;
  background: #F51800;
  text-decoration: none !important;
}

a.box.rev:hover,
.compare a.box:hover {
  color: #FFF;
  text-decoration: inherit;
  font-weight: inherit;
  background: none;
}

a.box.white:hover {
  color: #FFF;
}

p + p.linkwrap {
  margin-top: -10px;
}

/*	--------------------------------------------------
	Misc
	-------------------------------------------------- */
/* Utility classes */
.no-pad {
  padding: 0;
}

.no-margin {
  margin: 0;
}

.no-margin-top {
  margin-top: 0;
}

.color-white {
  color: #FFF;
}

.screen-reader-text {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.clearfloats {
  clear: both;
  line-height: 0px;
  height: 0px;
  font-size: 0px;
}

div[id*=gallery-] {
  margin: 20px 0 20px 0 !important;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 30px;
}

.two div[id*=gallery-] {
  grid-template-columns: 1fr 1fr;
}

.accordiancontent div[id*=gallery-] {
  margin: 30px 0 !important;
}

div[id*=gallery-] .gallery-item {
  margin: 0 !important;
}

.gallery-item {
  margin: 0 !important;
  width: 100% !important;
  padding: 0 !important;
}

.gallery br {
  display: none !important;
}

/* Mobile */
@media (max-width: 767px) {
  div[id*=gallery-] {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
div[id*=gallery-] img {
  border: none !important;
  max-width: 100%;
  width: 100%;
  height: auto;
  display: block;
}

div[id*=gallery-] img:hover {
  opacity: 0.8;
}

img[class*=wp-image-] {
  margin-top: 0;
  margin-bottom: 0;
}

/* Images sizes */
.size-auto,
.size-full,
.size-large,
.size-medium,
.size-thumbnail {
  max-width: 100%;
  height: auto;
}

.alignleft {
  float: left;
  margin: 4px 30px 20px 0 !important;
  display: block;
}

.alignright {
  float: right;
  margin: 4px 0 20px 30px !important;
  display: block;
}

.widget {
  margin-bottom: 0;
  margin-top: 0;
}

.wp-caption {
  padding: 0;
  border: none;
}

@media handheld, only screen and (max-width: 767px) {
  .alignleft {
    max-width: 40% !important;
    height: auto;
  }
  .alignright {
    max-width: 40% !important;
    height: auto;
  }
  .main-content-inner img {
    max-width: 100%;
    height: auto;
  }
}
@media (max-width: 767px) {
  .attachment-thumbnail {
    max-width: 100% !important;
    height: auto !important;
  }
}
.fancybox-skin {
  -webkit-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5) !important;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5) !important;
}

.fancybox-toolbar {
  right: auto !important;
  left: 0;
  top: 0;
}

/* Object Fit Image */
.object-fit-image {
  position: relative;
  padding-bottom: 70%;
  overflow: hidden;
}

.object-fit-image img {
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
  width: 100%;
  -o-object-position: center center;
     object-position: center center;
}

/* Appear Items */
.has-animation {
  opacity: 0;
  -webkit-transition-timing-function: ease-in;
          transition-timing-function: ease-in;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}

.has-animation.animate-in {
  opacity: 1 !important;
  -webkit-transform: translate(0, 0) !important;
          transform: translate(0, 0) !important;
}

/* Helper Classes */
.clear-first-child-margin-top > *:first-child {
  margin-top: 0;
}

.clear-first-child-margin-top > a.anchor:first-child + h2,
.clear-first-child-margin-top > a.anchor:first-child + h3,
.clear-first-child-margin-top > a.anchor:first-child + h4 {
  margin-top: 0;
}

.clear-last-child-margin-bottom > *:last-child {
  margin-bottom: 0;
}

.clear-child-margin-top-bottom > *:first-child {
  margin-top: 0;
}

.clear-child-margin-top-bottom > *:last-child {
  margin-bottom: 0;
}

.white-text {
  color: #FFF;
}
.white-text h1,
.white-text h2,
.white-text h3,
.white-text h4,
.white-text h5,
.white-text h6,
.white-text p,
.white-text ul,
.white-text a {
  color: #FFF;
}
.white-text a:not(a.box) {
  color: #FFF;
  text-decoration: underline !important;
}
.white-text a:hover:not(a.box),
.white-text a:visited:not(a.box) {
  color: #FFF;
  text-decoration: underline !important;
  opacity: 0.6;
}
.white-text ul li {
  list-style: url(images/bullet_white.png);
}

/*	--------------------------------------------------
   	Header
	-------------------------------------------------- */
/* Header */
.site-header {
  margin: 0 auto;
  padding: 0 20px;
  width: 1500px;
  max-width: 100%;
}

.site-header .wrap {
  position: static;
}

.site-header__pad {
  height: 140px;
  position: relative;
}

/* Site Branding */
.site-branding {
  width: 356px;
  height: 90px;
  position: absolute;
  bottom: 18px;
  left: 0;
}

.site-branding__site-title {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
}

.site-branding__site-title a {
  width: 100%;
  height: 100%;
  display: block;
  margin: 0;
  padding: 0;
  text-indent: -4000px;
  background: url(images/logo.png) no-repeat;
  background-size: contain;
}

/* Mobile */
@media (max-width: 1140px) {
  .site-branding {
    position: absolute;
    bottom: auto;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@media (max-width: 767px) {
  .site-branding {
    width: 300px;
    height: 80px;
  }
}
/* Tool */
.mobile-menu-cover .tool {
  display: none;
  position: static;
  margin: 15px 30px 0 30px;
}

/*	--------------------------------------------------
   	Nav Bar - Desk
	-------------------------------------------------- */
.primary-navigation {
  position: absolute;
  bottom: 20px;
  right: 0;
}

.primary-navigation .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.primary-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  padding: 0;
  z-index: 9999;
}

.primary-menu .menu-item {
  padding: 0;
  margin: 0;
  position: relative;
  list-style: none;
}

.primary-menu .menu-item a {
  display: block;
  font-size: 18px;
  line-height: 44px;
  margin: 0;
  padding: 0 15px;
  text-decoration: none;
  color: #010101;
  font-family: "Roboto", sans-serif;
  font-style: normal;
  font-weight: 700;
  text-transform: uppercase;
}

.primary-menu .menu-item:last-child a {
  padding-right: 0;
}

.primary-menu .menu-item.current_page_item > a,
.primary-menu .menu-item.current-menu-item > a,
.primary-menu .menu-item.current-post-ancestor > a,
.primary-menu .menu-item.current-category-ancestor > a,
.primary-menu .menu-item.current_page_ancestor > a {
  color: #F51800;
}

.primary-menu .menu-item:hover > a {
  color: #F51800;
}

.primary-menu .sub-menu {
  display: none;
  position: absolute;
  top: 50px;
  left: 0;
  min-width: 200px;
  margin: 0;
  padding: 0;
  z-index: 99999;
  background: #333;
  padding: 0;
}

/*.menu-desk > ul > li:hover > ul { display:block; }*/
.primary-menu .sub-menu .menu-item {
  padding: 0;
  margin: 0;
}

.primary-menu .menu-item .sub-menu .menu-item a {
  display: block;
  font-size: 16px;
  line-height: 24px;
  font-family: "Roboto", sans-serif;
  font-style: normal;
  font-weight: 700;
  padding: 5px 15px;
  color: #FFF;
  background: none;
  white-space: nowrap;
}

.primary-menu .sub-menu .menu-item:first-child a {
  padding-top: 12px;
}

.primary-menu .sub-menu .menu-item:last-child a {
  padding-bottom: 12px;
}

.primary-menu .menu-item .sub-menu .menu-item a:hover {
  color: #FFF;
  opacity: 0.6;
}

.primary-menu .menu-item .sub-menu .menu-item.current-menu-item > a {
  color: #FFF;
  opacity: 0.6;
}

.tool-navigation {
  position: absolute;
  right: 0;
  top: 24px;
}

@media (max-width: 1250px) {
  .tool-navigation {
    right: 37px;
  }
}
@media (max-width: 1140px) {
  .tool-navigation {
    display: none;
  }
}
.tool-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  margin: 0;
  padding: 0;
  z-index: 9999;
}
.tool-menu .menu-item {
  padding: 0;
  margin: 0;
  position: relative;
  list-style: none;
}
.tool-menu .menu-item a {
  display: block;
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 700;
  color: #FFF;
  text-decoration: none;
  background-color: #010101;
  border-radius: 6px;
  padding: 5px 10px;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}
.tool-menu .menu-item a .fa {
  padding-right: 8px;
}
.tool-menu .menu-item a:hover {
  background-color: #F51800;
}

@media (max-width: 1250px) {
  .primary-navigation {
    display: none;
  }
  .mobile-menu-cover .tool-navigation {
    position: static;
  }
  .mobile-menu-cover .tool-navigation .tool-menu {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin: 0 30px;
    gap: 20px;
  }
  .mobile-menu-cover .tool-navigation .tool-menu .menu-item {
    padding: 0;
    margin: 0;
    position: relative;
    list-style: none;
  }
  .mobile-menu-cover .tool-navigation .tool-menu .menu-item a {
    background-color: #F51800;
  }
  .mobile-menu-cover .tool-navigation .tool-menu .menu-item a:hover {
    background-color: #2C2E35;
  }
}
/*	--------------------------------------------------
   	Menu Mobile
	-------------------------------------------------- */
.mobile-hamburger {
  display: none;
  width: 34px;
  height: 34px;
  position: fixed;
  right: 10px;
  top: 24px;
  z-index: 999999;
}

.mobile-hamburger__link {
  background: #010101 url(images/mob-closed.png) center center no-repeat !important;
  display: block;
  width: 34px;
  height: 34px;
  padding: 0;
  padding: 0;
  text-indent: -4000px;
  border-radius: 6px;
}

.mobile-hamburger__link.open {
  background: #010101 url(images/mob-open.png) center center no-repeat !important;
}

.mobile-menu-cover {
  display: none;
  background: #010101;
  color: #FFF;
  padding: 0;
  clear: both;
  margin: 0 auto;
  position: fixed;
  top: 0;
  right: 0;
  height: 150%;
  max-width: 340px;
  min-width: 340px;
  overflow: auto;
  z-index: 99999;
}

.mob-nav-container {
  margin: 0;
  padding: 0;
  display: none;
}

.mob-nav-menu {
  margin: 20px 30px 15px 30px;
  padding: 0;
}

.mob-nav-menu .menu-item {
  display: block;
  padding: 0;
  margin: 0;
  list-style: none;
}

.mob-nav-menu .menu-item a {
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  line-height: 28px;
  padding: 8px 0;
  display: block;
  text-decoration: none;
  color: #FFF;
  margin: 0;
  font-weight: 600;
  font-style: normal;
  text-transform: uppercase;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}

.mob-nav-menu .menu-item a:hover {
  color: #FFF;
  opacity: 0.6;
}

.mob-nav-menu .sub-menu {
  display: none;
  margin: 0 0 10px 0;
  padding: 0;
  z-index: 99999;
  padding: 0;
}

.mob-nav-menu .sub-menu .menu-item a {
  font-size: 16px;
  line-height: 24px;
  padding: 8px 0;
  display: block;
  text-decoration: none;
  color: #FFF;
  margin: 0;
  font-weight: 400;
  font-style: normal;
}

.mob-nav-menu .sub-menu .menu-item:first-child a {
  padding-top: 4px;
}

.mob-nav-menu .sub-menu .menu-item:last-child a {
  padding-bottom: 10px;
}

@media (max-width: 1250px) {
  .mobile-hamburger {
    display: block;
  }
  .mobile-menu-cover {
    max-width: 400px;
    min-width: 400px;
  }
}
@media (max-width: 660px) {
  .mobile-hamburger {
    top: 10px;
    right: 10px;
  }
  .mobile-menu-cover {
    max-width: 100%;
    min-width: 100%;
  }
}
/*	--------------------------------------------------
   	Home
	-------------------------------------------------- */
/* Alert */
.alertbar {
  background: #F51800;
  padding: 15px 0;
  color: #FFF;
}

.alertbar .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 20px;
}

.alertbar .text {
  font-size: 20px;
  color: #FFF;
}

.alertbar .text p {
  font-size: 20px;
  color: #FFF;
  margin: 0;
}

.alertbar .text a {
  color: #FFF;
  font-weight: bold;
  text-decoration: none;
}

.alertbar .text a:hover {
  color: #FFF;
  font-weight: bold;
  text-decoration: underline;
}

.alertbar .close {
  font-size: 20px;
  color: #FFF;
  margin: 6px 0 0 0;
}

.alertbar .close:hover {
  opacity: 0.8;
  cursor: pointer;
}

/* Slideshow */
/* Stop Chrome Slick Flicker */
.slick-slide {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.home-slideshow-wrap {
  position: relative;
}

.homeslideshow {
  position: static;
  height: 800px;
  width: 100%;
  margin: 0;
  padding: 0;
  z-index: 10;
  opacity: 0;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}

.homeslideshow.slick-initialized {
  opacity: 1;
}

.homeslideshow .slide {
  position: relative;
  height: 800px;
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.homeslideshow .slide .text_overlay {
  position: absolute;
  left: calc(50% - 615px);
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  z-index: 30;
}
.homeslideshow .slide .text_overlay .text {
  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-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 20px;
  max-width: 600px;
}
.homeslideshow .slide .text_overlay .text h2 {
  font-size: 70px;
  line-height: 80px;
  margin: 0;
  text-shadow: 0px 5px 6px rgba(0, 0, 0, 0.25);
}

.homeslideshow .slide img {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center top;
     object-position: center top;
  z-index: 10;
}

.homeslideshow .slick-prev {
  left: 20px;
  z-index: 1;
}

.homeslideshow .slick-next {
  right: 20px;
  z-index: 1;
}

.slick-prev:before,
.slick-next:before {
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}

.slick-prev:hover:before,
.slick-next:hover:before {
  opacity: 0.8;
}

@media (max-width: 1330px) {
  .homeslideshow .slick-arrow {
    display: none !important;
  }
}
@media (max-width: 1270px) {
  .homeslideshow .slide .text_overlay {
    left: 20px;
    top: 50%;
  }
}
/* mobile */
@media (max-width: 767px) {
  .homeslideshow {
    height: 400px;
  }
  .homeslideshow .slide {
    height: 400px;
  }
  .homeslideshow .slide .text_overlay .text {
    padding-right: 25%;
  }
  .homeslideshow .slide .text_overlay .text h2 {
    font-size: 32px;
    line-height: 40px;
  }
}
/* Elevator */
.elevator {
  background: #F51800 url(images/background-product-header.png) calc(50% - 540px) 50px no-repeat;
  padding: 100px 0;
}
.elevator .wrap {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 50px;
  max-width: 100%;
}
.elevator .wrap h2 {
  font-size: 45px;
  line-height: 55px;
  margin: 0 0 15px 0;
}

/* mobile */
@media (max-width: 1000px) {
  .elevator {
    background-position: calc(50% - 250px) 50px;
  }
  .elevator .wrap h2 {
    font-size: 35px;
    line-height: 45px;
  }
}
@media (max-width: 767px) {
  .elevator {
    padding: 50px 0;
  }
  .elevator .wrap {
    gap: 30px;
  }
  .elevator .wrap h2 {
    font-size: 30px;
    line-height: 40px;
  }
}
/*	--------------------------------------------------
   	Content
	-------------------------------------------------- */
/* Page wrap */
.pagewrap {
  padding: 0 0 80px 0;
}

/* Page header */
.page-header {
  background-color: #F51800;
  height: 150px;
  position: relative;
  overflow: hidden;
  margin-bottom: 60px;
}

body.page-template-page-temp-products .page-header {
  margin-bottom: 0;
}

.page-header .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(calc(-1230px/2), 0);
          transform: translate(calc(-1230px/2), 0);
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 20;
}

.page-header h1,
.page-header .blog-title {
  margin: 0;
  padding: 0;
  color: #FFF;
  text-transform: uppercase;
}

/* Mobile */
@media (max-width: calc(1230px + 40px)) {
  .page-header .wrap {
    left: 0;
    -webkit-transform: none;
            transform: none;
    padding-left: 20px;
  }
}
/* Mobile */
@media (max-width: 767px) {
  .page-header h1,
.page-header .blog-title {
    font-size: 31px;
    line-height: 41px;
    margin: 0 0 20px 0;
  }
}
/* Main Content */
.intro {
  font-size: 20px;
  line-height: 1.6;
}

.intro p {
  font-size: 20px;
  line-height: 1.6;
}

/* Mobile */
@media (max-width: 767px) {
  .intro {
    font-size: 18px;
    line-height: 1.6;
  }
  .intro p {
    font-size: 18px;
    line-height: 1.6;
  }
}
/* Products page */
.product_grid_wrap {
  background-color: #2C2E35;
  padding: 60px 0;
  margin-bottom: 60px;
}

.product_grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 60px 30px;
}
.product_grid .product {
  position: relative;
  text-align: center;
  padding-bottom: 50px;
}
.product_grid .product img {
  display: block;
  margin: 0 auto 20px auto;
  max-width: 100%;
  height: auto;
  border-radius: 50%;
}
.product_grid .product h2 {
  font-size: 30px;
  line-height: 38px;
  margin: 0 0 5px 0;
}
.product_grid .product h2 a {
  text-decoration: none !important;
  color: #F51800 !important;
}
.product_grid .product h2 a:hover {
  text-decoration: underline !important;
  color: #F51800 !important;
  opacity: 1;
}
.product_grid .product .product_type {
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
  margin: 0 0 10px 0;
}
.product_grid .product a.box {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  white-space: nowrap;
}

@media (max-width: 767px) {
  .product_grid {
    grid-template-columns: 1fr;
    width: 600px;
    max-width: 100%;
    margin: 0 auto;
  }
}
/* Product Single */
.page-header-product {
  background: #F51800 url(images/background-product-header.png) calc(50% - 540px) 150px no-repeat;
  padding: 60px 0;
  margin-bottom: 80px;
}
.page-header-product h1 {
  margin: 0 0 6px 0;
}
.page-header-product .product_type {
  font-family: "Montserrat", sans-serif;
  font-size: 36px;
  line-height: 44px;
  font-weight: 600;
  margin-bottom: 20px;
}
.page-header-product .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
}
.page-header-product .wrap .right {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(50% - 15px);
          flex: 0 0 calc(50% - 15px);
}
.page-header-product .wrap .right img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 50%;
}
.page-header-product .anchor_link_bar {
  margin-top: 40px;
  margin-bottom: 0;
}

@media (max-width: 1230px) {
  .page-header-product {
    background-position: calc(50% - 400px) 150px;
  }
  .page-header-product .product_type {
    font-size: 28px;
    line-height: 36px;
  }
  .page-header-product .wrap .right {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(40% - 15px);
            flex: 0 0 calc(40% - 15px);
  }
}
@media (max-width: 900px) {
  .page-header-product {
    background-image: none;
  }
  .page-header-product .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .page-header-product .wrap .right {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
  }
  .page-header-product .wrap .right img {
    margin: 0 auto;
  }
}
/*	--------------------------------------------------
   	Sidebar
	-------------------------------------------------- */
.sidebar h3,
.sidebar .h3 {
  font-size: 24px;
  line-height: 34px;
}

.sidebar h4,
.sidebar .h4 {
  font-size: 20px;
  line-height: 30px;
}

.sidebar .fullwidthphoto {
  margin-bottom: 30px;
}

/*	--------------------------------------------------
   	Blog
	-------------------------------------------------- */
/* Blog Header */
.blog_header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  margin: 0 0 50px 0;
  gap: 30px;
}

.blog_header ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
  margin: 0;
  padding: 0;
}

.blog_header ul li {
  list-style: none;
  margin: 0;
}

.blog_header ul li a {
  display: block;
  font-size: 18px;
  line-height: 26px;
  font-weight: 700;
  color: #F51800;
}

.blog_header ul li a:hover,
.blog_header ul li.active a {
  font-weight: 700;
  color: #F51800;
}

@media (max-width: 767px) {
  .blog_header ul {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px;
  }
}
/* Blog Grid */
.bloggrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 40px 30px;
}
.bloggrid .object-fit-image {
  margin-bottom: 10px;
}

.blogitem h3 {
  margin-top: 0;
}

@media (max-width: 600px) {
  .bloggrid {
    max-width: 285px;
    margin-left: auto;
    margin-right: auto;
  }
}
/*	--------------------------------------------------
   	Pager
	-------------------------------------------------- */
ul.pager {
  margin: 0;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#nav-below {
  margin: 30px 0 0 0;
}

ul.pager li {
  margin: 0;
  padding: 0;
  list-style: none !important;
}

ul.pager a {
  display: inline-block;
  margin: 0;
  padding: 6px 12px;
  font-size: 16px;
  line-height: 24px;
  color: #FFF;
  text-decoration: none;
  font-style: normal !important;
  font-weight: 700 !important;
  position: relative;
  background: #F51800;
  text-transform: uppercase;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  border-radius: 6px;
}

ul.pager a:visited {
  color: #FFF;
  text-decoration: inherit;
  font-weight: inherit;
}

ul.pager a:after {
  font-size: 16px;
  content: "\f054";
  padding-left: 6px;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
  display: inline-block;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

ul.pager a:hover {
  color: #FFF;
  text-decoration: inherit;
  font-weight: inherit;
  background: #010101;
  text-decoration: none !important;
}

ul.pager .previous a:before {
  font-size: 16px;
  content: "\f053";
  padding-right: 6px;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
  display: inline-block;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

ul.pager .previous a:after {
  display: none;
}

/* Mobile */
/*	--------------------------------------------------
   	Footer
	-------------------------------------------------- */
.site-footer {
  background: #010101;
  padding: 0 0 100px 0;
  color: #FFF;
}

.site-footer h4,
.site-footer p {
  color: #FFF;
}

.site-footer a {
  color: #FFF;
  font-weight: 700;
}

.site-footer a:hover {
  color: #FFF;
  text-decoration: underline !important;
}

.site-footer a:visited {
  color: #FFF;
}

/* Mobile */
@media (max-width: 767px) {
  .site-footer {
    padding: 0 0 30px 0;
  }
}
/* Mobile */
/* Consultation */
a.consultation {
  display: block;
  background-color: #F51800;
  margin-bottom: 80px;
  padding: 30px 0;
  text-decoration: none;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}
a.consultation .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 30px;
}
a.consultation .wrap .image {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 175px;
          flex: 0 0 175px;
}
a.consultation .wrap .image img {
  display: block;
  margin: 0;
}
a.consultation .wrap .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  padding: 30px 0;
}
a.consultation .wrap .text h3 {
  margin: 0 0 6px 0;
}
a.consultation .wrap .text p {
  margin: 0;
}
a.consultation .wrap .text i {
  font-size: 52px;
}
a.consultation:hover {
  text-decoration: none !important;
  background-color: #dc1600;
}

/* Mobile */
@media (max-width: 550px) {
  a.consultation {
    margin-bottom: 50px;
  }
  a.consultation .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0;
  }
}
.footercolumns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px;
  margin-bottom: 60px;
}
.footercolumns .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px;
}
.footercolumns .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px;
  padding-top: 10px;
}
.footercolumns .text .loc {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}
.footercolumns .text .loc p {
  margin: 0;
}

h3.footer_site-title {
  width: 120px;
  height: 120px;
  margin: 0;
}
h3.footer_site-title a {
  display: block;
  width: 100%;
  height: 100%;
  text-indent: -4000px;
  background-image: url("images/logo_footer.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}

.assoc ul {
  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;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  margin: 10px 0 0 0;
}
.assoc ul li {
  list-style: none;
  margin: 0;
}
.assoc ul a {
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
}
.assoc ul a:hover {
  opacity: 0.6;
}
.assoc ul img {
  max-width: 200px;
  max-height: 100px;
  height: auto;
  width: auto;
}

/* Copyright */
.site-info {
  font-size: 12px;
  line-height: 16px;
}

.site-info p {
  font-size: 12px;
  line-height: 16px;
  margin: 0 0 20px 0;
}

.site-info a {
  font-size: 12px;
  line-height: 16px;
  font-weight: normal;
  text-decoration: none;
  padding-left: 5px;
}

.site-info a:hover {
  text-decoration: underline;
}

/*	--------------------------------------------------
   	Flexible Content
	-------------------------------------------------- */
/* UL columns */
.ul_two ul {
  -webkit-columns: 2;
     -moz-columns: 2;
          columns: 2;
  -webkit-column-gap: 80px;
     -moz-column-gap: 80px;
          column-gap: 80px;
}

.ul_three ul {
  -webkit-columns: 3;
     -moz-columns: 3;
          columns: 3;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}

.ul_four ul {
  -webkit-columns: 4;
     -moz-columns: 4;
          columns: 4;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}

.ul_two ul li,
.ul_three ul li,
.ul_four ul li {
  -webkit-column-break-inside: avoid;
     -moz-column-break-inside: avoid;
          break-inside: avoid-column;
}

@media (max-width: 1200px) {
  .ul_four ul {
    -webkit-columns: 3;
       -moz-columns: 3;
            columns: 3;
  }
}
@media (max-width: 1000px) {
  .ul_three ul,
.ul_four ul {
    -webkit-columns: 2;
       -moz-columns: 2;
            columns: 2;
  }
}
@media (max-width: 700px) {
  .ul_two ul,
.ul_three ul,
.ul_four ul {
    -webkit-columns: 1;
       -moz-columns: 1;
            columns: 1;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .ul_two ul li,
.ul_three ul li,
.ul_four ul li {
    -webkit-column-break-inside: auto;
       -moz-column-break-inside: auto;
            break-inside: auto;
  }
}
/* Padding Before and After */
.pad_before_small {
  padding-top: 30px;
}

.pad_before_med {
  padding-top: 50px;
}

.pad_before_large {
  padding-top: 80px;
}

.pad_after_small {
  padding-bottom: 30px;
}

.pad_after_med {
  padding-bottom: 50px;
}

.pad_after_large {
  padding-bottom: 80px;
}

/* Block Background */
.block_background_light {
  background-color: #efefef;
}

.block_background_dark {
  background-color: #2C2E35;
  padding: 75px 0 55px 0;
  border-top: 4px solid #FFF;
  color: #FFF;
}
.block_background_dark h1,
.block_background_dark h2,
.block_background_dark h3,
.block_background_dark p,
.block_background_dark ul,
.block_background_dark a {
  color: #FFF;
}
.block_background_dark a:not(a.box) {
  color: #FFF;
  text-decoration: underline !important;
}
.block_background_dark a:hover:not(a.box),
.block_background_dark a:visited:not(a.box) {
  color: #FFF;
  text-decoration: underline !important;
  opacity: 0.6;
}
.block_background_dark ul li {
  list-style: url(images/bullet_white.png);
}

/*	--------------------------------------------------
   	Flexible Content Styles
	-------------------------------------------------- */
/* Headline */
.testing {
  color: green;
}

/* Headline Left Intro */
.headline_left_intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  margin-bottom: 30px;
}

@media (max-width: 800px) {
  .headline_left_intro {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .headline_left_intro .headline br {
    display: none;
  }
}
/* Spacer Block */
.spacer_small {
  height: 20px;
}

.spacer_medium {
  height: 40px;
}

.spacer_large {
  height: 60px;
}

.spacer_lumbo {
  height: 80px;
}

/* 1 Column */
/* 4 Column / Multi Column */
.column_image.object-fit-image {
  padding-bottom: 66%;
  margin: 0 0 20px 0;
}

.fullwidth.columns.four .linkwrap {
  margin-bottom: 50px;
}

.columns.four.button_end .col {
  position: relative;
  padding-bottom: 60px;
}
.columns.four.button_end .col .linkwrap {
  position: absolute;
  bottom: 0;
  left: 0;
}

/* Full width Photo */
.fullwidthphoto {
  margin-bottom: 30px;
}

.fullwidthphoto img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

/* Highlight Box */
.highlight_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 0 50px 0;
  gap: 30px;
}

.block_background_light .highlight_box,
.block_background_dark .highlight_box {
  margin: 0 0 24px 0;
}

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

.highlight_box .imagecol {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 600px;
          flex: 0 0 600px;
}

.highlight_box.narrow .imagecol {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 400px;
          flex: 0 0 400px;
}

.highlight_box img {
  display: block;
  max-width: 100%;
  height: auto;
}

.highlight_box p.caption {
  font-size: 14px;
  line-height: 22px;
  margin: 10px 0 0 0;
  text-align: center;
}

.highlight_box ul {
  -webkit-column-count: 2;
     -moz-column-count: 2;
          column-count: 2;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}

@media (max-width: 1100px) {
  .highlight_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 30px 0 30px 0;
  }
  .highlight_box .imagecol {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
  }
  .highlight_box.narrow .imagecol {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
  }
  .highlight_box ul {
    -webkit-column-count: 1;
       -moz-column-count: 1;
            column-count: 1;
    -webkit-column-gap: 0;
       -moz-column-gap: 0;
            column-gap: 0;
  }
  .highlight_box.left {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .highlight_box .imagecol {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0px;
            flex: 1 1 0;
  }
  .highlight_box h2 {
    font-size: 30px;
    line-height: 40px;
  }
}
/* Hero Image & Text */
.hero_image {
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
}
.hero_image .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 80px 0;
  min-height: 500px;
}
.hero_image .text.right {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.hero_image .text .wrap {
  padding: 30px;
  max-width: 600px;
  background-color: rgba(1, 1, 1, 0.65);
}

/* Mobile */
@media (max-width: 767px) {
  .hero_image {
    background-attachment: scroll;
    padding: 60px 0;
  }
  .hero_image .container {
    padding: 0;
    margin: 0;
  }
  .hero_image .text {
    padding: 0 20px;
  }
  .hero_image .text.right {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .hero_image .text .wrap {
    padding: 20px;
    max-width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
  }
}
/* Page Quote */
.page-quote {
  padding: 0;
  margin: 60px 150px;
}

.page-quote .quotetext {
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
  text-align: center;
  margin-bottom: 10px;
}

.page-quote .quotetext p {
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
  text-align: center;
  margin: 0;
}

.page-quote .by {
  font-weight: 400;
  text-align: center;
}

/* small screen - hide on ipad */
@media (max-width: 767px) {
  .page-quote {
    padding: 0;
    margin: 40px 0;
  }
  .page-quote .quotetext {
    font-size: 26px;
    line-height: 36px;
  }
  .page-quote .quotetext p {
    font-size: 26px;
    line-height: 36px;
  }
}
/* Video embeds */
.vwrap {
  max-width: 100%;
  margin: 0 auto 30px auto;
}

.videoWrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  padding-top: 0;
  height: 0;
  margin-bottom: 30px;
}

.videoWrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Gallery */
.galleryblock {
  text-align: center;
  margin-bottom: 60px;
}
.galleryblock h3 {
  text-align: left;
}
.galleryblock p {
  text-align: left;
  margin-bottom: 20px;
}
.galleryblock a.box {
  margin-top: 30px;
}

.gallery_custom {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
.gallery_custom a:nth-child(n+5) {
  display: none;
}

/* Mobile */
@media (max-width: 767px) {
  .gallery_custom {
    gap: 20px;
  }
}
/* Accordion */
.accordianwrap {
  margin: 10px 0 30px 0;
  border-top: 1px solid #cccccc;
}

.accordianwrap.add {
  margin: -31px 0 30px 0;
}

.accordiantitle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 10px;
  border-bottom: 1px solid #cccccc;
}

.accordiantitle .fa-solid {
  font-size: 20px;
  line-height: 30px;
  font-weight: 900;
  color: #999;
  float: left;
  margin: 0;
}

.accordiantitle:hover .fa-solid {
  cursor: pointer;
  color: #F51800;
}

.accordiantitle.open .closedicon {
  display: none;
}

.accordiantitle.open .openicon {
  display: block;
}

.accordiantitle .openicon {
  display: none;
}

.accordiantitle h3 {
  font-size: 18px;
  line-height: 30px;
  color: #333;
  padding: 0 0 0 8px;
  margin: 0;
  font-weight: 600;
  text-transform: unset;
}

.accordiantitle:hover h3 {
  cursor: pointer;
  color: #333;
}

.accordiantitle.open:hover h3 {
  cursor: pointer;
}

.accordiancontent {
  display: none;
  padding: 20px 34px 1px 34px;
  margin: 0;
}
.accordiancontent ul {
  margin-left: 30px;
}

.pdf_grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  justify-items: flex-start;
  gap: 20px 30px;
  margin-bottom: 30px;
}
.pdf_grid a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  font-size: 16px;
  line-height: 24px;
}
.pdf_grid a i {
  font-size: 40px;
  line-height: 50px;
  color: #010101;
}
.pdf_grid a:hover {
  color: #010101;
  text-decoration: none;
}

/* Mobile */
@media (max-width: 767px) {
  .accordiancontent {
    display: none;
    padding: 20px 0 1px 0;
    margin: 0;
  }
}
/* Color Box */
.color_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 50px 0;
  background-color: #2C2E35;
  min-height: 285px;
}

.color_box .imagecol {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 285px;
          flex: 0 0 285px;
  position: relative;
}
.color_box .imagecol .object-fit-image {
  padding: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}

.color_box .text {
  position: relative;
  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: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 30px;
}

.color_box a.box {
  position: absolute;
  right: 20px;
  bottom: 20px;
  background-color: transparent !important;
  padding: 0;
}
.color_box a.box:hover {
  color: #F51800 !important;
  background-color: transparent !important;
}

/* Mobile */
@media (max-width: 767px) {
  .color_box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: 600px;
    margin: 50px auto;
  }
  .color_box .imagecol {
    -webkit-box-flex: 0;
        -ms-flex: none;
            flex: none;
    width: 100%;
    height: auto;
  }
  .color_box .imagecol .object-fit-image {
    padding: 0;
    width: 100%;
    height: auto;
  }
  .color_box .imagecol .object-fit-image img {
    position: static;
    width: 100%;
    height: auto;
  }
  .color_box .text {
    padding: 20px 20px 60px 20px;
  }
}
/* Reviews */
.reviews_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  margin-bottom: 50px;
}
.reviews_grid .review_text {
  margin: 0 0 10px 0;
}
.reviews_grid .review_text p {
  margin: 0;
  font-weight: 700;
}
.reviews_grid .review_by {
  margin: 0;
}

.block_background_light .reviews_grid,
.block_background_dark .reviews_grid {
  margin-bottom: 24px;
}

@media (max-width: 767px) {
  .reviews_grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
/* Button */
p.linkwrap.center {
  text-align: center;
}

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

/* Link Bar */
.link_bar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 20px;
  margin-bottom: 30px;
}

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

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

/* Logo Slider */
/* Stop Chrome Slick Flicker */
.slick-slide {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.logo_slideshow {
  width: calc(100% - 80px);
  opacity: 0;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  margin: 0 auto !important;
}

.logo_slideshow.slick-initialized {
  opacity: 1;
}

.logo_slideshow .logo {
  height: 120px;
  position: relative;
  -webkit-animation-duration: 0.25s;
          animation-duration: 0.25s;
}

.logo_slideshow a.logo:hover {
  -webkit-filter: grayscale(100%);
          filter: grayscale(100%);
  opacity: 0.8;
}

.logo_slideshow img {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  max-width: calc(100% - 20px);
  max-height: 120px;
  width: auto;
  height: auto;
  margin: 0 auto;
}

/* Arrows */
.logo_slideshow .slick-prev, .logo_slideshow .slick-next {
  width: 30px;
  height: 50px;
}

.logo_slideshow .slick-prev {
  left: -40px;
  z-index: 99;
}

.logo_slideshow .slick-next {
  right: -40px;
  z-index: 99;
}

.logo_slideshow .slick-prev:before,
.logo_slideshow .slick-next:before {
  font-size: 40px;
  line-height: 40px;
  width: 30px;
  text-align: center;
  opacity: 1;
  color: #BFBFBF;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  font-weight: 900;
  font-family: "Font Awesome 6 Free";
  display: inline-block;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}

.slick-prev:hover:before,
.slick-next:hover:before {
  color: #010101;
}

/* Link Bar */
.anchor_link_bar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px 20px;
  margin-bottom: 30px;
  margin-top: 10px;
}
.anchor_link_bar .anchor_title {
  font-size: 18px;
  font-weight: 600 !important;
}
.anchor_link_bar .anchor_title i {
  margin-left: 6px;
}
.anchor_link_bar a:not(a.box),
.anchor_link_bar a:hover:not(a.box),
.anchor_link_bar a:visited:not(a.box) {
  text-decoration: none !important;
}

/* Hero Image & Text */
.hero-compare {
  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;
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
  padding: 100px 0;
  min-height: 550px;
  background-attachment: fixed;
  border-top: 4px solid #FFF;
}
.hero-compare .compare {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 285px;
  width: 1230px;
  max-width: 100%;
  margin: 0 30px;
  background-color: rgba(245, 24, 0, 0.9);
}
@media (max-width: 1000px) {
  .hero-compare .compare {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 285px 285px;
    width: 600px;
  }
}
@media (max-width: 600px) {
  .hero-compare .compare {
    grid-template-columns: 1fr;
    grid-template-rows: 180px 180px 180px 210px;
    width: 320px;
  }
}
.hero-compare .compare .spec {
  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-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 30px;
}
.hero-compare .compare .spec h3,
.hero-compare .compare .spec h4,
.hero-compare .compare .spec p {
  margin: 0;
}
@media (max-width: 600px) {
  .hero-compare .compare .spec:last-child {
    padding-bottom: 60px;
  }
}
.hero-compare .compare .headline {
  background-color: #2C2E35;
}
.hero-compare .compare a.box {
  position: absolute;
  bottom: 15px;
  right: 20px;
}
@media (max-width: 600px) {
  .hero-compare .compare a.box {
    right: auto;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
    white-space: nowrap;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .hero-compare {
    background-attachment: scroll;
    padding: 60px 0;
  }
  .hero-compare .container {
    padding: 0;
    margin: 0;
  }
  .hero-compare .text {
    padding: 0 20px;
  }
  .hero-compare .text.right {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .hero-compare .text .wrap {
    padding: 20px;
    max-width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
  }
}
/*	--------------------------------------------------
   	Form - Gravity Forms (labels inside)
	-------------------------------------------------- */
/* Variables */
.gform-theme--api, .gform-theme--foundation {
  --gf-form-gap-x: 20px !important;
  --gf-form-gap-y: 20px !important;
  --gf-field-gap-x: 20px !important;
  --gf-field-gap-y: 20px !important;
}

.gform_wrapper h3 {
  font-size: 18px !important;
  line-height: 24px !important;
  font-weight: 600 !important;
  text-transform: unset;
  margin: 10px 0 -10px 0 !important;
}

/* Theme */
.gform_wrapper .gfield input[type=text],
.gform_wrapper .gfield input[type=email],
.gform_wrapper .gfield input[type=tel],
.gform_wrapper .gfield input[type=url],
.gform_wrapper .gfield input[type=number],
.gform_wrapper .gfield input[type=password],
.gform_wrapper .gfield select,
.gform_wrapper .gfield textarea,
.gform_wrapper .gfield textarea:focus {
  border: 1px solid #CCC !important;
  border-radius: 0 !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  font-size: 16px !important;
  line-height: 24px !important;
  color: #333 !important;
  height: 46px !important;
  padding: 10px !important;
}
.gform_wrapper .gfield input[type=text]:focus,
.gform_wrapper .gfield input[type=email]:focus,
.gform_wrapper .gfield input[type=tel]:focus,
.gform_wrapper .gfield input[type=url]:focus,
.gform_wrapper .gfield input[type=number]:focus,
.gform_wrapper .gfield input[type=password]:focus,
.gform_wrapper .gfield select:focus,
.gform_wrapper .gfield textarea:focus,
.gform_wrapper .gfield textarea:focus:focus {
  border: 1px solid #333 !important;
  border-radius: 0 !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

.gform_wrapper .gfield select,
.gform_wrapper .gfield select:focus {
  padding: 10px 5px !important;
}

.gform_wrapper span.ginput_address_city,
.gform_wrapper span.ginput_address_state {
  -webkit-box-flex: 0 !important;
      -ms-flex: 0 0 40% !important;
          flex: 0 0 40% !important;
}

.gform_wrapper span.ginput_address_zip {
  -webkit-box-flex: 0 !important;
      -ms-flex: 0 0 20% !important;
          flex: 0 0 20% !important;
}

/* Submit */
.gform_wrapper .gform_footer, .gform_wrapper.gravity-theme .gform_page_footer {
  margin: 30px 0 !important;
  padding: 0 !important;
}

.gform_wrapper .gform_footer input[type=submit] {
  display: inline-block;
  margin: 0;
  padding: 10px 15px !important;
  font-size: 20px !important;
  line-height: 30px !important;
  color: #FFF !important;
  text-decoration: none;
  font-style: normal !important;
  font-weight: 700 !important;
  position: relative;
  background-color: #010101 !important;
  text-transform: uppercase !important;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  border-radius: 6px;
  border: none !important;
  -webkit-appearance: none;
}

.gform_wrapper .gform_footer input[type=submit]:focus {
  outline: none !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

.gform_wrapper .gform_footer input[type=submit]:hover {
  background-color: #F51800 !important;
  cursor: pointer !important;
}

/* Error */
h2.gform_submission_error {
  text-transform: none;
}

p.gform_required_legend {
  display: none;
}

.gform_wrapper.gravity-theme .gform_validation_errors {
  background: #fff9f9;
  border: 1.5px solid #c02b0a;
  border-radius: 5px;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  margin-bottom: 8px;
  margin-top: 8px;
  padding: 15px !important;
  position: relative;
  width: 100%;
}

.gform_wrapper.gravity-theme .gfield_validation_message,
.gform_wrapper.gravity-theme .validation_message {
  background: transparent !important;
  border: none !important;
  font-size: 13px !important;
  margin-top: 8px;
  padding: 0 !important;
}

/* Placeholder color */
body .gform_wrapper ::-webkit-input-placeholder {
  color: #666666 !important;
}
body .gform_wrapper ::placeholder,
body .gform_wrapper ::-webkit-input-placeholder,
body .gform_wrapper input[placeholder] {
  color: #666666 !important;
}

/* Focus visible */
.gfield :focus-visible {
  outline: none !important;
}

.gform_ajax_spinner {
  margin: 5px 0 0 20px !important;
  width: 24px !important;
  max-width: 24px !important;
  height: 24px !important;
}

/*	--------------------------------------------------
	Print
	-------------------------------------------------- */
.showprint {
  display: none;
}

@media print {
  body {
    padding: 20px !important;
  }
  .container {
    padding: 0;
    margin: 0;
  }
  .showprint {
    display: block;
  }
  .hideprint {
    display: none;
  }
  .printlogo {
    margin: 15px 0;
  }
  .header-pad {
    display: none;
  }
  .page-header {
    margin: 0;
    padding: 0;
  }
  .page-header .wrap {
    display: block;
    height: auto;
  }
  .page-header h1 {
    color: #000;
    padding: 0;
    margin: 0 0 20px 0;
  }
  .main-content-inner {
    margin: 0;
  }
  p {
    margin: 0 0 20px 0;
  }
  #colophon a {
    display: none !important;
  }
}