/*! normalize.css v4.2.0 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Correct the line height in all browsers.
 * 3. Prevent adjustments of font size after orientation changes in IE and iOS.
 */
/* Document
   ========================================================================== */
html {
  font-family: sans-serif;
  /* 1 */
  line-height: 1.15;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 3 */
  -webkit-text-size-adjust: 100%;
  /* 3 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0; }

/**
 * Add the correct display in IE 9-.
 */
article,
aside,
footer,
header,
nav,
section {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */
figcaption,
figure,
main {
  /* 1 */
  display: block; }

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px; }

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */ }

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0; }

/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit; }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic; }

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000; }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block; }

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none; }

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */ }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on OS X.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */
details,
menu {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Scripting
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block; }

/**
 * Add the correct display in IE.
 */
template {
  display: none; }

/* Hidden
   ========================================================================== */
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none; }

/* box-sizing */
html {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

*,
:after,
:before {
  -webkit-box-sizing: inherit;
  -moz-box-sizing: inherit;
  box-sizing: inherit; }

/**
 *		Project (style guide)
 */
/**
 *		Standards (feel free to add, but don't delete existing!)
 */
/**
 *		Base elements
 */
/**
 *		Tables
 */
/**
 *		Forms
 */
/**
 *		Store (cart, checkout, etc)
 */
/**
 *		Column layouts
 */
.waterfurnace-graph-wave:after, .wave-btn-group:after, .wave-btn-wrapper:after, .waterfurnace-graph-wave-chart:after, .site_nav .contain:after, .site_footer .contain > div:after {
  content: '';
  display: block;
  clear: both; }

/**
 *		element/.class/#id {
 *			@extend %fullcoverage;
 *		}
 */
/**
 *		element/.class/#id {
 *			@extend %center;
 *		}
 */
.site_nav .commonNav ul li.search .search_container #nav_search_desktop button svg, .site_nav .commonNav ul li #nav_search_mobile button svg, .comNav .search .search_container #nav_search_desktop button svg, .comNav #nav_search_mobile button svg {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }

/*
    FROM BULMA.IO TO HELP WITH TRANSITION OF PAGES
*/
/*
    END FROM BULMA.IO
*/
body {
  position: relative;
  color: #656565;
  font-family: "proxima-nova", sans-serif;
  line-height: 1.5;
  background-color: #f2f4f5;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased; }
  body .page_wrapper {
    max-width: 80rem;
    margin: 0 auto;
    background-color: #fff;
    box-shadow: 0 0 1.875rem rgba(0, 0, 0, 0.07);
    overflow: hidden; }
  body.is-residential .page_wrapper {
    overflow: inherit; }

a {
  transition: .25s all;
  color: #4596d8;
  text-decoration: none; }
  a:hover {
    color: #004A8C; }

h1, h2, h3, h4, h5, h6 {
  font-family: "proxima-nova", sans-serif; }

h1 {
  font-size: 1.75rem; }
  @media (min-width: 20rem) {
    h1 {
      font-size: calc(1.75rem + 0.625 * (100vw - 20rem) / 10); } }
  @media (min-width: 30rem) {
    h1 {
      font-size: 2.375rem; } }

h2 {
  font-size: 1.625rem; }
  @media (min-width: 20rem) {
    h2 {
      font-size: calc(1.625rem + 0.375 * (100vw - 20rem) / 10); } }
  @media (min-width: 30rem) {
    h2 {
      font-size: 2rem; } }

h3 {
  font-size: 1.5rem; }
  @media (min-width: 20rem) {
    h3 {
      font-size: calc(1.5rem + 0.25 * (100vw - 20rem) / 10); } }
  @media (min-width: 30rem) {
    h3 {
      font-size: 1.75rem; } }

h4 {
  font-size: 1.375rem; }
  @media (min-width: 20rem) {
    h4 {
      font-size: calc(1.375rem + 0.125 * (100vw - 20rem) / 10); } }
  @media (min-width: 30rem) {
    h4 {
      font-size: 1.5rem; } }

h5 {
  font-size: 1.25rem; }

h6 {
  font-size: 1.125rem; }

blockquote {
  quotes: "\201C" "\201D" "\201C" "\201D";
  position: relative;
  margin: 0 5vw 4rem 5vw;
  color: #656565;
  font-family: "proxima-nova", sans-serif; }
  blockquote:before {
    content: open-quote;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate3d(0px, -50%, 0px); }
  blockquote p {
    margin-left: 4rem; }

@keyframes solar_collector_sun {
  0% {
    transform: translate3d(-50%, -70%, 0px);
    opacity: 0.000001; }
  50% {
    transform: translate3d(-50%, -60%, 0px);
    opacity: .6; }
  100% {
    transform: translate3d(-50%, -50%, 0px);
    opacity: 0.000001; } }

@keyframes solar_collector_arrow_yellow {
  0% {
    transform: translate3d(0px, 20%, 0px);
    opacity: 0.000001; }
  50% {
    transform: translate3d(0px, 35%, 0px);
    opacity: .75; }
  100% {
    transform: translate3d(0px, 45%, 0px);
    opacity: 0.000001; } }

@keyframes geothermal_heating {
  0% {
    opacity: 1; }
  40% {
    opacity: 1; }
  50% {
    opacity: 0.000001; }
  90% {
    opacity: 0.000001; }
  100% {
    opacity: 1; } }

@keyframes geothermal_heating_arrows {
  0% {
    transform: translate3d(0px, 45%, 0px);
    opacity: 0.000001; }
  50% {
    transform: translate3d(0px, 30%, 0px);
    opacity: .75; }
  100% {
    transform: translate3d(0px, 15%, 0px);
    opacity: 0.000001; } }

@keyframes geothermal_cooling {
  0% {
    opacity: 0.000001; }
  40% {
    opacity: 0.000001; }
  50% {
    opacity: 1; }
  90% {
    opacity: 1; }
  100% {
    opacity: 0.000001; } }

@keyframes geothermal_cooling_arrows {
  0% {
    transform: translate3d(0px, 35%, 0px);
    opacity: 0.000001; }
  50% {
    transform: translate3d(0px, 50%, 0px);
    opacity: .75; }
  100% {
    transform: translate3d(0px, 65%, 0px);
    opacity: 0.000001; } }

@keyframes navMenuShow {
  0% {
    display: none;
    opacity: 0; }
  1% {
    display: block;
    opacity: 0;
    transform: scaleY(0);
    transform-origin: top; }
  100% {
    opacity: 1;
    transform: scaleY(1);
    transform-origin: top; } }

@keyframes navMenuHide {
  0% {
    display: block;
    opacity: 1;
    transform: scaleY(1);
    transform-origin: top; }
  99% {
    display: none;
    opacity: 0;
    transform: scaleY(0);
    transform-origin: top; }
  100% {
    display: none;
    opacity: 0; } }

@keyframes navMenuShowVert {
  0% {
    display: none;
    opacity: 0; }
  1% {
    display: flex;
    opacity: 0;
    transform: scaleY(0);
    transform-origin: top; }
  100% {
    opacity: 1;
    transform: scaleY(1);
    transform-origin: top; } }

.animation_rise {
  transform: translate3d(0px, 3em, 0px);
  opacity: 0.0000001;
  transition: transform 1s cubic-bezier(0.075, 0.82, 0.165, 1), opacity 1s cubic-bezier(0.075, 0.82, 0.165, 1); }
  .animation_rise.on {
    transform: translate3d(0px, 0, 0px);
    opacity: 1; }

/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.5.2
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2017 Daniel Eden
 */
.animated {
  animation-duration: 1s;
  animation-fill-mode: both; }

.animated.infinite {
  animation-iteration-count: infinite; }

.animated.hinge {
  animation-duration: 2s; }

.animated.flipOutX,
.animated.flipOutY,
.animated.bounceIn,
.animated.bounceOut {
  animation-duration: .75s; }

@keyframes bounce {
  from, 20%, 53%, 80%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 0, 0); }
  40%, 43% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -30px, 0); }
  70% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -15px, 0); }
  90% {
    transform: translate3d(0, -4px, 0); } }

.bounce {
  animation-name: bounce;
  transform-origin: center bottom; }

@keyframes flash {
  from, 50%, to {
    opacity: 1; }
  25%, 75% {
    opacity: 0; } }

.flash {
  animation-name: flash; }

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@keyframes pulse {
  from {
    transform: scale3d(1, 1, 1); }
  50% {
    transform: scale3d(1.05, 1.05, 1.05); }
  to {
    transform: scale3d(1, 1, 1); } }

.pulse {
  animation-name: pulse; }

@keyframes rubberBand {
  from {
    transform: scale3d(1, 1, 1); }
  30% {
    transform: scale3d(1.25, 0.75, 1); }
  40% {
    transform: scale3d(0.75, 1.25, 1); }
  50% {
    transform: scale3d(1.15, 0.85, 1); }
  65% {
    transform: scale3d(0.95, 1.05, 1); }
  75% {
    transform: scale3d(1.05, 0.95, 1); }
  to {
    transform: scale3d(1, 1, 1); } }

.rubberBand {
  animation-name: rubberBand; }

@keyframes shake {
  from, to {
    transform: translate3d(0, 0, 0); }
  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(-10px, 0, 0); }
  20%, 40%, 60%, 80% {
    transform: translate3d(10px, 0, 0); } }

.shake {
  animation-name: shake; }

@keyframes headShake {
  0% {
    transform: translateX(0); }
  6.5% {
    transform: translateX(-6px) rotateY(-9deg); }
  18.5% {
    transform: translateX(5px) rotateY(7deg); }
  31.5% {
    transform: translateX(-3px) rotateY(-5deg); }
  43.5% {
    transform: translateX(2px) rotateY(3deg); }
  50% {
    transform: translateX(0); } }

.headShake {
  animation-timing-function: ease-in-out;
  animation-name: headShake; }

@keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 15deg); }
  40% {
    transform: rotate3d(0, 0, 1, -10deg); }
  60% {
    transform: rotate3d(0, 0, 1, 5deg); }
  80% {
    transform: rotate3d(0, 0, 1, -5deg); }
  to {
    transform: rotate3d(0, 0, 1, 0deg); } }

.swing {
  transform-origin: top center;
  animation-name: swing; }

@keyframes tada {
  from {
    transform: scale3d(1, 1, 1); }
  10%, 20% {
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg); }
  30%, 50%, 70%, 90% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg); }
  40%, 60%, 80% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg); }
  to {
    transform: scale3d(1, 1, 1); } }

.tada {
  animation-name: tada; }

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@keyframes wobble {
  from {
    transform: none; }
  15% {
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg); }
  30% {
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg); }
  45% {
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg); }
  60% {
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg); }
  75% {
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg); }
  to {
    transform: none; } }

.wobble {
  animation-name: wobble; }

@keyframes jello {
  from, 11.1%, to {
    transform: none; }
  22.2% {
    transform: skewX(-12.5deg) skewY(-12.5deg); }
  33.3% {
    transform: skewX(6.25deg) skewY(6.25deg); }
  44.4% {
    transform: skewX(-3.125deg) skewY(-3.125deg); }
  55.5% {
    transform: skewX(1.5625deg) skewY(1.5625deg); }
  66.6% {
    transform: skewX(-0.78125deg) skewY(-0.78125deg); }
  77.7% {
    transform: skewX(0.39063deg) skewY(0.39063deg); }
  88.8% {
    transform: skewX(-0.19531deg) skewY(-0.19531deg); } }

.jello {
  animation-name: jello;
  transform-origin: center; }

@keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3); }
  20% {
    transform: scale3d(1.1, 1.1, 1.1); }
  40% {
    transform: scale3d(0.9, 0.9, 0.9); }
  60% {
    opacity: 1;
    transform: scale3d(1.03, 1.03, 1.03); }
  80% {
    transform: scale3d(0.97, 0.97, 0.97); }
  to {
    opacity: 1;
    transform: scale3d(1, 1, 1); } }

.bounceIn {
  animation-name: bounceIn; }

@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    transform: translate3d(0, -3000px, 0); }
  60% {
    opacity: 1;
    transform: translate3d(0, 25px, 0); }
  75% {
    transform: translate3d(0, -10px, 0); }
  90% {
    transform: translate3d(0, 5px, 0); }
  to {
    transform: none; } }

.bounceInDown {
  animation-name: bounceInDown; }

@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    transform: translate3d(-3000px, 0, 0); }
  60% {
    opacity: 1;
    transform: translate3d(25px, 0, 0); }
  75% {
    transform: translate3d(-10px, 0, 0); }
  90% {
    transform: translate3d(5px, 0, 0); }
  to {
    transform: none; } }

.bounceInLeft {
  animation-name: bounceInLeft; }

@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    transform: translate3d(3000px, 0, 0); }
  60% {
    opacity: 1;
    transform: translate3d(-25px, 0, 0); }
  75% {
    transform: translate3d(10px, 0, 0); }
  90% {
    transform: translate3d(-5px, 0, 0); }
  to {
    transform: none; } }

.bounceInRight {
  animation-name: bounceInRight; }

@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    transform: translate3d(0, 3000px, 0); }
  60% {
    opacity: 1;
    transform: translate3d(0, -20px, 0); }
  75% {
    transform: translate3d(0, 10px, 0); }
  90% {
    transform: translate3d(0, -5px, 0); }
  to {
    transform: translate3d(0, 0, 0); } }

.bounceInUp {
  animation-name: bounceInUp; }

@keyframes bounceOut {
  20% {
    transform: scale3d(0.9, 0.9, 0.9); }
  50%, 55% {
    opacity: 1;
    transform: scale3d(1.1, 1.1, 1.1); }
  to {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3); } }

