/* Grid */
.wrapper,
.grid {
  margin: 0 auto;
  max-width: 960px;
  overflow: hidden; }

.row {
  width: 100%;
  margin-bottom: 50px;
  overflow: hidden; }

.row:before, .row:after {
  content: '';
  display: table; }

.row.tuck-bottom {
  margin-bottom: 0; }

.c1 {
  width: 8.33333%; }

.c2 {
  width: 16.66667%; }

.c3 {
  width: 25.0%; }

.c4 {
  width: 33.33333%; }

.c5 {
  width: 41.66667%; }

.c6 {
  width: 50.0%; }

.c7 {
  width: 58.33333%; }

.c8 {
  width: 66.66667%; }

.c9 {
  width: 75.0%; }

.c10 {
  width: 83.33333%; }

.c11 {
  width: 91.66667%; }

.s1 {
  margin-left: 8.33333%; }

.s2 {
  margin-left: 16.66667%; }

.s3 {
  margin-left: 25.0%; }

.s4 {
  margin-left: 33.33333%; }

.s5 {
  margin-left: 41.66667%; }

.s6 {
  margin-left: 50.0%; }

.s7 {
  margin-left: 58.33333%; }

.s8 {
  margin-left: 66.66667%; }

.s9 {
  margin-left: 75.0%; }

.s10 {
  margin-left: 83.33333%; }

.s11 {
  margin-left: 91.66667%; }

.s12 {
  margin-left: 100.0%; }

.c1 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c2 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c3 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c4 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c5 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c6 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c7 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c8 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c9 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c10 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c11 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c12 {
  position: relative;
  float: left;
  padding-left: 30px;
  padding-right: 30px;
  min-height: 1px; }

.c12,
.s12 {
  float: none;
  width: 100%; }

.no-pad {
  padding-left: 0px;
  padding-right: 0px; }

@media only screen and (max-width: 900px) {
  .med-c1 {
    width: 8.33333%; }

  .med-c2 {
    width: 16.66667%; }

  .med-c3 {
    width: 25.0%; }

  .med-c4 {
    width: 33.33333%; }

  .med-c5 {
    width: 41.66667%; }

  .med-c6 {
    width: 50.0%; }

  .med-c7 {
    width: 58.33333%; }

  .med-c8 {
    width: 66.66667%; }

  .med-c9 {
    width: 75.0%; }

  .med-c10 {
    width: 83.33333%; }

  .med-c11 {
    width: 91.66667%; }

  .med-s0 {
    margin-left: 0%; }

  .med-s1 {
    margin-left: 8.33333%; }

  .med-s2 {
    margin-left: 16.66667%; }

  .med-s3 {
    margin-left: 25.0%; }

  .med-s4 {
    margin-left: 33.33333%; }

  .med-s5 {
    margin-left: 41.66667%; }

  .med-s6 {
    margin-left: 50.0%; }

  .med-s7 {
    margin-left: 58.33333%; }

  .med-s8 {
    margin-left: 66.66667%; }

  .med-s9 {
    margin-left: 75.0%; }

  .med-s10 {
    margin-left: 83.33333%; }

  .med-s11 {
    margin-left: 91.66667%; }

  .med-s12 {
    margin-left: 100.0%; }

  .med-c12 {
    width: 100%; }

  .med-no-pad {
    padding-left: 0px;
    padding-right: 0px; } }
