* {
  font-family: 'Mignon-Medium';
  color: #222;
}

@font-face {
  font-family: 'Mignon-Medium';
  src: url('fonts/mignon-medium/Mignon-Medium.ttf.woff') format('woff'), url('fonts/mignon-medium/Mignon-Medium.ttf.svg#Mignon-Medium') format('svg'), url('fonts/mignon-medium/Mignon-Medium.ttf.eot'), url('fonts/mignon-medium/Mignon-Medium.ttf.eot?#iefix') format('embedded-opentype');
  font-weight: normal;
  font-style: normal;
}

body {
  background: #f0f1f3;
  margin: 0;
  padding: 0 1rem;
  text-align: center;
}

.page-wrapper {
  width: 100%;
  max-width: 800px;
  display: inline-block;
}

.header {
  border-radius: 1px;
  position: fixed;
  background: #f0f1f3;
  width: Calc(100% - 2rem);
  max-width: 800px;
  min-height: 13rem;
}

.content,
.header,
.header>* {
  transition: all .4s linear;
}

.header.vertically-centered {
  margin-top: 2.25rem;
}

.splash-image-wrapper {
  display: block;
  width: 100%;
  max-width: 800px;
  overflow: hidden;
  max-height: 300px;
  box-shadow: 0px 1px 5px #AAA;
}

.splash-image-attribution {
  color: white;
  position: absolute;
  bottom: 0;
  right: 0;
  text-decoration: none;
  font-size: .75rem;
}

img {
  max-height: 100%;
  max-width: 100%;
}

.title {
  font-size: 3rem;
  margin: 0;
  padding: 2rem 0 1rem 0;
  border-bottom: 1px solid #4f5054;
  border-top: 1px solid #4f5054;
  margin-top: 2rem;
  font-weight: 100;
  position: absolute;
  width: 100%;
}

.menu {
  border-bottom: 1px solid #4f5054;
  position: absolute;
  width: 100%;
  top: Calc(9rem - 4px);
}

.menu>a {
  text-decoration: none;
  font-size: 1.5rem;
  padding: 1.25rem;
  padding-bottom: 1rem;
  display: inline-block;
  border-right: 1px solid #4f5054;
}

.menu>a:first-of-type {
  border-left: 1px solid #4f5054;
}

.menu>a.selected,
.menu>a.selected:hover {
  background: #c7c7ce;
}

.menu>a:hover {
  background: #9f9fa7;
}

.content {
  margin-top: 15rem;
  text-align: left;
  font-size: 1.15rem;
  padding-bottom: Calc(50vh - 275px);
}

p {
  margin: 1rem 0;
  line-height: 1.5rem;
}

li {
  margin-bottom: .5rem;
}

.headshot {
  box-shadow: 0px 1px 5px #AAA;
  max-width: Calc(100% - 2rem);
  width: 190px;
  float: right;
  margin: 0 0 1.5rem 1.5rem;
}

.with-splash-image .header {
  position: relative;
}

.with-splash-image .menu {
  top: auto;
  margin-top: Calc(9rem - 4px);
}

.with-splash-image .content {
  margin-top: 11rem;
}

.linebreak {
  width: 100%;
  border-top: 1px solid;
}

.centered {
  text-align: center;
}

@media only screen and (min-width: 831px) {
  .condensed .title {
    font-size: 1.5rem;
    font-weight: 800;
    padding: 1.2rem 1rem .75rem 1rem;
    margin-bottom: Calc(-4rem - 2px);
    position: absolute;
    background: #f0f1f3;
    left: 0;
    margin: 0;
    width: 10rem;
  }
  .condensed .menu {
    margin-left: 12rem;
    border-top: 1px solid;
    border-bottom: 1px solid;
    top: 0;
    width: auto;
  }
  .condensed .menu>a {
    font-size: 1.25rem;
  }
  .condensed .menu>a {
    border-right: none;
    border-left: 1px solid;
  }
  .condensed .content {
    margin-top: 10rem;
  }
  .condensed .header {
    min-height: 4rem;
  }
}

@media only screen and (max-width: 703px) {
  .menu>a {
    width: Calc(100% - 2.5rem - 2px);
    border: 1px solid;
    margin: -1px 0 0px 0;
    border-bottom: 0;
  }
  .content {
    margin-top: 20rem;
  }
  .header {
    position: relative;
    width: 100%;
  }
  .with-splash-image .content {
    margin-top: 24rem;
  }
}