/* Defaults
-------------------------------------------------------------------------------*/
html, body, body div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video, details, summary {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

article, aside, figure, footer, header, hgroup, nav, section, details, summary, main, img {
  display: block; }

img,
object,
embed {
  max-width: 100%; }

html {
  overflow-y: scroll; }

ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted #000;
  cursor: help; }

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

th {
  font-weight: bold;
  vertical-align: bottom; }

td {
  font-weight: normal;
  vertical-align: top; }

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

pre {
  white-space: pre;
  white-space: pre-wrap;
  white-space: pre-line;
  word-wrap: break-word; }

input[type="radio"] {
  vertical-align: text-bottom; }

input[type="checkbox"] {
  vertical-align: bottom; }

.ie7 input[type="checkbox"] {
  vertical-align: baseline; }

.ie6 input {
  vertical-align: text-bottom; }

select, input, textarea {
  font: 99% sans-serif; }

table {
  font-size: inherit;
  font: 100%; }

small {
  font-size: 85%; }

strong {
  font-weight: bold; }

td, td img {
  vertical-align: top; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

pre, code, kbd, samp {
  font-family: monospace, sans-serif; }

.clickable,
label,
input[type=button],
input[type=submit],
button {
  cursor: pointer; }

button, input, select, textarea {
  margin: 0; }

button {
  width: auto;
  overflow: visible; }

.ie7 img {
  -ms-interpolation-mode: bicubic; }

.ie6 html {
  filter: expression(document.execCommand("BackgroundImageCache", false, true)); }

.chromeframe {
  position: absolute;
  top: 0; }

.clearfix:before, .clearfix:after {
  content: "\0020";
  display: block;
  height: 0;
  overflow: hidden; }

.clearfix:after {
  clear: both; }

.clearfix {
  zoom: 1; }

* {
  box-sizing: border-box; }

/* The font-size mixin */
/* ------------------------------------ */

.spacer {
  float: none;
  clear: both;
  margin: 0;
  border: 0;
  padding: 0;
  width: 0;
  height: 0; }

body,
html {
  min-height: 100%; }

body {
  background-color: white;
  overflow-x: hidden; }

* {
  box-sizing: border-box; }

html,
body {
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #131515;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

a {
  text-decoration: none; }
  a:hover {
    text-decoration: none; }

p {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 40px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #197e7e; }
  @media screen and (min-width: 850px) {
    p {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }
  p strong {
    font-weight: 700; }
  p em {
    font-style: italic; }

.content {
  position: relative; }
  .content h2, .content h3, .content h4, .content h5 {
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #302F39; }
  .content h2 {
    font-size: 28px;
    font-size: 1.75rem;
    line-height: 1.25;
    letter-spacing: 0px;
    margin: 0 0 25px; }
    @media screen and (min-width: 850px) {
      .content h2 {
        font-size: 32px;
        font-size: 2rem;
        line-height: 1.25;
        letter-spacing: 0px;
        margin: 0 0 30px; } }
  .content h3 {
    font-size: 23px;
    font-size: 1.4375rem;
    line-height: 1.2173913043;
    letter-spacing: 0px;
    margin: 0 0 15px; }
    @media screen and (min-width: 850px) {
      .content h3 {
        font-size: 26px;
        font-size: 1.625rem;
        line-height: 1.2307692308;
        letter-spacing: 0px;
        margin: 0 0 20px; } }
  .content h4, .content h5 {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.5555555556;
    letter-spacing: 0px;
    margin: 0 0 10px; }
    @media screen and (min-width: 850px) {
      .content h4, .content h5 {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1.5;
        letter-spacing: 0px; } }
  .content blockquote {
    margin-bottom: 40px;
    padding: 20px;
    background-color: #527fef; }
    @media screen and (min-width: 850px) {
      .content blockquote {
        padding: 40px; } }
    .content blockquote h2 {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.2307692308;
      letter-spacing: 0px;
      margin: 0px 0px 20px 0px;
      color: #fff; }
      @media screen and (min-width: 850px) {
        .content blockquote h2 {
          font-size: 32px;
          font-size: 2rem;
          line-height: 1.25;
          letter-spacing: 0px; } }
    .content blockquote p {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1.5555555556;
      letter-spacing: 0px;
      margin: 0;
      font-family: "Source Code Pro", monospace;
      font-weight: 400;
      color: #fff; }
      @media screen and (min-width: 850px) {
        .content blockquote p {
          font-size: 20px;
          font-size: 1.25rem;
          line-height: 1.5;
          letter-spacing: 0px; } }
      .content blockquote p a {
        transition: all .25s ease 0s;
        padding-bottom: 1px; }
      .content blockquote p a:link,
      .content blockquote p a:visited {
        font-weight: 600;
        color: #fff;
        border-bottom: 1px solid #fff; }
      .content blockquote p a:hover {
        border-bottom: 1px solid #fff; }
  .content pre, .content code {
    font-family: "Source Code Pro", monospace; }
  .content hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid rgba(48, 47, 57, 0.2);
    margin: 60px 0;
    padding: 0; }
  .content p {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.5555555556;
    letter-spacing: 0px;
    margin: 0 0 40px;
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    font-weight: 400;
    font-style: normal;
    color: #3d305f; }
    @media screen and (min-width: 850px) {
      .content p {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1.5;
        letter-spacing: 0px;
        margin: 0 0 50px; } }
    .content p strong {
      font-weight: 600; }
    .content p em {
      font-style: italic; }
  .content ul,
  .content ol {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.5555555556;
    letter-spacing: 0px;
    margin: 0 0 40px;
    padding: 0;
    counter-reset: item;
    font-weight: 400;
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    color: #3d305f; }
    @media screen and (min-width: 850px) {
      .content ul,
      .content ol {
        font-size: 20px;
        font-size: 1.25rem;
        line-height: 1.5;
        letter-spacing: 0px; } }
  .content ul li {
    position: relative;
    list-style: none;
    padding-left: 40px;
    margin-bottom: 20px; }
    .content ul li::before {
      position: absolute;
      top: 14px;
      left: 0;
      width: 18px;
      height: 1px;
      margin-right: 30px;
      background-color: #131515;
      content: ''; }
    .content ul li strong {
      font-weight: 600; }
    .content ul li em {
      font-style: italic; }
  .content ol li {
    position: relative;
    counter-increment: item;
    list-style: none;
    padding-left: 40px;
    margin-bottom: 20px; }
    .content ol li::before {
      position: absolute;
      top: 0;
      left: 0;
      content: counters(item, "") ".";
      color: #131515;
      width: 20px; }
    .content ol li strong {
      font-weight: 600; }
    .content ol li em {
      font-style: italic; }
  .content ol ul,
  .content ul ul {
    margin-top: 20px; }
  .content ol ul li,
  .content ul ul li {
    position: relative;
    list-style: none;
    padding-left: 40px;
    margin-bottom: 20px; }
    .content ol ul li::before,
    .content ul ul li::before {
      position: absolute;
      top: 14px;
      left: 0;
      width: 18px;
      height: 1px;
      margin-right: 30px;
      background-color: #131515;
      content: ''; }
    .content ol ul li strong,
    .content ul ul li strong {
      font-weight: 600; }
    .content ol ul li em,
    .content ul ul li em {
      font-style: italic; }
  .content p a,
  .content li a,
  .content h2 a,
  .content h3 a,
  .content h4 a,
  .content h5 a {
    transition: all .25s ease 0s;
    padding-bottom: 1px; }
  .content p a:link,
  .content p a:visited,
  .content li a:link,
  .content li a:visited,
  .content h2 a:link,
  .content h2 a:visited,
  .content h3 a:link,
  .content h3 a:visited,
  .content h4 a:link,
  .content h4 a:visited,
  .content h5 a:link,
  .content h5 a:visited {
    font-weight: 600;
    color: #527fef;
    border-bottom: 1px solid transparent; }
  .content p a:hover,
  .content li a:hover,
  .content h2 a:hover,
  .content h3 a:hover,
  .content h4 a:hover,
  .content h5 a:hover {
    border-bottom: 1px solid #527fef; }
  .content img {
    display: block;
    margin: 10px auto 50px; }
    @media screen and (min-width: 850px) {
      .content img {
        margin: 10px auto 60px; } }

.row {
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
  width: 100%; }

.container {
  margin: 0 auto;
  padding: 0 20px;
  max-width: 1360px; }
  @media screen and (min-width: 850px) {
    .container {
      padding: 0 60px; } }
  .container.container--full {
    padding: 0; }
    @media screen and (min-width: 850px) {
      .container.container--full {
        padding: 0 60px; } }

.container--min {
  max-width: 920px; }

.container--med {
  max-width: 1120px; }

main {
  background-color: white; }

.section {
  padding: 80px 0 100px; }
  @media screen and (min-width: 850px) {
    .section {
      padding: 100px 0 140px; } }

.section--thin {
  padding: 80px 0; }
  @media screen and (min-width: 850px) {
    .section--thin {
      padding: 100px 0; } }

@media screen and (min-width: 850px) {
  .section__columns {
    display: grid; } }

.section__columns--2 {
  grid-template-columns: 1fr 1fr;
  grid-gap: 120px; }

.section__columns--3 {
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 80px; }

.section__columns--flip .flip {
  order: 1; }

.section__column {
  margin-bottom: 40px; }
  .section__column:last-child {
    margin: 0; }
  @media screen and (min-width: 850px) {
    .section__column {
      margin: 0; } }

.section__header {
  padding-bottom: 100px;
  max-width: 600px; }

.section__headline {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .section__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.section__byline {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Source Code Pro", monospace;
  font-weight: 400;
  font-style: normal;
  color: #b3efef; }
  @media screen and (min-width: 850px) {
    .section__byline {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1;
      letter-spacing: 0px; } }

.intro {
  margin: 100px 0 -40px; }
  @media screen and (min-width: 850px) {
    .intro {
      margin: 0; } }

.fourohfour {
  padding-bottom: 100px; }
  @media screen and (min-width: 850px) {
    .fourohfour {
      padding-bottom: 140px; } }

.page__headline {
  font-size: 42px;
  font-size: 2.625rem;
  line-height: 1.1904761905;
  letter-spacing: 0px;
  margin: 0 0 50px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #3d305f; }
  @media screen and (min-width: 850px) {
    .page__headline {
      font-size: 42px;
      font-size: 2.625rem;
      line-height: 1.1904761905;
      letter-spacing: 0px;
      margin: 0 0 50px; } }

.page-banner {
  position: relative;
  height: 80px;
  margin-bottom: 60px; }
  @media screen and (min-width: 1000px) {
    .page-banner {
      height: 120px;
      margin-bottom: 80px; } }

.post {
  background-color: #f0fafa;
  padding: 40px 0 60px; }
  @media screen and (min-width: 850px) {
    .post {
      padding: 80px 0 100px; } }

.posts {
  padding: 40px 0 60px;
  text-align: left; }
  @media screen and (min-width: 850px) {
    .posts {
      padding: 80px 0 100px; } }

.cat-item__wrapper {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 60px; }

.cat-item {
  transition: all .25s ease 0s;
  border: 2px solid #131515;
  border-radius: 5px;
  margin: 0 12px 12px 0; }
  @media screen and (min-width: 850px) {
    .cat-item {
      margin: 0 20px 20px 0; } }
  .cat-item:hover {
    border: 2px solid #131515; }
  .cat-item a {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1;
    letter-spacing: -0.3px;
    font-family: "Source Code Pro", monospace;
    font-weight: 500;
    font-style: normal;
    display: block;
    padding: 12px 20px;
    width: 100%;
    height: 100%;
    color: #131515; }
    @media screen and (min-width: 850px) {
      .cat-item a {
        font-size: 22px;
        font-size: 1.375rem;
        line-height: 1;
        letter-spacing: -0.5px;
        padding: 18px 30px; } }
  .cat-item.current-cat {
    border: 2px solid #131515;
    background-color: #131515; }

@media screen and (min-width: 850px) {
  .post-list {
    display: flex;
    flex-wrap: wrap; } }

.post-list__item {
  display: flex;
  margin: 0 0 40px; }

.post-list__image {
  display: block;
  flex-shrink: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  margin: 0 20px 0 0;
  width: 120px;
  height: 80px; }
  .post-list__image.post-list__image--placeholder {
    background-image: url("../img/wmc-logo.svg");
    background-size: 80%;
    background-color: #131515; }
  @media screen and (min-width: 850px) {
    .post-list__image {
      margin: 0 60px 0 0;
      width: 300px;
      height: 200px; }
      .post-list__image.post-list__image--placeholder {
        background-size: 60%; } }

.post-list__content p {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.5px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #131515; }

.post-list__content a {
  color: #131515; }

.post-list__headline {
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 1.2727272727;
  letter-spacing: -0.5px;
  margin: 0 0 10px;
  font-family: "Source Code Pro", monospace;
  font-weight: 500;
  font-style: normal; }
  @media screen and (min-width: 850px) {
    .post-list__headline {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.3076923077;
      letter-spacing: -0.5px; } }

.post-list__excerpt {
  display: none; }
  @media screen and (min-width: 850px) {
    .post-list__excerpt {
      display: block; } }

.article {
  background-color: #f0fafa;
  padding: 40px 0 60px; }
  @media screen and (min-width: 850px) {
    .article {
      padding: 80px 0 100px; } }

.article__headline {
  font-size: 34px;
  font-size: 2.125rem;
  line-height: 1.2352941176;
  letter-spacing: 0px;
  margin: 0 0 40px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #3d305f; }
  @media screen and (min-width: 850px) {
    .article__headline {
      font-size: 42px;
      font-size: 2.625rem;
      line-height: 1.1904761905;
      letter-spacing: 0px;
      margin: 0 0 50px; } }

.article-category-list {
  padding: 20px 0;
  background-color: white; }

.article-list {
  display: grid;
  grid-gap: 30px;
  margin-bottom: 30px; }
  @media screen and (min-width: 580px) {
    .article-list {
      grid-template-columns: 1fr 1fr; } }
  @media screen and (min-width: 850px) {
    .article-list {
      margin-bottom: 100px;
      grid-template-columns: 1fr 1fr 1fr 1fr; } }

.article-list__item {
  transition: all .25s ease 0s; }

.article-list-sm {
  display: grid;
  grid-gap: 20px; }
  @media screen and (min-width: 1100px) {
    .article-list-sm {
      grid-template-columns: 1fr 1fr; } }

.article-list-sm__item {
  transition: all .25s ease 0s; }

.article-card {
  border-radius: 4px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(19, 21, 21, 0.07);
  height: 100%; }

.article-card__image {
  display: block;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  border-radius: 4px 0 0 4px;
  height: 150px; }
  .article-card__image.article-card__image--placeholder {
    background-image: url("../img/wifibooth-logo.svg");
    background-size: 60%;
    background-color: #131515; }

.article-card__main {
  padding: 20px; }

.article-card__headline {
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 1.1818181818;
  letter-spacing: 0px;
  margin-bottom: 10px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #527fef; }
  @media screen and (min-width: 850px) {
    .article-card__headline {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.2;
      letter-spacing: 0px; } }
  .article-card__headline a {
    transition: all .25s ease 0s;
    padding-bottom: 1px; }
  .article-card__headline a:link,
  .article-card__headline a:visited {
    color: #527fef;
    border-bottom: 1px solid transparent; }
  .article-card__headline a:hover {
    border-bottom: 1px solid #527fef; }

.article-card__text p {
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.4666666667;
  letter-spacing: 0px;
  margin-bottom: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #197e7e; }
  @media screen and (min-width: 850px) {
    .article-card__text p {
      font-size: 15px;
      font-size: 0.9375rem;
      line-height: 1.4666666667;
      letter-spacing: 0px; } }

.article-card-sm {
  display: grid;
  grid-template-columns: 1fr 3fr;
  height: 100%;
  min-height: 110px;
  border-radius: 4px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(19, 21, 21, 0.07); }

.article-card-sm__main {
  padding: 20px; }

.article-card-sm__image {
  display: block;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  border-radius: 4px 0 0 4px; }
  @media screen and (min-width: 850px) {
    .article-card-sm__image {
      height: auto; } }
  .article-card-sm__image.article-card__image--placeholder {
    background-image: url("../img/wifibooth-logo.svg");
    background-size: 60%;
    background-color: #131515; }

.article-card-sm__headline {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #527fef; }
  @media screen and (min-width: 850px) {
    .article-card-sm__headline {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.2;
      letter-spacing: 0px; } }
  .article-card-sm__headline a {
    transition: all .25s ease 0s;
    padding-bottom: 1px; }
  .article-card-sm__headline a:link,
  .article-card-sm__headline a:visited {
    color: #527fef;
    border-bottom: 1px solid transparent; }
  .article-card-sm__headline a:hover {
    border-bottom: 1px solid #527fef; }

.articles {
  position: relative;
  background-color: #f0fafa;
  padding: 80px 0 120px; }
  @media screen and (min-width: 850px) {
    .articles {
      padding: 80px 0 120px; } }

.articles-header {
  position: relative;
  margin: 0 auto 60px;
  max-width: 460px;
  text-align: center; }
  .articles-header::after {
    position: absolute;
    bottom: -20px;
    left: 50%;
    margin-left: -23px;
    width: 46px;
    height: 4px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    background-image: url("../img/squiggle.svg");
    content: ""; }
  .articles-header a {
    transition: all .25s ease 0s;
    padding-bottom: 1px; }
  .articles-header a:link,
  .articles-header a:visited {
    font-weight: 600;
    color: #527fef;
    border-bottom: 1px solid transparent; }
  .articles-header a:hover {
    border-bottom: 1px solid #527fef; }

.articles-header__headline-evergreen {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 60px 0 10px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #302F39; }
  @media screen and (min-width: 850px) {
    .articles-header__headline-evergreen {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.articles-header__headline {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 10px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #302F39; }
  @media screen and (min-width: 850px) {
    .articles-header__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.articles-header__byline {
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: 0px;
  margin: 0; }

.videos {
  position: relative;
  padding: 60px 0; }
  @media screen and (min-width: 850px) {
    .videos {
      padding: 80px 0 120px; } }

.video-card {
  padding-bottom: 2px; }

.video-card__main {
  margin-top: 20px;
  text-align: center; }

.video-card__headline {
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 1.1818181818;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #527fef; }
  @media screen and (min-width: 850px) {
    .video-card__headline {
      font-size: 22px;
      font-size: 1.375rem;
      line-height: 1.1818181818;
      letter-spacing: 0px; } }
  .video-card__headline a {
    transition: all .25s ease 0s;
    padding-bottom: 1px; }
  .video-card__headline a:link,
  .video-card__headline a:visited {
    color: #527fef;
    border-bottom: 1px solid transparent; }
  .video-card__headline a:hover {
    border-bottom: 1px solid #527fef; }

.video-card__image {
  display: block; }

.owl-nav {
  display: none; }

.owl-dots {
  margin-top: 20px;
  text-align: center;
  height: 16px; }

.owl-dot {
  background-color: #00c7c7 !important;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  margin: 0 5px;
  opacity: 0.3; }
  .owl-dot:focus {
    outline-offset: 0px !important;
    outline: none !important; }
  .owl-dot.active {
    opacity: 1; }

.help-nav {
  padding: 15px 0; }

.help-nav__wrapper {
  display: flex;
  justify-content: space-between;
  padding: 0 20px; }
  @media screen and (min-width: 850px) {
    .help-nav__wrapper {
      padding: 0 60px; } }

.help-nav__back {
  transition: all .25s ease 0s;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  color: #527fef;
  font-weight: 600;
  font-style: normal; }
  .help-nav__back::before {
    transform: rotate(180deg);
    content: '';
    display: flex;
    flex-shrink: 0;
    height: 100%;
    width: 20px;
    background-image: url("../img/arrow-ocean.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    margin-right: 10px; }

.help-nav__next {
  transition: all .25s ease 0s;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  color: #527fef;
  font-weight: 600;
  font-style: normal; }
  .help-nav__next::after {
    content: '';
    display: flex;
    flex-shrink: 0;
    height: 100%;
    width: 20px;
    background-image: url("../img/arrow-ocean.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain;
    margin-left: 10px; }

.banner {
  display: flex;
  position: relative;
  background-color: #3d305f;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 100px 0 60px; }
  @media screen and (min-width: 580px) {
    .banner {
      padding: 120px 0 60px; } }
  @media screen and (min-width: 1100px) {
    .banner {
      padding: 0;
      height: calc(100vh - 4rem); } }

@media screen and (min-width: 850px) {
  .banner--home .banner__headline {
    font-size: 34px;
    font-size: 2.125rem;
    line-height: 1.2352941176;
    letter-spacing: 0px; } }

@media screen and (min-width: 1100px) {
  .banner--home .banner__headline {
    font-size: 60px;
    font-size: 3.75rem;
    line-height: 1.1;
    letter-spacing: 0px; } }

@media screen and (min-width: 850px) {
  .banner__wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 60px; } }

@media screen and (min-width: 1100px) {
  .banner__wrapper {
    height: calc(100vh - 4rem); } }

@media screen and (min-width: 850px) {
  .banner__wrapper--wide {
    display: flex;
    width: 100%; }
    .banner__wrapper--wide .banner__header {
      max-width: 640px; } }

@media screen and (min-width: 850px) {
  .banner__main {
    display: flex;
    align-items: center; } }

@media screen and (min-width: 580px) {
  .banner__header {
    width: 80%; } }

@media screen and (min-width: 850px) {
  .banner__header {
    width: auto; } }

.banner__media {
  display: flex;
  justify-content: center;
  margin-top: 60px;
  margin-bottom: -160px; }
  @media screen and (min-width: 850px) {
    .banner__media {
      margin-top: 0;
      margin-bottom: -240px; } }
  @media screen and (min-width: 1100px) {
    .banner__media {
      margin-bottom: -160px; } }
  .banner__media svg {
    display: block;
    width: 100%; }

.banner__image {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 350px; }

.banner__headline {
  font-size: 34px;
  font-size: 2.125rem;
  line-height: 1.2352941176;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .banner__headline {
      font-size: 60px;
      font-size: 3.75rem;
      line-height: 1.1;
      letter-spacing: 0px; } }

.banner__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .banner__text {
      font-size: 22px;
      font-size: 1.375rem;
      line-height: 1.3636363636;
      letter-spacing: 0px; } }

.banner__arrow {
  display: none;
  position: absolute;
  right: 50%;
  bottom: 20px;
  margin-right: -10px;
  padding: 0;
  border: none;
  width: 20px;
  height: 28px;
  background: transparent;
  -webkit-appearance: none; }
  @media screen and (min-width: 850px) {
    .banner__arrow {
      display: block; } }
  .banner__arrow:hover .arrow-svg {
    fill: #F9398C; }
  .banner__arrow:focus {
    outline-offset: 0px !important;
    outline: none !important; }
    .banner__arrow:focus .arrow-svg {
      fill: #F9398C; }
  .banner__arrow .arrow-svg {
    transition: all .25s ease 0s;
    fill: #fff; }
  .banner__arrow svg {
    display: block; }

.device {
  display: grid;
  position: relative;
  width: 100%;
  max-width: 488px;
  align-content: end; }

.ipad {
  position: relative;
  width: 100%;
  height: auto; }

.vid {
  position: absolute;
  top: 9.8%;
  left: 5%;
  opacity: 1;
  width: calc(90%); }
  .vid video {
    display: block; }

.help-banner {
  display: flex;
  align-items: center;
  position: relative;
  background-color: #00c7c7;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  padding: 120px 0 60px; }
  @media screen and (min-width: 850px) {
    .help-banner {
      height: 500px;
      padding: 0; } }

.help-banner__wrapper {
  position: relative;
  flex-grow: 1;
  z-index: 2;
  max-width: 820px;
  text-align: center; }

.help-banner__image {
  position: absolute;
  top: 0;
  left: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 100%;
  width: 100%;
  background-color: #3d305f;
  z-index: 1;
  opacity: 0.1;
  filter: saturate(0); }

.help-banner__header {
  position: relative; }

.help-banner__headline {
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .help-banner__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.post-banner {
  position: relative;
  height: 80px; }
  @media screen and (min-width: 1000px) {
    .post-banner {
      height: 120px; } }

.header {
  transition: all .4s ease 0s;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  background-color: transparent;
  z-index: 100;
  padding: 0 20px;
  width: 100%;
  height: 80px; }
  @media screen and (min-width: 1000px) {
    .header {
      padding: 0 60px;
      height: 120px; } }
  .header.header--off-banner {
    background-color: #00c7c7; }
  .header.header--is-hidden {
    top: -80px; }
    @media screen and (min-width: 1000px) {
      .header.header--is-hidden {
        top: -120px; } }
  .header.nav--is-open {
    top: 0; }

.single .header,
.search .header,
.page .header,
.error404 .header {
  background-color: #00c7c7; }
  .single .header::before,
  .search .header::before,
  .page .header::before,
  .error404 .header::before {
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("../img/post-banner.jpg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    width: 100%;
    height: 100%;
    opacity: 0.1;
    filter: saturate(0);
    content: ""; }

.page-template-index .header,
.page-template-blueprint .header,
.page-template-help .header {
  background-color: transparent; }
  .page-template-index .header::before,
  .page-template-blueprint .header::before,
  .page-template-help .header::before {
    display: none; }
  .page-template-index .header.header--off-banner,
  .page-template-blueprint .header.header--off-banner,
  .page-template-help .header.header--off-banner {
    background-color: #00c7c7; }

.footer {
  background-color: #fff;
  padding: 100px 0 20px; }
  @media screen and (min-width: 850px) {
    .footer {
      padding: 160px 0 20px; } }

.footer__wrapper {
  display: grid; }
  @media screen and (min-width: 580px) {
    .footer__wrapper {
      grid-template-columns: 1fr 1fr;
      grid-gap: 80px; } }
  @media screen and (min-width: 850px) {
    .footer__wrapper {
      grid-template-columns: 1fr 1fr 2fr; } }

@media screen and (min-width: 850px) {
  .footer__logos {
    order: 1; } }

.footer__nav {
  margin-bottom: 60px; }
  @media screen and (min-width: 580px) {
    .footer__nav {
      margin: 0; } }
  @media screen and (min-width: 850px) {
    .footer__nav {
      order: 2; } }

.footer__support {
  margin-bottom: 60px; }
  @media screen and (min-width: 580px) {
    .footer__support {
      grid-column: 1 / span 2;
      margin: 0; } }
  @media screen and (min-width: 850px) {
    .footer__support {
      grid-column: auto;
      order: 3; } }

.footer__logo {
  width: 120px;
  display: block;
  margin-bottom: 30px; }

.footer__app-store {
  display: block;
  margin-bottom: 30px; }

.footer__copyright {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.4285714286;
  letter-spacing: 0px; }

.footer__disclaimer {
  padding-top: 60px; }
  @media screen and (min-width: 850px) {
    .footer__disclaimer {
      padding-top: 100px; } }
  .footer__disclaimer p {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.4285714286;
    letter-spacing: 0px;
    margin: 0; }

.search-result-list__wrapper {
  padding-top: 120px;
  background-color: #f0fafa; }

.search-result-list {
  position: relative; }

.search-result-list__item {
  margin-bottom: 30px; }

.search-result-list__headline {
  font-size: 42px;
  font-size: 2.625rem;
  line-height: 1.1904761905;
  letter-spacing: 0px;
  margin: 0 0 50px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #3d305f; }
  @media screen and (min-width: 850px) {
    .search-result-list__headline {
      font-size: 42px;
      font-size: 2.625rem;
      line-height: 1.1904761905;
      letter-spacing: 0px;
      margin: 0 0 50px; } }

.search-result-card {
  transition: all .25s ease 0s;
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.4;
  letter-spacing: 0px;
  display: flex;
  background-color: white;
  border-radius: 4px;
  box-shadow: 0 0 10px rgba(19, 21, 21, 0.07);
  padding: 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #527fef; }
  @media screen and (min-width: 850px) {
    .search-result-card {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.4;
      letter-spacing: 0px; } }
  .search-result-card:hover {
    box-shadow: 0 0 20px rgba(19, 21, 21, 0.1); }

.help-search {
  position: relative;
  width: 100%; }

.help-search-callout {
  text-align: center;
  max-width: 700px; }
  .help-search-callout .search-form__field {
    border: 1px solid #d6d6d6; }
    @media screen and (min-width: 850px) {
      .help-search-callout .search-form__field {
        border-right: 0; } }

.help-search-callout__headline {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.3333333333;
  letter-spacing: 0px;
  margin: 60px 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .help-search-callout__headline {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.2307692308;
      letter-spacing: 0px; } }

.search-form {
  display: flex;
  flex-direction: column;
  position: relative; }
  .search-form input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none; }
  @media screen and (min-width: 580px) {
    .search-form {
      align-items: center; } }
  @media screen and (min-width: 850px) {
    .search-form {
      flex-direction: row; } }

.search-form__field {
  position: relative;
  height: 40px;
  margin-bottom: 20px;
  padding: 0 30px;
  border-radius: 20px;
  background-color: #fff;
  border: 0;
  flex-grow: 1;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #9b9b9b; }
  @media screen and (min-width: 580px) {
    .search-form__field {
      width: 80%; } }
  @media screen and (min-width: 850px) {
    .search-form__field {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1;
      letter-spacing: 0px;
      border-radius: 30px 0 0 30px;
      height: 60px;
      margin: 0; } }

.search-form__submit {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 50px;
  width: auto;
  padding: 0 25px;
  background-color: #527fef;
  border: 0;
  border-radius: 25px;
  align-self: center;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .search-form__submit {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1;
      letter-spacing: 0px;
      padding: 0 30px;
      height: 60px;
      border-radius: 0 30px 30px 0; } }

.social-links {
  display: flex;
  align-items: center;
  margin: 40px 0 0 0; }

.social-links__icon {
  transition: all .25s ease 0s;
  margin-right: 20px;
  opacity: 1; }
  .social-links__icon:hover {
    opacity: 1; }

.primary-menu {
  position: fixed;
  opacity: 0;
  visibility: hidden;
  padding-bottom: 60px;
  overflow: -moz-scrollbars-none;
  overflow-y: scroll;
  -ms-overflow-style: none; }
  @media screen and (min-width: 1000px) {
    .primary-menu {
      position: relative;
      opacity: 1.0;
      visibility: visible;
      overflow: visible;
      padding: 0; } }
  .primary-menu.nav--is-open {
    position: fixed;
    opacity: 1.0;
    visibility: visible;
    top: 0;
    left: 0;
    z-index: 100;
    background-color: #3d305f;
    border-top: 1px solid #131515;
    height: calc(100vh);
    width: 100%; }
    @media screen and (min-width: 1000px) {
      .primary-menu.nav--is-open {
        position: relative;
        height: 64px; } }
  .primary-menu .menu {
    padding-top: 160px; }
    @media screen and (min-width: 1000px) {
      .primary-menu .menu {
        display: flex;
        padding: 0; } }
  .primary-menu .menu-item {
    margin-bottom: 30px;
    padding-left: 20px; }
    @media screen and (min-width: 1000px) {
      .primary-menu .menu-item {
        margin: 0;
        padding-left: 40px; } }
    .primary-menu .menu-item a {
      transition: all .25s ease 0s;
      font-size: 22px;
      font-size: 1.375rem;
      line-height: 1;
      letter-spacing: 0px;
      font-family: "Montserrat", Helvetica, Arial, sans-serif;
      font-weight: 400;
      font-style: normal;
      text-decoration: none;
      border-bottom: 1px solid transparent;
      padding-bottom: 3px; }
      @media screen and (min-width: 1000px) {
        .primary-menu .menu-item a {
          font-size: 17px;
          font-size: 1.0625rem;
          line-height: 1;
          letter-spacing: 0px;
          font-weight: 600;
          border-bottom: 2px solid transparent;
          padding-bottom: 4px; } }
    .primary-menu .menu-item a:link,
    .primary-menu .menu-item a:visited {
      color: white; }
    .primary-menu .menu-item a:hover {
      color: white;
      border-bottom: 1px solid #fff; }
      @media screen and (min-width: 1000px) {
        .primary-menu .menu-item a:hover {
          border-bottom: 2px solid #fff; } }
    @media screen and (min-width: 1000px) {
      .primary-menu .menu-item.current-menu-item a {
        border-bottom: 2px solid #fff; } }

.single .primary-menu .menu-item.menu-item--help a {
  /* commented out by TC on Feb 8 2020 to avoid pricing & help both being underlined */
  /* border-bottom: 2px solid #fff; */ 
}

.sitemap-menu {
  position: relative; }
  .sitemap-menu .menu {
    position: relative; }
  .sitemap-menu .menu-item a {
    transition: all .25s ease 0s;
    font-size: 17px;
    font-size: 1.0625rem;
    line-height: 1.1764705882;
    letter-spacing: 0px;
    display: block;
    margin-bottom: 15px;
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    font-weight: 500;
    font-style: normal;
    text-decoration: none;
    color: #527fef; }
  .sitemap-menu .menu-item a:link,
  .sitemap-menu .menu-item a:visited {
    color: #527fef; }
  .sitemap-menu .menu-item a:hover {
    color: #527fef; }

.nav-open {
  display: block;
  position: absolute;
  top: 17px;
  right: 10px;
  border: 0;
  background-color: transparent;
  margin: 0;
  padding: 14px 10px;
  z-index: 101;
  width: 40px;
  height: 44px; }
  .nav-open:focus {
    outline-offset: 0px !important;
    outline: none !important; }
  .nav-open.nav--is-open {
    display: none; }
  @media screen and (min-width: 1000px) {
    .nav-open {
      display: none; } }
  .nav-open svg {
    display: block; }

.nav-close {
  display: none;
  position: absolute;
  top: 17px;
  right: 10px;
  border: 0;
  border: 0;
  background-color: transparent;
  margin: 0;
  padding: 12px 10px;
  z-index: 101;
  width: 40px;
  height: 44px; }
  .nav-close:focus {
    outline-offset: 0px !important;
    outline: none !important; }
  .nav-close.nav--is-open {
    display: block; }
    @media screen and (min-width: 1000px) {
      .nav-close.nav--is-open {
        display: none; } }
  .nav-close svg {
    display: block; }

.btn {
  transition: all .25s ease 0s;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  padding: 0 20px;
  background-color: #F9398C;
  height: 40px;
  border-radius: 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  color: #fff;
  font-weight: 600;
  font-style: normal; }
  @media screen and (min-width: 850px) {
    .btn {
      font-size: 22px;
      font-size: 1.375rem;
      line-height: 1;
      letter-spacing: 0px;
      padding: 0 30px;
      height: 60px;
      border-radius: 30px; } }
  .btn:hover {
    background-color: #f8207e; }
  .btn:focus {
    background-color: #f8207e !important; }
  .btn::after {
    content: '';
    display: flex;
    flex-shrink: 0;
    margin-left: 20px;
    height: 100%;
    width: 28px;
    background-image: url("../img/arrow-light.svg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: contain; }
    @media screen and (min-width: 850px) {
      .btn::after {
        margin-left: 30px; } }

.btn--secondary {
  background-color: #527fef; }
  .btn--secondary:hover {
    background-color: #3b6eed; }
  .btn--secondary:focus {
    background-color: #3b6eed !important; }

.btn--play::after {
  background-image: url("../img/play.svg");
  width: 16px; }

.btn--light-ocean {
  background-color: #fff;
  color: #527fef; }
  .btn--light-ocean:hover {
    background-color: #fff; }
  .btn--light-ocean:focus {
    background-color: #f2f2f2 !important; }
  .btn--light-ocean::after {
    background-image: url("../img/arrow-ocean.svg"); }

.btn--light-coral {
  background-color: #fff;
  color: #F9398C; }
  .btn--light-coral:hover {
    background-color: #fff; }
  .btn--light-coral:focus {
    background-color: #f2f2f2 !important; }
  .btn--light-coral::after {
    background-image: url("../img/arrow-coral.svg"); }

.btn--outline {
  border: 1px solid #527fef;
  background-color: transparent;
  color: #527fef; }
  .btn--outline:hover {
    background-color: transparent;
    border: 1px solid #3b6eed;
    color: #3b6eed; }
  .btn--outline:focus {
    background-color: transparent !important;
    border: 1px solid #3b6eed !important; }
  .btn--outline::after {
    background-image: url("../img/arrow-ocean.svg"); }

.btn--small {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0px;
  padding: 0 20px;
  border-radius: 20px;
  height: 40px; }
  .btn--small::after {
    margin-left: 20px;
    width: 22px; }

.btn--inline {
  margin-right: 20px;
  margin-bottom: 20px; }

.logo {
  display: block;
  position: relative;
  background-image: url("../img/wifibooth-logo.svg");
  background-repeat: no-repeat;
  background-position: center center;
  width: 119px;
  height: 36px;
  text-indent: -999em;
  z-index: 101; }
  @media screen and (min-width: 1000px) {
    .logo {
      background-image: url("../img/wifibooth-logo.svg");
      width: 119px;
      height: 36px; } }
  .logo svg {
    display: block;
    width: 119px; }
    @media screen and (min-width: 1000px) {
      .logo svg {
        width: 119px; } }

@media screen and (min-width: 850px) {
  .contact {
    display: flex;
    justify-content: space-between; } }

.contact__form {
  margin-bottom: 60px; }
  .contact__form input, .contact__form textarea {
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    box-shadow: none !important; }
    .contact__form input:focus, .contact__form textarea:focus {
      outline-offset: 0px !important;
      outline: none !important;
      border: 2px solid #131515 !important; }
  .contact__form .field_sublabel_below .ginput_complex.ginput_container label {
    margin: 8px 0 0 !important;
    font-family: "Source Code Pro", monospace;
    font-size: 14px !important;
    line-height: 14px !important;
    letter-spacing: 0px !important;
    color: #131515; }
  .contact__form .gform_wrapper {
    margin: 0 !important; }
  .contact__form .ginput_container {
    margin: 0 !important; }
  .contact__form .gform_footer {
    display: inline-block;
    margin: 0 !important;
    padding: 0 !important; }
  .contact__form .gfield {
    margin: 0 0 30px !important;
    padding: 0 !important; }
  .contact__form .gfield_label {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.25;
    letter-spacing: 2px;
    margin: 0 0 15px;
    font-family: "Source Code Pro", monospace;
    font-weight: 700;
    text-transform: uppercase;
    color: #131515; }
  .contact__form .gform_fields input {
    border-radius: 5px;
    border: 2px solid #131515;
    padding: 20px !important;
    height: 50px; }
  .contact__form .textarea {
    border-radius: 5px;
    border: 2px solid #131515;
    padding: 20px !important; }
  .contact__form input[type=submit] {
    transition: all .25s ease 0s;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background-color: #F9398C;
    border: none !important;
    border-radius: 5px;
    margin: 0 !important;
    padding: 0 25px;
    height: 50px;
    font-family: "Source Code Pro", monospace;
    font-size: 22px !important;
    line-height: 22px !important;
    letter-spacing: -0.5px !important;
    font-weight: 500;
    font-style: normal;
    color: #fff; }
    .contact__form input[type=submit]:hover {
      background-color: #f8086f; }
    .contact__form input[type=submit]:focus {
      background-color: #c60659 !important; }
  .contact__form .gfield_required {
    color: #131515 !important; }
  .contact__form h2 {
    font-size: 38px;
    font-size: 2.375rem;
    line-height: 1.2105263158;
    letter-spacing: -0.5px;
    display: inline-block;
    margin: 0 0 15px;
    font-family: "Source Code Pro", monospace;
    font-weight: 500;
    color: #131515; }
  @media screen and (min-width: 850px) {
    .contact__form {
      width: calc(50% - 50px); } }
  .contact__form .subscribe {
    position: relative;
    top: -30px; }
    .contact__form .subscribe .gfield_label {
      display: none; }
  .contact__form .gform_wrapper .gfield_checkbox li input[type=checkbox] {
    position: relative;
    -webkit-appearance: checkbox;
    padding: 0 !important;
    margin-right: 10px !important;
    top: -2px;
    height: auto !important; }
  .contact__form .gform_wrapper .gfield_checkbox li label {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.25;
    letter-spacing: 2px;
    font-family: "Source Code Pro", monospace;
    font-weight: 700;
    text-transform: uppercase;
    color: #131515; }

@media screen and (min-width: 850px) {
  .contact__content {
    width: calc(50% - 50px); } }

.contact__map iframe {
  display: block; }

.validation_message {
  color: #da4242 !important; }

.gfield_error {
  border: none !important;
  background-color: transparent !important; }

.validation_error {
  background-color: #da4242;
  padding: 20px !important;
  border: none !important;
  border-radius: 5px;
  margin: 0 0 20px !important;
  font-family: "Source Code Pro", monospace;
  font-size: 22px !important;
  line-height: 26px !important;
  letter-spacing: -0.5px !important;
  font-weight: 500;
  font-style: normal;
  color: #fff !important; }

.developer {
  position: relative;
  padding: 100px 0 0;
  background: linear-gradient(to bottom right, #303039, #050506); }
  @media screen and (min-width: 850px) {
    .developer {
      padding: 100px 0 0; } }

.developer__wrapper {
  margin-bottom: 60px; }
  @media screen and (min-width: 850px) {
    .developer__wrapper {
      margin-bottom: 60px; } }

.developer__content {
  margin-bottom: 60px; }
  @media screen and (min-width: 850px) {
    .developer__content {
      margin: 0; } }
  .developer__content h1, .developer__content h2, .developer__content h3, .developer__content h4, .developer__content h5 {
    font-size: 28px;
    font-size: 1.75rem;
    line-height: 1.25;
    letter-spacing: 0px;
    margin: 0 0 20px;
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    font-weight: 600;
    font-style: normal;
    color: #fff; }
    @media screen and (min-width: 850px) {
      .developer__content h1, .developer__content h2, .developer__content h3, .developer__content h4, .developer__content h5 {
        font-size: 32px;
        font-size: 2rem;
        line-height: 1.25;
        letter-spacing: 0px; } }
  .developer__content p {
    color: #bfc8c8; }

.developer__header {
  margin-bottom: 60px;
  text-align: center; }
  @media screen and (min-width: 850px) {
    .developer__header {
      margin: 0; } }

.developer__image {
  border-radius: 50%;
  margin: 0 auto 30px;
  max-width: 250px;
  width: 100%; }

.developer__name {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.25;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .developer__name {
      font-size: 40px;
      font-size: 2.5rem;
      line-height: 1.25;
      letter-spacing: 0px;
      margin: 0 0 5px; } }

.developer__title {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Source Code Pro", monospace;
  font-weight: 400;
  font-style: normal;
  color: #bfc8c8; }
  @media screen and (min-width: 850px) {
    .developer__title {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.2;
      letter-spacing: 0px; } }

.feature {
  position: relative;
  display: grid; }
  @media screen and (min-width: 580px) {
    .feature.flip .feature__content,
    .feature.flip .feature__related-container {
      grid-column: 2; } }
  @media screen and (min-width: 580px) {
    .feature.flip .feature__media {
      grid-column: 1; } }
  @media screen and (min-width: 580px) {
    .feature {
      grid-template-columns: 1fr 1fr;
      grid-gap: 0 60px; } }
  @media screen and (min-width: 850px) {
    .feature {
      grid-gap: 0 120px; } }

.feature__headline {
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .feature__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.feature__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #197e7e; }
  @media screen and (min-width: 850px) {
    .feature__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }

.feature__content {
  position: relative;
  margin-bottom: 40px; }
  @media screen and (min-width: 580px) {
    .feature__content {
      margin: 0; } }

.feature__content--bp {
  margin-bottom: 60px; }
  @media screen and (min-width: 850px) {
    .feature__content--bp {
      margin: 0; } }

.feature__media {
  display: grid;
  align-items: center;
  position: relative; }
  @media screen and (min-width: 580px) {
    .feature__media {
      grid-column: 2;
      grid-row: 1 / span 2; } }

.feature__related-wrapper {
  display: flex;
  position: relative;
  margin-top: 60px; }
  @media screen and (min-width: 580px) {
    .feature__related-wrapper {
      margin-top: 30px; } }

.feature__related {
  font-size: 17px;
  font-size: 1.0625rem;
  line-height: 1;
  letter-spacing: 0px;
  display: flex;
  align-items: center;
  position: relative;
  margin-right: 40px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #527fef; }
  .feature__related::before {
    flex-shrink: 0;
    content: "";
    width: 32px;
    height: 32px;
    background-repeat: no-repeat;
    background-position: center center;
    margin-right: 10px; }
  .feature__related.feature__related--video::before {
    background-image: url("../img/video-icon.svg"); }
  .feature__related.feature__related--article::before {
    background-image: url("../img/article-icon.svg"); }

.feature__cta {
  margin-top: 30px; }

.feature__video {
  margin-top: 50px;
  text-align: center; }

.feature-list {
  position: relative; }

.feature-list__item {
  margin-bottom: 80px;
  padding-bottom: 80px;
  border-bottom: 1px solid #b3efef; }
  @media screen and (min-width: 850px) {
    .feature-list__item {
      margin-bottom: 80px;
      padding-bottom: 80px; } }
  .feature-list__item:last-child {
    margin: 0;
    padding: 0;
    border: 0; }

.feature-list__header {
  padding: 0 0 60px;
  text-align: center; }
  @media screen and (min-width: 850px) {
    .feature-list__header {
      padding: 40px 0 100px; } }

.feature-list__headline {
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .feature-list__headline {
      font-size: 40px;
      font-size: 2.5rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.feature-list__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 40px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #197e7e; }
  @media screen and (min-width: 850px) {
    .feature-list__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }

.feature-list__arrow {
  position: relative;
  margin: 0 auto;
  width: 20px;
  height: 28px; }
  .feature-list__arrow svg {
    display: block; }
  .feature-list__arrow .arrow-svg {
    fill: #527fef; }

.support-callout {
  position: relative; }
  @media screen and (min-width: 580px) {
    .support-callout {
      width: 80%; } }
  @media screen and (min-width: 850px) {
    .support-callout {
      width: auto; } }

.support-callout__headline {
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .support-callout__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.support-callout__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 40px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #197e7e; }
  @media screen and (min-width: 850px) {
    .support-callout__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }

.try-wifibooth-callout {
  position: relative;
  background-color: #527fef;
  background-repeat: no-repeat;
  background-position: left 200px bottom -40px;
  background-image: url("../img/wifi-icon-lg.svg");
  background-size: 450px;
  text-align: center; }

.try-wifibooth-callout__headline {
  font-size: 38px;
  font-size: 2.375rem;
  line-height: 1.1578947368;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .try-wifibooth-callout__headline {
      font-size: 42px;
      font-size: 2.625rem;
      line-height: 1.1904761905;
      letter-spacing: 0px; } }

.try-wifibooth-callout__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .try-wifibooth-callout__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }

.roi-callout {
  position: relative;
  background-color: #F9398C;
  background: linear-gradient(to top right, #f339eb, #f83995); }
  .roi-callout::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: repeat-x;
    background-position: center center;
    background-image: url("../img/pattern.svg");
    content: ""; }
  .roi-callout::after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(at 75% 25%, rgba(255, 255, 255, 0.25), rgba(255, 255, 255, 0));
    content: ""; }

.roi-callout__wrapper {
  position: relative;
  z-index: 4;
  margin: 0 auto;
  max-width: 800px;
  text-align: center; }

.roi-callout__headline {
  font-size: 38px;
  font-size: 2.375rem;
  line-height: 1.1578947368;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .roi-callout__headline {
      font-size: 42px;
      font-size: 2.625rem;
      line-height: 1.1904761905;
      letter-spacing: 0px;
      margin: 0 0 15px; } }

.roi-callout__byline {
  font-size: 22px;
  font-size: 1.375rem;
  line-height: 1.3636363636;
  letter-spacing: 0px;
  margin: 0 0 30px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .roi-callout__byline {
      font-size: 26px;
      font-size: 1.625rem;
      line-height: 1.3846153846;
      letter-spacing: 0px;
      margin: 0 0 15px; } }

.roi-callout__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0 0 15px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .roi-callout__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px; } }

.roi-callout__cta {
  margin: 40px 0 0 0; }

.subscribe--home .subscribe {
  padding: 140px 0 80px; }
  @media screen and (min-width: 850px) {
    .subscribe--home .subscribe {
      padding: 140px 0 80px; } }

.subscribe {
  position: relative;
  background-color: #ecf7f7;
  padding: 80px 0; }
  @media screen and (min-width: 850px) {
    .subscribe {
      padding: 80px 0; } }

@media screen and (min-width: 580px) {
  .subscribe__wrapper {
    width: 80%; } }

@media screen and (min-width: 850px) {
  .subscribe__wrapper {
    width: auto; } }

.subscribe__headline {
  font-size: 28px;
  font-size: 1.75rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .subscribe__headline {
      font-size: 32px;
      font-size: 2rem;
      line-height: 1.25;
      letter-spacing: 0px; } }

.subscribe__text {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 300;
  font-style: normal;
  color: #197e7e;
  margin-bottom: 30px; }
  @media screen and (min-width: 850px) {
    .subscribe__text {
      font-size: 20px;
      font-size: 1.25rem;
      line-height: 1.5;
      letter-spacing: 0px;
      margin: 0; } }

.subscribe-form {
  display: flex;
  flex-direction: column;
  position: relative; }
  .subscribe-form input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none; }
  @media screen and (min-width: 850px) {
    .subscribe-form {
      flex-direction: row;
      width: auto; } }

.subscribe-form__field {
  position: relative;
  height: 50px;
  margin-bottom: 20px;
  padding: 0 30px;
  border-radius: 25px;
  background-color: #fff;
  border: 0;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #131515; }
  @media screen and (min-width: 850px) {
    .subscribe-form__field {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1;
      letter-spacing: 0px;
      border-radius: 30px 0 0 30px;
      height: 60px;
      margin: 0;
      flex-grow: 1; } }

.subscribe-form__submit {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 50px;
  width: auto;
  padding: 0 25px;
  background-color: #527fef;
  border: 0;
  border-radius: 25px;
  align-self: flex-start;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: 0px;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #fff; }
  @media screen and (min-width: 850px) {
    .subscribe-form__submit {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1;
      letter-spacing: 0px;
      padding: 0 30px;
      height: 60px;
      border-radius: 0 30px 30px 0; } }

.subscribe-form__messages {
  padding-top: 20px; }

.subscribe-form--error {
  display: none;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #da4242; }
  .subscribe-form--error.subscribe-form--error-on {
    display: block; }

.subscribe-form--success {
  display: none;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.25;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #527fef; }
  .subscribe-form--success.subscribe-form--success-on {
    display: block; }

.console {
  transition: all .25s ease 0s;
  position: relative;
  border-radius: 14px;
  background-color: #25272d;
  box-shadow: 0 10px 30px rgba(19, 21, 21, 0.2);
  max-width: 940px;
  margin: 0 auto -60px auto;
  overflow: visible;
  z-index: 1;
  padding: 5px; }
  @media screen and (min-width: 850px) {
    .console {
      margin: 0 auto -60px auto; } }

.console__header {
  position: relative;
  padding: 15px 30px 20px 30px; }

.console__headline {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0px;
  margin: 0;
  font-family: "Source Code Pro", monospace;
  font-weight: 400;
  font-style: normal;
  color: #527fef; }
  @media screen and (min-width: 850px) {
    .console__headline {
      font-size: 18px;
      font-size: 1.125rem;
      line-height: 1;
      letter-spacing: 0px; } }

.console__text p, .console__text h1, .console__text h2, .console__text h3, .console__text h4 {
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.625;
  letter-spacing: 0px;
  margin: 0 0 20px;
  font-family: "Source Code Pro", monospace;
  font-weight: 400;
  font-style: normal;
  color: #bfc8c8; }
  @media screen and (min-width: 850px) {
    .console__text p, .console__text h1, .console__text h2, .console__text h3, .console__text h4 {
      font-size: 16px;
      font-size: 1rem;
      line-height: 1.625;
      letter-spacing: 0px; } }
  .console__text p strong, .console__text h1 strong, .console__text h2 strong, .console__text h3 strong, .console__text h4 strong {
    color: #ffe74c;
    text-transform: uppercase;
    font-weight: 400; }

.console__wrapper {
  border-radius: 9px;
  background-color: #1a1b1f;
  min-height: 200px;
  padding: 30px 30px 30px 30px; }

/* Wordpress reset
-------------------------------------------------------------------------------*/
#page-wrap {
  width: 960px;
  margin: 20px auto; }

ol.commentlist {
  list-style: none; }

ol.commentlist li.comment {
  border-bottom: 1px dotted #666;
  padding: 10px; }

ol.commentlist li.comment div.vcard cite.fn {
  font-style: normal; }

ol.commentlist li.comment div.vcard img.avatar {
  float: right;
  margin: 0 0 10px 10px; }

ol.commentlist li.comment div.comment-meta {
  font-size: 10px; }

ol.commentlist li.comment div.comment-meta a {
  color: #ccc; }

ol.commentlist li.comment div.reply {
  font-size: 11px; }

ol.commentlist li.comment div.reply a {
  font-weight: bold; }

ol.commentlist li.comment ul.children {
  list-style: none;
  margin: 10px 0 0; }

ol.commentlist li.comment ul.children li.depth-2 {
  border-left: 5px solid #555;
  margin: 0 0 10px 10px; }

ol.commentlist li.comment ul.children li.depth-3 {
  border-left: 5px solid #999;
  margin: 0 0 10px 10px; }

ol.commentlist li.comment ul.children li.depth-4 {
  border-left: 5px solid #bbb;
  margin: 0 0 10px 10px; }

ol.commentlist li.even {
  background: #fff; }

ol.commentlist li.odd {
  background: #f6f6f6; }

ol.commentlist li.parent {
  border-left: 5px solid #111; }
