@charset "UTF-8";
/* Defaults
-------------------------------------------------- */
/* Compass
-------------------------------------------------- */
@import url("http://fonts.googleapis.com/css?family=Muli:300,400|Karla:400,700|Open+Sans:300italic,400italic,700italic,400,300,700");
html, body, div, span, applet, object, iframe,
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,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

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

a img {
  border: none;
}

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

/* Functions
-------------------------------------------------- */
/* ------------------------------------------------------------
|   Function Set: Maths
|--------------------------------------------------------------
|
|   Some pixel / em / percentage maths and other related
|	functions for re-use
|
|------------------------------------------------------------*/
/* Modules
-------------------------------------------------- */
/* ------------------------------------------------------------
|   Module: Globals
|--------------------------------------------------------------
|
|   Globals
|
|------------------------------------------------------------*/
/* ----------------
   Global Variables
   ---------------- */
/* ------------------------------------------------------------
|   Module: Typography
|--------------------------------------------------------------
|
|   Define font families used throughout the site
|
|------------------------------------------------------------*/
/* ----------------
   Common colours
   ---------------- */
/* ----------------
   Global text colours
   ---------------- */
/* ----------------
   Theme colours
   ---------------- */
/* Breakpoints
-------------------------------------------------- */
/* Animations adapted from:
        |
        |   Animate.css - http://daneden.me/animate
        |   Licensed under the MIT license - http://opensource.org/licenses/MIT
        |
        |   Copyright (c) 2015 Daniel Eden
        |
-------------------------------------------------- */
.animated {
  /* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -moz context. */
  -moz-animation-duration: 1s;
  /* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -webkit context. */
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  /* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -moz context. */
  -moz-animation-fill-mode: both;
  /* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -webkit context. */
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

/* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
/* Creating new -moz context. */
@-moz-keyframes slideInUp {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* content for -moz because -moz is already in scope. */
    -moz-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -moz is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -webkit because -moz is already in scope. */
    /* Content for official syntax. Prefix context is still -moz. */
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* content for -moz because -moz is already in scope. */
    -moz-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -moz is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -webkit because -moz is already in scope. */
    /* Content for official syntax. Prefix context is still -moz. */
    transform: translate3d(0, 0, 0);
  }
}
/* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
/* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
/* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
/* Creating new -webkit context. */
@-webkit-keyframes slideInUp {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -moz because -webkit is already in scope. */
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -webkit is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* content for -webkit because -webkit is already in scope. */
    -webkit-transform: translate3d(0, 100%, 0);
    /* Content for official syntax. Prefix context is still -webkit. */
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -moz because -webkit is already in scope. */
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -webkit is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* content for -webkit because -webkit is already in scope. */
    -webkit-transform: translate3d(0, 0, 0);
    /* Content for official syntax. Prefix context is still -webkit. */
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slideInUp {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -moz context. */
    -moz-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -ms context. */
    -ms-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -webkit context. */
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -moz context. */
    -moz-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -ms context. */
    -ms-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -webkit context. */
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
.slideInUp {
  /* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -moz context. */
  -moz-animation-name: slideInUp;
  /* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -webkit context. */
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp;
}

/* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
/* Creating new -moz context. */
@-moz-keyframes slideOutDown {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* content for -moz because -moz is already in scope. */
    -moz-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -moz is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -webkit because -moz is already in scope. */
    /* Content for official syntax. Prefix context is still -moz. */
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* content for -moz because -moz is already in scope. */
    -moz-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -moz is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -webkit because -moz is already in scope. */
    /* Content for official syntax. Prefix context is still -moz. */
    transform: translate3d(0, 100%, 0);
  }
}
/* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
/* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
/* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
/* Creating new -webkit context. */
@-webkit-keyframes slideOutDown {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -moz because -webkit is already in scope. */
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -webkit is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* content for -webkit because -webkit is already in scope. */
    -webkit-transform: translate3d(0, 0, 0);
    /* Content for official syntax. Prefix context is still -webkit. */
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -moz because -webkit is already in scope. */
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Omitting content for -ms because -webkit is already in scope. */
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* content for -webkit because -webkit is already in scope. */
    -webkit-transform: translate3d(0, 100%, 0);
    /* Content for official syntax. Prefix context is still -webkit. */
    transform: translate3d(0, 100%, 0);
  }
}
@keyframes slideOutDown {
  from {
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -moz context. */
    -moz-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -ms context. */
    -ms-transform: translate3d(0, 0, 0);
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -webkit context. */
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    /* Capability transforms2d is prefixed with -moz because 0.77252% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -moz context. */
    -moz-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is prefixed with -ms because 2.6001% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -ms context. */
    -ms-transform: translate3d(0, 100%, 0);
    /* Capability transforms2d is not prefixed with -o because 0.08196% of users are affected which is less than the threshold of 0.1. */
    /* Capability transforms2d is prefixed with -webkit because 52.08628% of users need it which is more than the threshold of 0.1%. */
    /* Creating new -webkit context. */
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}
.slideOutDown {
  /* Capability css-animation is prefixed with -moz because 0.57224% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -moz context. */
  -moz-animation-name: slideOutDown;
  /* Capability css-animation is not prefixed with -ms because 0% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is not prefixed with -o because 0.02146% of users are affected which is less than the threshold of 0.1. */
  /* Capability css-animation is prefixed with -webkit because 57.87258% of users need it which is more than the threshold of 0.1%. */
  /* Creating new -webkit context. */
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown;
}

/* Partials
-------------------------------------------------- */
/* Common styles
-------------------------------------------------- */
.colophon {
  color: #CECECE;
}

.copyright {
  color: #CECECE;
}

@font-face {
  font-family: "akico";
  src: url(../fonts/akico.eot);
  src: url(../fonts/akico.eot#iefix) format('embedded-opentype'), url(../fonts/akico.woff) format('woff'), url(../fonts/akico.ttf) format('truetype'), url(../fonts/akico.svg) format('svg');
}
@font-face {
  font-family: "akico";
  src: url(../fonts/akico.eot);
  src: url(../fonts/akico.eot#iefix) format('embedded-opentype'), url(../fonts/akico.woff) format('woff'), url(../fonts/akico.ttf) format('truetype'), url(../fonts/akico.svg) format('svg');
}
.icon-chevron-down:before, .icon-chevron-left:before, .icon-chevron-right:before, .icon-chevron-up:before, .nextprev .next .nextprev-title:after, .nextprev .prev .nextprev-text:before, .scroll-hint:before {
  font-family: "akico";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  speak: none;
  text-decoration: none;
  text-transform: none;
}

.icon-chevron-down:before {
  content: "";
}

.icon-chevron-left:before {
  content: "";
}

.icon-chevron-right:before {
  content: "";
}

.icon-chevron-up:before {
  content: "";
}

/* Common styles
-------------------------------------------------- */
a {
  cursor: pointer;
}

a, a:hover, a:visited {
  color: inherit;
  text-decoration: none;
}

a.text-link {
  font-size: 0.8rem;
  color: #4a90e2;
}
a.text-link:hover {
  color: #4ad0e2;
}

a.button {
  padding: 0.74rem 1.76rem;
  border: 1px solid #e7e7e7;
  text-transform: uppercase;
  font-family: "Karla", "Helvetica Neue", "Helvetica-Neue", sans-serif;
  font-weight: bold;
  display: inline-block;
  font-size: 0.8rem;
  letter-spacing: 0.06rem;
  line-height: 1rem;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

p, ol, .main.text ul {
  margin: 0.8rem 0;
  font-size: 0.82rem;
  line-height: 1.4em;
}

h1 {
  margin: 1em 0 2em;
}

ol {
  list-style-type: decimal;
  padding-left: 2em;
}
ol li {
  margin-bottom: 0.2em;
}

.bio .main ul li {
  margin-bottom: 0.5em;
  padding-left: 2em;
  text-indent: -2em;
}
.bio .main td br {
  margin-bottom: 0.5em;
}

table p {
  margin: 0;
}
table tr {
  margin-bottom: 0.2em;
}
table td {
  padding-right: 1em;
  vertical-align: top;
}

.hidden {
  display: none;
}

.full-width-height {
  width: 100%;
  height: 100%;
}

.full-width {
  width: 100%;
}

.full-height {
  height: 100%;
}

.width-1-1 {
  width: 100%;
}

.width-1-2 {
  width: 50%;
}
@media screen and (max-width: 480px) {
  .width-1-2 {
    width: 100%;
  }
}

.width-1-4 {
  width: 25%;
}
@media screen and (max-width: 800px) {
  .width-1-4 {
    width: 50%;
  }
  .width-1-4.layout-text {
    width: 100%;
  }
}

.width-3-4 {
  width: 75%;
}
@media screen and (max-width: 800px) {
  .width-3-4 {
    width: 100%;
  }
}

/* Primary layouts
-------------------------------------------------- */
html {
  position: relative;
  min-height: 480px;
  font-family: "Open Sans", "Helvetica Neueu", "Helvetica-Neueu", "Arial", sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  width: 100%;
  min-width: 240px;
  min-height: 100%;
  -moz-user-select: -moz-none;
  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;
}

header {
  display: block;
}

footer {
  bottom: 0;
  width: 100%;
  height: 10rem;
  text-align: right;
  margin-top: 5rem;
  padding: 5.5rem 1rem 1rem;
  background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPSc1JyBoZWlnaHQ9JzUnPgo8cGF0aCBkPSdNMCA1TDUgMFpNNiA0TDQgNlpNLTEgMUwxIC0xWicgc3Ryb2tlPScjODg4JyBzdHJva2Utb3BhY2l0eT0nMC4yJyBzdHJva2Utd2lkdGg9JzEnIHRyYW5zZm9ybT0ncm90YXRlKDkwIDIuNSAyLjUpJy8+Cjwvc3ZnPg==');
  box-sizing: border-box;
}
footer * {
  font-size: 0.6rem;
}

.page.next, .page.prev {
  position: absolute;
}
.page.next {
  right: -100%;
}
.page.prev {
  left: -100%;
}

.main.text {
  padding: 1rem;
  max-width: 680px;
}
.main.text img {
  max-width: 100%;
}

/* Specific layouts
-------------------------------------------------- */
/* Main menu
-------------------------------------------------- */
.header {
  position: relative;
  z-index: 2;
  border: 1px solid #e7e7e7;
  font-family: "Karla", "Helvetica Neue", "Helvetica-Neue", sans-serif;
  text-transform: uppercase;
  font-weight: bold;
}

.menu-main-container {
  overflow: hidden;
}
@media screen and (min-width: 801px) {
  .menu-main-container {
    height: auto !important;
  }
}

.logo {
  float: left;
  padding: 0.74rem 4rem 0.74rem 1rem;
  letter-spacing: 0.12rem;
  line-height: 1rem;
}

.hamburger {
  display: none;
}

.menu-main > li {
  float: left;
}

.menu-main > li a {
  padding: 0.74rem 1.76rem;
  display: block;
  margin: -1px -1px -1px 0;
  border: 1px solid #e7e7e7;
  font-size: 0.8rem;
  letter-spacing: 0.06rem;
  line-height: 1rem;
}

@media screen and (max-width: 800px) {
  .header {
    border: none;
  }

  .logo-container {
    z-index: 1;
    border: 1px solid #e7e7e7;
    overflow: hidden;
  }

  .logo {
    float: none;
    display: block;
    position: relative;
    line-height: 1.35em;
  }

  .hamburger {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    text-indent: -1000px;
    overflow: hidden;
    display: block;
    float: right;
    width: 1em;
    height: 100%;
    padding: 0 1em;
  }
  .hamburger:after {
    content: '☰';
    display: block;
    position: absolute;
    top: 1em;
    text-indent: 0;
    -moz-transition: -moz-transform 0.8s ease-in-out;
    -o-transition: -o-transform 0.8s ease-in-out;
    -webkit-transition: -webkit-transform 0.8s ease-in-out;
    transition: transform 0.8s ease-in-out;
  }

  .auto-expand-menu .hamburger:after,
  .menu-expanded .hamburger:after {
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }

  body:not(.auto-expand-menu) header:not(.menu-expanded) .menu-main-container {
    height: 0 !important;
  }

  .menu-main-container {
    position: relative;
    z-index: 0;
    width: 100%;
    height: 0;
    overflow: hidden;
    border-top: 1px solid #e7e7e7;
    -moz-transition: height 0.8s ease-in-out;
    -o-transition: height 0.8s ease-in-out;
    -webkit-transition: height 0.8s ease-in-out;
    transition: height 0.8s ease-in-out;
  }

  .auto-expand-menu .menu-main-container {
    height: auto !important;
  }
  .auto-expand-menu .menu-main {
    position: relative;
  }
  .auto-expand-menu .hamburger {
    display: none;
  }

  .menu-main {
    position: absolute;
    bottom: 0;
    width: 100%;
  }

  .menu-main > li {
    position: relative;
    float: none;
  }

  .menu-main > li a {
    margin: -1px 0 0;
    padding: 0.74rem 1rem;
  }
}
/* Home page specific styles
-------------------------------------------------- */
.home .featured-content {
  position: relative;
  bottom: 0;
  z-index: 1;
  padding: 2rem;
  border-bottom: 1px solid #e7e7e7;
  box-sizing: border-box;
}
@media screen and (min-width: 640px) {
  .home .featured-content.mask-mobile {
    border-bottom: none !important;
    background: none !important;
  }
}
@media screen and (min-width: 1024px) {
  .home .featured-content.mask-tablet {
    border-bottom: none !important;
    background: none !important;
  }
}
.home .featured-content.mask-off {
  border-bottom: none !important;
  background: none !important;
}
.home .featured-content h1 {
  margin: -0.8rem 0 1.8rem 0;
  font-size: 2.5rem;
  font-family: "Karla", "Helvetica Neue", "Helvetica-Neue", sans-serif;
  font-weight: normal;
  line-height: 1.2em;
}
.home .featured-content h1:first-of-type {
  margin-top: 1.2rem;
}
.home .featured-content a.button {
  margin: 1rem 0;
}
.home .featured-content a:not(.button) {
  opacity: 0.6;
  text-decoration: none;
}
.home .featured-content a:not(.button):hover {
  opacity: 1;
  text-decoration: underline;
}
.home .featured-image-container.pre-loaded {
  -webkit-filter: blur(4px);
  filter: blur(4px);
  opacity: 0.8;
}

/* Project listing
-------------------------------------------------- */
.projects-list {
  margin-top: 1.8rem;
}

.projects-section {
  margin-top: 0.8rem;
}

.projects-section-header {
  padding: 1rem;
  font-size: 0.86rem;
  font-weight: bold;
  letter-spacing: 0.05rem;
}

.projects-set {
  width: 100%;
  overflow: hidden;
}

.project-set-item {
  display: inline-block;
  width: 14em;
  vertical-align: top;
}

.project-thumb-container {
  width: 100%;
  display: block;
  float: left;
  position: relative;
}

.project-footer-thumb {
  width: 14em;
}

.project-thumb {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 74%;
  z-index: 1;
  overflow: hidden;
  background-position: center center;
  -moz-background-size: cover !important;
  -o-background-size: cover !important;
  -webkit-background-size: cover !important;
  background-size: cover !important;
}
.project-thumb img.full-image,
.project-thumb img.pre-loaded {
  position: absolute !important;
  top: 0;
  left: 0;
}
.project-thumb img.pre-loaded {
  width: 102%;
  margin-left: -1%;
}

.project-info {
  padding: 1rem;
  font-size: 0.85rem;
}
.project-info .title {
  font-style: italic;
}
.project-info .year {
  font-size: 0.8em;
  line-height: 2.2em;
}

@media screen and (max-width: 800px) {
  .project-set-item {
    width: 33.3%;
  }
}
@media screen and (max-width: 480px) {
  .project-set-item {
    width: 50%;
  }

  .project-footer-thumb {
    width: 50%;
  }
}
@media screen and (max-width: 320px) {
  .featured .project-set-item {
    width: 100%;
  }
}
/* Project layout
-------------------------------------------------- */
.layout {
  position: relative;
}

.layout:after {
  content: "";
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPSc1JyBoZWlnaHQ9JzUnPgo8cGF0aCBkPSdNMCA1TDUgMFpNNiA0TDQgNlpNLTEgMUwxIC0xWicgc3Ryb2tlPScjODg4JyBzdHJva2Utb3BhY2l0eT0nMC4yJyBzdHJva2Utd2lkdGg9JzEnIHRyYW5zZm9ybT0ncm90YXRlKDkwIDIuNSAyLjUpJy8+Cjwvc3ZnPg==');
  opacity: 0.5;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  position: absolute;
  z-index: -1;
}

.layout-section {
  width: 100%;
  display: block;
  line-height: 0;
  clear: both;
  overflow: hidden;
}

.layout-section:last-child .layout-item:last-child.layout-text {
  padding-bottom: 5.5rem;
}

.layout-item {
  float: left;
  position: relative;
  vertical-align: top;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.layout-text {
  line-height: 1.25em;
  padding: 1rem 1rem 1.5rem;
  pointer-events: none;
}
.layout-text h1, .layout-text h2, .layout-text h3 {
  margin: 0.8rem 0;
}
.layout-text p {
  max-width: 680px;
}
.layout-text ol {
  font-size: 0.77rem;
}

.project-thumb,
.layout-img,
.layout-loop {
  overflow: hidden;
}
.project-thumb img,
.layout-img img,
.layout-loop img {
  width: 100%;
  height: auto;
}
.project-thumb img.pre-loaded,
.layout-img img.pre-loaded,
.layout-loop img.pre-loaded {
  position: relative;
  z-index: 0;
  -webkit-filter: blur(4px);
  filter: blur(4px);
  opacity: 0.8;
}
.project-thumb img.full-image,
.layout-img img.full-image,
.layout-loop img.full-image {
  z-index: 1;
  -moz-transition: opacity 0.7s;
  -o-transition: opacity 0.7s;
  -webkit-transition: opacity 0.7s;
  transition: opacity 0.7s;
}
.project-thumb img.full-image.loading, .project-thumb img.full-image.transition,
.layout-img img.full-image.loading,
.layout-img img.full-image.transition,
.layout-loop img.full-image.loading,
.layout-loop img.full-image.transition {
  position: absolute;
  top: 0;
  left: 0;
}
.project-thumb img.full-image, .project-thumb img.full-image.transition,
.layout-img img.full-image,
.layout-img img.full-image.transition,
.layout-loop img.full-image,
.layout-loop img.full-image.transition {
  opacity: 1;
}
.project-thumb img.full-image.loading,
.layout-img img.full-image.loading,
.layout-loop img.full-image.loading {
  opacity: 0;
}

.layout-loop img {
  z-index: 0;
  position: relative;
}

.layout-loop video {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
}

.project-footer {
  padding: 1rem 1rem 1.6rem;
  position: relative;
  z-index: 1;
}
.project-footer:after {
  content: "";
  opacity: 0.4;
  background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPSc1JyBoZWlnaHQ9JzUnPgo8cGF0aCBkPSdNMCA1TDUgMFpNNiA0TDQgNlpNLTEgMUwxIC0xWicgc3Ryb2tlPScjODg4JyBzdHJva2Utb3BhY2l0eT0nMC4yJyBzdHJva2Utd2lkdGg9JzEnIHRyYW5zZm9ybT0ncm90YXRlKDkwIDIuNSAyLjUpJy8+Cjwvc3ZnPg==');
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  position: absolute;
  z-index: -1;
}
.project-footer .top-link {
  display: block;
  margin: 2.5rem 0 6rem;
}
.project-footer .projects-link {
  display: block;
}

.nextprev {
  position: relative;
  overflow: hidden;
}
.nextprev .nextprev-text {
  display: block;
  position: relative;
  margin-top: 0.8rem;
}
.nextprev .nextprev-title, .nextprev .nextprev-year {
  display: block;
}
.nextprev .next .nextprev-title:after, .nextprev .prev .nextprev-text:before {
  position: absolute;
  top: 0.14rem;
  font-size: 0.6rem;
}
.nextprev .nextprev-title {
  font-style: italic;
  margin: 0.4rem 0;
  font-size: 0.85rem;
}
.nextprev .nextprev-year {
  margin: 0.2rem 0;
  font-size: 0.68em;
}
.nextprev .next .nextprev-title, .nextprev .next .nextprev-year {
  padding-left: 0.5rem;
}
.nextprev .next .nextprev-title:after {
  content: "";
  margin-left: 0.6rem;
}
.nextprev .prev .nextprev-title, .nextprev .prev .nextprev-year {
  padding-left: 2.0rem;
}
.nextprev .prev .nextprev-text:before {
  content: "";
  margin-left: 0.8rem;
}

/* Columns (kibry text plugin)
-------------------------------------------------- */
/* Articles
-------------------------------------------------- */
/* Background audio player
-------------------------------------------------- */
.background-audio-player-container {
  width: 100%;
  height: 1.81rem;
  line-height: 1.81rem;
  bottom: 0;
  background-color: inherit;
  z-index: 99999;
  border: 1px solid #e7e7e7;
  vertical-align: middle;
  position: fixed;
  position: sticky;
  position: -webkit-sticky;
  position: -moz-sticky;
  position: -ms-sticky;
  position: -o-sticky;
}
.background-audio-player-container .background-audio-player {
  height: 100%;
  width: 100%;
}
.background-audio-player-container .controls, .background-audio-player-container .controls > *,
.background-audio-player-container .meta,
.background-audio-player-container .meta > * {
  display: inline-block;
}
.background-audio-player-container .controls {
  position: relative;
  float: left;
  height: 100%;
  font-family: "Karla", "Helvetica Neue", "Helvetica-Neue", sans-serif;
  text-transform: uppercase;
  font-weight: bold;
  vertical-align: top;
}
.background-audio-player-container .controls .playpause {
  position: relative;
  width: 5rem;
  height: 100%;
  display: block;
  float: left;
  border-left: 1px solid #e7e7e7;
  text-align: center;
}
.background-audio-player-container .controls .playpause .play,
.background-audio-player-container .controls .playpause .pause {
  display: block;
  width: 100%;
  position: absolute;
  padding: 0;
  top: 0;
  left: 0;
}
.background-audio-player-container .controls .control {
  display: inline-block;
  margin: 0 auto;
  padding: 0 1rem;
  height: 100%;
  font-size: 0.7rem;
  z-index: 1;
  opacity: 1;
  -moz-transition: opacity 1s;
  -o-transition: opacity 1s;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}
.background-audio-player-container .controls .pause, .background-audio-player-container .controls.paused .pause {
  pointer-events: none;
  opacity: 0;
  z-index: 0;
}
.background-audio-player-container .controls.playing .play {
  pointer-events: none;
  opacity: 0;
  z-index: 0;
}
.background-audio-player-container .controls.playing .pause {
  opacity: 1;
  pointer-events: auto;
}
.background-audio-player-container .controls.buffering .play {
  opacity: 0.4;
  pointer-events: none;
  cursor: not-allowed;
}
.background-audio-player-container .controls.buffering .playpause:after {
  content: "";
}
.background-audio-player-container .controls.error .play {
  color: red;
}
.background-audio-player-container .meta {
  height: 100%;
  padding: 0 2rem 0 1rem;
  vertical-align: top;
}
.background-audio-player-container .meta > * {
  display: block;
  float: left;
}
.background-audio-player-container .meta .title {
  font-size: 0.6rem;
  font-weight: bold;
}
.background-audio-player-container .meta .caption {
  display: none;
}

/* Video loop
-------------------------------------------------- */
.video-loop-container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.video-loop-container .video-loop {
  position: absolute;
  left: 50%;
  top: 50%;
  margin: auto;
  min-width: 101%;
  min-height: 101%;
  width: auto;
  height: auto;
  opacity: 1.0;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.video-loop-container:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.layout-loop video,
.video-loop-container video {
  -moz-transition: opacity 3.5s linear;
  -o-transition: opacity 3.5s linear;
  -webkit-transition: opacity 3.5s linear;
  transition: opacity 3.5s linear;
}
.layout-loop.loading video,
.video-loop-container.loading video {
  opacity: 0;
}

/* Specicific featured video loop / image container
-------------------------------------------------- */
.featured-loop-container, .featured-image-container {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 0;
  -moz-background-size: cover;
  -o-background-size: cover;
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center center;
}

/* All loader spinner instances
-------------------------------------------------- */
/* Specific loaders
-------------------------------------------------- */
/* Scroll hinting
-------------------------------------------------- */
.scroll-hint {
  position: fixed;
  bottom: 0;
  right: 0;
  padding: 1rem;
  z-index: 999999;
  cursor: pointer;
  background: #fff;
}
.scroll-hint:before {
  content: "";
}
.dark-theme .scroll-hint {
  background: #212121;
}
.scroll-hint:hover {
  background: #eaeaea;
}
.dark-theme .scroll-hint:hover {
  background: #131313;
}

/* Default theme (light)
-------------------------------------------------- */
.page {
  color: #161616;
  background-color: #fff;
}

.header,
.home .featured-content,
.full-width-height .background-audio-player-container {
  background-color: rgba(255, 255, 255, 0.44);
}

.menu-main a:hover,
.background-audio-player .controls a:hover,
a.button:hover {
  background: rgba(242, 242, 242, 0.56);
}
.menu-main a.active,
.background-audio-player .controls a.active,
a.button.active {
  background: rgba(236, 236, 236, 0.56);
}

.home a.button:hover {
  background: #fff;
}

.project-thumb,
.layout-img,
.layout-loop {
  background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuMCIgeDI9IjEuMCIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2Y1ZjVmNSIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2ViZWJlYiIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background-size: 100%;
  background-image: -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #f5f5f5), color-stop(100%, #ebebeb));
  background-image: -moz-linear-gradient(top, #f5f5f5, #ebebeb);
  background-image: -webkit-linear-gradient(top, #f5f5f5, #ebebeb);
  background-image: linear-gradient(to bottom right, #f5f5f5, #ebebeb);
}

.project-info .title {
  color: #777;
}
.project-info .year {
  color: #979797;
}

.projects-section-header {
  color: #2c2c2c;
}

.project-footer:after {
  background-color: #eaeaea;
}

.layout-text {
  background-color: #fff;
}

/* Dark theme
-------------------------------------------------- */
.dark-theme {
  color: #c5c5c5;
  background-color: #212121;
}
.dark-theme .header, .dark-theme.home .featured-content,
.dark-theme .full-width-height .background-audio-player-container {
  background-color: rgba(33, 33, 33, 0.44);
}
.dark-theme .menu-main a:hover,
.dark-theme .background-audio-player .controls a:hover,
.dark-theme a.button:hover {
  background: rgba(30, 30, 30, 0.56);
}
.dark-theme .menu-main a.active,
.dark-theme .background-audio-player .controls a.active,
.dark-theme a.button.active {
  background: rgba(28, 28, 28, 0.56);
}
.dark-theme .project-thumb,
.dark-theme .layout-img,
.dark-theme .layout-loop {
  background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuMCIgeDI9IjEuMCIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzJiMmIyYiIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzM1MzUzNSIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background-size: 100%;
  background-image: -webkit-gradient(linear, 0% 0%, 100% 100%, color-stop(0%, #2b2b2b), color-stop(100%, #353535));
  background-image: -moz-linear-gradient(top, #2b2b2b, #353535);
  background-image: -webkit-linear-gradient(top, #2b2b2b, #353535);
  background-image: linear-gradient(to bottom right, #2b2b2b, #353535);
}
.dark-theme .project-info .title {
  color: #777;
}
.dark-theme .project-info .year {
  color: #979797;
}
.dark-theme .projects-section-header {
  color: #2c2c2c;
}
.dark-theme .project-footer:after {
  background-color: #131313;
}
.dark-theme .layout-text {
  background-color: #212121;
}

/* IE8 and below
-------------------------------------------------- */
.ie8 .pre-loaded {
  display: none !important;
}
.ie8 .featured-content {
  background: #fff;
}
.dark-theme .ie8 .featured-content {
  background: #212121;
}
.ie8 .featured-content h1 {
  font-size: 28px !important;
}
.ie8 .header {
  background: #fff;
}
.dark-theme .ie8 .header {
  background: #212121;
}