@media only screen and (max-width: 600px) {
  .sml-c1 {
    width: 8.33333%; }

  .sml-c2 {
    width: 16.66667%; }

  .sml-c3 {
    width: 25.0%; }

  .sml-c4 {
    width: 33.33333%; }

  .sml-c5 {
    width: 41.66667%; }

  .sml-c6 {
    width: 50.0%; }

  .sml-c7 {
    width: 58.33333%; }

  .sml-c8 {
    width: 66.66667%; }

  .sml-c9 {
    width: 75.0%; }

  .sml-c10 {
    width: 83.33333%; }

  .sml-c11 {
    width: 91.66667%; }

  .sml-s0 {
    margin-left: 0%; }

  .sml-s1 {
    margin-left: 8.33333%; }

  .sml-s2 {
    margin-left: 16.66667%; }

  .sml-s3 {
    margin-left: 25.0%; }

  .sml-s4 {
    margin-left: 33.33333%; }

  .sml-s5 {
    margin-left: 41.66667%; }

  .sml-s6 {
    margin-left: 50.0%; }

  .sml-s7 {
    margin-left: 58.33333%; }

  .sml-s8 {
    margin-left: 66.66667%; }

  .sml-s9 {
    margin-left: 75.0%; }

  .sml-s10 {
    margin-left: 83.33333%; }

  .sml-s11 {
    margin-left: 91.66667%; }

  .sml-s12 {
    margin-left: 100.0%; }

  .sml-c12 {
    width: 100%; } }
.center {
  float: none;
  margin-left: auto;
  margin-right: auto; }

.push-top {
  margin-top: 50px; }

.push-top-half {
  margin-top: 10px; }

@media only screen and (max-width: 900px) {
  .med-push-top {
    margin-top: 50px; }

  .med-push-top-half {
    margin-top: 25px; } }
.t-center {
  text-align: center; }

@font-face {
  font-family: 'icomoon';
  src: url("../fonts/icomoon.eot?acaiqq");
  src: url("../fonts/icomoon.eot?#iefixacaiqq") format("embedded-opentype"), url("../fonts/icomoon.woff?acaiqq") format("woff"), url("../fonts/icomoon.ttf?acaiqq") format("truetype"), url("../fonts/icomoon.svg?acaiqq#icomoon") format("svg");
  font-weight: normal;
  font-style: normal; }
.icon {
  font-family: 'icomoon'; }

::selection {
  background: #00ad5a; }

::-moz-selection {
  background: #00ad5a; }

body {
  margin: 0;
  padding: 0;
  font-family: "Apercu Regular", Calibri, sans-serif;
  font-size: 16px; }

h1 {
  margin-bottom: 0.5em;
  font-size: 30px;
  line-height: 1.5; }
  @media only screen and (max-width: 600px) {
    h1 {
      font-size: 25px; } }

h1.giant {
  font-size: 65px;
  line-height: 1; }
  @media only screen and (max-width: 900px) {
    h1.giant {
      font-size: 32px; } }

h2 {
  font-size: 22px;
  line-height: 1.5; }

p {
  font-weight: 100;
  line-height: 1.5; }
  @media only screen and (max-width: 600px) {
    p {
      font-size: 14px; } }

a.btn {
  display: inline-block;
  margin-bottom: 3px;
  padding: 16.66667px 15px;
  font-size: 18px;
  text-decoration: none;
  background-color: white;
  border-radius: 10px;
  box-shadow: 2px 3px rgba(0, 0, 0, 0.2);
  color: #2da660;
  word-wrap: break-word;
  -webkit-transition: all 0.1s ease-in-out;
  -moz-transition: all 0.1s ease-in-out;
  -o-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out; }

a.btn:hover {
  -webkit-transform: translate(0, 2px);
  -moz-transform: translate(0, 2px);
  -o-transform: translate(0, 2px);
  transform: translate(0, 2px);
  box-shadow: 1px 2px rgba(0, 0, 0, 0.2); }

nav {
  position: fixed;
  width: 100px;
  height: 100%;
  padding-top: 12.5px;
  background-color: white;
  z-index: 3; }
  @media only screen and (max-width: 600px) {
    nav {
      width: 55px; } }

nav ol {
  position: relative; }

nav li a {
  position: relative;
  display: block;
  line-height: 2;
  padding-left: 30px;
  text-decoration: none;
  color: #929292;
  transition: all .25s ease-in-out; }
  @media only screen and (max-width: 600px) {
    nav li a {
      padding-left: 17px;
      line-height: 1.6; } }

nav li a:hover,
nav li a:focus,
nav li a.active {
  color: #2ecc71; }

@media only screen and (max-width: 600px) {
  nav ol.year-links span {
    display: none; } }

nav span.arrow {
  position: absolute;
  right: -11px;
  top: 10px;
  font-size: 2em;
  color: white;
  transition: all .25s ease-in-out; }

.hasOverlayOpen nav span.arrow {
  display: none; }

nav ul.icon-links {
  position: fixed;
  bottom: 0;
  left: 3px;
  width: 97px;
  padding-bottom: 12.5px;
  background-color: white;
  opacity: 0.8; }
  @media only screen and (max-width: 600px) {
    nav ul.icon-links {
      width: 52px; } }

nav ul.icon-links a {
  margin-left: 10px; }
  @media only screen and (max-width: 600px) {
    nav ul.icon-links a {
      margin-left: 0; } }

body {
  background-color: #2ecc71; }

div#site-body {
  position: relative;
  padding-left: 100px; }
  @media only screen and (max-width: 600px) {
    div#site-body {
      padding-left: 55px;
      overflow: hidden; } }

.hasOverlayOpen div#site-body {
  padding-bottom: 0; }

div#site-body .intro {
  position: relative;
  margin-bottom: 0;
  padding-top: 450px;
  padding-bottom: 50px;
  text-align: center;
  background: url("../images/pattern.gif");
  color: white;
  z-index: 1; }
  @media only screen and (max-width: 900px) {
    div#site-body .intro {
      padding-top: 250px; } }