.bounceOut {
  animation-name: bounceOut; }

@keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0); }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, -20px, 0); }
  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0); } }

.bounceOutDown {
  animation-name: bounceOutDown; }

@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    transform: translate3d(20px, 0, 0); }
  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0); } }

.bounceOutLeft {
  animation-name: bounceOutLeft; }

@keyframes bounceOutRight {
  20% {
    opacity: 1;
    transform: translate3d(-20px, 0, 0); }
  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0); } }

.bounceOutRight {
  animation-name: bounceOutRight; }

@keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0); }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, 20px, 0); }
  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0); } }

.bounceOutUp {
  animation-name: bounceOutUp; }

@keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

.fadeIn {
  animation-name: fadeIn; }

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, -100%, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInDown {
  animation-name: fadeInDown; }

@keyframes fadeInDownBig {
  from {
    opacity: 0;
    transform: translate3d(0, -2000px, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInDownBig {
  animation-name: fadeInDownBig; }

@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(-100%, 0, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInLeft {
  animation-name: fadeInLeft; }

@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInLeftBig {
  animation-name: fadeInLeftBig; }

@keyframes fadeInRight {
  from {
    opacity: 0;
    transform: translate3d(100%, 0, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInRight {
  animation-name: fadeInRight; }

@keyframes fadeInRightBig {
  from {
    opacity: 0;
    transform: translate3d(2000px, 0, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInRightBig {
  animation-name: fadeInRightBig; }

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 100%, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInUp {
  animation-name: fadeInUp; }

@keyframes fadeInUpBig {
  from {
    opacity: 0;
    transform: translate3d(0, 2000px, 0); }
  to {
    opacity: 1;
    transform: none; } }

.fadeInUpBig {
  animation-name: fadeInUpBig; }

@keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }

.fadeOut {
  animation-name: fadeOut; }

@keyframes fadeOutDown {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(0, 100%, 0); } }

.fadeOutDown {
  animation-name: fadeOutDown; }

@keyframes fadeOutDownBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0); } }

.fadeOutDownBig {
  animation-name: fadeOutDownBig; }

@keyframes fadeOutLeft {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(-100%, 0, 0); } }

.fadeOutLeft {
  animation-name: fadeOutLeft; }

@keyframes fadeOutLeftBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0); } }

.fadeOutLeftBig {
  animation-name: fadeOutLeftBig; }

@keyframes fadeOutRight {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0); } }

.fadeOutRight {
  animation-name: fadeOutRight; }

@keyframes fadeOutRightBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0); } }

.fadeOutRightBig {
  animation-name: fadeOutRightBig; }

@keyframes fadeOutUp {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(0, -100%, 0); } }

.fadeOutUp {
  animation-name: fadeOutUp; }

@keyframes fadeOutUpBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0); } }

.fadeOutUpBig {
  animation-name: fadeOutUpBig; }

@keyframes flip {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    animation-timing-function: ease-out; }
  40% {
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    animation-timing-function: ease-out; }
  50% {
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    animation-timing-function: ease-in; }
  80% {
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    animation-timing-function: ease-in; }
  to {
    transform: perspective(400px);
    animation-timing-function: ease-in; } }

.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  animation-name: flip; }

@keyframes flipInX {
  from {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    animation-timing-function: ease-in; }
  60% {
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1; }
  80% {
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg); }
  to {
    transform: perspective(400px); } }

.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipInX; }

@keyframes flipInY {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    animation-timing-function: ease-in; }
  60% {
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1; }
  80% {
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg); }
  to {
    transform: perspective(400px); } }

.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipInY; }

@keyframes flipOutX {
  from {
    transform: perspective(400px); }
  30% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1; }
  to {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0; } }

.flipOutX {
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important; }

@keyframes flipOutY {
  from {
    transform: perspective(400px); }
  30% {
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1; }
  to {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0; } }

.flipOutY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  animation-name: flipOutY; }

@keyframes lightSpeedIn {
  from {
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0; }
  60% {
    transform: skewX(20deg);
    opacity: 1; }
  80% {
    transform: skewX(-5deg);
    opacity: 1; }
  to {
    transform: none;
    opacity: 1; } }

.lightSpeedIn {
  animation-name: lightSpeedIn;
  animation-timing-function: ease-out; }

@keyframes lightSpeedOut {
  from {
    opacity: 1; }
  to {
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0; } }

.lightSpeedOut {
  animation-name: lightSpeedOut;
  animation-timing-function: ease-in; }

@keyframes rotateIn {
  from {
    transform-origin: center;
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0; }
  to {
    transform-origin: center;
    transform: none;
    opacity: 1; } }

.rotateIn {
  animation-name: rotateIn; }

@keyframes rotateInDownLeft {
  from {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; }
  to {
    transform-origin: left bottom;
    transform: none;
    opacity: 1; } }

.rotateInDownLeft {
  animation-name: rotateInDownLeft; }

@keyframes rotateInDownRight {
  from {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    transform-origin: right bottom;
    transform: none;
    opacity: 1; } }

.rotateInDownRight {
  animation-name: rotateInDownRight; }

@keyframes rotateInUpLeft {
  from {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    transform-origin: left bottom;
    transform: none;
    opacity: 1; } }

.rotateInUpLeft {
  animation-name: rotateInUpLeft; }

@keyframes rotateInUpRight {
  from {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0; }
  to {
    transform-origin: right bottom;
    transform: none;
    opacity: 1; } }

.rotateInUpRight {
  animation-name: rotateInUpRight; }

@keyframes rotateOut {
  from {
    transform-origin: center;
    opacity: 1; }
  to {
    transform-origin: center;
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0; } }

.rotateOut {
  animation-name: rotateOut; }

@keyframes rotateOutDownLeft {
  from {
    transform-origin: left bottom;
    opacity: 1; }
  to {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; } }

.rotateOutDownLeft {
  animation-name: rotateOutDownLeft; }

@keyframes rotateOutDownRight {
  from {
    transform-origin: right bottom;
    opacity: 1; }
  to {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

.rotateOutDownRight {
  animation-name: rotateOutDownRight; }

@keyframes rotateOutUpLeft {
  from {
    transform-origin: left bottom;
    opacity: 1; }
  to {
    transform-origin: left bottom;
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }

.rotateOutUpLeft {
  animation-name: rotateOutUpLeft; }

@keyframes rotateOutUpRight {
  from {
    transform-origin: right bottom;
    opacity: 1; }
  to {
    transform-origin: right bottom;
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0; } }

.rotateOutUpRight {
  animation-name: rotateOutUpRight; }

@keyframes hinge {
  0% {
    transform-origin: top left;
    animation-timing-function: ease-in-out; }
  20%, 60% {
    transform: rotate3d(0, 0, 1, 80deg);
    transform-origin: top left;
    animation-timing-function: ease-in-out; }
  40%, 80% {
    transform: rotate3d(0, 0, 1, 60deg);
    transform-origin: top left;
    animation-timing-function: ease-in-out;
    opacity: 1; }
  to {
    transform: translate3d(0, 700px, 0);
    opacity: 0; } }

.hinge {
  animation-name: hinge; }

@keyframes jackInTheBox {
  from {
    opacity: 0;
    transform: scale(0.1) rotate(30deg);
    transform-origin: center bottom; }
  50% {
    transform: rotate(-10deg); }
  70% {
    transform: rotate(3deg); }
  to {
    opacity: 1;
    transform: scale(1); } }

.jackInTheBox {
  animation-name: jackInTheBox; }

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@keyframes rollIn {
  from {
    opacity: 0;
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg); }
  to {
    opacity: 1;
    transform: none; } }

.rollIn {
  animation-name: rollIn; }

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@keyframes rollOut {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg); } }

.rollOut {
  animation-name: rollOut; }

@keyframes zoomIn {
  from {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3); }
  50% {
    opacity: 1; } }

.zoomIn {
  animation-name: zoomIn; }

