html,body {height: 100%; margin: 0px; padding: 0px; -webkit-overflow-scrolling: touch;}
body {font-family:'Helvetica Neue', Helvetica, Arial, sans-serif; color:#000; overflow-x:hidden;}
.grid-container {overflow-x: hidden;}

/*KEEPS THE NAV-BAR FROM FLASHING*/
.no-js .top-bar {display: none;}
@media screen and (min-width: 40em) {
    .no-js .top-bar {display: none;}
    .no-js #main-nav {display: none;}
}

/* Test */
/* .logo-subtext {
    font-size: 0.8rem;
    margin-top: -13px;
}

.sub-logo {
  width: 5em;
} */

/* Dropdown select input field search / filter system */
.search-dropdown-wrapper {
    position: relative;
    width: 100%;
    max-width: 400px;
    margin: 1rem 0;
    z-index: 2000;
}

.search-dropdown-wrapper input {
    width: 100%;
    box-sizing: border-box;
}

#company-filter-input {
    border: 1px solid #105fac;
    border-radius: 6px;
    font-size: 0.95rem;
    outline: none;
    transition: border-radius 0.2s ease;
    position: relative;
    width: 100%;
    padding: 0.6rem 0.75rem;
}

#filter-suggestions {
    border: 1px solid black;
    border-top: 0px;
}

.suggestions-list {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
    background: #fff;
    border: 1px solid #105fac;
    border-top: none;
    border-radius: 0 0 6px 6px;
    max-height: 200px;
    overflow-y: auto;
    display: none;
    z-index: 3000;
}

.suggestions-list li:hover {
    background: #fff;
    color: #ed1f24;
}

.suggestions-list.show {
    display: block;
}

.suggestions-list li {
    padding: 8px 12px;
    cursor: pointer;
}

#company-filter-input::placeholder {
    color: #000;
    opacity: 1;
}

.suggestions-list li:hover {
    background: #f0f0f0;
}

.search-dropdown-wrapper.open #company-filter-input {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.company-section {
    margin-bottom: 2rem;
}

/* End of dropdown select input field search / filter system */