div#site-body .intro a.logo {
  position: absolute;
  top: 50px;
  left: 50%;
  margin-left: -175px;
  font-size: 350px;
  text-decoration: none;
  color: white;
  z-index: 1;
  -webkit-transform: rotate(-10deg);
  -moz-transform: rotate(-10deg);
  -o-transform: rotate(-10deg);
  transform: rotate(-10deg); }
  @media only screen and (max-width: 900px) {
    div#site-body .intro a.logo {
      top: 20px;
      margin-left: -100px;
      font-size: 200px; } }

@media only screen and (max-width: 900px) {
  div#site-body .intro h1 {
    font-size: 22px; } }

@media only screen and (max-width: 900px) {
  div#site-body .intro h2 {
    font-size: 16px; } }

div#site-body .intro h1 a {
  text-decoration: none;
  color: white; }

div#site-body .intro h1 a:hover,
div#site-body .intro h1 a:focus {
  color: #58d68d; }

div#site-body .intro a.scroll-link {
  display: inline-block;
  margin: 40px auto 3px auto;
  color: white;
  font-size: 18px;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none; }
  @media only screen and (max-width: 900px) {
    div#site-body .intro a.scroll-link {
      margin-top: 25px; } }

div#site-body .intro a.scroll-link:after {
  content: "\76";
  display: block;
  width: 44px;
  height: 44px;
  margin: 16.66667px auto 0 auto;
  font-family: "icomoon";
  line-height: 46px;
  text-transform: none;
  background-color: white;
  border-radius: 22px;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.25);
  color: #2ecc71;
  -webkit-transition: all 0.1s ease-in-out;
  -moz-transition: all 0.1s ease-in-out;
  -o-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out; }

div#site-body .intro a.scroll-link:hover:after {
  -webkit-transform: translate(0, 2px);
  -moz-transform: translate(0, 2px);
  -o-transform: translate(0, 2px);
  transform: translate(0, 2px);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.25); }

div#site-body .sml-logo {
  position: fixed;
  right: 15px;
  top: 12.5px;
  display: block;
  width: 134px;
  height: 134px;
  background: url("../images/logo-small.png") 50% 50% no-repeat;
  z-index: 3;
  -webkit-transition: opacity 0.2s ease-in-out;
  -moz-transition: opacity 0.2s ease-in-out;
  -o-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out; }
  @media only screen and (max-width: 900px) {
    div#site-body .sml-logo {
      position: absolute; } }
  @media (min--moz-device-pixel-ratio: 1.3), (-o-min-device-pixel-ratio: 2.6 / 2), (-webkit-min-device-pixel-ratio: 1.3), (min-device-pixel-ratio: 1.3), (min-resolution: 1.3dppx) {
    div#site-body .sml-logo {
      background-image: url("../images/logo-small@2x.png");
      background-size: 134px 134px; } }

