header {
  padding-top: 0.25em;
  padding-bottom: 0.25em; }
  @media screen and (max-width: 420px) {
    header {
      padding: 0.25em; } }

.header {
  position: fixed;
  box-shadow: 2px 0 10px rgba(0, 0, 0, 0.2);
  width: 100%;
  background-color: white;
  z-index: 9; }
  .header .logo {
    background-color: none;
    background-image: url("images/favicon2.png");
    float: left;
    font-size: 1.75em;
    line-height: 1em;
    height: 58px;
    margin: 0;
    padding: 0;
    position: relative;
    text-indent: -99999px;
    width: 58px;
    margin-top: 0.25em;
    margin-left: 1em; }
    @media screen and (max-width: 420px) {
      .header .logo {
        background-size: cover;
        margin-left: 0.25em; } }
    .header .logo a {
      text-decoration: none;
      padding-top: 1.25em;
      padding-left: 0.1em;
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0; }
  .header .supporting-links {
    font-size: 1.125em;
    float: right;
    list-style-type: none;
    padding: 0;
    display: inline-flex;
    margin-right: 1em; }
    @media screen and (max-width: 420px) {
      .header .supporting-links {
        font-size: 1em;
        display: block;
        text-align: right; }
        .header .supporting-links li:nth-child(2) {
          display: none; }
        .header .supporting-links li:nth-child(1) {
          display: none; } }
    .header .supporting-links a {
      text-decoration: none; }
      .header .supporting-links a:link {
        color: #212121; }
      .header .supporting-links a:visited {
        color: #212121; }
      .header .supporting-links a:hover {
        color: #E6141B; }
      .header .supporting-links a:focus {
        color: #E6141B; }
      .header .supporting-links a:active {
        color: #212121; }
    .header .supporting-links li {
      text-transform: uppercase;
      font-weight: 600;
      margin: auto;
      padding-left: 1em;
      padding-right: 1em; }
      .header .supporting-links li:nth-child(3) a {
        background-color: #212121;
        color: white;
        padding: 8px 25px;
        border-radius: 100px; }
        .header .supporting-links li:nth-child(3) a:hover {
          background-color: #E6141B; }
  .header .work {
    font-weight: 100;
    margin: 1em;
    display: -webkit-inline-box;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 24px;
    color: #E6141B; }
    @media screen and (max-width: 420px) {
      .header .work {
        display: none; } }
    .header .work span {
      font-weight: 600;
      color: #212121; }

.home-page .column.is-1 {
  min-width: 200px; }
.home-page #home {
  margin: 2em auto 3em; }
  .home-page #home span {
    color: #E6141B; }
.home-page #learn::before, .home-page #connect::before {
  display: block;
  content: " ";
  margin-top: -6em;
  height: 6em;
  visibility: hidden;
  pointer-events: none; }

/* layout */
body {
  background-color: white;
  font-family: 'Avenir', sans-serif;
  font-size: 1.25em;
  letter-spacing: normal;
  margin: 0;
  padding: 0; }

.columns {
  display: flex;
  flex-wrap: wrap; }

.columns .column {
  padding: 0 10px; }

.column.is-1 {
  flex: 1; }

.column.is-2 {
  flex: 2; }

.column.is-3 {
  flex: 3; }

.main-wrapper {
  background-color: white;
  color: #020e0f;
  margin-bottom: 5em; }
  .main-wrapper a:link {
    color: #E6141B; }
  .main-wrapper a:visited {
    color: #E6141B; }
  .main-wrapper a:hover {
    color: #212121; }
  .main-wrapper a:focus {
    color: #212121; }
  .main-wrapper a:active {
    color: #E6141B; }
  @media screen and (max-width: 420px) {
    .main-wrapper {
      margin-bottom: 1em; } }
  .main-wrapper h1,
  .main-wrapper h2,
  .main-wrapper h3,
  .main-wrapper h4 {
    color: #020e0f; }
  .main-wrapper h2 {
    text-align: center;
    font-weight: 300; }

input {
  display: inline-block;
  margin: 10px 0; }

input[type="submit"] {
  margin-top: 20px;
  font-weight: 500;
  background-color: #212121;
  color: white;
  padding: 10px 20px;
  border-radius: 100px;
  border: none;
  text-transform: uppercase; }
  input[type="submit"]:hover {
    background-color: #E6141B; }

main {
  padding: 6em 5em 2em; }
  @media screen and (max-width: 420px) {
    main {
      padding: 1.5em; } }
  @media screen and (max-width: 620px) {
    main {
      padding-top: 6em !important; } }
  main a {
    font-weight: 500;
    line-height: 1.5em; }

footer {
  box-shadow: -2px 0 10px rgba(0, 0, 0, 0.2);
  background-color: white;
  position: fixed;
  bottom: 0;
  width: 100%;
  padding: 1em 0; }
  footer .columns {
    justify-content: center;
    text-align: center;
    flex-wrap: wrap; }
    @media screen and (max-width: 420px) {
      footer .columns {
        display: block; } }
  @media screen and (max-width: 420px) {
    footer {
      position: relative;
      box-shadow: none;
      border-top: 1px #212121 solid; }
      footer ul {
        padding-left: 1em; } }
  footer a {
    font-weight: 600;
    font-size: 16px;
    text-decoration: none; }
    footer a:link {
      color: #212121; }
    footer a:visited {
      color: #212121; }
    footer a:hover {
      color: #E6141B; }
    footer a:focus {
      color: #E6141B; }
    footer a:active {
      color: #212121; }

h1 {
  font-size: 3em;
  text-align: center;
  /* 16x2.25=36 */ }
  @media screen and (max-width: 420px) {
    h1 {
      font-size: 1.96875em;
      /* 2.25 * .875 */ } }

h2 {
  font-size: 1.5em;
  /* 16x1.5=24 */ }
  @media screen and (max-width: 420px) {
    h2 {
      font-size: 1em;
      /* 1.5 * .875 */ } }

h3 {
  font-size: 1.125em;
  /* 16x1.125=18 */ }
  @media screen and (max-width: 420px) {
    h3 {
      font-size: 1.09375em;
      /* 1.25 * .875 */ } }

h4 {
  font-size: 0.875em;
  font-style: italic;
  /* 16x0.875=14 */ }
  @media screen and (max-width: 420px) {
    h4 {
      font-size: 0.765625em;
      font-style: italic;
      /* .875 * .875 */ } }

h1,
h2,
h3,
h4 {
  margin-bottom: 0.5em; }

blockquote,
ol,
p,
ul {
  margin-bottom: 1em;
  line-height: 1.25em; }

li {
  margin-bottom: 0.375em; }

.thumbnail {
  position: relative;
  margin-top: 20px;
  padding: 2px;
  background-color: white;
  border: 1px solid grey; }
  .thumbnail img {
    width: 100%; }
  .thumbnail:hover .overlay {
    opacity: 0.8; }
  .thumbnail .overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    height: 100%;
    width: 100%;
    opacity: 0;
    transition: 0.5s ease;
    background-color: #0d544f; }
    .thumbnail .overlay .text {
      color: white;
      font-size: 20px;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%); }

.join-form div {
  padding: 8px 0; }

.highlight {
  background: yellow; }
