@import url("https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css");

html,
body,
div,
span,
applet,
object,
iframe,
button,
input,
select,
textarea,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
main,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  background: none;
  vertical-align: baseline;
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  text-decoration: none;
}

/* This stylesheet generated by Transfonter (https://transfonter.org) on May 30, 2017 6:29 PM */
@font-face {
  font-family: "Festivo LC RShadow";
  src: url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.eot");
  src: url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.eot?#iefix")
      format("embedded-opentype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.woff2")
      format("woff2"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.woff")
      format("woff"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.ttf")
      format("truetype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-BasicRShadow.svg#FestivoLC-BasicRShadow")
      format("svg");
  font-weight: normal;
}

@font-face {
  font-family: "Festivo LC Basic";
  src: url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.eot");
  src: url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.eot?#iefix")
      format("embedded-opentype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.woff2")
      format("woff2"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.woff")
      format("woff"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.ttf")
      format("truetype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/FestivoLC-Basic.svg#FestivoLC-Basic")
      format("svg");
  font-weight: normal;
}

/* This stylesheet generated by Transfonter (https://transfonter.org) on May 30, 2017 6:29 PM */
@font-face {
  font-family: "Gotham Rounded";
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.eot");
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.eot?#iefix")
      format("embedded-opentype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.woff2")
      format("woff2"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.woff")
      format("woff"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.ttf")
      format("truetype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Bold.svg#GothamRounded-Bold")
      format("svg");
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: "Gotham Rounded";
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.eot");
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.eot?#iefix")
      format("embedded-opentype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.woff2")
      format("woff2"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.woff")
      format("woff"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.ttf")
      format("truetype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Book.svg#GothamRounded-Book")
      format("svg");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: "Gotham Rounded";
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.eot");
  src: url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.eot?#iefix")
      format("embedded-opentype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.woff2")
      format("woff2"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.woff")
      format("woff"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.ttf")
      format("truetype"),
    url("https://www.freal.com/assets/gecko-theme/fonts/GothamRounded-Light.svg#GothamRounded-Light")
      format("svg");
  font-weight: 300;
  font-style: normal;
}

/* Breakpoint Utilities (1.0.0)
 * Provides utilities for imlementing custom, flexible breakpoints.
 */
/* Touch Nav Detection (1.1.0)
 * Determines whether we should be using touch navigation or not.
 * Pass in 'false' to the argument if the mixin is being used in the root instead of in a block.
 */
.hamburger {
  padding: 0px 0px;
  display: inline-block;
  cursor: pointer;
  transition-property: opacity, -webkit-filter;
  transition-property: opacity, filter;
  transition-property: opacity, filter, -webkit-filter;
  transition-duration: 0.5s;
  transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
  border: 0;
  margin: 0;
  overflow: visible;
}

.hamburger-box {
  width: 60px;
  height: 32px;
  display: inline-block;
  position: relative;
}

.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -2px;
}
.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
  width: 60px;
  height: 4px;
  background-color: #ee3a43;
  border-radius: 2px;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}
.hamburger-inner::before,
.hamburger-inner::after {
  content: "";
  display: block;
}
.hamburger-inner::before {
  top: -14px;
}
.hamburger-inner::after {
  bottom: -14px;
}

header.touch .toggle-touch-menu[data-status="active"] .hamburger-inner,
header.touch .toggle-touch-menu[data-status="active"] .hamburger-inner::before,
header.touch .toggle-touch-menu[data-status="active"] .hamburger-inner::after {
  background-color: #eb1924;
}

.hamburger--elastic .hamburger-inner {
  top: 2px;
  transition-duration: 0.275s;
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger--elastic .hamburger-inner::before {
  top: 14px;
  transition: opacity 0.125s 0.275s ease;
}
.hamburger--elastic .hamburger-inner::after {
  top: 28px;
  transition: transform 0.275s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

[data-status="active"] .hamburger--elastic .hamburger-inner {
  transform: translate3d(0, 14px, 0) rotate(135deg);
  transition-delay: 0.075s;
}
[data-status="active"] .hamburger--elastic .hamburger-inner::before {
  transition-delay: 0s;
  opacity: 0;
}
[data-status="active"] .hamburger--elastic .hamburger-inner::after {
  transform: translate3d(0, -28px, 0) rotate(-270deg);
  transition-delay: 0.075s;
}

html,
body {
  height: 100%;
}

body {
  font-size: 20px;
  font-family: "Gotham Rounded", sans-serif;
  line-height: 1.4;
  font-weight: 300;
  background-color: #fff;
  -webkit-tap-highlight-color: rgba(238, 58, 67, 0.1);
}
body ::-moz-selection {
  color: #fff;
  background: #00aeef;
}
body ::selection {
  color: #fff;
  background: #00aeef;
}

.row {
  margin: 0 auto;
  width: 100%;
  max-width: 75rem;
}

body > header.desktop {
  position: fixed;
  z-index: 1500;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background-color: #fff;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15), 0 2px 5px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 71.25rem) {
  body > header.desktop {
    display: none;
  }
}
html.touch body > header.desktop {
  display: none;
}
body > header.desktop .site-branding {
  margin-left: 3.25rem;
  width: 207px;
  height: 120px;
  font-size: 1.2rem;
}
body > header.desktop .site-branding .logo {
  display: block;
  margin: 1rem 0 0;
  height: calc(120px - 2rem);
  width: 207px;
  font-size: 0;
  color: transparent;
  background-image: url(https://www.freal.com/assets/gecko-theme/images/logo.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.2s ease-in-out;
}
body > header.desktop nav {
  display: -ms-flexbox;
  display: flex;
}
body > header.desktop .primary > div,
body > header.desktop .primary .primary-menu {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
}
body > header.desktop .primary .menu-item {
  position: relative;
  transition: transform 0.125s ease-in-out;
}
body > header.desktop .primary .menu-item img._before {
  margin-right: 0;
}
body > header.desktop .primary .menu-item:nth-child(4n + 1):hover {
  transform: scale(1.1) rotate(2deg);
}
body > header.desktop .primary .menu-item:nth-child(4n + 2):hover {
  transform: scale(1.1) rotate(-2deg);
}
body > header.desktop .primary .menu-item:nth-child(4n + 3):hover {
  transform: scale(1.1) rotate(2deg);
}
body > header.desktop .primary .menu-item:nth-child(4n + 4):hover {
  transform: scale(1.1) rotate(-2deg);
}
body > header.desktop .primary .menu-item > a {
  position: relative;
  z-index: 2;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  -ms-flex-align: center;
  align-items: center;
  padding: 5rem 1.5rem 0.5rem;
  color: #095090;
  text-align: center;
  text-transform: uppercase;
  font-size: 1.125rem;
  font-family: "Festivo LC Basic", sans-serif;
}
body > header.desktop .primary .menu-item svg {
  position: absolute;
  z-index: 1;
  top: 0.75rem;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  height: 3.75rem;
  width: 3.75rem;
}
body > header.desktop .primary .menu-item svg .red-block path {
  fill: transparent;
  stroke: transparent;
}
body > header.desktop .primary .menu-item svg .blue-block path {
  fill: transparent;
  stroke: transparent;
}
body > header.desktop .primary .menu-item svg .white-block path {
  fill: #fff;
  stroke: transparent;
}
body > header.desktop .primary .sub-menu {
  display: none;
}
body > header.desktop .social {
  margin-right: 1rem;
  -ms-flex-align: center;
  align-items: center;
}
body > header.desktop .social a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  padding: 1rem;
  font-size: 0;
  color: transparent;
}
body > header.desktop .social a::before {
  color: #00aeef;
  font-family: fontawesome;
  font-size: 2rem;
}
body > header.desktop .social a:hover::before {
  color: #0abcff;
}
body > header.desktop .site-switcher {
  -ms-flex-align: start;
  align-items: flex-start;
  margin-right: 1.5rem;
}
@media (max-width: 1240px) {
  body > header.desktop .site-switcher {
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: end;
    align-items: flex-end;
    -ms-flex-pack: center;
    justify-content: center;
    margin-left: 1rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }
}
body > header.desktop .site-switcher a {
  position: relative;
  display: block;
  padding: 0.5rem 1rem;
  font-size: 1rem;
  color: #3d454d;
  transition: all 0.2s ease-in-out;
  background-color: #ccc;
}
body > header.desktop .site-switcher a.active {
  cursor: default;
  background-color: #ee3a43;
  color: #fff;
}
body > header.desktop .site-switcher a.active::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  border-color: blue;
  border-style: solid;
  border-top: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 4px solid #fff;
  content: "";
}
body > header.desktop .site-switcher a:not(.active):hover {
  color: #000;
  background-color: #b3b3b3;
}

body > header.touch {
  position: fixed;
  z-index: 10006;
  top: 0;
  left: 0;
  right: 0;
  display: none;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 1rem;
  width: 100%;
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15), 0 2px 5px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 71.25rem) {
  body > header.touch {
    display: -ms-flexbox;
    display: flex;
  }
}
html.touch body > header.touch {
  display: -ms-flexbox;
  display: flex;
}
body > header.touch > .logo {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  font-size: 0;
  color: transparent;
  text-indent: -9999px;
  height: 75px;
  width: 160px;
  background-image: url(https://www.freal.com/assets/gecko-theme/images/logo.svg);
  background-size: contain;
  background-position: left center;
  background-repeat: no-repeat;
}
body > header.touch > .toggle-touch-menu {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 1rem;
  cursor: pointer;
}

body > aside.touch-menu {
  position: fixed;
  top: 0;
  left: 0;
  transform: translateY(0);
  z-index: 10005;
  opacity: 1;
  width: 100%;
  max-height: 100vh;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  transition: transform 0.3s ease-in-out, opacity 0.4s ease-in-out,
    top 0.3s ease-in-out;
}
@media screen and (min-width: 71.25rem) {
  body > aside.touch-menu {
    display: none;
  }
}
html.no-touch body > aside.touch-menu {
  display: none;
}
body > aside.touch-menu[hidden] {
  transform: translateY(-100%);
  opacity: 0;
}
body > aside.touch-menu header {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  padding: 1rem;
  border-bottom: 1px solid black;
}
body > aside.touch-menu nav {
  padding: 1rem 0 0;
  overflow-y: auto;
  max-height: 100vh;
}
body > aside.touch-menu nav li {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  padding: 1rem 0;
  -ms-flex-align: center;
  align-items: center;
}
body > aside.touch-menu nav li a {
  position: relative;
  z-index: 2;
  display: block;
  padding: 1rem 2rem 1rem 9rem;
  width: 100%;
  font-size: 2.4rem;
  font-family: "Festivo LC Basic", sans-serif;
  text-transform: uppercase;
  color: #095090;
  transition: all 0.2s ease-in-out;
}
@media (max-width: 540px) {
  body > aside.touch-menu nav li a {
    padding: 0.5rem 2rem 0.5rem 6.5rem;
    font-size: 1.6rem;
  }
}
body > aside.touch-menu nav li svg {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 2rem;
  transform: translateY(-50%);
  display: block;
  height: 5rem;
  width: 5rem;
}
@media (max-width: 540px) {
  body > aside.touch-menu nav li svg {
    height: 3.5rem;
    width: 3.5rem;
  }
}

gecko-blackout {
  position: fixed;
  z-index: 10001;
  top: 0;
  left: 0;
  bottom: 0;
  display: block;
  width: 100vw;
  max-height: 100vh;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.96) 33%,
    rgba(255, 255, 255, 0.92) 66%,
    rgba(255, 255, 255, 0.5) 90%,
    rgba(255, 255, 255, 0.2) 100%
  );
  transition: opacity 0.3s ease-in-out, visibility 0s linear 0.3s;
}
gecko-blackout:not([hidden]) {
  transition-delay: 0s;
}
gecko-blackout[hidden] {
  visibility: hidden;
  opacity: 0;
}

body > .colophon {
  padding: 1.5rem 0;
  background-color: #1a2733;
  color: #fff;
  font-size: 1rem;
  font-weight: 300;
  text-align: center;
}
body > .colophon .row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (max-width: 768px) {
  body > .colophon .row {
    -ms-flex-direction: column;
    flex-direction: column;
    text-align: center;
  }
}
@media (max-width: 768px) {
  body > .colophon nav {
    margin: 0 0 1.5rem;
    text-align: center;
  }
}
body > .colophon nav ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
}
@media (max-width: 768px) {
  body > .colophon nav ul {
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 1rem;
  }
}
body > .colophon nav ul li {
  display: block;
}
@media (max-width: 768px) {
  body > .colophon nav ul li:not(:last-of-type) {
    margin-bottom: 1.5rem;
  }
}
body > .colophon nav ul li:not(:first-child) {
  padding-left: 1rem;
  border-left: 1px solid rgba(255, 255, 255, 0.2);
}
@media (max-width: 768px) {
  body > .colophon nav ul li:not(:first-child) {
    border: 0;
  }
}
body > .colophon nav ul li::before {
  display: inline-block;
  margin: 0 0.5rem 0 0;
  color: #fff;
  font-family: fontawesome;
  -webkit-font-smoothing: antialiased;
}
body > .colophon nav a {
  display: inline-block;
  padding: 0 0.75rem 0 0;
  color: #00aeef;
}
body > .colophon nav a:hover {
  text-decoration: underline;
}
body > .colophon nav.international {
  display: -ms-flexbox;
  display: flex;
}
body > .colophon nav.international .flag {
  position: relative;
  display: block;
  padding: 0;
  height: 15px;
  width: 24px;
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.2s ease-in-out;
}
@media (max-width: 768px) {
  body > .colophon nav.international .flag {
    display: inline-block;
  }
}
body > .colophon nav.international .flag.active {
  cursor: default;
}
body > .colophon nav.international .flag.active::after {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 50%;
  transform: translateX(-50%);
  height: 4px;
  width: 4px;
  border-radius: 4px;
  content: "";
  background-color: rgba(255, 255, 255, 0.8);
}
body > .colophon nav.international .flag:not(:last-of-type) {
  margin-right: 1.5rem;
}
body > .colophon nav.international .flag.united-states {
  background-image: url("https://www.freal.com/assets/gecko-theme/images/flag-us.png");
}
body > .colophon nav.international .flag.canada {
  background-image: url("https://www.freal.com/assets/gecko-theme/images/flag-ca.png");
}
@media (max-width: 768px) {
  body > .colophon .legal {
    margin: 0 0 1.5rem;
  }
}

main.row {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

#pardot-form {
  margin: 0 auto;
  padding: 0 2rem;
  max-width: 768px;
}
#pardot-form p:first-of-type {
  display: block;
  margin-bottom: 1rem;

  font-family: "Festivo LC Basic", sans-serif;
  font-weight: bold;
  text-transform: uppercase;
}
#pardot-form p:first-of-type font {
  font-size: 2em !important;
}
@media (max-width: 540px) {
  #pardot-form p:first-of-type font {
    font-size: 1.4em !important;
  }
}
#pardot-form .errors {
  margin: 0 0 1rem;
  color: #dc3a42;
  font-size: 0.8em;
  font-weight: 700;
}
#pardot-form .field-label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 700;
  font-size: 0.9em;
}
#pardot-form .form-field.no-label a {
  display: block;
  margin-top: 1rem;
  font-weight: normal;
  color: #ee3a43;
}
#pardot-form .form-field.no-label a:hover {
  color: #dc3a42;
  text-decoration: underline;
}
#pardot-form .error.no-label {
  margin: 0 0 1rem;
  color: #dc3a42;
  font-size: 0.8em;
  font-weight: 700;
}
#pardot-form input[type="text"],
#pardot-form input[type="email"],
#pardot-form select {
  display: block;
  margin: 0 0 1rem;
  padding: 0.5rem;
  width: 100%;
  max-width: 100%;

  font-size: 1.2rem;

  border-radius: 0.125rem;
  border: 1px solid #095090;
}
#pardot-form input[type="text"][readonly],
#pardot-form input[type="email"][readonly] {
  border: 0;
  border-bottom: 2px solid #ccc;
  padding-left: 0;
  color: #666;
}
#pardot-form input[type="submit"] {
  display: inline-block;
  margin: 2rem auto;
  padding: 1rem 2rem;

  border-radius: 0.5rem;

  color: #fff;

  background-color: #ee3a43;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 400;

  transition: all 0.2s ease-in-out;
}
#pardot-form input[type="submit"]:hover {
  color: #fff;

  background-color: #dc3a42;
}

p img {
  display: inline-block;
  max-width: 100%;
}