div#site-body .sml-logo.hidden {
  opacity: 0; }

.year-head {
  background: #2ecc71;
  color: #229955;
  color: rgba(0, 0, 0, 0.25);
  padding: 25px 160px 0 30px;
  position: relative;
  z-index: 2; }
  @media only screen and (max-width: 900px) {
    .year-head {
      padding: 15px 15px 0;
      margin-bottom: -1em;
      z-index: 3; } }

.year-head > div {
  max-width: 860px;
  margin: 0 auto; }

.year-head h1 {
  margin: 0; }

.year-head p {
  font-size: 22px; }
  @media only screen and (max-width: 900px) {
    .year-head p {
      font-size: 18px; } }
  @media only screen and (max-width: 600px) {
    .year-head p {
      font-size: 16px; } }

div.item {
  position: relative;
  padding: 25px 160px 27px 30px;
  background-color: #2ecc71;
  border-bottom: 1px solid #58d68d;
  z-index: 2; }
  @media only screen and (max-width: 900px) {
    div.item {
      padding-right: 30px; } }
  @media only screen and (max-width: 900px) {
    div.item {
      padding-left: 15px;
      padding-right: 15px; } }

div.year:last-child div.item:last-child {
  padding-bottom: 250px; }

div.item div.block {
  position: relative;
  overflow: hidden;
  max-width: 860px;
  margin: 0 auto;
  background-color: white;
  box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.25); }

div.item div.content h1 {
  line-height: 1.2; }

/* text-only block */
div.item div.block.text-only {
  background-color: transparent;
  box-shadow: none; }

div.item div.block.text-only.active {
  box-shadow: none; }

div.item div.block.text-only div.content {
  padding-left: 0; }

div.item div.block.text-only div.content p {
  color: white; }

