/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
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-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

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

html, body {
  width: 100%;
  height: 100%;
  font-family: 'Lato', sans-serif;
  font-size: 1em;
  letter-spacing: 0.14em;
  line-height: 1.25em; }

strong {
  font-weight: 700; }

a {
  text-decoration: none;
  color: #435a59;
  background-color: #F5F5F5; }
  a:hover {
    border-bottom: 1px solid #435a59;
    padding-bottom: 0px; }

#navigation a {
  text-transform: uppercase;
  font-weight: 900; }
  #navigation a.active {
    color: #2d6361; }
    #navigation a.active:hover {
      border-bottom: 1px solid #2d6361;
      padding-bottom: 0px; }

#navigation li a, .events-by-date li a, .event-list li a {
  color: #000;
  background-color: transparent; }
  #navigation li a:hover, .events-by-date li a:hover, .event-list li a:hover {
    border-bottom: 1px solid black;
    padding-bottom: 0px; }

h1 {
  font-size: 1.15em; }

h1, h2, h3, h4 {
  margin-bottom: 10px;
  font-weight: 700;
  line-height: 1em; }

h3 {
  margin-bottom: 20px; }

.underline {
  border-bottom: 1px solid black;
  padding-bottom: 2px; }

h1, h2 {
  margin-bottom: 20px;
  text-transform: uppercase; }

h3, h4 {
  text-align: center; }

sup {
  vertical-align: super;
  font-size: 0.5em; }

p {
  margin-bottom: 15px;
  text-align: center; }
  h3 + p {
    margin-top: 30px; }

.body {
  letter-spacing: 0.05em;
  padding: 0 15px 50px 15px; }
  .body ul {
    text-align: center; }
  .body li {
    margin-bottom: 15px; }
  .body.event-list {
    text-transform: uppercase; }

.strokebottom-bg {
  z-index: -99;
  opacity: 0.75;
  background-image: url(../img/strokebottom_bg.png);
  background-position: top left;
  background-repeat: no-repeat;
  background-size: 315px 238px;
  position: fixed;
  bottom: 0;
  right: 0;
  width: 315px;
  height: 238px; }

#painted-bg {
  background-image: url(../img/painted_bg.jpg); }

.strokeleft-bg {
  background-image: url(../img/strokeleft_bg.png); }

.events-by-date ul {
  margin-bottom: 40px; }

@media only screen and (-Webkit-min-device-pixel-ratio: 1.5), only screen and (-moz-min-device-pixel-ratio: 1.5), only screen and (-o-min-device-pixel-ratio: 3 / 2), only screen and (min-device-pixel-ratio: 1.5) {
  #painted-bg {
    background-image: url(../img/painted_bg-2x.jpg);
    background-size: 378px 1031px; }

  .strokeleft-bg {
    background-image: url(../img/strokeleft_bg-2x.png);
    background-size: 557px 768px; }

  .strokebottom-bg {
    background-image: url(../img/strokebottom_bg-2x.png); } }
@media screen and (min-width: 600px) {
  #navigation h1 {
    display: none; }

  .body p, .body li {
    margin-left: 13%;
    margin-right: 13%; }

  #home-link {
    position: absolute;
    top: 63px;
    left: 80px;
    width: 220px;
    height: 377px; }

  #painted-bg {
    background-repeat: no-repeat;
    background-attachment: fixed;
    position: fixed;
    left: 0;
    width: 388px;
    height: 100%;
    min-height: 630px; }

  .strokeleft-bg {
    background-repeat: no-repeat;
    background-attachment: fixed;
    position: absolute;
    top: 0;
    left: 0;
    width: 557px;
    height: 100%; }

  #content-wrapper {
    padding-left: 500px; }

  #content {
    min-width: 350px; }
    #content .header {
      padding: 80px 0 20px 260px;
      margin: 0 15px 25px -250px;
      border-bottom: 1px solid #9FD3D1; }
      #content .header h1, #content .header h2 {
        position: relative;
        padding-left: 4%; }
      #content .header h1 + h2 {
        padding-left: 8%;
        font-size: 0.95em; }
    #content .body {
      padding-left: 4%;
      width: 80%; }
      #content .body.event-list, #content .body.resources, #content .body.past-festivals {
        position: relative;
        right: 10%; }

  #navigation {
    position: absolute;
    margin-top: 350px;
    right: 305px;
    text-align: right;
    top: 23%; }

  #navigation li {
    padding: 2px 0 2px 0; } }
@media screen and (min-width: 600px) and (max-width: 1100px), screen and (min-width: 600px) and (max-height: 650px) {
  .strokeleft-bg {
    background-attachment: scroll;
    background-size: 400px 552px;
    width: 400px; }

  #painted-bg {
    float: left;
    position: relative;
    background-attachment: scroll;
    background-size: 300px 797px;
    height: 670px;
    width: 300px; }

  #content-wrapper {
    padding-left: 360px; }

  #home-link {
    top: 0;
    left: 0;
    width: 100%;
    height: 360px; }

  #navigation {
    margin-top: 350px;
    top: 0;
    right: 200px; }

  .body {
    right: 0 !important; } }
@media screen and (max-width: 600px) {
  #navigation h1 {
    margin-bottom: 10px; }

  #content-wrapper h1 {
    display: none; }

  .strokebottom-bg {
    opacity: 0.45; }

  h1, h2, h3, h4 {
    text-align: center; }

  #home-link {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 105px;
    z-index: 99; }

  #navigation {
    text-align: center;
    padding: 10px;
    position: fixed;
    background-color: #fff;
    max-height: 87px;
    padding-top: 115px;
    background-repeat: no-repeat;
    background-image: url(../img/banner.jpg);
    background-size: 600px 105px;
    background-position: center top; }

  #navigation li {
    margin: 10px;
    display: inline;
    list-style-type: none;
    white-space: nowrap; }

  #content-wrapper {
    padding-top: 222px; }

  #painted-bg, .strokeleft-bg {
    background-image: none; }

  .header {
    padding: 0 15px; } }
@media only screen and (max-width: 600px) and (-Webkit-min-device-pixel-ratio: 1.5), only screen and (max-width: 600px) and (-moz-min-device-pixel-ratio: 1.5), only screen and (max-width: 600px) and (-o-min-device-pixel-ratio: 3 / 2), only screen and (max-width: 600px) and (min-device-pixel-ratio: 1.5) {
  #navigation {
    background-image: url(../img/banner-2x.jpg); } }
@media screen and (max-width: 350px) {
  #navigation {
    padding: 10px;
    max-height: 130px;
    padding-top: 101px;
    background-size: 520px 91px; }

  #content-wrapper {
    padding-top: 251px; } }