/* Color Styles */
.red {color:#ed1f24;} /* rgba(237, 31, 36, 1) */
.blue {color:#105fac;} /* rgba(16, 95, 172, 1) */
.dark-blue {color:#0c457d;} /* rgba(12, 69, 125, 1) */
.gray {color:#fafafa;}
.dark-gray{color:"#dcdcdc";} /* rgba(220, 220, 220) */
.black {color:#000;}
.white {color:#fff;}

/* Link Styles */
a img {border:none;}
a {color:#105fac; text-decoration:none; line-height:inherit;}
a:hover {color:#ed1f24; text-decoration:underline;}
a:focus {color:#ed1f24; outline:none;}

/* Font Styles */
h1, h2, h3, h4, h5 {font-family:'Spectral SC', serif; font-weight:bold;}
h1 {font-size:2.5em; color:#105fac; line-height: 1.2; padding-bottom: 15px;}
h2 {font-size:1.65em; font-family:'Spectral', serif; color:#ed1f24; line-height: 1.2; padding-top: 15px;}
h2.product-hero {font-size:1.85em; font-family:'Spectral', serif; color:#fff;}

h3 {font-size:1.4em; font-family:'Spectral', serif; color:#0c457d; line-height: 1.2; padding-top: 15px;}
h4 {font-size:1.35em;}
p {font-size:1em;}

/* Misc Styles */
.lower-h {font-family:'Mate', serif !important;}
.bold {font-weight:bold;}
.italic {font-style:italic;}
.upper {text-transform:uppercase;}
.shadow {-moz-box-shadow:3px 3px 3px rgba(0,0,0,0.5); -webkit-box-shadow:3px 3px 3px rgba(0,0,0,0.5); box-shadow:3px 3px 3px rgba(0,0,0,0.5);}
.img-border {border:1px solid black;}
.light-padding-top{padding-top: 2em;}

/* List Styles */
ul.bullet {font-size:1em;}
ul.alpha {font-size:1em; list-style-type:lower-alpha;}

/* HR Styles */
hr {border:solid #105FAC; border-width:2px 0 0; clear:both; margin :2vw auto 1vw; max-width:100%; height:0; /*-moz-box-shadow:2px 2px 2px rgba(0,0,0,0.5); -webkit-box-shadow:2px 2px 2px rgba(0,0,0,0.5); box-shadow:2px 2px 2px rgba(0,0,0,0.5);*/}
hr.divider {border-top:1px solid; height:0; margin:20px 0 30px 0; padding:0; list-style:none; border-top-color:#ed1f24;}
hr.content-top-border {height:.001px; box-shadow:0px -1px 2px 1px rgba(0,0,0,0.29);}

/*************************
*   Image Hover Classes   *
**************************/
.image-hover-wrapper {position: relative;}
.image-hover-wrapper a {display: inline-block; letter-spacing: normal; line-height: initial; margin: 0; padding: 0; position: relative;}
.image-hover-wrapper a img {float: left; overflow: hidden; width: 100%;}
.image-hover-wrapper a .image-hover-wrapper-reveal {background-color: rgba(0, 0, 0, 0.5); color: #fefefe; display: inline; height: 100%; margin-left: -100%; margin-top:0; opacity: 0; position: absolute;  width: 100%; z-index: 80; transition: all 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55); transition-delay: 0.25s;}
.image-hover-wrapper a .image-hover-wrapper-reveal:hover {opacity: 1; transition: all 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55);}
.image-hover-wrapper a .image-hover-wrapper-reveal:hover p {opacity: 1; -webkit-transform:translateY(50px); -ms-transform: translateY(50px); transform: translateY(50px); transition: all 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55); transition-delay: 0.25s;}
.image-hover-wrapper a .image-hover-wrapper-reveal p {display: block; opacity: 0; position: absolute; text-align: center; width: 100%; transition: all 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55);}
.image-hover-wrapper a .fa {font-size: 24px;}
.image-hover-wrapper .image-hover-wrapper-banner {background-color: rgba(16, 95, 172, 0.8); color: #fefefe; font-weight: 600; padding:5px; width:100%;  position: absolute; z-index: 10;}
.image-hover-wrapper-banner{font-size:1.3em;}


/***************************
*       HEADER STYLES
***************************/
header {border-bottom:2px solid #105fac;}
body.no-line header {border-bottom:none;}

/****************************
*       HERO/ORBIT
******************************/
.hero-background-image {background-repeat:no-repeat; background-position:center; background-size:cover; height:82vh;}
#hero-background-image-0 {background-position:top; background-image:linear-gradient( rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2) ),url('/images/man-with-shovel-removes-snow-from-roof.jpg');}
#hero-background-image-1 {background-position:top; background-image:linear-gradient( rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2) ),url('/images/december-man-with-shovel-removes-snow-from-roof.jpg');}
#hero-background-image-2 {background-position:left; background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/electrical-supply-products.jpg');}
#hero-background-image-3 {background-position:left; background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/infrared-radiant-heaters-for-outside-dining.jpg');}
/*#hero-background-image-3 {background-position:left; background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/man-in-workshop-electric-heat.jpg');}*/
#hero-background-image-4 {background-position:top; background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/heated-stone-walkway-in-winter-with-snow-on-the-sides.jpg');}
#hero-background-image-5 {background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/air-curtain-over-door.jpg');}
#hero-background-image-6 {background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/harger-lightning-protection.jpg');}
#hero-background-image-7 {background-image:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ),url('/images/residential-led-lighting-fixtures.jpg');}
.orbit-bullets {background-color:rgba(0,0,0,0); margin-top:-45px;}
.orbit-bullets button {background-color:#ddd;}
.orbit-bullets button.is-active {background-color:rgba(52,105,178,0.9);}
.orbit-bullets button:hover {background-color:rgba(52,105,178,0.9);}
.orbit-previous, .orbit-next, .orbit-previous:focus, .orbit-next:focus {background-color: rgba(52,105,178,0.8); border-radius:3px;}
.orbit-previous:hover, .orbit-next:hover {background-color: rgba(97, 95, 98, 0.6);}

/**********************
*    HERO ANIMATIONS  *
***********************/
.hero-frame-title-1 {opacity:0; color:#fff; animation:hero-frame-1-anim; position:relative; animation-duration:1s; animation-delay:0; animation-fill-mode:forwards;}
.hero-frame-tag-1 {opacity:0; color:#fff; text-shadow: 0.5px 1px black; margin-top: 10vh; animation:hero-frame-tag-anim; position:relative; animation-duration:1s; animation-delay:.5s; animation-fill-mode:forwards;}
.hero-frame-learn {text-align:center; opacity:0; color:#fff; padding:8px 20px; display:inline-block; position:relative; border:2px #fff solid; animation:hero-frame-learn-anim; animation-duration:1s; animation-delay:1s; animation-fill-mode:forwards; background-color:rgba(0,0,0,0);}
.hero-frame-learn:hover {background-color:#0c457d;}
.hero-frame-request {text-align:center; opacity:0; color:#fff; margin-top:10px; padding:8px 20px; display:inline-block; position:relative; border:2px #fff solid; animation:hero-frame-learn-anim; animation-duration:1s; animation-delay:1.25s; animation-fill-mode:forwards; background-color:rgba(0,0,0,0);}
.hero-frame-request:hover {background-color:#0c457d;}
.hero-info-wrapper {margin:0px 10px; padding-top:10vh; padding-right:20px; padding-left:20px; width:100%; max-width:800px; font-size:.8em;}

/**************************
*       PRODUCTS         *
***************************/
.product-request-quote {text-align:center; color:#fff; padding:15px 20px; border:2px #fff solid; background-color:rgba(0,0,0,0);}
.product-request-quote:hover {background-color:#0c457d;}
.featured h2 {font-size:1.2em; text-align:center;}
#top-image-products-container-heattrace {background:linear-gradient( rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4) ), url('../images/heattrace-product-hero.jpg'); background-position:center; background-size:cover; min-height:400px;}
#top-image-products-container-heattrace h1{padding-top: 9vh;}
#top-image-products-container-electricheat {background:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ), url('../images/electric-heat-product-hero.jpg'); background-position:center; background-size:cover; min-height:400px;}
#top-image-products-container-electricheat h1{padding-top: 9vh;}
#top-image-products-container-electrical-supply {background:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ), url('../images/electrical-supply-product-hero.jpg'); background-position:right; background-size:cover; min-height:400px;}
#top-image-products-container-electrical-supply h1{padding-top: 9vh;}
#top-image-products-container-ventilation {background:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ), url('../images/ventilation-product-hero.jpg'); background-position:right; background-size:cover; min-height:400px;}
#top-image-products-container-ventilation h1{padding-top: 9vh;}
#top-image-products-container-sensors-controls-safety {background:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ), url('../images/sensors-controls-automation-product-hero.jpg'); background-position:center; background-size:cover; min-height:400px;}
#top-image-products-container-sensors-controls-safety h1{padding-top: 9vh;}
#top-image-products-container-lighting {background:linear-gradient( rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.3) ), url('../images/lighting-product-hero.jpg'); background-position:right; background-size:cover; min-height:400px;}
#top-image-products-container-lighting h1{padding-top: 9vh;}
.featured .clickable:hover {border:2px solid #105fac;}
.featured h3 {margin-top:10vh;}
.content-padding-top {padding-top: 120px;}

/* Table Styles */
table {border:none;}
.responsive-card-table th {background-color:#0c457d; color:#fff; border:1px solid #000; text-align:center;}
.responsive-card-table th.first {border:none !important; background-color:#fff; border-collapse: none;}
.responsive-card-table td {border:1px solid #000; text-align:center;}
.large-table {font-size: 12px;}

/*.title-bar and .top-bar is set to fixed to keep the menu-bar on top of page when screen is small*/
/* header {min-height: 10vw; max-height: 168px;} */
#main-nav{position:relative; z-index:9999;}
.title-bar {position:fixed; top:0; width:100%; height:100px; min-height:100px; margin-bottom:50px; z-index:999;}
.top-bar {background:#fff; font-family:'Spectral', serif; z-index:999;}
.top-bar ul {background:#fff;}
.top-bar ul ul {background:#fafafa;}
.top-bar ul li a {color:#105fac; font-size:1.25em; font-weight:bold;}
.top-bar ul li a:hover, .top-bar ul li a:focus, .top-bar ul li a:active {background:#0c457d !important; color:#fff !important; text-decoration:none;}
.top-bar ul ul li a {background:none !important; color:#ed1f24 !important; font-size:1em; font-weight:normal; width: 100%; text-align: left;}
.top-bar ul ul ul li a {color:#ed1f24 !important; font-size:0.875em; font-weight:normal; padding:0.35rem 0.5rem !important; white-space:normal; text-align: left;}

.top-bar ul ul ul li a:hover {background:#0c457d!important; color:#fff;}
/* overwrite the submenu hover and after arrow colors */
.dropdown.menu > li.is-dropdown-submenu-parent:hover a {background:#0c457d; color:#fff;}
.dropdown.menu > li.is-dropdown-submenu-parent:hover a::after {border-color:#fff transparent transparent !important;}
.dropdown.menu > li.is-dropdown-submenu-parent > a:hover, .dropdown.menu > li.is-dropdown-submenu-parent > a:active, .dropdown.menu > li.is-dropdown-submenu-parent > a:focus {background:#0c457d; color:#fff;}
.dropdown.menu > li.is-dropdown-submenu-parent > a::after {border-color:#105fac transparent transparent !important;}
.dropdown.menu > li.is-dropdown-submenu-parent > a:hover::after, .dropdown.menu > li.is-dropdown-submenu-parent > a:active::after, .dropdown.menu > li.is-dropdown-submenu-parent > a:focus::after {border-color:#fff transparent transparent !important;}
.drilldown .is-drilldown-submenu-parent > a::hover {background:#0c457d; color:#fff;}
.drilldown .is-drilldown-submenu-parent > a::after {border-color:transparent transparent transparent #105fac !important;}
.drilldown .is-drilldown-submenu-parent > a:hover::after {border-color:transparent transparent transparent #fff !important;}
/* overwrite mobile Back arrow colors */
.drilldown .js-drilldown-back > a::before {border-color: transparent #105fac transparent transparent;}
.drilldown .js-drilldown-back > a:hover::before {border-color: transparent #fff transparent transparent;}
.is-dropdown-submenu {background-color:#fafafa; border:none; white-space:nowrap; -moz-box-shadow:3px 3px 3px rgba(0,0,0,0.5); -webkit-box-shadow:3px 3px 3px rgba(0,0,0,0.5); box-shadow:3px 3px 3px rgba(0,0,0,0.5);}
/* overwrite the responsive menu icon dark color */
.menu-icon.dark {margin-right:10px;}
.menu-icon.dark::after {box-shadow:0 7px 0 #105fac, 0 14px 0 #105fac; background:#105fac;}
.menu-icon.dark:hover::after {box-shadow:0 7px 0 #ed1f24, 0 14px 0 #ed1f24; background:#ed1f24;}
.menu-float-right {float:none;}

/* Google Search Bar & Search Results */
.gsc-thumbnail {
    display: none !important;
}

.gsc-results-wrapper-overlay {
    top: auto !important;
    left: 15% !important;
}

#___gcse_0 {
    margin-bottom: 7px;
}

.gs-image-box {
    margin: 0px 10px 0px 0px !important;
}

.gsc-table-result {
    margin: 5px 0px 0px 0px !important;
}

.gsc-control-cse table thead, .gsc-control-cse table tbody, .gsc-control-cse table tfoot {
  border: none !important;
}

.gsc-control-cse {
    padding: 0 !important;
}

.quick-links li:last-of-type {
  min-width: 257.15px;
}

.gcse-container-wrapper {
  z-index: 101 !important;
  background-color: #fff;
  margin-top: var(--nav-bar-margin) !important;
  height: calc(100vh - var(--nav-bar-margin)) !important;
  overflow-y: scroll !important;
  direction: rtl !important;
  position: fixed !important;
  top: 0;
  right: -800px;
  min-width: 800px;
  max-width: 800px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity 0.4s ease,
    visibility 0s linear 0.4s,
    transform 0.4s ease;
}
.gcse-container-wrapper * {
  direction: ltr !important;
}
.gcse-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(0);
}
#content-container {
  position: relative;
  overflow: hidden;
  display: flex;
  width: 100%;
}
#content-container > .grid-x, #content-container > div.small-11.medium-11.large-9.cell {
  transition: transform 0.4s ease;
  position: relative;
}
#content-container > .gcse-container-wrapper {
  flex: 0 0 100%;
  position: relative;
}

#recaptcha-wrapper {
  margin-top: 0 !important;
}

.gsib_b {
  margin-left: -26px !important; display: flex !important; padding: 0px !important;
}

.gsib_b * {
  padding: 0px !important
}

.gsc-search-box.gsc-search-box-tools {
  margin: 0px !important;
}

table.gsc-search-box,
table.gsc-search-box tbody {
  margin: 0px !important; padding: 0px !important;
}

.gstl_50.gssb_c {
  left: auto !important; right: 61px !important; position: fixed !important; width: fit-content !important;
}


input.gsc-input {
  background: none !important; border: 1px solid #000 !important;
}

.gsc-input table {
  margin: 0 !important; border: none !important;
}

.gsib_a {
  padding: 0 !important;
}

.gsib_a input {
  padding: 1px 6px !important;
}

.gsst_a {
  display: flex !important; justify-content: center !important; align-items: center !important;
}

#___gcse_0 .gsst_a .gscb_a {
  color: #ed1f24 !important; font-size: 2em !important; padding: 0px 5px !important;
}

.gsc-control-cse table {
  border: none !important;
}

.gsc-result-info {
  padding: 4px !important;
}

.gsc-input {
  padding: 0px !important;
}

.gstl_50 tr input {
  background: #fff !important; cursor: text; transition: all 0.1s ease;
}

.gsc-input-box input:hover {
  background: #fafafa !important;
}

.gstl_50.gssb_c {
  display: block !important;
}

.gssb_a {
  padding: 0px !important;
}

.gssb_a table tr td {
  padding: 0px 7px !important;
}

tr.gsc-completion-selected .gssb_a table tr td {
  background: #fafafa !important;
}

.gssb_a table tr td:hover {
  background: #fafafa !important; cursor: pointer;
}

table.gsc-completion-container tbody tr:nth-child(2n) {
  background: #fff;
}

.gssb_a img {
  display: none !important;
}

#___gcse_0 {
  padding: 0em 0.5em !important;
}

#___gcse_0 svg {
  width: 17px !important; height: 17px !important;
}

#___gcse_0 .gsc-search-button button {
  margin: 0px !important; padding: 5px !important;
}

#___gcse_0 .gsc-search-button {
  padding: 0px 5px !important;
}

#___gcse_0 input {
    padding: 2px 22px 2px 5px !important; font-size: 14px !important;
}

.gsc-search-button-v2 {
  border: none !important; background-color: #ed1f24 !important; cursor: pointer !important;
}

table.gstl_50,
.gsc-option-menu {
  z-index: 9999 !important;
}

table.gsc-search-box,
table.gsc-search-box tbody {
  background: none !important; background-color: none !important;
}

.gsc-option-menu {
  top: 33px !important;
}

.gsc-input-box {
}

a.gs-title:hover,
a.gs-title:hover * {
  color: #ed1f24 !important;
}

.gs-web-image-box .gs-image,
.gs-promotion-image-box .gs-promotion-image {
  max-width: 300px !important; max-height: 600px !important;
}

.gs-web-image-box,
.gs-promotion-image-box {
  width: fit-content !important;
}

.gs-snippet {
  font-size: 1.3em !important;
}

.gs-title * {
  font-size: 22px !important;
}

.gs-webResult div.gs-visibleUrl {
  font-size: 15px; color: #ed1f24 !important; font-weight: bold;
}

.gsc-thumbnail img,
img.gs-image {
  border: 1px solid #000 !important; box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important; -moz-box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important; -webkit-box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important;
}

.gsc-thumbnail:focus img,
a:focus .gsc-thumbnail img,
img.gs-image:focus,
a:focus img.gs-image {
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.5) !important; -moz-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.5) !important; -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.5) !important;
}

.gsc-thumbnail:hover img,
img.gs-image:hover {
  box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important; -moz-box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important; -webkit-box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important;
}

.gsc-thumbnail:focus img,
img.gs-image:focus {
  box-shadow: 2px 2px 2px rgba(204, 51, 51, 0.5) !important; -moz-box-shadow: 2px 2px 2px rgba(204, 51, 51, 0.5) !important; -webkit-box-shadow: 2px 2px 2px rgba(204, 51, 51, 0.5) !important;
}

.gsc-webResult.gsc-result {
  margin: 0; padding: 20px 0 !important;
}

.gsc-input-box {
  border: none !important;
}

.gsc-input-box input:focus {
  background-color: #c4d6f9 !important;
}

.gsc-input-box input:focus {
  border: 1px solid #0c457d !important;
}

.gs-imageResult-popup .gs-image-popup-box {
  width: calc(100% - 10px) !important;
}

.gcsc-more-maybe-branding-root {
  display: none !important;
}

.gsc-tabData.gsc-tabdActive {
  margin-top: 10px;
}

.gs-imagePreviewArea {
  background: var(--blue) !important; height: auto !important; position: relative !important; min-height: fit-content !important; margin: 20px 0px !important; border: 1px solid var(--black) !important; box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important; transition: all 0.25s ease !important; -moz-box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important; -webkit-box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5) !important;
}

.gs-imagePreviewArea:has(img:hover) {
  box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important; -moz-box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important; -webkit-box-shadow: 3px 3px 3px rgba(204, 51, 51, 0.5) !important;
}

.gs-imagePreview:not([src$=".svg"]) {
  width: min-content;
}

.gs-previewSnippet {
  margin: 0px 30px !important;
}

.gs-previewUrl,
.gs-previewDescription {
  display: none !important;
}

.gs-previewLink {
  display: inline-block;
}

.gs-imagePreviewArea a:has(img) {
  height: fit-content !important;
}

.gs-selectedImageResult {
  height: fit-content !important;
}

.gs-result.gs-imageResult.gs-imageResult-popup {
  width: fit-content !important;
}

.gsc-imageResult.gsc-imageResult-popup.gsc-result.gs-selectedImageResult:has(.gs-imagePreviewArea) .gs-result.gs-imageResult.gs-imageResult-popup {
  display: none !important;
}

.hero-background-image {
  transition: transform 0.4s ease !important;
}

/* MOBILE Google Search */
@media screen and (max-width:1023px) {
  #content-container.search-active>.hero-background-image {
    transform: translateX(-100%) !important;}

  #content-container.search-active>div.small-11.medium-11.large-9.cell {
    transform: translateX(-100%) !important;}

  #content-container.search-active>.grid-x {
    transform: translateX(-100%) !important;}

  body:has(.search-active) footer {
    transform: translateX(-100%) !important;}

  #content-container.search-active>.gcse-container-wrapper {
    transform: translateX(-100%) !important;}

  .gcse-container-wrapper {
    right: -100% !important; min-width: 100% !important; max-width: 100% !important;}

  #___gcse_0 .gsc-search-button {
    padding: 0px 5px 0px 0px !important;}

  #___gcse_0 .gsc-search-button button {
    margin: 2px 2px 2px 0px !important;}

  .gstl_50.gssb_c {
    right: 84px !important;}

  .gsc-expansionArea .gsc-imageResult:has(img.gs-image) {
    display: flex; justify-content: center;}

  .gs-mobilePreview {
    background: var(--blue) !important;}

  .gs-previewSnippet {
    background: transparent !important;}

  .gs-previewVisit {
    background: var(--red) !important; color: var(--white) !important; border-radius: 8px !important;}

  .gs-previewLink {
    width: 100% !important; margin: 50px 0px 0px 0px !important;}

  .gs-imagePreview {
    width: 100% !important; padding: 0px !important;}

  .gs-closeButton {
    fill: var(--red) !important; background: var(--white); border-radius: 1000px; margin: 10px; padding: 0px !important; cursor: pointer;}
}

/******PRODUCTS DROPDOWN*****/
.column-menu {background-color:#fafafa; position:absolute; max-width:70vw; width: max-content; -moz-box-shadow:3px 3px 3px rgba(0,0,0,0.5); -webkit-box-shadow:3px 3px 3px rgba(0,0,0,0.5); box-shadow:3px 3px 3px rgba(0,0,0,0.5); padding:20px;}
.column-menu-inner-box {float:left; width:25%; padding:0 10px;}
.top-bar ul li .column-menu-inner-box h4, .top-bar ul li .column-menu-inner-box h4 a {background:none !important; font-size:0.9em; color:#0c457d !important; text-align:left; white-space:normal; padding:0.35rem 0 !important;}
.top-bar ul li .column-menu-inner-box h4 a:hover {background:none; color:#ed1f24;}

/**Serives sticky side button**/
.services-side-button .sticky.is-stuck{z-index:0;}

/***************************
*       CONTENT
***************************/
#content-container {padding-top:5vh;}
.low-content {min-height:400px;}

/* Home Page Style */
#home-about {padding:5vh 10px 10px 10px; min-height:300px;}

/***MEDIUM TO SMALL SCREEN CONTENT***/
.top-shadow {box-shadow:0 -5px 5px -5px #333;}
#content-1 {display:none; min-height:400px;}
#content-1-with-background {min-height:430px; background-color:#aaa; background:linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4) ), url("../images/concrete-snow-melt-outside-of-store-front.png"); background-repeat:no-repeat; background-position:right; background-size:cover;}
#content-2 {display:none; min-height:400px;}
#content-2-with-background {min-height:430px; background-color:#aaa; background:linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.4) ), url("../images/services.jpg"); background-repeat:no-repeat; background-position:right; background-size:cover;}
.info-wrapper {padding-top:15vh; padding-bottom:15vh; width:85%; margin:0 auto; text-align:center; color:#fff; min-height:420px;}
.info-wrapper h2 {color:#fff; font-size:2em;}
.info-wrapper p {font-weight:1.2em !important;}

/* Home Page More Info */
.more-info {background-color:#105fac; width:100%; height:100%; padding:12px 0 12px 0;}
.more-info h3 {font-size:1.65em; color:#fff; margin-top:0;}
.more-info-shadow {padding:10px 10px 20px 10px; -moz-box-shadow:0px 0px 2px 1px rgba(0,0,0,0.5); -webkit-box-shadow:0px 0px 2px 1px rgba(0,0,0,0.5); box-shadow:0px 0px 5px 2px rgba(0,0,0,0.3);}
.more-info-section {text-align:center; margin-top:5vh;}
.more-info-section a:hover img {opacity:0.5;}

.more-info-red {
    background-color: #ed1f24;
    margin-bottom: 30px;
}



/* Home Page Acquisition Info */
.grid-x.grid-padding-x.grid-margin-x.acq-info {background-color:#ed1f24; width:100%; height:100%; padding:12px 0 6px 0;}


/* Breadcrumb Styles */
ul.breadcrumbs li.current {color:#ed1f24;}

/* Sidebar Styles */
.sidebar {padding-left:2vw;}
.sidebar h4 {font-size:1.25em; color:#0c457d;}
.sidebar h5 {font-size:1.0625em; color:#ed1f24;}
.align-center.vertical.menu > li > a {
    width: 100%;
    text-align: left;
}
.is-drilldown {
    max-width: 100% !important;
    width: 100%;
}

.drilldown .is-drilldown-submenu a {
    width: 100%;
    text-align: left;
}
.dropdown.menu.large-horizontal > li.opens-right:nth-of-type(2) > .is-dropdown-submenu {
    /* left: 19vw; */
}
@media (min-width:1023px) and (max-width:1190px) {
    .top-bar ul li a {
        font-size: 1.55vw;
    }
}
.sidebar ul.sidebar-nav li a {color:#105fac; text-decoration:none;}
.sidebar ul.sidebar-nav li.active a { background:none; color:#ed1f24;}
.sidebar p {font-size:0.9em;}
 ul.sidebar-nav li a:hover {color:#ed1f24;}

/* Callout Styles */
.callout {position:relative; border:1px solid #dcdcdc; border-radius:5px; background-color:#fafafa; color:#000; margin:0 0 1rem 0; padding:1.5rem;}
.callout h4 {color:#ed1f24; font-family:'Spectral', serif; font-size:1.25em; text-align:center;}
.callout p {font-size:0.75em; text-align:center;}

/* Image Thumbnails */
.th {margin:5px; padding:5px; display:inline-block; box-shadow:5px 5px 5px rgba(0,0,0,0.2); border:2px solid rgba(15,95,171,0.5);}
.th:hover, .th:focus {border:solid 1px #ed1f24; box-shadow:5px 5px 5px rgba(15,95,171,0.5);}
a.th {display:block;}
h2.array {font-size:1.125em; color:#ed1f24; text-align:center; margin-top:10px;}

.th h3 {
    text-align: center;
}

.th a {
    display: flex;
    align-items: center;
    flex-direction: column;
}

.th:has(small) {
    padding-top: 15px;
}

.th hr {
    margin: 15px 0px 0px 0px;
    width: 85%;
}

.th a:hover {
    text-decoration: none;
}

.th small {
    color: #ed1f24;
    display: flex;
    justify-content: center;
    text-align: center;
    padding-bottom: 5px;
    max-width: 90%;
}

/* Microformats */
.vcard {display:inline-block; margin:0 0 1.25em 0; padding:0.625em 0.75em;}
.vcard li {font-size:1.1em; margin:0; display:block;}
.vcard .fn {font-weight:bold; font-size:1.1em;}
.vevent .summary {font-weight:bold;}
.vevent abbr {cursor:default; text-decoration:none; font-weight:bold; border:none; padding:0 0.0625em;}

/* slidebox Plugin */
#slidebox {position:fixed; bottom:12vh; right:-480px; padding:0px 0px 0px 0px; z-index:100;}
#slidebox h2 {color:#3366CC; font-size:24px; margin:0 0 15px 0;}
#slidebox h3 {font-size:16px; margin:0}
#slidebox p {font-size:12px; font-weight:bold; margin:0 0 20px 0;}
#slidebox a.close {font-size:14px; font-weight:bold; position:absolute; cursor:pointer; top:5px; right:10px;}
#slidebox a.close:hover {text-decoration:underline;}

/* YouTube Video Image Overlay Load Times */
.youtube-container {background:#000000;}
.youtube-player {cursor:pointer;}
img.youtube-thumb {display:block; margin:auto; max-width:100%; width:100%; height:auto; position:absolute; top:0; right:0; bottom:0; left:0;}
div.play-button {background:url("../images/play-button.png") no-repeat; height:72px; width:72px; position:absolute; left:50%; top:50%; margin-left:-36px; margin-top:-36px;}
div.play-button:hover {background:url("../images/play-button-hover.png") no-repeat;}
#youtube-iframe {width:100%; height:100%; max-height:100%; position:absolute; top:0; left:0;}
.slide-deck {padding-top:9%;}

/* Standard Forms */
form {margin:0 0 19.41641px;}
label {color:#000; cursor:pointer; display:block; font-size:12px; font-weight:normal; text-align:left; margin-top:10px; margin-bottom:2px;}
label.right {float:none; text-align:right;}
label.inline-search {line-height:12px; margin:0;}
.prefix, .postfix {display:block; position:relative; z-index:2; text-align:center; width:100%; padding-top:0; padding-bottom:0; height:30px; line-height:29px;}
a.button.prefix, a.button.postfix {padding-left:0; padding-right:0; text-align:center;}
span.prefix, span.postfix {background:#f2f2f2; border:1px solid #ed1f24;}
.prefix {left:2px; -moz-border-radius-topleft:2px; -webkit-border-top-left-radius:2px; border-top-left-radius:2px; -moz-border-radius-bottomleft:2px; -webkit-border-bottom-left-radius:2px; border-bottom-left-radius:2px; overflow:hidden;}
.postfix {right:2px; -moz-border-radius-topright:2px; -webkit-border-top-right-radius:2px; border-top-right-radius:2px; -moz-border-radius-bottomright:2px; -webkit-border-bottom-right-radius:2px; border-bottom-right-radius:2px;}
input[type="text"], input[type="password"], input[type="date"], input[type="datetime"], input[type="email"], input[type="number"], input[type="search"], input[type="tel"], input[type="time"], input[type="url"], textarea {background-color:#fff; font-family:inherit; border:1px solid #ccc; -webkit-border-radius:2px; -moz-border-radius:2px; -ms-border-radius:2px; -o-border-radius:2px; border-radius:2px; -webkit-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); -moz-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); color:rgba(0, 0, 0, 0.75); display:block; font-size:14px; margin:0 0 0 0; padding:6px; height:30px; width:100%;}
input[type="text"].oversize, input[type="password"].oversize, input[type="date"].oversize, input[type="datetime"].oversize, input[type="email"].oversize, input[type="number"].oversize, input[type="search"].oversize, input[type="tel"].oversize, input[type="time"].oversize, input[type="url"].oversize, textarea.oversize {font-size:12px; padding:4px 6px;}
input[type="text"]:focus, input[type="password"]:focus, input[type="date"]:focus, input[type="datetime"]:focus, input[type="email"]:focus, input[type="number"]:focus, input[type="search"]:focus, input[type="tel"]:focus, input[type="time"]:focus, input[type="url"]:focus, textarea:focus, select:focus {background:#C4D6F9; color:#000000; outline:none !important; border-color:#105fac; -webkit-border-radius:2px; -moz-border-radius:2px; -ms-border-radius:2px; -o-border-radius:2px; border-radius:2px;}
input[type="text"][disabled], input[type="password"][disabled], input[type="date"][disabled], input[type="datetime"][disabled], input[type="email"][disabled], input[type="number"][disabled], input[type="search"][disabled], input[type="tel"][disabled], input[type="time"][disabled], input[type="url"][disabled], textarea[disabled] {background-color:#ddd;}
textarea {height:auto;}
select {font-family:inherit; border:1px solid #ccc; -webkit-border-radius:2px; -moz-border-radius:2px; -ms-border-radius:2px; -o-border-radius:2px; border-radius:2px; -webkit-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); -moz-box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1); color:rgba(0, 0, 0, 0.75); display:block; font-size:14px; margin:0 0 0 0; padding:4px; height:100%; width:100%;}
select:focus{outline:none;}
input:-webkit-input-placeholder {font-size:10px; color:#105fac;}
input:-moz-placeholder {font-size:11px; color:#105fac;}
input::placeholder, textarea::placeholder {color:#dcdcdc; font-size:0.85em;}
select::placeholder {color:#dcdcdc; font-size:0.85em;}

/* PDF Grid */
.pdf-grid {
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
}
.pdf-grid > div.cell {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

/* Button Styles */
.learn-more {background-color:#fff; border:2px #105fac solid; color:#105fac; margin:20px auto 0 auto; padding:15px 30px;}
.learn-more:hover {background-color:#0c457d; color:#fff; text-decoration:none;}
.learn-more-red {background-color:#ed1f24; color:#fff; margin:0 auto; padding:10px 20px;}
.learn-more-red:hover {background-color:#0c457d; color:#fff; text-decoration:none;}
.button-red {background-color:#ed1f24; color:#fff; margin:0 auto; padding:10px 20px;}
.button-red:hover {background-color:#0c457d; color:#fff; text-decoration:none;}
.button-blue {background-color:#105fac; color:#fff; margin:0 auto; padding:10px 20px;}
.button-blue:hover {background-color:#0c457d; color:#fff; text-decoration:none;}

/* HubSpot Form Overides */
.hs-form-required {color:#ed1f24; font-size:14px; font-weight:bold;}
.inline-form .hs-form-required {display:none !important;}
ul.hs-error-msgs li, ul.inputs-list li {list-style-type:none;}
ul.hs-error-msgs li label {color:#ed1f24 !important;}
ul.inputs-list li label {font-weight:normal;}
.hs-richtext {color:#105fac; cursor:pointer; display:block; font-size:14px; font-weight:bold; text-align:left; margin-top:20px; margin-bottom:2px;}
.actions {text-align:left; margin-top:20px;}

/* HubSpot Form 2 COlumn Width Fixes */
fieldset, .form-columns-1 .hs-form-field, input[type=text], input[type="email"],input[type="tel"], input.title, textarea, select, email , .hs-form select {width:100% !important; max-width:100% !important;}
.hs-form fieldset.form-columns-1 .input {margin-right:0 !important;}

/* HubSpot Form Message */
.hbspt-form div.submitted-message {color:#ed1f24; padding:25px 0 50px 0;}

/* Join Our Mailing List Form */
.hbspt-form .inline-form {display:inline; position:relative;}
.hbspt-form .inline-form .hs-form-required {display:none !important;}
.inline-form div.hs_email.field.hs-form-field {width:90%; float:left;}
.inline-form div.hs_submit {width:9%; float:right;}
.inline-form input.hs-input {font-size:12px; margin:0; vertical-align:top;}
.inline-form input.hs-button {font-size:14px !important; background-color:#105fac; color:#fff; margin:-11px 0 0 0; padding:8px 20px 8px; vertical-align:top; -webkit-border-radius:0; -moz-border-radius:0; -ms-border-radius:0; -o-border-radius:0; border-radius:0; cursor:pointer;}
.inline-form input.hs-button:hover {background-color:#0c457d;}
.inline-form input::placeholder {font-size:12px; color:#105fac;}
.mailing {margin-bottom:20px; margin-left:10px;}

/* HubSpot Buttons */
input.hs-button {width:auto; background:#105fac; border:none; color:#fff; cursor:pointer; display:inline-block; font-family:inherit; font-size:12px; font-weight:bold; line-height:14px; margin:0; outline:none; padding:15px 20px 14px; position:relative; text-align:center; text-decoration:none; -webkit-transition:background-color 0.15s ease-in-out; -moz-transition:background-color 0.15s ease-in-out; -o-transition:background-color 0.15s ease-in-out; transition:background-color 0.15s ease-in-out; -moz-box-shadow:3px 3px 3px rgba(0,0,0,0.5); -webkit-box-shadow:3px 3px 3px rgba(0,0,0,0.5); box-shadow:3px 3px 3px rgba(0,0,0,0.5);}
input.hs-button:hover {color:#Fff; background-color:#0c457d; text-decoration:none;}
input.hs-button:active {-webkit-box-shadow:0 1px 0 rgba(0, 0, 0, 0.2) inset; -moz-box-shadow:0 1px 0 rgba(0, 0, 0, 0.2) inset; box-shadow:0 1px 0 rgba(0, 0, 0, 0.2) inset;}
input.hs-button:focus {-webkit-box-shadow:0 0 4px #0c457d, 0 1px 0 rgba(255, 255, 255, 0.5) inset; -moz-box-shadow:0 0 4px #0c457d, 0 1px 0 rgba(255, 255, 255, 0.5) inset; box-shadow:0 0 4px #0c457d, 0 1px 0 rgba(255, 255, 255, 0.5) inset; color:#fff;}
input.hs-button.large {font-size:14px;white-space:nowrap;}

/* Don't use native buttons on iOS */
input[type=submit].button, button.button {-webkit-appearance:none;}

/* Footer Styles */
.footer {background-color:#dcdcdc; /*border-top:2px solid #105fac;*/ margin-top:6vh;}
.footer h5 {font-size:1.25em; color:#0c457d; margin-top:3vh;}
.footer p {font-size:0.9em;}
.footer ul {margin-left:0;}
.footer hr {border:solid #105fac; border-width:1px 0 0; clear:both; margin:40px 0 20px 0; height:0;}
.copyright {display: flex; flex-direction: row; background-color:#105fac; font-size:0.8em; text-align:center; color:#fff; margin-top: 15px; padding: 15px 0px 15px 0px;}
.copyright .LEP {
    margin-right: auto;
}

.copyright .links {
    display: flex;
    flex-direction: row;
    gap: 20px;
}

.copyright .NEES {
    margin-left: auto;
}

.copyright small {
    color:#fff !important;
    font-size: 1em;
}


/* Mobile footer */
@media (max-width: 1024px)  {
    .copyright {display: flex; flex-direction: column;}
    .copyright .links { justify-content: center; margin: 30px 0px;}
    .copyright .LEP, .copyright .NEES {margin: 0;}
    .member-logos img{width: 25%;}
}

.copyright a {color:#fff;}

.copyright a:hover {text-decoration:underline;}
.social-icon {font-size:2.5em;}

.member-header {background-color: #105fac; color: #fff !important; width: 100%; margin: 0px 0px 15px 0px;}

.member-logos {
    display: flex;
    flex-direction: row;
    justify-content: center;
    gap: 40px;
    max-width: 90%;
    margin: 0 auto;
}

.member-logos img{width: 12%;}

/*
.fa.fa-twitter {display: inline-block; font-family:sans-serif;}
.fa.fa-twitter::before {background-color: #0c457d; color: #dcdcdc; border-radius: 2px; padding: 0px 4px; content:"𝕏"; font-size:1.5rem;}
.fa.fa-twitter a {font-family: Arial, Helvetica, sans-serif;}
*/
.contact-us-list {font-size:0.9em; list-style-type:none; margin:0;}
.contact-us-list.social-media {
     display: flex; flex-direction: row;
}
.contact-us-list li {margin-bottom:1em;}
.contact-us-list.social-media li {
     margin-right: 15px;
}
.contact-us-list li::before {color:#0c457d; font-size:2rem; vertical-align:middle; margin-right:1rem;}
.contact-us-list img {height: 1.9em; margin: 0.2em 0.8em 0.2em 0em;}

/* Page Scroll Up */
.scrollup {background:url("../images/icon-top.png") no-repeat; display:none; width:40px; height:40px; position:fixed; bottom:100px; right:25px; text-indent:-9999px; opacity:0.5; -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; filter:alpha(opacity=50); zoom:1;}


/* START MAP */

.map {
    padding: 20px 0px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    justify-content: center;
}

.map img {
    width: 30%;
}

/* END MAP */

/**************************
*      RESPONSIVE STYLES
****************************/


/*Firefox only*/
@supports (-moz-appearance:none) {
    #SearchResults {
    /* Remove default list styling */
    box-shadow: 1px 3px #888888;
    list-style-type: none;
    position: absolute;
    z-index: 1;
    display:block;
	}
}

/*GG Chrome*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
#SearchBar {
    position: relative;
    font-size: 16px; /* Increase font-size */
    padding: 12px 20px 12px 4px; /* Add some padding */
    border: 1px solid #ddd; /* Add a grey border */
    }
}

/*For small screens*/
@media only screen and (orientation:landscape) and (max-width:600px) {
   .hero-frame-tag-1 {font-size:1.5em;}
   .hero-info-wrapper {padding-top:2vh;}
}

@media only screen and (orientation:portrait) and (max-width:600px) {
   .hero-frame-tag-1 {font-size:1.5em;}
   .hero-info-wrapper {padding-top:5vh;}
}

@media only screen and (min-width:1200px) {
    .info-wrapper{width:60%;}


}

/*KEEPS ROWS WITH ONE IMAGE AND TEXT ROUGHLY THE SAME SIZE ON PRODUCT PAGES*/
@media screen and (max-width: 1300px) and (min-width: 1024px) {
    #content-container > .large-9{width:91%;}
}

@media only screen and (max-width:800px) {
    #heattrace-table{font-size: .6em;}
}

/* Medium and larger*/
@media only screen and (orientation:portrait) and (max-width:799px) and (min-width:600px) {
   .hero-frame-tag-1 {font-size:3em;}
}
@media only screen and (orientation:landscape) and (max-width:799px) and (min-width:600px) {
   .hero-frame-tag-1 {font-size:2em;}
}

@media only screen and (max-width:1200px) and (min-width:800px) {
    .hero-frame-tag-1 {font-size:3em;}
}

@media only screen and (min-width:1024px) {
    .menu-float-right {float:right;}
}

/*Shrinks font-size of main nav anchor tags between 640px and 721px */
@media only screen and (min-width:640px) and (max-width:721px){
    .font-shrink-on-medium a {font-size:0.8em;}
}

/**Screens Less than 960px****/
@media only screen and (max-width:960px) {
    #main-nav {font-size:.7em;}
}

@media only screen and (min-width:950px) {

}

/***LARGE SCREEN STYLES***/
@media only screen and (min-width:1024px) {
    #content-1 {background-image:url("../images/concrete-snow-melt-outside-of-store-front.png"); background-repeat:no-repeat; background-position:right; background-size:cover; display:block;}
    #content-1-with-background {height:75vh; background-image:none;}
    #content-2 {background-image:url("../images/services.jpg"); background-repeat:no-repeat; background-position:center; background-size:cover; display:block;}
    #content-2-with-background {height:75vh; background-image:none;}
    .info-wrapper {padding-top:15vh; color:#000; padding-bottom:100px; min-height:400px;}
    .info-wrapper h2 {font-size:2.2em; color:#105fac;}
    .info-wrapper p {font-size:1.2em;}
}

/*EXTRA LARGE SCREENS*/
@media only screen and (min-width:1200px) {
    .hero-frame-tag-1 {font-size:3.5em;}
    .hero-frame-learn {font-size:1.5em;}
    .hero-frame-request {font-size:1.5em;}
    .hero-info-wrapper {padding-top:5vh; padding-left:5%; width:100%; max-width:1400px;}
}