div.item div.block.text-only div.content span.date {
  padding-top: 2px;
  color: #4e4e4e; }

div.item div.block div.content {
  overflow: hidden;
  padding: 25px 30px; }
  @media only screen and (max-width: 600px) {
    div.item div.block div.content {
      padding: 25px 15px; } }

div.item div.block div.image {
  float: left;
  width: 250px;
  height: 250px;
  background-size: 100%;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 600px) {
    div.item div.block div.image {
      width: 100%; } }

div.item div.block span.date {
  padding-top: 12.5px;
  font-size: 18px;
  color: #2ecc71; }
  @media only screen and (max-width: 600px) {
    div.item div.block span.date {
      font-size: 16px;
      padding-top: 0; } }

div.item div.block span.category {
  padding: 16.66667px 36px 12.5px 0;
  font-size: 12px;
  text-align: right;
  text-transform: uppercase;
  word-wrap: break-word;
  color: #929292; }
  @media only screen and (max-width: 600px) {
    div.item div.block span.category {
      width: auto;
      text-align: left;
      padding-right: 31px; } }

div.item div.block span.category:before {
  position: absolute;
  top: 9px;
  right: 0;
  font-family: 'icomoon';
  font-size: 26px;
  text-transform: none; }

/* Category: ventures */
div.item div.block[data-category="ventures"] a,
div.item div.block[data-category="ventures"] span.date,
div.item div.block[data-category="ventures"] span.category:before {
  color: #52b3d9; }

div.item div.block[data-category="ventures"] span.category:before {
  content: "\71"; }

/* Category: community */
div.item div.block[data-category="community"] a,
div.item div.block[data-category="community"] span.date,
div.item div.block[data-category="community"] span.category:before {
  color: #f89406; }

div.item div.block[data-category="community"] span.category:before {
  content: "\63"; }

/* Category: studio */
div.item div.block[data-category="studio"] a,
div.item div.block[data-category="studio"] span.date,
div.item div.block[data-category="studio"] span.category:before {
  color: #d2527f; }

div.item div.block[data-category="studio"] span.category:before {
  content: "\73"; }

/* Category: good-times */
div.item div.block[data-category="good-times"] a,
div.item div.block[data-category="good-times"] span.date,
div.item div.block[data-category="good-times"] span.category:before {
  color: #913d88; }

div.item div.block[data-category="good-times"] span.category:before {
  content: "\67"; }

/* Category: hard-times */
div.item div.block[data-category="hard-times"] a,
div.item div.block[data-category="hard-times"] span.date,
div.item div.block[data-category="hard-times"] span.category:before {
  color: #cf000f; }

div.item div.block[data-category="hard-times"] span.category:before {
  content: "\68"; }

/* Category: awards */
div.item div.block[data-category="awards"] a,
div.item div.block[data-category="awards"] span.date,
div.item div.block[data-category="awards"] span.category:before {
  color: #f5ab35; }

div.item div.block[data-category="awards"] span.category:before {
  content: "\79"; }

/* Category: design */
div.item div.block[data-category="design"] a,
div.item div.block[data-category="design"] span.date,
div.item div.block[data-category="design"] span.category:before {
  color: #3a539b; }

div.item div.block[data-category="design"] span.category:before {
  content: "\64"; }

/* Category: tech */
div.item div.block[data-category="tech"] a,
div.item div.block[data-category="tech"] span.date,
div.item div.block[data-category="tech"] span.category:before {
  color: #36d7b7; }

div.item div.block[data-category="tech"] span.category:before {
  content: "\e62d"; }

/* Category: animals */
div.item div.block[data-category="animals"] a,
div.item div.block[data-category="animals"] span.date,
div.item div.block[data-category="animals"] span.category:before {
  color: #e26a6a; }

div.item div.block[data-category="animals"] span.category:before {
  content: "\61"; }

/* Category: current */
div.item div.block[data-category="current"] a,
div.item div.block[data-category="current"] span.date,
div.item div.block[data-category="current"] span.category:before {
  color: #95a5a6; }

div.item div.block[data-category="current"] span.category:before {
  content: "\6e"; }

/* Outtro */
div#site-body .outtro {
  margin-bottom: 0;
  padding-top: 85px;
  text-align: center;
  background: url("../images/pattern.gif");
  color: white; }
  @media only screen and (max-width: 600px) {
    div#site-body .outtro {
      left: 55px; } }

div#site-body .outtro a.logo {
  text-decoration: none; }

div#site-body .outtro a.logo:before {
  content: '\e605';
  display: block;
  color: white;
  font-family: 'icomoon';
  font-size: 28px;
  margin-bottom: 40px; }

div#site-body .outtro .alpaca {
  margin: 10px 0 50px 0; }

div#site-body .outtro .alpaca:after {
  font-family: 'icomoon';
  display: block;
  content: '\e601';
  font-size: 80px; }

div#site-body .outtro .keep-going h2 {
  margin-bottom: 12px;
  line-height: 1.2; }

div#site-body .outtro h2:before {
  display: block;
  margin-bottom: 12px;
  font-family: 'icomoon';
  font-size: 36px; }

div#site-body .outtro div.sharing h2:before {
  content: '\e602';
  font-size: 28px;
  margin-top: 8px; }

div#site-body .outtro div.newsletter h2:before {
  content: 'n'; }

div#site-body .outtro div.chat h2:before {
  content: '\e604';
  font-size: 30px;
  margin-top: 6px; }

div#site-body .outtro div.keep-going {
  margin-bottom: 0;
  padding: 50px 0;
  background-color: #2ecc71; }

div#site-body div.outtro div.keep-going p.copyright {
  margin-top: 75px;
  font-size: 14px;
  color: rgba(255, 255, 255, 0.5); }

div#site-body ul.share li {
  display: inline; }

div#site-body ul.share li a {
  text-decoration: none; }

div#site-body ul.share li a:before {
  display: inline-block;
  width: 35px;
  height: 35px;
  margin: 10px;
  font-family: 'icomoon';
  font-size: 18px;
  line-height: 36px;
  background-color: #FFF;
  border-radius: 10px; }

div#site-body ul.share li a.facebook:before {
  content: '\e600';
  color: #44619d; }

div#site-body ul.share li a.twitter:before {
  content: '\74';
  color: #55acee; }
