/* Links */
a,
a:focus,
a:hover {
  color: #fff;
}

/* Base structure */
html,
body {
  height: 100%;
  background-color: #333;
}
body {
  color: #fff;
  text-align: center;
  text-shadow: 0 .05rem .1rem rgba(0,0,0,.5);
}

.section { padding-top: 100px; margin-bottom: 200px; }
#contact { margin-top: 200px; }
.banner { margin-top: 50px; margin-bottom: 50px; }
.left { text-align: left; color: #d8d8d8;}
h2 { margin-bottom: 40px; }

/* Extra markup and styles for table-esque vertical and horizontal centering */
.site-wrapper {
  display: table;
  width: 100%;
  height: 100%; /* For at least Firefox */
  min-height: 100%;
  -webkit-box-shadow: inset 0 0 5rem rgba(0,0,0,.5);
          box-shadow: inset 0 0 5rem rgba(0,0,0,.5);
}
.site-wrapper-inner {
  display: table-cell;
  vertical-align: top;
}
.cover-container {
  margin-right: auto;
  margin-left: auto;
  max-width: 760px;
}

/* Header */
.masthead { margin-bottom: 2rem; position: fixed; top: 0; }
.nav-masthead .nav-link {
  padding: .25rem 0;
  font-weight: bold;
  color: rgba(255,255,255,.5);
  background-color: transparent;
  border-bottom: .25rem solid transparent;
}
.nav-masthead .nav-link:hover,
.nav-masthead .nav-link:focus {
  border-bottom-color: rgba(255,255,255,.25);
}
.nav-masthead .nav-link + .nav-link { margin-left: 1rem; }
.nav-masthead .active {
  color: #fff;
  border-bottom-color: #fff;
}

/* Footer */
.mastfoot { color: rgba(255,255,255,.5); }