@keyframes zoomInDown {
  from {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInDown {
  animation-name: zoomInDown; }

@keyframes zoomInLeft {
  from {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInLeft {
  animation-name: zoomInLeft; }

@keyframes zoomInRight {
  from {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInRight {
  animation-name: zoomInRight; }

@keyframes zoomInUp {
  from {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomInUp {
  animation-name: zoomInUp; }

@keyframes zoomOut {
  from {
    opacity: 1; }
  50% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3); }
  to {
    opacity: 0; } }

.zoomOut {
  animation-name: zoomOut; }

@keyframes zoomOutDown {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomOutDown {
  animation-name: zoomOutDown; }

@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0); }
  to {
    opacity: 0;
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform-origin: left center; } }

.zoomOutLeft {
  animation-name: zoomOutLeft; }

@keyframes zoomOutRight {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0); }
  to {
    opacity: 0;
    transform: scale(0.1) translate3d(2000px, 0, 0);
    transform-origin: right center; } }

.zoomOutRight {
  animation-name: zoomOutRight; }

@keyframes zoomOutUp {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }

.zoomOutUp {
  animation-name: zoomOutUp; }

@keyframes slideInDown {
  from {
    transform: translate3d(0, -100%, 0);
    visibility: visible; }
  to {
    transform: translate3d(0, 0, 0); } }

.slideInDown {
  animation-name: slideInDown; }

@keyframes slideInLeft {
  from {
    transform: translate3d(-100%, 0, 0);
    visibility: visible; }
  to {
    transform: translate3d(0, 0, 0); } }

.slideInLeft {
  animation-name: slideInLeft; }

@keyframes slideInRight {
  from {
    transform: translate3d(100%, 0, 0);
    visibility: visible; }
  to {
    transform: translate3d(0, 0, 0); } }

.slideInRight {
  animation-name: slideInRight; }

@keyframes slideInUp {
  from {
    transform: translate3d(0, 100%, 0);
    visibility: visible; }
  to {
    transform: translate3d(0, 0, 0); } }

.slideInUp {
  animation-name: slideInUp; }

@keyframes slideOutDown {
  from {
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    transform: translate3d(0, 100%, 0); } }

.slideOutDown {
  animation-name: slideOutDown; }

@keyframes slideOutLeft {
  from {
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    transform: translate3d(-100%, 0, 0); } }

.slideOutLeft {
  animation-name: slideOutLeft; }

@keyframes slideOutRight {
  from {
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    transform: translate3d(100%, 0, 0); } }

.slideOutRight {
  animation-name: slideOutRight; }

@keyframes slideOutUp {
  from {
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    transform: translate3d(0, -100%, 0); } }

.slideOutUp {
  animation-name: slideOutUp; }

figure {
  margin: 0; }
  figure img {
    display: block;
    width: 100%; }
  figure.aspect {
    position: relative;
    width: 100%;
    height: 0;
    overflow: hidden; }
    figure.aspect.portrait, figure.aspect.Portrait {
      padding-bottom: 160%; }
    figure.aspect.square, figure.aspect.Square {
      padding-bottom: 100%; }
    figure.aspect.traditional, figure.aspect.Traditional {
      padding-bottom: 75%; }
    figure.aspect.computer, figure.aspect.Computer {
      padding-bottom: 62.5%; }
    figure.aspect.hd, figure.aspect.HD, figure.aspect.video, figure.aspect.Video, figure.aspect.landscape, figure.aspect.Landscape {
      padding-bottom: 56.25%; }
    figure.aspect.widescreen, figure.aspect.Widescreen {
      padding-bottom: 54%; }
    figure.aspect.cinema, figure.aspect.Cinema {
      padding-bottom: 42%; }
    figure.aspect.banner, figure.aspect.Banner {
      padding-bottom: 25%; }
    figure.aspect img {
      -o-object-fit: cover;
      object-fit: cover;
      font-family: "object-fit: cover";
      position: absolute;
      height: 100%; }
      figure.aspect img.contain {
        -o-object-fit: contain;
        object-fit: contain;
        font-family: "object-fit: contain"; }

body:not(.bulma) a.button, body:not(.bulma) input[type=submit],
body:not(.bulma) button {
  display: inline-block;
  padding: 1rem 1.5rem;
  color: #fff;
  font-weight: 700;
  font-size: 1.0625rem;
  text-align: center;
  text-decoration: none;
  background: #ea7500;
  border-radius: 4px; }
  body:not(.bulma) a.button:hover, body:not(.bulma) input:hover[type=submit],
  body:not(.bulma) button:hover {
    background: #b75c00; }

*:focus {
  outline: none; }

body:not(.bulma) label {
  display: block;
  width: 100%;
  margin: 1rem 0 2rem 0; }
  body:not(.bulma) label.checkbox {
    display: flex;
    cursor: pointer; }
    body:not(.bulma) label.checkbox.centered {
      justify-content: center; }
  body:not(.bulma) label.error input,
  body:not(.bulma) label.error select,
  body:not(.bulma) label.error textarea {
    padding-right: 3rem;
    background-position: calc(100% - .75rem) 50%;
    background-size: initial;
    background-repeat: no-repeat;
    background-attachment: scroll;
    border-color: #c7031e; }
  body:not(.bulma) label.complete input,
  body:not(.bulma) label.complete select,
  body:not(.bulma) label.complete textarea {
    border-color: #85c169; }
  body:not(.bulma) label span {
    display: block;
    width: 100%;
    margin-bottom: .25rem; }
    body:not(.bulma) label span.required:before {
      content: '*';
      padding: 0 .25rem;
      color: #c7031e;
      font-weight: 700; }
    body:not(.bulma) label span small {
      font-size: .75rem;
      font-family: "proxima-nova", sans-serif;
      letter-spacing: normal; }
      body:not(.bulma) label span small:before {
        content: "("; }
      body:not(.bulma) label span small:after {
        content: ")"; }
    body:not(.bulma) label span.error {
      padding: .375rem;
      color: #c7031e;
      font-size: .875rem; }

body:not(.bulma) input,
body:not(.bulma) select,
body:not(.bulma) textarea,
body:not(.bulma) button {
  transition: .25s all;
  width: 100%;
  padding: .6875rem .875rem;
  color: #656565;
  font-family: inherit;
  line-height: 1.5;
  border: 4px solid #b6d4e5;
  border-radius: 5px; }
  body:not(.bulma) input::-webkit-input-placeholder, body:not(.bulma) select::-webkit-input-placeholder, body:not(.bulma) textarea::-webkit-input-placeholder, body:not(.bulma) button::-webkit-input-placeholder {
    color: #acacac;
    font: inherit; }
  body:not(.bulma) input:-moz-placeholder, body:not(.bulma) select:-moz-placeholder, body:not(.bulma) textarea:-moz-placeholder, body:not(.bulma) button:-moz-placeholder {
    color: #acacac;
    font: inherit; }
  body:not(.bulma) input::-moz-placeholder, body:not(.bulma) select::-moz-placeholder, body:not(.bulma) textarea::-moz-placeholder, body:not(.bulma) button::-moz-placeholder {
    color: #acacac;
    font: inherit; }
  body:not(.bulma) input:-ms-input-placeholder, body:not(.bulma) select:-ms-input-placeholder, body:not(.bulma) textarea:-ms-input-placeholder, body:not(.bulma) button:-ms-input-placeholder {
    color: #acacac;
    font: inherit; }
  body:not(.bulma) input:focus,
  body:not(.bulma) select:focus,
  body:not(.bulma) textarea:focus,
  body:not(.bulma) button:focus {
    background-color: #f4f4f4; }

body:not(.bulma) input[type=checkbox] {
  -webkit-appearance: none;
  -moz-appearance: none;
  display: inline-block;
  width: 1.5625rem;
  height: 1.5625rem;
  margin-right: 1.5rem;
  background: transparent center center no-repeat scroll;
  border: 4px solid #b6d4e5;
  cursor: pointer; }
  body:not(.bulma) input[type=checkbox]::-ms-expand {
    display: none; }
  body:not(.bulma) input[type=checkbox]:checked {
    background-color: #b6d4e5;
    background-image: url(/assets/svg/checkmark.svg);
    border-color: #b6d4e5; }
  body:not(.bulma) input[type=checkbox] + span {
    position: relative;
    width: auto;
    display: inline-block;
    margin-bottom: 0;
    font-family: "proxima-nova", sans-serif;
    line-height: 1.5625;
    letter-spacing: normal; }

body:not(.bulma) select {
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.625rem;
  background-color: #fff;
  background-image: url(/assets/svg/chevron-down-white.svg), linear-gradient(to right, #fff 0, #fff calc(100% - 2.625rem), #5998c9 calc(100% - 2.625rem), #5998c9 100%);
  background-position: calc(100% - .875rem) 50%, 100%;
  background-repeat: no-repeat;
  background-attachment: scroll; }
  body:not(.bulma) select::-ms-expand {
    display: none; }

body:not(.bulma) input[type=submit],
body:not(.bulma) button {
  padding: .625rem 1.5rem;
  color: #fff;
  background: #ea7500;
  border: 0;
  cursor: pointer; }
  body:not(.bulma) input[type=submit]:hover, body:not(.bulma) input[type=submit]:focus,
  body:not(.bulma) button:hover,
  body:not(.bulma) button:focus {
    background: #b75c00; }
  @media (min-width: 25em) {
    body:not(.bulma) input[type=submit],
    body:not(.bulma) button {
      float: right;
      width: auto; } }

/**
 *		Override image paths
 */
#fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
  background-image: url("/assets/images/fancybox/fancybox_sprite.png") !important; }

#fancybox-loading div {
  background-image: url("/assets/images/fancybox/fancybox_loading.gif") !important; }

.fancybox-nav {
  background-image: url("/assets/images/fancybox/blank.gif") !important;
  /* helps IE */ }

.fancybox-overlay {
  background-image: url("/assets/images/fancybox/fancybox_overlay.png") !important; }

/*Retina graphics!*/
@media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min--moz-device-pixel-ratio: 1.5), only screen and (min-device-pixel-ratio: 1.5) {
  #fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
    background-image: url("/assets/images/fancybox/fancybox_sprite-2x.png") !important; }
  #fancybox-loading div {
    background-image: url("/assets/images/fancybox/fancybox_loading-2x.gif") !important; } }

/**
 *		Fix nav button placement for video (iframe) lightboxes
 */
.fancybox-type-iframe .fancybox-nav,
[data-fancybox-type=iframe] .fancybox-nav {
  top: calc(50% - 1.5rem);
  width: 48px;
  height: 38px; }

.fancybox-type-iframe .fancybox-nav span,
[data-fancybox-type=iframe] .fancybox-nav span {
  left: 50%;
  margin-top: 0;
  transform: translate(-50%, -50%);
  visibility: visible; }

.fancybox-type-iframe .fancybox-next,
[data-fancybox-type=iframe] .fancybox-next {
  right: -35px; }

.fancybox-type-iframe .fancybox-prev,
[data-fancybox-type=iframe] .fancybox-prev {
  left: -35px; }

/**
 *		Override image paths
 */
.bx-wrapper .bx-loading {
  background-image: url("/assets/images/bxslider/bx_loader.gif") !important; }

.bx-wrapper .bx-prev,
.bx-wrapper .bx-next,
.bx-wrapper .bx-controls-auto .bx-start,
.bx-wrapper .bx-controls-auto .bx-stop {
  background-image: url("/assets/images/bxslider/controls.png") !important; }

/**
 *		Remove some built-in styles
 */
.bx-wrapper {
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important; }

.embed-container {
  position: relative;
  max-width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden; }

.embed-container iframe,
.embed-container object,
.embed-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

.table_overflow {
  width: 100%;
  margin-bottom: 2rem;
  overflow-x: auto; }
  .table_overflow table {
    min-width: 40rem; }

table {
  table-layout: fixed;
  border-collapse: collapse;
  width: 100%;
  border: 1px solid #dbdbdb; }
  table thead tr {
    border-bottom: 1px solid #dbdbdb; }
    table thead tr th {
      padding: .75rem;
      font-weight: 400;
      font-size: .875rem;
      font-family: serif;
      text-align: left;
      background: #f4f4f4; }
  table tbody tr td {
    padding: 1rem .75rem; }
    table tbody tr td.no_results_message {
      padding: 4rem 0;
      text-align: center; }
  table tbody tr:nth-of-type(even) td {
    background: #f4f4f4; }

.flexSection {
  position: relative; }
  .flexSection > .background {
    position: relative;
    width: 100%; }
    .flexSection > .background img {
      display: block; }
  .flexSection > figure.custom_graph {
    padding: 3vw; }
  .flexSection > article {
    position: relative;
    padding: 3vw;
    text-align: center;
    opacity: 0.000001;
    z-index: 2;
    transition: 1.7s transform cubic-bezier(1, 0, 0, 1), 0.5s opacity cubic-bezier(0.83, 0, 0.8, 1); }
    .flexSection > article .step {
      width: 3.5rem;
      margin: 0 auto .5rem auto;
      text-align: center;
      color: #fff;
      background-color: #4596d8;
      opacity: 0.000001;
      transition: transform 0.8s cubic-bezier(1, 0, 0, 1) 1s, opacity 0.8s cubic-bezier(0.9, 0, 0, 1) 1s; }

@media screen and (-ms-high-contrast: active) and (min-width: 700px), screen and (-ms-high-contrast: none) and (min-width: 700px) {
  .flexSection > article .step,
  .flexSection > article h1,
  .flexSection > article header,
  .flexSection > article p,
  .flexSection > article a {
    flex: 1 0 auto; } }
    .flexSection > article h1 {
      color: #4596d8;
      font-size: 1.5rem;
      font-weight: 400;
      line-height: 1.2;
      margin: 0; }
      @media (min-width: 20em) {
        .flexSection > article h1 {
          font-size: calc(1.5rem + 0.5 * (100vw - 20em) / 20); } }
      @media (min-width: 40em) {
        .flexSection > article h1 {
          font-size: 2rem; } }
    .flexSection > article header {
      color: #4596d8;
      font-size: 1.5rem;
      line-height: 1.2; }
      @media (min-width: 20em) {
        .flexSection > article header {
          font-size: calc(1.5rem + 0.5 * (100vw - 20em) / 20); } }
      @media (min-width: 40em) {
        .flexSection > article header {
          font-size: 2rem; } }
      .flexSection > article header img {
        width: 100%; }
    .flexSection > article p {
      max-width: 100%; }
    .flexSection > article > a {
      display: block;
      margin-top: 0.5rem;
      color: #6ab04b;
      font-weight: 700;
      font-size: .9375rem;
      text-decoration: none; }
      @media (min-width: 55em) {
        .flexSection > article > a {
          transform: translate3d(0px, 0.6rem, 0px);
          transition: transform 0.5s ease 1.7s, opacity 0.5s ease 1.7s;
          opacity: 0.0000001; } }
      @media (min-width: 55em) {
        .flexSection > article > a.on {
          transform: translate3d(0px, 0, 0px);
          opacity: 1; } }
      .flexSection > article > a:after {
        content: '';
        position: relative;
        top: 1px;
        display: inline-block;
        width: .75rem;
        height: .75rem;
        margin-left: .5rem;
        background: transparent url(/assets/svg/chevron-down-apple.svg) center/contain no-repeat scroll;
        transform: rotate(-90deg); }
    .flexSection > article .icons {
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 2rem; }
      .flexSection > article .icons svg {
        flex: 1 1 auto;
        max-width: 5rem;
        margin: 0 2rem; }
  .flexSection.left .primary {
    transform: translateX(-100%); }
    .flexSection.left .primary .step {
      transform: translateX(-8em); }
  .flexSection.left .secondary {
    transform: translateX(100%); }
    .flexSection.left .secondary .step {
      transform: translateX(8em); }
  .flexSection.right .primary {
    transform: translateX(100%); }
    .flexSection.right .primary .step {
      transform: translateX(8em); }
  .flexSection.right .secondary {
    transform: translateX(-100%); }
    .flexSection.right .secondary .step {
      transform: translateX(-8em); }
  .flexSection .primary.on, .flexSection .secondary.on {
    opacity: 1;
    transform: translateX(0); }
    .flexSection .primary.on .step, .flexSection .secondary.on .step {
      transform: translateX(0em);
      opacity: 1; }

@media (min-width: 700px) {
  .flexSection {
    display: flex; }
    .flexSection .background {
      flex: 1 1 100%;
      min-width: 100%;
      width: 100%;
      max-width: 100%; }
    .flexSection.left .primary {
      padding-right: 10vw; }
    .flexSection.right .primary {
      padding-left: 10vw; }
    .flexSection .primary, .flexSection .secondary {
      position: absolute;
      top: 0;
      height: 100%;
      display: flex;
      flex-direction: column;
      justify-content: center;
      min-width: 50%;
      width: 50%;
      max-width: 50%;
      text-align: left; }
      .flexSection .primary .step, .flexSection .secondary .step {
        margin-right: 0;
        margin-left: 0; }
      .flexSection .primary h1, .flexSection .secondary h1 {
        /*@media (max-width:960px) and (min-width:720px) {*/
        font-size: 1.25rem; }
      .flexSection .primary header, .flexSection .secondary header {
        /*@media (max-width:960px) and (min-width:720px) {*/
        font-size: 1.25rem; }
      .flexSection .primary p, .flexSection .secondary p {
        /*@media (max-width:960px) and (min-width:720px) {*/
        font-size: .9rem; }
    .flexSection .background:after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0; }
    .flexSection.fade .background {
      right: 0;
      left: 0; }
    .flexSection.fade.left .background:after {
      background: linear-gradient(to right, #fff 0%, rgba(255, 255, 255, 0.95) 32%, rgba(255, 255, 255, 0.75) 42%, rgba(255, 255, 255, 0.45) 52%, rgba(255, 255, 255, 0.15) 60%, rgba(255, 255, 255, 0) 70%); }
    .flexSection.fade.right .background:after {
      background: linear-gradient(to left, #fff 0%, rgba(255, 255, 255, 0.95) 32%, rgba(255, 255, 255, 0.75) 42%, rgba(255, 255, 255, 0.45) 52%, rgba(255, 255, 255, 0.15) 60%, rgba(255, 255, 255, 0) 70%); }
    .flexSection:not(.fade) .primary {
      color: #fff; }
      .flexSection:not(.fade) .primary header, .flexSection:not(.fade) .primary h1 {
        color: #fff; }
      .flexSection:not(.fade) .primary > a {
        color: #fff; }
        .flexSection:not(.fade) .primary > a:after {
          background-image: url(/assets/svg/chevron-down-white.svg); }
    .flexSection.left > article {
      left: auto;
      right: 0; }
    .flexSection.left > .primary {
      left: 0;
      right: auto;
      order: 1; }
    .flexSection.right > article {
      left: 0;
      right: auto; }
    .flexSection.right > .primary {
      left: auto;
      right: 0; } }

@media (min-width: 80em) {
  .flexSection .primary, .flexSection .secondary {
    padding: 6rem 8rem; } }

.centered_copy {
  margin: 0 auto;
  max-width: 40rem;
  padding: 3rem 1.5rem;
  text-align: center; }
  @media (min-width: 43.75em) {
    .centered_copy {
      padding: 5rem 1.5rem; } }
  .centered_copy h1, .centered_copy h2 {
    color: #4596d8;
    font-size: 2.375rem;
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 2rem; }
  .centered_copy.unitPullupIntro {
    padding: 0rem 1.5rem 5rem 1.5rem; }
  .centered_copy .summary {
    margin: -1rem 0 2rem 0;
    font-weight: 700; }
  .centered_copy p {
    margin: 0 0 2.34375rem; }
    .centered_copy p:last-child {
      margin: 0; }
    .centered_copy p.size_up {
      font-size: 1.25rem; }
  .centered_copy > a {
    display: block;
    margin-top: 2.5rem;
    color: #6ab04b;
    font-weight: 700;
    font-size: .9375rem;
    text-decoration: none; }
    .centered_copy > a.short {
      margin-top: 0rem; }
    .centered_copy > a:after {
      content: '';
      position: relative;
      top: 1px;
      display: inline-block;
      width: .75rem;
      height: .75rem;
      margin-left: .5rem;
      background: transparent url(/assets/svg/chevron-down-apple.svg) center/contain no-repeat scroll;
      transform: rotate(-90deg); }

.banner_with_copy {
  background: url(/assets/images/SAMPLES/utilities-banner_with_text.jpg) center top no-repeat;
  background-size: 100% auto; }
  .banner_with_copy .banner_copy {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #fff 20%, #fff 100%);
    padding: 6rem 1.5rem 3.75rem; }
    @media (min-width: 43.75em) {
      .banner_with_copy .banner_copy {
        background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #fff 50%, #fff 100%);
        padding: 12rem 1.5rem 3.75rem; } }
    @media (min-width: 50em) {
      .banner_with_copy .banner_copy {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        height: 35rem; } }
    .banner_with_copy .banner_copy h2 {
      color: #4596d8;
      font-size: 2rem;
      font-weight: 400;
      margin: 0 0 1rem; }
      @media (min-width: 50em) {
        .banner_with_copy .banner_copy h2 {
          margin: auto 0 2rem; } }
    .banner_with_copy .banner_copy p {
      margin: 0 0 2rem; }
      .banner_with_copy .banner_copy p:last-child {
        margin: 0; }
        @media (min-width: 50em) {
          .banner_with_copy .banner_copy p:last-child {
            margin: 0 0 auto; } }
  @media (min-width: 50em) {
    .banner_with_copy.left {
      display: flex;
      justify-content: flex-start;
      background-size: cover; } }
  @media (min-width: 50em) {
    .banner_with_copy.left .banner_copy {
      background: linear-gradient(to left, rgba(255, 255, 255, 0) 0%, #fff 50%, #fff 100%);
      padding: 0 40% 0 1.5rem;
      width: 80%; } }
  @media (min-width: 80em) {
    .banner_with_copy.left .banner_copy {
      padding: 0 35% 0 9rem; } }
  @media (min-width: 50em) {
    .banner_with_copy.right {
      display: flex;
      justify-content: flex-end;
      background-size: cover; } }
  @media (min-width: 50em) {
    .banner_with_copy.right .banner_copy {
      background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, #fff 50%, #fff 100%);
      padding: 0 1.5rem 0 40%;
      width: 80%; } }
  @media (min-width: 80em) {
    .banner_with_copy.right .banner_copy {
      padding: 0 9rem 0 35%; } }

.image_text_overlay {
  position: relative;
  /*&:not(.product_banner) {
        //edge only hack

        @include for-tablet-portrait-up{
            @supports ( -ms-ime-align : auto) {
                figure img {
                    height: 0;
                    padding-bottom: 39.0625%;
                }
            }
        }
    }*/
  /*&.text_overflow figure {
        overflow: hidden;

        @include for-tablet-portrait-up{
            overflow: visible;
            flex: 1 1 100%;
            position: static;
            min-width: 100%;
            padding-bottom: 0;
            //height: unset;
            img {
                position: absolute;
                min-width: 0;
                max-width: none;
                width: 100%;
                height: 100%;
                top: 0;
                left: 0;
            }
        }
    }*/ }
  @media (min-width: 700px) {
    .image_text_overlay {
      display: flex;
      /*height: 40vw;
        max-height:500px;*/ } }
  .image_text_overlay figure {
    position: relative;
    width: 100%;
    /*@include for-tablet-landscape-up {
            padding-bottom: 450px;
        }*/ }
    .image_text_overlay figure:empty {
      display: none; }
    @media (min-width: 700px) {
      .image_text_overlay figure {
        flex: 1 1 100%;
        min-width: 100%;
        width: 100%;
        max-width: 100%; } }
    .image_text_overlay figure img {
      /*@include object-fit(cover); // Use ofi.browser.js polyfill for IE/Edge support
            height: 100%;*/ }
  .image_text_overlay.no_img {
    padding: 3vw 0;
    /*height: 40vw;
        max-height:500px;*/ }
    .image_text_overlay.no_img.text_left .text {
      padding-right: 5vw; }
    .image_text_overlay.no_img.text_right .text {
      padding-left: 5vw; }
  .image_text_overlay figure .alttext {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0; }
  @media (min-width: 700px) {
    .image_text_overlay.text_left:not(.no_padding) .text {
      padding-right: 6vw; } }

@media (min-width: 700px) and (min-width: 700px) and (max-width: 899px) {
  .image_text_overlay.text_left.no_padding .text {
    padding-right: 0; } }
  @media (min-width: 700px) {
    .image_text_overlay.text_left .alttext {
      width: 50%; }
    .image_text_overlay.text_right .text {
      padding-left: 6vw; } }

@media (min-width: 700px) and (min-width: 700px) and (max-width: 899px) {
  .image_text_overlay.text_right.no_padding .text {
    padding-left: 0; } }
  @media (min-width: 700px) {
    .image_text_overlay.text_right .alttext {
      width: 50%; } }
  .image_text_overlay .text, .image_text_overlay .alttext {
    position: relative;
    padding: 3vw;
    text-align: center;
    opacity: 0.000001;
    z-index: 2;
    transition: 1.7s transform cubic-bezier(1, 0, 0, 1), 0.5s opacity cubic-bezier(0.83, 0, 0.8, 1); }
    @media (min-width: 700px) {
      .image_text_overlay .text, .image_text_overlay .alttext {
        position: absolute;
        top: 0;
        left: 0;
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
        min-width: 50%;
        width: 50%;
        max-width: 50%;
        text-align: left; } }
    @media (min-width: 80em) {
      .image_text_overlay .text, .image_text_overlay .alttext {
        padding: 6rem 8rem; } }
    .image_text_overlay .text .step, .image_text_overlay .alttext .step {
      width: 3.5rem;
      margin: 0 auto .5rem auto;
      text-align: center;
      color: #fff;
      background-color: #4596d8;
      transition: transform 0.8s cubic-bezier(1, 0, 0, 1) 1s, opacity 0.8s cubic-bezier(0.9, 0, 0, 1) 1s; }
      @media (min-width: 700px) {
        .image_text_overlay .text .step, .image_text_overlay .alttext .step {
          margin-right: 0;
          margin-left: 0; } }

@media screen and (-ms-high-contrast: active) and (min-width: 700px), screen and (-ms-high-contrast: none) and (min-width: 700px) {
  .image_text_overlay .text .step, .image_text_overlay .text h1, .image_text_overlay .text header, .image_text_overlay .text p, .image_text_overlay .text a, .image_text_overlay .alttext .step, .image_text_overlay .alttext h1, .image_text_overlay .alttext header, .image_text_overlay .alttext p, .image_text_overlay .alttext a {
    flex: 1 0 auto; } }
    .image_text_overlay .text h1, .image_text_overlay .alttext h1 {
      color: #4596d8;
      font-size: 1.5rem;
      font-weight: 400;
      line-height: 1.2;
      margin: 0; }
      @media (min-width: 20em) {
        .image_text_overlay .text h1, .image_text_overlay .alttext h1 {
          font-size: calc(1.5rem + 0.5 * (100vw - 20em) / 20); } }
      @media (min-width: 40em) {
        .image_text_overlay .text h1, .image_text_overlay .alttext h1 {
          font-size: 2rem; } }
      @media (min-width: 700px) and (max-width: 899px) {
        .image_text_overlay .text h1, .image_text_overlay .alttext h1 {
          font-size: 1.25rem; } }
    .image_text_overlay .text header, .image_text_overlay .alttext header {
      color: #4596d8;
      font-size: 1.5rem;
      line-height: 1.2; }
      @media (min-width: 20em) {
        .image_text_overlay .text header, .image_text_overlay .alttext header {
          font-size: calc(1.5rem + 0.5 * (100vw - 20em) / 20); } }
      @media (min-width: 40em) {
        .image_text_overlay .text header, .image_text_overlay .alttext header {
          font-size: 2rem; } }
      @media (min-width: 700px) and (max-width: 899px) {
        .image_text_overlay .text header, .image_text_overlay .alttext header {
          font-size: 1.25rem; } }
      .image_text_overlay .text header img, .image_text_overlay .alttext header img {
        width: 75%; }
    .image_text_overlay .text p, .image_text_overlay .alttext p {
      max-width: 100%; }
      @media (min-width: 700px) and (max-width: 899px) {
        .image_text_overlay .text p, .image_text_overlay .alttext p {
          font-size: .9rem; } }
    .image_text_overlay .text > a:not(.button), .image_text_overlay .alttext > a:not(.button) {
      display: block;
      margin-top: 0.5rem;
      color: #6ab04b;
      font-weight: 700;
      font-size: .9375rem;
      text-decoration: none; }
      @media (min-width: 55em) {
        .image_text_overlay .text > a:not(.button), .image_text_overlay .alttext > a:not(.button) {
          transform: translate3d(0px, 0.6rem, 0px);
          transition: transform 0.5s ease 1.7s, opacity 0.5s ease 1.7s;
          opacity: 0.0000001; } }
      @media (min-width: 55em) {
        .image_text_overlay .text > a:not(.button).on, .image_text_overlay .alttext > a:not(.button).on {
          transform: translate3d(0px, 0, 0px);
          opacity: 1; } }
      .image_text_overlay .text > a:not(.button):after, .image_text_overlay .alttext > a:not(.button):after {
        content: '';
        position: relative;
        top: 1px;
        display: inline-block;
        width: .75rem;
        height: .75rem;
        margin-left: .5rem;
        background: transparent url(/assets/svg/chevron-down-apple.svg) center/contain no-repeat scroll;
        transform: rotate(-90deg); }
    .image_text_overlay .text .icons, .image_text_overlay .alttext .icons {
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 2rem; }
      .image_text_overlay .text .icons svg, .image_text_overlay .alttext .icons svg {
        flex: 1 1 auto;
        max-width: 5rem;
        margin: 0 2rem; }
  .image_text_overlay.text_left .text {
    transform: translateX(-100%); }
    .image_text_overlay.text_left .text .step {
      opacity: 0.000001;
      transform: translateX(-8em); }
  .image_text_overlay.text_left .text.on {
    opacity: 1;
    transform: translateX(0); }
    .image_text_overlay.text_left .text.on .step {
      opacity: 1;
      transform: translateX(0em); }
  .image_text_overlay.text_left .alttext {
    transform: translateX(100%); }
    .image_text_overlay.text_left .alttext .step {
      opacity: 1;
      transform: translateX(0em); }
  .image_text_overlay.text_left .alttext.on {
    opacity: 1;
    transform: translateX(0); }
    .image_text_overlay.text_left .alttext.on .step {
      opacity: 1;
      transform: translateX(0em); }
  .image_text_overlay.text_right .text {
    transform: translateX(100%); }
    .image_text_overlay.text_right .text .step {
      opacity: 0.000001;
      transform: translateX(8em); }
  .image_text_overlay.text_right .text.on {
    opacity: 1;
    transform: translateX(0); }
    .image_text_overlay.text_right .text.on .step {
      opacity: 1;
      transform: translateX(0em); }
  .image_text_overlay.text_right .alttext {
    transform: translateX(-100%); }
    .image_text_overlay.text_right .alttext .step {
      opacity: 0.000001;
      transform: translateX(-8em); }
  .image_text_overlay.text_right .alttext.on {
    opacity: 1;
    transform: translateX(0); }
    .image_text_overlay.text_right .alttext.on .step {
      opacity: 1;
      transform: translateX(0em); }
  @media (min-width: 700px) {
    .image_text_overlay figure:empty {
      z-index: -1; }
    .image_text_overlay figure:after {
      content: '';
      position: absolute;
      top: 0;
      bottom: 0; }
    .image_text_overlay.text_left:not(.no_fade) figure:after {
      right: 0;
      left: 0;
      background: linear-gradient(to right, #fff 0%, rgba(255, 255, 255, 0.95) 32%, rgba(255, 255, 255, 0.75) 42%, rgba(255, 255, 255, 0.45) 52%, rgba(255, 255, 255, 0.15) 60%, rgba(255, 255, 255, 0) 70%); }
    .image_text_overlay.text_left .text {
      order: -1; }
    .image_text_overlay.text_left .alttext {
      order: 1; }
    .image_text_overlay.text_left.no_fade .text {
      color: #fff; }
      .image_text_overlay.text_left.no_fade .text header,
      .image_text_overlay.text_left.no_fade .text h1 {
        color: #fff; }
      .image_text_overlay.text_left.no_fade .text > a {
        color: #fff; }
        .image_text_overlay.text_left.no_fade .text > a:after {
          background-image: url(/assets/svg/chevron-down-white.svg); }
    .image_text_overlay.text_right:not(.no_fade) figure:after {
      right: 0;
      left: 0;
      background: linear-gradient(to left, #fff 0%, rgba(255, 255, 255, 0.95) 32%, rgba(255, 255, 255, 0.75) 42%, rgba(255, 255, 255, 0.45) 52%, rgba(255, 255, 255, 0.15) 60%, rgba(255, 255, 255, 0) 70%); }
    .image_text_overlay.text_right .text {
      left: auto;
      right: 0;
      transform: translateX(100%); }
      .image_text_overlay.text_right .text.on {
        opacity: 1;
        transform: translateX(0); }
    .image_text_overlay.text_right .alttext {
      right: auto;
      left: 0;
      transform: translateX(-100%); }
      .image_text_overlay.text_right .alttext.on {
        opacity: 1;
        transform: translateX(0); }
    .image_text_overlay.text_right.no_fade .text {
      color: #fff; }
      .image_text_overlay.text_right.no_fade .text header,
      .image_text_overlay.text_right.no_fade .text h1 {
        color: #fff; }
      .image_text_overlay.text_right.no_fade .text > a {
        color: #fff; }
        .image_text_overlay.text_right.no_fade .text > a:after {
          background-image: url(/assets/svg/chevron-down-white.svg); } }

@media (min-width: 700px) {
  .image_text_overlay.half_image figure {
    padding-bottom: 40%; }
    .image_text_overlay.half_image figure div.centered {
      max-width: 50%;
      margin-left: auto;
      display: flex;
      align-items: center;
      justify-content: center;
      height: 500px;
      padding: 2rem; }
      .image_text_overlay.half_image figure div.centered svg {
        height: 100%; }
  .image_text_overlay.half_image img {
    position: absolute;
    height: 100%; } }

.image_text_overlay.half_svg div.centered {
  padding: 2rem;
  display: flex;
  align-items: center;
  justify-content: center; }
  .image_text_overlay.half_svg div.centered svg {
    height: 500px;
    max-height: 18rem; }

@media (min-width: 700px) {
  .image_text_overlay.half_svg figure div.centered {
    max-width: 50%;
    margin-left: auto;
    height: 500px;
    padding: 2rem; } }

@media (min-width: 700px) {
  .image_text_overlay.half_image.text_left img {
    right: 0;
    left: auto; } }

@media (min-width: 700px) {
  .image_text_overlay.half_image.text_left.force_half figure,
  .image_text_overlay.half_image.text_right.force_half figure {
    min-width: 50%;
    max-width: 50%;
    width: 50%; } }

.image_text_overlay_flip {
  transform: scale(-1, 1); }

.accordion {
  background: #e5e5e5;
  padding: 2rem 0 0; }
  @media (min-width: 55em) {
    .accordion {
      padding: 3.75rem 0 0; } }
  .accordion h2 {
    color: #4596d8;
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 2rem;
    text-align: center; }
  .accordion ul {
    list-style: none;
    margin: 0;
    padding: 0; }
    .accordion ul li.accordion_topic.active .accordion_title {
      background: #4596d8;
      color: #fff;
      position: relative; }
      .accordion ul li.accordion_topic.active .accordion_title:after {
        content: '';
        border-top: 1rem solid #4596d8;
        border-right: 1rem solid transparent;
        border-bottom: 1rem solid transparent;
        border-left: 1rem solid transparent;
        margin: 0 auto;
        position: absolute;
        right: 0;
        bottom: -2rem;
        left: 0;
        width: 2rem; }
      .accordion ul li.accordion_topic.active .accordion_title svg {
        transform: rotate(180deg);
        display: block;
        opacity: 1; }
    .accordion ul li.accordion_topic.active ul.accordion_content {
      display: block; }
    .accordion ul li.accordion_topic .accordion_title {
      align-items: center;
      display: flex;
      justify-content: center;
      color: #4596d8;
      cursor: pointer;
      padding: 1rem 1.5rem;
      transition: all 0.2s ease; }
      .accordion ul li.accordion_topic .accordion_title:hover {
        background: #4596d8;
        color: #fff; }
        .accordion ul li.accordion_topic .accordion_title:hover svg {
          display: block;
          opacity: 1; }
      .accordion ul li.accordion_topic .accordion_title p {
        font-size: 1.25rem;
        margin: 0;
        max-width: 60rem;
        width: 100%; }
      .accordion ul li.accordion_topic .accordion_title svg {
        fill: #fff;
        height: auto;
        opacity: 0.000001;
        width: 2rem; }
    .accordion ul li.accordion_topic ul.accordion_content {
      display: none; }
      .accordion ul li.accordion_topic ul.accordion_content li {
        background: #fff; }
        .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper {
          margin: 0 auto;
          max-width: 65rem;
          padding: 3.75rem 1.5rem; }
          @media (min-width: 43.75em) {
            .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper {
              display: flex;
              flex-wrap: wrap;
              justify-content: space-between; } }
          .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper h3 {
            color: #4596d8;
            font-weight: 400;
            line-height: 1.2;
            margin: 0 0 2rem;
            text-align: center;
            width: 100%; }
            @media (min-width: 43.75em) {
              .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper h3 {
                margin: 0 0 3rem; } }
          .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper h4 {
            color: #4596d8;
            font-size: 1.25rem;
            line-height: 1.2;
            margin: 2rem 0 3rem;
            text-align: center;
            width: 100%; }
          .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content {
            width: 100%; }
            @media (min-width: 43.75em) {
              .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content.column {
                margin: 0 0 1.5rem;
                width: 46%; } }
            .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content ul {
              margin: 0 0 2rem 1rem; }
              .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content ul li {
                margin: 0 0 1rem; }
                .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content ul li:before {
                  color: #4596d8;
                  content: '\2022';
                  display: inline-block;
                  font-size: 1.5rem;
                  margin: 0 0 0 -1rem;
                  width: 1rem; }
            .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content p {
              margin: 0 0 1.5rem; }
              .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content p.info {
                font-size: 1.25rem; }
                @media (min-width: 43.75em) {
                  .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content p.info {
                    display: flex; }
                    .accordion ul li.accordion_topic ul.accordion_content li .accordion_content_wrapper .content p.info strong {
                      margin: 0 0.5rem 0 0; } }

.custom_graph ~ .text {
  z-index: auto;
  pointer-events: none; }
  .custom_graph ~ .text > * {
    pointer-events: auto; }

@media screen and (min-width: 700px) and (-ms-high-contrast: active), screen and (min-width: 700px) and (-ms-high-contrast: none) {
  .custom_graph {
    padding-left: 0 !important; } }

.custom_graph header {
  margin: 0 1.5rem 0.5rem 1.5rem;
  color: #689661;
  font-size: 1.3125rem;
  text-align: center; }

@media (min-width: 700px) {
  .image_text_overlay.text_right .custom_graph {
    padding-left: 0 !important; }
  .image_text_overlay.text_left .custom_graph {
    position: absolute;
    top: 50%;
    right: 0;
    width: 50%;
    padding-right: 0 !important;
    transform: translateY(-50%); }
  .precise_temperature_control .image_text_overlay.text_right .custom_graph {
    position: absolute;
    top: 50%;
    left: 5%;
    width: 45%;
    padding-left: 0 !important;
    transform: translateY(-50%); } }

.waterfurnace-graph text {
  font-family: 'Proxima Nova', 'proxima-nova', sans-serif; }

@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  .waterfurnace-graph {
    height: 260px !important; } }

.waterfurnace-graph .financial_case .graph img, .waterfurnace-graph .financial_case .graph svg {
  height: 40vw; }

.waterfurnace-graph .grid-line {
  fill: none;
  stroke: #CCCCCC;
  stroke-width: 1px; }

.waterfurnace-graph .graph-bar {
  fill: url(#waterfurnace-graph-gradient-gray) #B3B3B3;
  transition: transform 0.75s cubic-bezier(0.39, 1.12, 0.56, 1), fill 0.75s cubic-bezier(0.39, 1.12, 0.56, 1) 0.75s; }

.waterfurnace-graph .waterfurnace-graph-transition-start.highlight-red, .waterfurnace-graph .waterfurnace-graph-transition-start.highlight-blue {
  fill: #969696 !important; }

.waterfurnace-graph .highlight-red {
  fill: #E64961; }

.waterfurnace-graph .highlight-blue {
  fill: #1693D4; }

.waterfurnace-graph .fill-white {
  fill: #FFFFFF; }

.waterfurnace-graph .fill-light {
  fill: #EAEAE9; }

.waterfurnace-graph .fill-dark {
  fill: #909090; }

@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  .waterfurnace-graph .graph-bar {
    opacity: 0; } }

@supports (-ms-ime-align: auto) {
  .waterfurnace-graph .graph-bar {
    opacity: 0; } }

.waterfurnace-graph-wave {
  width: 100%;
  height: 10rem;
  margin-bottom: 10rem;
  margin-top: 7.5vw; }
  @media screen and (min-width: 60em) {
    .waterfurnace-graph-wave {
      height: 15rem; } }

.wave-btn-group {
  position: relative;
  margin-top: 1rem; }

.wave-btn-wrapper {
  position: relative;
  float: left;
  width: 100%;
  margin-bottom: 0.6rem;
  cursor: default;
  user-select: none; }
  @media (min-width: 70rem) {
    .wave-btn-wrapper {
      width: 33.33333%; } }

.wave-btn {
  display: block;
  float: left;
  height: 1rem;
  width: 1rem;
  margin-top: 3px;
  padding: 5px;
  border-radius: 50%; }
  .wave-btn:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: white; }

.wave-btn-label {
  margin: 0 !important;
  display: block;
  float: left;
  width: calc(100% - 3rem);
  padding-left: 0.6rem; }

.waterfurnace-graph-wave-chart {
  position: relative;
  width: 100%;
  height: 100%;
  border: 1px solid #B3B3B3; }
  .waterfurnace-graph-wave-chart::after {
    content: '';
    display: block;
    position: relative;
    width: 100%;
    top: 50%;
    left: 0;
    z-index: -1;
    border-top: 1px solid #B3B3B3; }
  .waterfurnace-graph-wave-chart > .wave-axis {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    right: 0;
    width: 3rem;
    height: 100%;
    background: #B3B3B3; }
    .waterfurnace-graph-wave-chart > .wave-axis > p {
      flex: 1 1 auto;
      text-align: center;
      font-weight: 600;
      padding-top: 0.6em;
      color: white; }
  .waterfurnace-graph-wave-chart > canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.flapper {
  font-family: proxima-nova-condensed, sans-serif;
  font-weight: 700;
  box-sizing: content-box;
  padding: 10px;
  /* SIZE STYLES */
  line-height: 1.17;
  height: 1.05em;
  padding: 5px 0;
  /* XXL 96x128 */
  /* XL 72x96 */
  /* L 54x72 */
  /* M 40x54  */
  /* S 30x40 */
  /* XS 24x30 */
  /* THEME STYLES */
  /* DARK (default) */
  /* LIGHT */
  /* SAVINGS CALC */ }
  .flapper .digit {
    position: relative;
    display: inline-block;
    box-sizing: content-box; }
    .flapper .digit div {
      position: absolute;
      text-align: center;
      box-sizing: content-box; }
    .flapper .digit .top {
      top: 0px;
      left: 0px;
      overflow: hidden; }
    .flapper .digit .bottom {
      bottom: 0px;
      left: 0px;
      overflow: hidden; }
  .flapper .digit,
  .flapper .digit div {
    height: 100%;
    width: .8em;
    font-size: inherit;
    line-height: inherit; }
  .flapper .digit {
    border-radius: .5rem;
    margin: 0 0 0 .3rem; }
    .flapper .digit:first-child {
      margin: 0; }
    .flapper .digit div {
      border-radius: .5rem; }
    .flapper .digit .top {
      clip: rect(0px, auto, 0.5em, 0); }
    .flapper .digit .bottom {
      clip: rect(0.52em, auto, auto, 0); }
  .flapper.XXL {
    font-size: 116px;
    line-height: 123px;
    height: 132px; }
    .flapper.XXL .digit,
    .flapper.XXL .digit div {
      height: 128px;
      width: 96px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.XXL .digit {
      border-radius: 8px;
      margin: 0 0 0 4px; }
      .flapper.XXL .digit:first-child {
        margin: 0; }
      .flapper.XXL .digit div {
        border-radius: 6px; }
      .flapper.XXL .digit .top {
        clip: rect(0px, 96px, 64px, 0px); }
      .flapper.XXL .digit .bottom {
        clip: rect(65px, 96px, 128px, 0px); }
  .flapper.XL {
    font-size: 89px;
    line-height: 92px;
    height: 100px; }
    .flapper.XL .digit,
    .flapper.XL .digit div {
      height: 96px;
      width: 72px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.XL .digit {
      border-radius: 7px;
      margin: 0 0 0 4px; }
      .flapper.XL .digit:first-child {
        margin: 0; }
      .flapper.XL .digit div {
        border-radius: 5px; }
      .flapper.XL .digit .top {
        clip: rect(0px, 72px, 47px, 0px); }
      .flapper.XL .digit .bottom {
        clip: rect(48px, 72px, 96px, 0px); }
  .flapper.L {
    font-size: 66px;
    line-height: 70px;
    height: 76px; }
    .flapper.L .digit,
    .flapper.L .digit div {
      height: 72px;
      width: 54px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.L .digit {
      border-radius: 6px;
      margin: 0 0 0 4px; }
      .flapper.L .digit:first-child {
        margin: 0; }
      .flapper.L .digit div {
        border-radius: 4px; }
      .flapper.L .digit .top {
        clip: rect(0px, 54px, 35px, 0px); }
      .flapper.L .digit .bottom {
        clip: rect(36px, 54px, 72px, 0px); }
  .flapper.M {
    font-size: 51px;
    line-height: 52px;
    height: 58px; }
    .flapper.M .digit,
    .flapper.M .digit div {
      height: 54px;
      width: 40px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.M .digit {
      border-radius: 5px;
      margin: 0 0 0 4px; }
      .flapper.M .digit:first-child {
        margin: 0; }
      .flapper.M .digit div {
        border-radius: 3px; }
      .flapper.M .digit .top {
        clip: rect(0px, 40px, 26px, 0px); }
      .flapper.M .digit .bottom {
        clip: rect(27px, 40px, 54px, 0px); }
  .flapper.S {
    font-size: 36px;
    line-height: 39px;
    height: 44px; }
    .flapper.S .digit,
    .flapper.S .digit div {
      height: 40px;
      width: 30px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.S .digit {
      border-radius: 4px;
      margin: 0 0 0 2px; }
      .flapper.S .digit:first-child {
        margin: 0; }
      .flapper.S .digit div {
        border-radius: 2px; }
      .flapper.S .digit .top {
        clip: rect(0px, 30px, 19px, 0px); }
      .flapper.S .digit .bottom {
        clip: rect(20px, 30px, 40px, 0px); }
  .flapper.XS {
    font-size: 28px;
    line-height: 30px;
    height: 34px; }
    .flapper.XS .digit,
    .flapper.XS .digit div {
      height: 30px;
      width: 24px;
      font-size: inherit;
      line-height: inherit; }
    .flapper.XS .digit {
      border-radius: 3px;
      margin: 0 0 0 2px; }
      .flapper.XS .digit:first-child {
        margin: 0; }
      .flapper.XS .digit div {
        border-radius: 1px; }
      .flapper.XS .digit .top {
        clip: rect(0px, 24px, 14px, 0px); }
      .flapper.XS .digit .bottom {
        clip: rect(15px, 24px, 30px, 0px); }
  .flapper .digit {
    background-color: #222;
    border: 1px solid #333; }
    .flapper .digit div {
      color: #f0f0f0;
      padding: 0px;
      background-color: black; }
  .flapper.light .digit {
    border: 1px solid #ddd;
    background-color: #eee; }
    .flapper.light .digit div {
      color: #222;
      padding: 0px;
      background-color: #f6f6f6; }
  .flapper.savingsCalc .digit {
    border: none;
    background-color: #2c7ab9; }
    .flapper.savingsCalc .digit div {
      color: #ffffff;
      padding: 0px;
      background-color: #4596d8; }

.site_nav {
  box-shadow: 0 1rem 2rem -2rem #000;
  position: sticky;
  top: 0;
  width: 100%;
  background-color: #fff;
  margin: 0 auto;
  max-width: 80rem;
  z-index: 60000; }
  .site_nav .nav-trigger {
    position: absolute;
    clip: rect(0, 0, 0, 0); }
    .site_nav .nav-trigger:checked ~ .commonNav,
    .site_nav .nav-trigger:checked ~ .comNav {
      left: auto;
      display: flex; }
    .site_nav .nav-trigger:checked ~ label[for="nav-trigger"] span:nth-child(1) {
      top: 18px;
      width: 0%;
      left: 50%; }
    .site_nav .nav-trigger:checked ~ label[for="nav-trigger"] span:nth-child(2) {
      transform: rotate(45deg); }
    .site_nav .nav-trigger:checked ~ label[for="nav-trigger"] span:nth-child(3) {
      transform: rotate(-45deg); }
    .site_nav .nav-trigger:checked ~ label[for="nav-trigger"] span:nth-child(4) {
      top: 18px;
      width: 0%;
      left: 50%; }
  .site_nav label[for="nav-trigger"] {
    position: absolute;
    top: 1.1875rem;
    right: .75rem;
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
    margin: 0; }
    @media (min-width: 44rem) {
      .site_nav label[for="nav-trigger"] {
        display: none; } }
    .site_nav label[for="nav-trigger"] span:nth-child(1) {
      top: 0px; }
    .site_nav label[for="nav-trigger"] span:nth-child(2), .site_nav label[for="nav-trigger"] #nav-icon3 span:nth-child(3) {
      top: 18px; }
    .site_nav label[for="nav-trigger"] span:nth-child(4) {
      top: 36px; }
    .site_nav label[for="nav-trigger"] svg {
      display: block;
      width: 1.5rem;
      height: 1.5rem;
      margin: .75rem 0; }
      .site_nav label[for="nav-trigger"] svg path {
        fill: #8a8a8a;
        transition: .25s all; }
    .site_nav label[for="nav-trigger"]:hover svg path {
      fill: #184a6d; }
  .site_nav .contain {
    position: relative;
    width: 100%;
    max-width: 65.5rem;
    margin: 0 auto;
    padding: 0 1.5rem; }
  .site_nav .logo {
    float: left;
    display: block;
    width: 45%;
    max-width: 10.6875rem;
    height: 5.34375rem;
    padding: 1rem 0;
    position: relative;
    z-index: 1; }
    .site_nav .logo svg {
      display: block;
      width: 100%;
      height: 100%; }
  .site_nav .calculator {
    position: absolute;
    top: 1.5625rem;
    right: 6.125rem;
    display: inline-flex;
    align-items: center;
    padding: .5rem;
    text-decoration: none; }
    @media (min-width: 33.75em) {
      .site_nav .calculator {
        right: 11.125rem; } }
    @media (min-width: 44rem) {
      .site_nav .calculator {
        display: none; } }
    .site_nav .calculator svg {
      display: block;
      width: 1.25rem;
      height: 1.25rem; }
    .site_nav .calculator span {
      display: none;
      padding-left: .5rem;
      font-weight: 700;
      text-transform: uppercase; }
      @media (min-width: 33.75em) {
        .site_nav .calculator span {
          display: block; } }
  .site_nav .dealer {
    position: absolute;
    top: 1.5625rem;
    right: 3.75rem;
    display: inline-flex;
    align-items: center;
    padding: .5rem;
    text-decoration: none; }
    @media (min-width: 44rem) {
      .site_nav .dealer {
        display: none; } }
    .site_nav .dealer svg {
      display: block;
      width: 1.25rem;
      height: 1.25rem; }
    .site_nav .dealer span {
      display: none;
      padding-left: .5rem;
      font-weight: 700;
      text-transform: uppercase; }
      @media (min-width: 33.75em) {
        .site_nav .dealer span {
          display: block; } }
  .site_nav .utility {
    display: none;
    color: #777777;
    font-size: .75rem;
    font-weight: 700; }
    @media (min-width: 44rem) {
      .site_nav .utility {
        position: absolute;
        top: 0;
        right: 1.5rem;
        display: flex; } }
  .site_nav .siteSection {
    text-transform: uppercase;
    position: relative; }
    .site_nav .siteSection div {
      display: inline-block;
      width: 150px;
      height: 1rem;
      margin-right: .75rem;
      position: relative; }
    .site_nav .siteSection #siteSectionToggle {
      display: none; }
    .site_nav .siteSection div:hover li:not(:first-child) {
      max-height: 1.625rem; }
    .site_nav .siteSection div:hover li:first-child::after {
      transform: rotate(-90deg); }
    .site_nav .siteSection div:hover ul {
      background-color: #f2f4f5; }
    .site_nav .siteSection ul {
      display: inline-block;
      width: 100%;
      position: absolute;
      top: 0;
      z-index: 1; }
      .site_nav .siteSection ul li:first-child::after {
        content: "\f054";
        font: normal normal 400 .75rem/1 "Font Awesome 5 Pro";
        display: inline-block;
        transition: all .25s;
        transform: rotate(90deg); }
    .site_nav .siteSection li {
      position: relative;
      padding: 0 .5rem; }
      .site_nav .siteSection li label,
      .site_nav .siteSection li a {
        display: inline-block;
        padding: 0;
        margin: .25rem .75rem;
        color: #8a8a8a; }
        .site_nav .siteSection li label:hover,
        .site_nav .siteSection li a:hover {
          color: #004A8C; }
      .site_nav .siteSection li:not(:first-child) {
        overflow: hidden;
        transition: max-height .25s;
        max-height: 0; }
  .site_nav a {
    padding: .25rem .75rem;
    text-decoration: none;
    text-transform: uppercase;
    transition: .25s all; }
    .site_nav a:hover {
      color: #184a6d; }
    .site_nav a.is-curved-button {
      color: #fff;
      text-transform: none;
      background-color: #a8adb5; }
      .site_nav a.is-curved-button:hover {
        color: #184a6d; }
        .site_nav a.is-curved-button:hover svg path {
          fill: #184a6d; }
      .site_nav a.is-curved-button svg {
        position: relative;
        top: .0625rem;
        width: .625rem;
        height: .625rem;
        margin-right: -.25rem;
        margin-left: .125rem;
        transform: rotate(-90deg); }
        .site_nav a.is-curved-button svg path {
          fill: #fff;
          transition: .25s all; }
    .site_nav a.has-left-curve {
      margin-right: 1px;
      border-bottom-left-radius: .375rem; }
    .site_nav a.has-right-curve {
      border-bottom-right-radius: .375rem; }
  .site_nav .commonNav {
    clear: both;
    display: none;
    width: 100vw;
    background-color: #fff;
    border-top: 1px solid #8a8a8a;
    transform: translateX(-1.5rem); }
    @media (max-width: 44rem) {
      .site_nav .commonNav {
        margin-top: 85px;
        background-color: #f3f4f6;
        display: flex;
        flex-flow: column nowrap;
        justify-content: flex-start;
        background-color: #f3f4f6;
        flex: 0 1 100%;
        position: absolute;
        left: -200%;
        top: 0;
        z-index: 1; }
        .site_nav .commonNav > ul {
          display: block;
          margin: 0 auto;
          width: 100%;
          background-color: #f3f4f6; }
        .site_nav .commonNav a {
          display: block;
          width: 100%; }
        .site_nav .commonNav a {
          font-weight: 700;
          color: #8a8a8a;
          font-size: .875rem;
          text-decoration: none;
          line-height: 2;
          padding: .25rem 2rem;
          transition: padding .3s linear;
          overflow: hidden; }
        .site_nav .commonNav li.indent a {
          padding-left: 4rem; }
        .site_nav .commonNav > ul.level1 > li > a {
          text-transform: uppercase; }
        .site_nav .commonNav ul.level2 a::after {
          color: #8a8a8a; }
        .site_nav .commonNav ul.level2 {
          background-color: #67a9d9; }
          .site_nav .commonNav ul.level2 a {
            color: #fff;
            padding: .5rem 2rem; }
        .site_nav .commonNav li.indent ul.level2 a {
          padding-left: 4rem; }
        .site_nav .commonNav ul.level2 a::after {
          color: #fff; }
        .site_nav .commonNav ul.level3 a {
          color: #fff;
          padding: .25rem 2rem .25rem 4rem; }
        .site_nav .commonNav li.indent ul.level3 a {
          padding: .25rem 2rem .25rem 4rem; }
        .site_nav .commonNav a:hover {
          color: #184a6d; }
          .site_nav .commonNav a:hover:after {
            color: #184a6d; }
        .site_nav .commonNav li ul {
          max-height: 0;
          overflow: hidden;
          transition: max-height .3s ease-in-out; }
        .site_nav .commonNav li:hover > ul {
          max-height: 700px;
          transition: max-height .3s ease-in-out; }
        .site_nav .commonNav li a span::after {
          content: "\f054";
          font: normal normal 400 .75rem/1 "Font Awesome 5 Pro";
          position: relative;
          text-align: right;
          float: right;
          line-height: 2; }
        .site_nav .commonNav li:hover > a span::after {
          content: "\f078"; }
        .site_nav .commonNav li.level1 > a, .site_nav .commonNav #lowerNav {
          border-bottom: solid 1px #8a8a8a; }
        .site_nav .commonNav > ul {
          border-bottom: solid 1px #8a8a8a; } }
    @media (min-width: 44rem) {
      .site_nav .commonNav {
        position: absolute;
        right: .75rem;
        bottom: 0;
        display: flex !important;
        width: 100%;
        background-color: transparent;
        border-top: 0;
        transform: translateX(0);
        flex-flow: row nowrap;
        justify-content: flex-end;
        transition: margin ease-in-out .2s; } }
  @media (min-width: 44rem) and (min-width: 700px) {
    .site_nav .commonNav .section {
      display: none; } }
    @media (min-width: 44rem) {
        .site_nav .commonNav .indent {
          padding-left: 1rem; }
        .site_nav .commonNav > ul {
          flex: 1 0 auto;
          display: flex;
          flex-flow: row nowrap;
          justify-content: flex-end; }
          .site_nav .commonNav > ul > li {
            flex: 0 1 auto;
            text-align: right;
            font-size: .75rem; }
            .site_nav .commonNav > ul > li > :hover > a {
              color: #184a6b; }
              .site_nav .commonNav > ul > li > :hover > a > ::before {
                content: none; }
            .site_nav .commonNav > ul > li > a {
              text-transform: uppercase; }
        .site_nav .commonNav li {
          display: inline-block; }
          .site_nav .commonNav li:hover > nav > ul {
            display: flex;
            flex-flow: row nowrap;
            justify-content: space-around; }
            .site_nav .commonNav li:hover > nav > ul > li {
              flex: 1 1; }
          .site_nav .commonNav li:hover ul.level2 {
            display: block; }
            .site_nav .commonNav li:hover ul.level2.vertical {
              padding: .5rem 0rem;
              animation: navMenuShowVert .3s ease-in-out;
              display: flex;
              flex-flow: column nowrap;
              justify-content: space-around; }
              .site_nav .commonNav li:hover ul.level2.vertical > li > a {
                padding: .5rem 1rem; }
            .site_nav .commonNav li:hover ul.level2:not(.vertical) {
              animation: navMenuShow .3s ease-in-out; }
            .site_nav .commonNav li:hover ul.level2 > li {
              padding: 0;
              text-align: left; }
              .site_nav .commonNav li:hover ul.level2 > li > a {
                padding: 1rem 1.5rem;
                position: relative; }
          .site_nav .commonNav li:hover > ul.level3 {
            position: absolute;
            top: 100%;
            right: 0;
            display: flex;
            flex-flow: row wrap;
            justify-content: space-around;
            width: 100%;
            animation: navMenuShowVert .3s ease-in-out; }
          .site_nav .commonNav li:not(:hover) ul {
            display: none; }
          .site_nav .commonNav li a {
            display: inline-block;
            font-size: .85rem;
            color: #fff;
            font-weight: 600;
            text-decoration: none;
            position: relative; }
        .site_nav .commonNav ul.level1 > li > a {
          color: #8a8a8a;
          text-transform: uppercase;
          padding: 1rem; }
        .site_nav .commonNav ul.level1 li.collapsable:hover > a::before {
          content: "\f0c8";
          transform: rotate(45deg);
          font: normal normal 400 .875rem/1 "Font Awesome 5 Pro";
          position: absolute;
          top: calc(100% - 7px);
          z-index: 1;
          left: 50%;
          color: #fff; }
        .site_nav .commonNav ul.level2 {
          position: absolute;
          top: 100%;
          background-color: rgba(89, 152, 201, 0.95);
          right: 0; }
          .site_nav .commonNav ul.level2.vertical {
            right: auto; }
          .site_nav .commonNav ul.level2 > li {
            padding: .25rem .5rem;
            flex: 1 0 auto; }
            .site_nav .commonNav ul.level2 > li:hover > a::before {
              color: #184a6b; }
            .site_nav .commonNav ul.level2 > li > a {
              padding: .5rem 0;
              position: relative; }
            .site_nav .commonNav ul.level2 > li a:hover {
              color: #184a6b; }
          .site_nav .commonNav ul.level2 li a {
            color: #fff; }
          .site_nav .commonNav ul.level2 li:hover ul.level3 {
            display: flex;
            align-items: center;
            justify-content: flex-start;
            flex-flow: row wrap;
            padding: 1rem 0rem; }
            .site_nav .commonNav ul.level2 li:hover ul.level3 > li {
              flex: 0 1 50%;
              padding: 0;
              text-align: left; }
          .site_nav .commonNav ul.level2 > ul {
            display: flex;
            flex-flow: row nowrap;
            justify-content: space-around; }
        .site_nav .commonNav ul.level3 {
          background-color: rgba(89, 152, 201, 0.95);
          width: 200px;
          top: 100%;
          border-top: solid 1px #184a6b; }
          .site_nav .commonNav ul.level3 > li > a {
            padding: .5rem 2rem; } }
    .site_nav .commonNav ul {
      list-style: none;
      margin: 0;
      padding: 0; }
      .site_nav .commonNav ul li.search {
        display: none; }
        .site_nav .commonNav ul li.search svg {
          display: none; }
          @media (min-width: 44rem) {
            .site_nav .commonNav ul li.search svg {
              display: block; } }
          .site_nav .commonNav ul li.search svg path {
            fill: #8a8a8a;
            transition: .25s all; }
        .site_nav .commonNav ul li.search:hover path {
          fill: #184a6d; }
        @media (min-width: 44rem) {
          .site_nav .commonNav ul li.search {
            display: inline-block; }
            .site_nav .commonNav ul li.search span {
              display: none; } }
        .site_nav .commonNav ul li.search .search_container {
          position: absolute;
          top: 100%;
          right: 0;
          display: none; }
          .site_nav .commonNav ul li.search .search_container #nav_search_desktop {
            display: flex;
            width: 20rem;
            padding: 0; }
            .site_nav .commonNav ul li.search .search_container #nav_search_desktop input {
              flex: 1 1 auto;
              height: 3.125rem;
              line-height: 1.75rem;
              border: 0;
              border-top: 1px solid #e5e5e5;
              border-radius: 0; }
            .site_nav .commonNav ul li.search .search_container #nav_search_desktop button {
              position: relative;
              min-width: 3.25rem;
              width: 3.25rem;
              padding: 0;
              border-radius: 0;
              background-color: #5998c9; }
              .site_nav .commonNav ul li.search .search_container #nav_search_desktop button svg {
                width: 1rem;
                height: 1rem; }
                .site_nav .commonNav ul li.search .search_container #nav_search_desktop button svg path {
                  fill: #fff; }
      .site_nav .commonNav ul li #nav_search_mobile {
        display: flex;
        padding: 0; }
        .site_nav .commonNav ul li #nav_search_mobile input {
          flex: 1 1 auto;
          height: 3.125rem;
          line-height: 1.75;
          border: 0;
          border-radius: 0; }
        .site_nav .commonNav ul li #nav_search_mobile button {
          position: relative;
          min-width: 3.25rem;
          width: 3.25rem;
          padding: 0;
          background-color: #5998c9;
          border-radius: 0; }
          .site_nav .commonNav ul li #nav_search_mobile button svg {
            width: 1rem;
            height: 1rem; }
            .site_nav .commonNav ul li #nav_search_mobile button svg path {
              fill: #fff; }
      @media (min-width: 44rem) {
        .site_nav .commonNav ul li {
          display: inline-block;
          border-bottom: 0; }
          .site_nav .commonNav ul li.mobile {
            display: none; } }

.navUnits > li:nth-child(1) {
  order: 1; }

.navUnits > li:nth-child(2) {
  order: 2; }

.navUnits > li:nth-child(3) {
  order: 3; }

.navUnits > li:nth-child(4) {
  order: 4; }

.navUnits > li:nth-child(5) {
  order: 5; }

.navUnits > li:nth-child(6) {
  order: 6; }

.navUnits > li:nth-child(7) {
  order: 1; }

.navUnits > li:nth-child(8) {
  order: 2; }

.navUnits > li:nth-child(9) {
  order: 3; }

.navUnits > li:nth-child(10) {
  order: 4; }

.navUnits > li:nth-child(11) {
  order: 5; }

.navUnits > li:nth-child(12) {
  order: 6; }

.navAccessories > li:nth-child(3n+1) {
  order: 1; }

.navAccessories > li:nth-child(3n+2) {
  order: 2; }

.navAccessories > li:nth-child(3n+3) {
  order: 3; }

.comNav {
  clear: both;
  display: none;
  width: 100vw;
  background-color: #fff;
  border-top: 1px solid #8a8a8a;
  transform: translateX(-1.5rem); }
  @media (max-width: 44rem) {
    .comNav {
      width: calc(100% + 3rem);
      left: -200%;
      flex: 0 1 100%;
      display: none;
      flex-flow: column nowrap;
      justify-content: flex-start;
      top: 0;
      margin-top: 85px;
      z-index: 1;
      background-color: #f2f4f5; }
      .comNav > ul {
        display: block;
        margin: 0 auto;
        width: 100%; }
        .comNav > ul li > input.menuToggle:checked ~ ul {
          max-height: 700px;
          transition: max-height .3s ease-in-out; }
        .comNav > ul li ul {
          max-height: 0;
          overflow: hidden;
          transition: max-height .3s ease-in-out; }
      .comNav ul.level0 a {
        padding-left: 1.5rem;
        margin-right: 3.5rem; }
      .comNav ul.level0 li {
        border-top: solid 1px #8a8a8a; }
      .comNav ul.level0 > li > label.menuToggle {
        clip: auto; }
      .comNav ul.level1 a {
        padding-left: 2.5rem;
        margin-right: 3.5rem; }
      .comNav ul.level1 li {
        border-top: solid 1px #8a8a8a; }
      .comNav ul.level1 > li > label.menuToggle {
        clip: auto; }
      .comNav ul.level2 {
        background-color: #5998c9; }
        .comNav ul.level2 label {
          color: #fff; }
        .comNav ul.level2 a {
          color: #fff;
          padding-left: 3.5rem; }
          .comNav ul.level2 a::after {
            color: #fff; }
      .comNav ul.level3 a {
        text-transform: none;
        padding-left: 4.5rem; }
      .comNav a {
        position: relative;
        display: block;
        padding-top: .25rem;
        padding-bottom: .25rem;
        overflow: hidden;
        color: #8a8a8a;
        font-size: .875rem;
        font-weight: 700;
        line-height: 2;
        text-decoration: none;
        text-transform: uppercase;
        transition: padding .3s linear; }
        .comNav a a:hover {
          color: #004A8C; }
      .comNav li {
        position: relative; }
      .comNav label.menuToggle {
        font: normal normal 400 .75rem/1 "Font Awesome 5 Pro";
        position: absolute;
        text-align: right;
        right: 0;
        line-height: 2;
        transform: rotate(45deg);
        transition: transform linear .25s;
        z-index: 1;
        clip: rect(0, 0, 0, 0);
        height: 36px;
        width: 36px;
        border-radius: 18px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-color: #8a8a8a;
        font-size: 1.1rem; }
      .comNav input.menuToggle:checked ~ label {
        transform: rotate(-360deg); }
      .comNav input.menuToggle:checked ~ ul > li > label.menuToggle {
        clip: auto; }
      .comNav input.menuToggle {
        display: none; } }
  @media (min-width: 44rem) {
    .comNav {
      position: absolute;
      right: .75rem;
      bottom: 0;
      display: flex !important;
      width: 100%;
      background-color: transparent;
      border-top: 0;
      transform: translateX(0);
      flex-flow: row nowrap;
      justify-content: flex-end;
      transition: margin ease-in-out .2s; }
      .comNav .indent {
        padding-left: 1rem; }
      .comNav a {
        display: inline-block;
        font-weight: 600;
        font-size: .85rem;
        text-transform: uppercase;
        padding: 1rem;
        color: #fff; }
        .comNav a:hover {
          color: #004A8C; }
      .comNav .level1 {
        flex: 1 0 auto;
        display: flex;
        flex-flow: row nowrap;
        justify-content: flex-end; }
        .comNav .level1 > li {
          flex: 0 1 auto;
          text-align: right; }
          .comNav .level1 > li > a {
            color: #8a8a8a; }
            .comNav .level1 > li > a:hover {
              color: #004A8C; }
        .comNav .level1 ul {
          display: none; }
      .comNav .level2 {
        position: absolute;
        top: 100%;
        background-color: rgba(89, 152, 201, 0.95);
        right: 0;
        animation: navMenuShow .3s ease-in-out; }
        .comNav .level2.vertical {
          right: auto;
          padding: .5rem 0rem;
          animation: navMenuShowVert .3s ease-in-out;
          flex-flow: column nowrap;
          justify-content: space-around; }
          .comNav .level2.vertical > li > a {
            padding: .5rem 1rem; }
        .comNav .level2 > li {
          flex: 1 0 auto;
          text-align: left; }
          .comNav .level2 > li > a {
            padding: 1rem 1.5rem; }
        .comNav .level2 li:hover ul.level3 {
          display: flex;
          align-items: center;
          justify-content: flex-start;
          flex-flow: row wrap;
          padding: 1rem 0rem; }
          .comNav .level2 li:hover ul.level3 > li {
            flex: 0 1 50%;
            padding: 0;
            text-align: left; }
      .comNav .level2:not(.is-inline-menu) .level3 {
        position: absolute;
        top: 100%;
        right: 0;
        flex-flow: row wrap;
        justify-content: space-around;
        width: 100%;
        animation: navMenuShowVert .3s ease-in-out;
        background-color: rgba(89, 152, 201, 0.95);
        width: 100%;
        border-top: solid 1px #004A8C; }
        .comNav .level2:not(.is-inline-menu) .level3 > li > a {
          padding: .5rem 2rem; }
      .comNav li {
        display: inline-block; }
        .comNav li:hover ul {
          display: none; }
        .comNav li:hover > ul {
          display: flex; } }
  .comNav .search {
    display: none; }
    .comNav .search svg {
      display: none; }
      @media (min-width: 44rem) {
        .comNav .search svg {
          display: block; } }
      .comNav .search svg path {
        fill: #8a8a8a;
        transition: .25s all; }
    .comNav .search:hover path {
      fill: #184a6d; }
    @media (min-width: 44rem) {
      .comNav .search {
        display: inline-block; }
        .comNav .search span {
          display: none; } }
    .comNav .search .search_container {
      position: absolute;
      top: 100%;
      right: 0;
      display: none; }
      .comNav .search .search_container #nav_search_desktop {
        display: flex;
        width: 20rem;
        padding: 0; }
        .comNav .search .search_container #nav_search_desktop input {
          flex: 1 1 auto;
          height: 3.125rem;
          line-height: 1.75rem;
          border: 0;
          border-top: 1px solid #e5e5e5;
          border-radius: 0; }
        .comNav .search .search_container #nav_search_desktop button {
          position: relative;
          min-width: 3.25rem;
          width: 3.25rem;
          padding: 0;
          border-radius: 0;
          background-color: #5998c9; }
          .comNav .search .search_container #nav_search_desktop button svg {
            width: 1rem;
            height: 1rem; }
            .comNav .search .search_container #nav_search_desktop button svg path {
              fill: #fff; }
  .comNav #nav_search_mobile {
    display: flex;
    padding: 0; }
    .comNav #nav_search_mobile input {
      flex: 1 1 auto;
      border: 0;
      border-radius: 0;
      font-size: .875rem;
      padding: .25rem 1.5rem;
      line-height: 2;
      color: #5998c9; }
    .comNav #nav_search_mobile button {
      position: relative;
      min-width: 3.25rem;
      width: 3.25rem;
      padding: 0;
      background-color: #5998c9;
      border-radius: 0;
      border: none; }
      .comNav #nav_search_mobile button svg {
        width: 1rem;
        height: 1rem; }
        .comNav #nav_search_mobile button svg path {
          fill: #fff; }
  .comNav ul {
    list-style: none;
    margin: 0;
    padding: 0; }
    @media (min-width: 44rem) {
      .comNav ul {
        display: inline-block;
        border-bottom: 0; }
        .comNav ul.mobile {
          display: none; } }

.page_content {
  width: 100%;
  overflow: hidden; }

@media (min-width: 45em) {
  .col2 {
    display: flex;
    flex-wrap: wrap; } }

.col2 .col {
  display: block;
  width: 100%;
  margin-bottom: 1.5rem; }
  @media (min-width: 45em) {
    .col2 .col {
      flex: 1 1 auto;
      width: calc((100% - 1.5rem) / 2.0001);
      max-width: calc((100% - 1.5rem) / 2.0001); }
      .col2 .col:nth-child(odd) {
        margin-right: 1.5rem; } }

@media (min-width: 36em) {
  .col3 {
    display: flex;
    flex-wrap: wrap; } }

.col3 .col {
  display: block;
  width: 100%;
  margin-bottom: 1.5rem; }
  @media (min-width: 36em) {
    .col3 .col {
      flex: 1 1 auto;
      width: calc((100% - 1.5rem) / 2.0001);
      max-width: calc((100% - 1.5rem) / 2.0001); }
      .col3 .col:nth-child(2n + 1) {
        margin-right: 1.5rem; } }
  @media (min-width: 52em) {
    .col3 .col {
      width: calc((100% - 3rem) / 3.0001);
      max-width: calc((100% - 3rem) / 3.0001); }
      .col3 .col:nth-child(2n + 1) {
        margin-right: 0; }
      .col3 .col:not(:nth-child(3n + 3)) {
        margin-right: 1.5rem; } }

@media (min-width: 24em) {
  .col4 {
    display: flex;
    flex-wrap: wrap; } }

.col4 .col {
  display: block;
  width: 100%;
  margin-bottom: 1.5rem; }
  @media (min-width: 24em) {
    .col4 .col {
      flex: 1 1 auto;
      width: calc((100% - 1.5rem) / 2.0001);
      max-width: calc((100% - 1.5rem) / 2.0001); }
      .col4 .col:nth-child(2n + 1) {
        margin-right: 1.5rem; } }
  @media (min-width: 44em) {
    .col4 .col {
      width: calc((100% - 3rem) / 3.0001);
      max-width: calc((100% - 3rem) / 3.0001); }
      .col4 .col:nth-child(2n + 1) {
        margin-right: 0; }
      .col4 .col:not(:nth-child(3n + 3)) {
        margin-right: 1.5rem; } }
  @media (min-width: 64em) {
    .col4 .col {
      width: calc((100% - 4.5rem) / 4.0001);
      max-width: calc((100% - 4.5rem) / 4.0001); }
      .col4 .col:not(:nth-child(3n + 3)) {
        margin-right: 0; }
      .col4 .col:not(:nth-child(4n + 4)) {
        margin-right: 1.5rem; } }

@media (min-width: 12em) {
  .col5 {
    display: flex;
    flex-wrap: wrap; } }

.col5 .col {
  display: block;
  width: 100%;
  margin-bottom: 1.5rem; }
  @media (min-width: 12em) {
    .col5 .col {
      flex: 1 1 auto;
      width: calc((100% - 1.5rem) / 2.0001);
      max-width: calc((100% - 1.5rem) / 2.0001); }
      .col5 .col:nth-child(2n + 1) {
        margin-right: 1.5rem; } }
  @media (min-width: 24em) {
    .col5 .col {
      width: calc((100% - 3rem) / 3.0001);
      max-width: calc((100% - 3rem) / 3.0001); }
      .col5 .col:nth-child(2n + 1) {
        margin-right: 0; }
      .col5 .col:not(:nth-child(3n + 3)) {
        margin-right: 1.5rem; } }
  @media (min-width: 36em) {
    .col5 .col {
      width: calc((100% - 4.5rem) / 4.0001);
      max-width: calc((100% - 4.5rem) / 4.0001); }
      .col5 .col:not(:nth-child(3n + 3)) {
        margin-right: 0; }
      .col5 .col:not(:nth-child(4n + 4)) {
        margin-right: 1.5rem; } }
  @media (min-width: 48em) {
    .col5 .col {
      width: calc((100% - 6rem) / 5.0001);
      max-width: calc((100% - 6rem) / 5.0001); }
      .col5 .col:not(:nth-child(4n + 4)) {
        margin-right: 0; }
      .col5 .col:not(:nth-child(5n + 5)) {
        margin-right: 1.5rem; } }

.site_footer {
  position: relative;
  padding-top: 2.25rem;
  background-color: #585a5f; }
  .site_footer .contain {
    position: relative;
    width: 100%;
    max-width: 67.5rem;
    margin: 0 auto;
    padding: 0 1.5rem;
    text-align: center; }
    @media (min-width: 35rem) {
      .site_footer .contain {
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2; } }
    @media (min-width: 54rem) {
      .site_footer .contain {
        -webkit-column-count: 3;
        -moz-column-count: 3;
        column-count: 3;
        text-align: left; } }
    @media (min-width: 67.5rem) {
      .site_footer .contain {
        -webkit-column-count: 1;
        -moz-column-count: 1;
        column-count: 1;
        display: flex;
        justify-content: space-between; } }
    .site_footer .contain > div {
      -webkit-column-break-inside: avoid;
      page-break-inside: avoid;
      break-inside: avoid;
      position: relative;
      padding: 0 1rem 2.25rem 1rem; }
      @media (min-width: 67.5rem) {
        .site_footer .contain > div {
          flex: 1; } }
      .site_footer .contain > div .toggle {
        float: right;
        width: 3rem;
        margin-right: -1rem;
        text-align: center; }
        @media (min-width: 35rem) {
          .site_footer .contain > div .toggle {
            display: none; } }
        .site_footer .contain > div .toggle svg {
          transition: .25s all; }
          .site_footer .contain > div .toggle svg path {
            fill: rgba(255, 255, 255, 0.5);
            transition: .25s all; }
        .site_footer .contain > div .toggle.on svg {
          transform: rotate(180deg); }
        .site_footer .contain > div .toggle:hover svg path {
          fill: #fff; }
      .site_footer .contain > div .colHeader {
        margin-bottom: 1rem;
        color: #fff;
        font: 600 0.875rem "proxima-nova", sans-serif; }
        .site_footer .contain > div .colHeader a {
          color: inherit;
          text-decoration: none; }
        .site_footer .contain > div .colHeader img {
          width: 1rem;
          height: .6875rem;
          margin-right: .375rem; }
      .site_footer .contain > div .toggle + colHeader {
        float: left;
        width: calc(100% - 3rem);
        margin-bottom: 0;
        text-align: left; }
        @media (min-width: 35rem) {
          .site_footer .contain > div .toggle + colHeader {
            float: none;
            width: 100%;
            margin-bottom: 1rem;
            padding-bottom: 0;
            text-align: center; } }
        @media (min-width: 54rem) {
          .site_footer .contain > div .toggle + colHeader {
            text-align: left; } }
      .site_footer .contain > div ul {
        list-style: none;
        margin: 0;
        padding: 0; }
        .site_footer .contain > div ul li {
          margin-bottom: .125rem; }
          .site_footer .contain > div ul li a {
            display: inline-block;
            color: rgba(255, 255, 255, 0.5);
            font-weight: 600;
            font-size: .8125rem;
            line-height: 1.3;
            text-decoration: none;
            transition: .25s all; }
            .site_footer .contain > div ul li a:hover {
              color: #fff; }
      .site_footer .contain > div .toggle + .colHeader + ul {
        clear: both;
        display: none;
        text-align: left; }
        @media (min-width: 35rem) {
          .site_footer .contain > div .toggle + .colHeader + ul {
            display: block !important;
            text-align: center; } }
        @media (min-width: 54rem) {
          .site_footer .contain > div .toggle + .colHeader + ul {
            text-align: left; } }
      .site_footer .contain > div .social {
        margin: 0 0 1.1rem -.25rem;
        white-space: nowrap; }
        .site_footer .contain > div .social a {
          display: inline-block;
          padding: .25rem; }
          .site_footer .contain > div .social a svg {
            width: 1.5625rem;
            height: 1.5625rem; }
            .site_footer .contain > div .social a svg path {
              fill: #fff; }

[data-tooltip] {
  position: relative;
  z-index: 2;
  cursor: pointer; }

[data-tooltip]:before,
[data-tooltip]:after {
  visibility: hidden;
  opacity: 0;
  pointer-events: none; }

[data-tooltip]:before {
  position: absolute;
  bottom: 150%;
  left: 50%;
  margin-bottom: 5px;
  margin-left: -80px;
  padding: 7px;
  width: 160px;
  border-radius: 3px;
  background-color: #000;
  background-color: rgba(51, 51, 51, 0.9);
  color: #fff;
  content: attr(data-tooltip);
  text-align: center;
  font-size: 1rem;
  line-height: 1.2; }

[data-tooltip]:after {
  position: absolute;
  bottom: 150%;
  left: 50%;
  margin-left: -5px;
  width: 0;
  border-top: 5px solid #000;
  border-top: 5px solid rgba(51, 51, 51, 0.9);
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  content: " ";
  font-size: 0;
  line-height: 0; }

[data-tooltip]:hover:before,
[data-tooltip]:hover:after {
  visibility: visible;
  opacity: 1; }

.fa-file-pdf {
  color: #e31e24; }

.savingsCalcBar {
  padding: 3.4375rem 1.5rem;
  background-color: #f4f4f4; }
  @media (min-width: 60em) {
    .savingsCalcBar {
      display: flex;
      justify-content: center;
      align-items: center; } }
  @media (min-width: 60em) {
    .savingsCalcBar header {
      margin-right: 4rem;
      white-space: nowrap; } }
  .savingsCalcBar header input {
    display: none; }
  .savingsCalcBar header p {
    font-size: 0.8rem;
    text-align: center; }
    @media (min-width: 20rem) {
      .savingsCalcBar header p {
        font-size: calc(0.8rem + 0.1 * (100vw - 20rem) / 5); } }
    @media (min-width: 25rem) {
      .savingsCalcBar header p {
        font-size: 0.9rem; } }
  .savingsCalcBar header span {
    display: block;
    text-align: center; }
    .savingsCalcBar header span:first-of-type {
      color: #8a8a8a;
      font-weight: 300;
      font-size: 2rem; }
      @media (min-width: 20rem) {
        .savingsCalcBar header span:first-of-type {
          font-size: calc(2rem + 1 * (100vw - 20rem) / 5); } }
      @media (min-width: 25rem) {
        .savingsCalcBar header span:first-of-type {
          font-size: 3rem; } }
    .savingsCalcBar header span:last-of-type {
      margin-top: -.25em;
      color: #80b141;
      font-weight: 400;
      font-size: 2.625rem;
      text-transform: uppercase; }
      @media (min-width: 20em) {
        .savingsCalcBar header span:last-of-type {
          font-size: calc(2.625rem + 0.65625 * (100vw - 20em) / 5); } }
      @media (min-width: 25em) {
        .savingsCalcBar header span:last-of-type {
          font-size: 3.28125rem; } }
  .savingsCalcBar .savingsCalcFlapper.fullWidth {
    text-align: center;
    padding: 10px;
    font-size: 3.3rem; }
    @media (min-width: 20rem) {
      .savingsCalcBar .savingsCalcFlapper.fullWidth {
        font-size: calc(3.3rem + 2.2 * (100vw - 20rem) / 15); } }
    @media (min-width: 35rem) {
      .savingsCalcBar .savingsCalcFlapper.fullWidth {
        font-size: 5.5rem; } }
  .savingsCalcBar form {
    display: flex;
    height: 100%;
    justify-content: space-between;
    align-items: center;
    flex-flow: column wrap;
    padding: 10px; }
    .savingsCalcBar form > label {
      display: block;
      flex: 1 1 auto;
      margin-bottom: .75rem;
      font-size: 1.25rem;
      font-size: 1.75rem;
      text-align: center;
      white-space: nowrap; }
      @media (min-width: 20em) {
        .savingsCalcBar form > label {
          font-size: calc(1.25rem + 0.5 * (100vw - 20em) / 5); } }
      @media (min-width: 25em) {
        .savingsCalcBar form > label {
          font-size: 1.75rem; } }
    .savingsCalcBar form input[type=submit] {
      margin: 0 auto; }
    .savingsCalcBar form .has-addons {
      width: 80%;
      margin: 0 auto; }
      .savingsCalcBar form .has-addons div:nth-of-type(2) {
        margin-top: .75rem;
        text-align: center; }
      @media screen and (min-width: 769px), print {
        .savingsCalcBar form .has-addons {
          width: auto; }
          .savingsCalcBar form .has-addons div:nth-of-type(2) {
            margin-top: 0; } }

/*# sourceMappingURL=site.css.map */
