@media only screen and (max-width: 1024px) {
  #wrapper {
    width: 100%;
    margin: 0;
  }
  #contact {
    width: 30%;
    padding: 1%;
  }
  #main {
    width: auto;
    float: none;
  }
  .content_box, nav {
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
  }
  nav {
    margin-bottom: 1%;
  }
  .typography figcaption, .typography .caption {
    font-size: 0.75em;
  }
}

@media only screen and (max-width: 640px) {
  #wrapper {
    width: 100%;
    margin: 0;
  }
  #logo {
    width: 40%;
  }
  #contact {
    width: 96%;
    position: static;
    font-size: 0.8em;
    padding: 2%;
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
    margin: 1% 0;
  }
  #main {
    width: auto;
    float: none;
  }
  .content_box, nav {
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
  }
  nav {
    margin-bottom: 0;
    padding: 0;
  }  
  nav li {
    display:block;
    border-bottom: 1px solid #ccc;
    padding: 2%;
  }
  header img {
    width: 50%;
  }
  .typography figure, .typography .captionImage {
    margin: 2% 0;
  }
  .typography .captionImage {
    width: 96% !important;
  }
  .typography figure._25, .typography figure._50, .typography .captionImage, .typography .captionImage img, .typography img.right, .typography img.left {
    width: 100% !important;
    height: auto;
    margin: 0;
  }
  .typography figure.right, .typography .captionImage.right, .typography figure.left, .typography .captionImage.left, .typography img.right, img.left {
    float: none;
  }
}