@charset "UTF-8";
* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

/* HTML5 Elements */
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, main { display: block; }

audio[controls], canvas, video { display: inline-block; *display: inline; *zoom: 1; }

/* Eric Meyer's Reset CSS */
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, main, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }

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; }

/* HTML5 Boilerplate */
html { font-size: 100%; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

a:focus { outline: thin dotted; }

a:hover, a:active { outline: 0; }

abbr[title] { border-bottom: 1px dotted; }

img { border: 0; -ms-interpolation-mode: bicubic; }

/* Correct overflow displayed oddly in IE9  */
svg:not(:root) { overflow: hidden; }

label { cursor: pointer; }

legend { border: 0; *margin-left: -7px; padding: 0; }

button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; }

button, input { line-height: normal; *overflow: visible; }

button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; }

input[type="checkbox"], input[type="radio"] { box-sizing: border-box; }

input[type="search"] { -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

textarea { overflow: auto; vertical-align: top; }

/*
html { -webkit-tap-highlight-color: rgba(0,0,0,0); }
::-moz-selection  { background: #fe57a1; color: #fff; text-shadow: none; }
::selection       { background: #fe57a1; color: #fff; text-shadow: none; }
*/
body { font-family: 'Gotham SSm A', 'Gotham SSm B', sans-serif; background-color: white; font-size: 0.875em; }
@media screen and (max-width: 399px) { body { font-size: 0.75em; } }

body:after { display: none; }
@media screen and (max-width: 699px) { body:after { content: 'small'; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { body:after { content: 'medium'; } }
@media screen and (min-width: 1050px) { body:after { content: 'large'; } }

body > * > div { *zoom: 1; max-width: 1400px; margin-left: auto; margin-right: auto; margin: 0; position: relative; }
body > * > div:before, body > * > div:after { content: " "; display: table; }
body > * > div:after { clear: both; }

body > nav { position: fixed; top: 0; left: 0; width: 100%; z-index: 10; }
@media screen and (min-width: 700px) and (max-width: 1049px) { body > nav { padding-left: 2.5641%; } }
@media screen and (min-width: 700px) { body > nav ul { *zoom: 1; display: block; }
  body > nav ul:before, body > nav ul:after { content: " "; display: table; }
  body > nav ul:after { clear: both; } }
body > nav .background, body > nav ul, body > nav li, body > nav a { height: 55px; }
body > nav a { line-height: 55px; }
body > nav .background { -webkit-box-sizing: content-box; -moz-box-sizing: content-box; box-sizing: content-box; }
@media screen and (min-width: 1050px) { body > nav ul { height: 56px; } }
@media screen and (min-width: 1050px) { body > nav .background { display: block; float: left; margin-right: 2.5641%; width: 55.12821%; float: right; }
  body > nav .background:last-child { margin-right: 0; }
  body > nav.wide .background { display: block; float: left; margin-right: 2.5641%; width: 67.94872%; float: right; }
  body > nav.wide .background:last-child { margin-right: 0; } }
@media screen and (max-width: 699px) { body > nav .background { width: 55px; float: right; cursor: pointer; background-image: url("../../images/nav-button.svg"); background-size: 23px 17px; background-position: center; background-repeat: no-repeat; }
  .no-svg body > nav .background { background-image: url("../../images/nav-button@2x.png"); }
  body > nav ul { outline: none; display: none; position: absolute; top: 55px; height: auto !important; left: 0; right: 0; border: solid 1px #e6e6e6 !important; }
  .no-js body > nav .background:hover ul, body > nav .background.expanded ul { display: block; }
  body > nav li { display: block; background-color: white; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { body > nav ul { display: block; float: left; margin-right: 2.5641%; width: 80.76923%; float: right; }
  body > nav ul:last-child { margin-right: 0; }
  body > nav li { float: left; padding-right: 1em; }
  body > nav li + li { margin-left: 3%; } }
@media screen and (min-width: 1050px) { body > nav.wide ul { display: block; float: left; margin-right: 3.77358%; width: 81.13208%; float: right; }
  body > nav.wide ul:last-child { margin-right: 0; }
  body > nav li { float: left; padding-right: 1em; }
  body > nav li + li { margin-left: 4%; } }

@media screen and (max-width: 1049px) { body > header { margin-top: 55px; } }

@media screen and (min-width: 700px) and (max-width: 1049px) { body > header .pattern { *zoom: 1; display: block; }
  body > header .pattern:before, body > header .pattern:after { content: " "; display: table; }
  body > header .pattern:after { clear: both; }
  body > header .pattern > p { display: block; float: left; margin-right: 2.5641%; width: 35.89744%; }
  body > header .pattern > p:last-child { margin-right: 0; }
  body > header .pattern > h1 { display: block; float: left; margin-right: 2.5641%; width: 23.07692%; }
  body > header .pattern > h1:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { body > header .pattern { padding-top: 15.38462%; padding-bottom: 15.38462%; display: block; float: left; margin-right: 2.5641%; width: 29.48718%; position: relative; }
  body > header .pattern:last-child { margin-right: 0; }
  body > header .pattern > * { width: 200%; }
  body > header .pattern:after { content: ""; display: block; width: 100%; height: 17.3913%; position: absolute; bottom: 0; } }

@media screen and (min-width: 1050px) { body > header .main { margin-top: 15.38462%; padding-top: 4.3em; display: block; float: left; margin-right: 2.5641%; width: 55.12821%; float: right; }
  body > header .main:last-child { margin-right: 0; }
  body > header .main > * { display: block; float: left; margin-right: 4.65116%; width: 88.37209%; }
  body > header .main > *:last-child { margin-right: 0; } }

@media screen and (max-width: 1049px) { section.module + section.module { padding-top: 55px; } }
@media screen and (max-width: 699px) { .module header, .module .main { padding-left: 5.12821%; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .module header, .module .main { padding-left: 2.5641%; } }

@media screen and (max-width: 699px) { .module header { padding-top: 6.41026%; padding-bottom: 5.12821%; }
  .module header dl { *zoom: 1; display: block; margin-bottom: -2.5641%; }
  .module header dl:before, .module header dl:after { content: " "; display: table; }
  .module header dl:after { clear: both; }
  .module header dl dt { display: none; }
  .module header dl dd { display: block; float: left; margin-right: 2.5641%; width: 48.71795%; }
  .module header dl dd:last-child { margin-right: 0; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .module header { *zoom: 1; display: block; padding-top: 6.41026%; padding-bottom: 6.41026%; }
  .module header:before, .module header:after { content: " "; display: table; }
  .module header:after { clear: both; }
  .module header h2 { display: block; float: left; margin-right: 2.5641%; width: 16.66667%; }
  .module header h2:last-child { margin-right: 0; }
  .module header h1 { display: block; float: left; margin-right: 2.5641%; width: 61.53846%; }
  .module header h1:last-child { margin-right: 0; }
  .module header p { display: block; float: left; margin-right: 2.5641%; width: 55.12821%; margin-left: 19.23077%; }
  .module header p:last-child { margin-right: 0; }
  .module header dl { display: block; float: left; margin-right: 2.5641%; width: 16.66667%; float: right; margin-bottom: -2em; }
  .module header dl:last-child { margin-right: 0; }
  .module header dl dt { display: none; } }
@media screen and (min-width: 1050px) { .module header { display: block; float: left; margin-right: 2.5641%; width: 29.48718%; max-width: 412.82051px; }
  .module header:last-child { margin-right: 0; }
  .module header.sticky { position: fixed; top: 0; }
  .module header.sticky.sticky-bottom { position: absolute; top: auto; bottom: 0; }
  .module header > * { margin-left: 8.69565%; margin-right: 8.69565%; }
  .module header > *:first-child { margin-top: 55px; }
  .module header > *:last-child { margin-bottom: 43.47826%; } }
@media screen and (min-width: 1050px) { .module header dl { *zoom: 1; display: block; }
  .module header dl:before, .module header dl:after { content: " "; display: table; }
  .module header dl:after { clear: both; }
  .module header dl dt { display: block; float: left; margin-right: 8.69565%; width: 23.91304%; clear: both; }
  .module header dl dt:last-child { margin-right: 0; }
  .module header dl dd { display: block; float: left; margin-right: 8.69565%; width: 67.3913%; margin-right: 0; }
  .module header dl dd:last-child { margin-right: 0; } }

@media screen and (max-width: 1049px) { #sponsors.module header, footer.module header { padding-top: 5.12821%; padding-bottom: 5.12821%; } }
@media screen and (max-width: 699px) { .module .main { padding-top: 5.12821%; padding-bottom: 5.12821%; } }
@media screen and (max-width: 399px) { .module .main { padding-top: 7.69231%; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .module .main { clear: both; *zoom: 1; display: block; padding-top: 5.12821%; padding-bottom: 10.25641%; }
  .module .main:before, .module .main:after { content: " "; display: table; }
  .module .main:after { clear: both; } }
@media screen and (min-width: 1050px) { .module .main { display: block; float: left; margin-right: 2.5641%; width: 67.94872%; float: right; padding-top: 55px; padding-bottom: 15.38462%; }
  .module .main:last-child { margin-right: 0; } }

#sponsors.module .main { padding-bottom: 10.25641%; }

footer.module .main { padding-bottom: 2.5641%; }
@media screen and (max-width: 699px) { footer.module .main { padding-bottom: 5.12821%; } }

.events > *, .places > * { *zoom: 1; display: block; }
.events > :before, .places > :before, .events > :after, .places > :after { content: " "; display: table; }
.events > :after, .places > :after { clear: both; }

@media screen and (min-width: 700px) and (max-width: 1049px) { .main > h1 { margin-left: 19.23077%; } }
@media screen and (min-width: 1050px) { .main > h1 { margin-left: 18.86792%; } }

@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > p:first-child, .places > * > h2, .events > * > aside, .places > * > aside { display: block; float: left; margin-right: 2.5641%; width: 16.66667%; }
  .events > * > p:last-child:first-child, .places > * > h2:last-child, .events > * > aside:last-child, .places > * > aside:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .events > * > p:first-child, .places > * > h2, .events > * > aside, .places > * > aside { display: block; float: left; margin-right: 3.77358%; width: 15.09434%; }
  .events > * > p:last-child:first-child, .places > * > h2:last-child, .events > * > aside:last-child, .places > * > aside:last-child { margin-right: 0; } }

@media screen and (min-width: 700px) { .events > * > aside, .places > * > aside { float: right; } }

@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > h2, .places > * > h3 { display: block; float: left; margin-right: 2.5641%; width: 80.76923%; margin-right: 0; margin-left: 19.23077%; }
  .events > * > h2:last-child, .places > * > h3:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .events > * > h2, .places > * > h3 { display: block; float: left; margin-right: 3.77358%; width: 81.13208%; margin-right: 0; margin-left: 18.86792%; }
  .events > * > h2:last-child, .places > * > h3:last-child { margin-right: 0; } }

@media screen and (min-width: 700px) { .events > * > p:first-child + h2, .events.places > * > h2 + h2, .places.events > * > p:first-child + h3, .places > * > h2 + h3 { margin-left: 0; } }

@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > h3 { display: block; float: left; margin-right: 2.5641%; width: 80.76923%; margin-left: 19.23077%; margin-right: 0; }
  .events > * > h3:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .events > * > h3 { display: block; float: left; margin-right: 3.77358%; width: 81.13208%; margin-left: 18.86792%; margin-right: 0; }
  .events > * > h3:last-child { margin-right: 0; } }

@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > div, .places > * > div { display: block; float: left; margin-right: 2.5641%; width: 61.53846%; margin-left: 19.23077%; }
  .events > * > div:last-child, .places > * > div:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .events > * > div, .places > * > div { display: block; float: left; margin-right: 3.77358%; width: 62.26415%; margin-left: 18.86792%; }
  .events > * > div:last-child, .places > * > div:last-child { margin-right: 0; } }

.events > * > h4 { clear: both; }
@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > h4 { display: block; float: left; margin-right: 2.5641%; width: 61.53846%; margin-left: 19.23077%; }
  .events > * > h4:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .events > * > h4 { display: block; float: left; margin-right: 3.77358%; width: 62.26415%; margin-left: 18.86792%; }
  .events > * > h4:last-child { margin-right: 0; } }

.events > * > aside.photo { float: left; }

@media screen and (min-width: 700px) { .events > * > aside.photo + div.bio { margin-left: 0; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .events > * > aside.photo + div.bio { margin-right: 2.5641% !important; } }
@media screen and (min-width: 1050px) { .events > * > aside.photo + div.bio { margin-right: 3.77358% !important; } }

.sponsors { *zoom: 1; display: block; }
.sponsors:before, .sponsors:after { content: " "; display: table; }
.sponsors:after { clear: both; }
@media screen and (max-width: 699px) { .sponsors > * { display: block; float: left; margin-right: 2.5641%; width: 48.71795%; }
  .sponsors > *:last-child { margin-right: 0; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .sponsors > * { display: block; float: left; margin-right: 2.5641%; width: 42.30769%; }
  .sponsors > *:last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .sponsors > * { display: block; float: left; margin-right: 3.77358%; width: 43.39623%; }
  .sponsors > *:last-child { margin-right: 0; } }
.sponsors > *:nth-child(odd) { clear: left; }
@media screen and (max-width: 699px) { .sponsors > *:nth-child(even) { display: block; float: left; margin-right: 2.5641%; width: 48.71795%; margin-right: 0; }
  .sponsors > *:nth-child(even):last-child { margin-right: 0; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .sponsors > *:nth-child(even) { display: block; float: left; margin-right: 2.5641%; width: 55.12821%; margin-right: 0; }
  .sponsors > *:nth-child(even):last-child { margin-right: 0; } }
@media screen and (min-width: 1050px) { .sponsors > *:nth-child(even) { display: block; float: left; margin-right: 3.77358%; width: 52.83019%; margin-right: 0; }
  .sponsors > *:nth-child(even):last-child { margin-right: 0; } }
.sponsors > *.stray { width: 100%; }

body > footer .main .credits { clear: both; }
@media screen and (min-width: 700px) and (max-width: 1049px) { body > footer .main .contact { display: block; float: left; margin-right: 2.5641%; width: 16.66667%; }
  body > footer .main .contact:last-child { margin-right: 0; }
  body > footer .main .about { display: block; float: left; margin-right: 2.5641%; width: 35.89744%; }
  body > footer .main .about:last-child { margin-right: 0; }
  body > footer .main .previous { display: block; float: left; margin-right: 2.5641%; width: 42.30769%; margin-right: 0; float: right; }
  body > footer .main .previous:last-child { margin-right: 0; }
  body > footer .main .previous > * { display: block; float: left; margin-right: 6.06061%; width: 84.84848%; }
  body > footer .main .previous > *:last-child { margin-right: 0; }
  body > footer .main .credits { padding-top: 2.5641%; padding-right: 2.5641%; } }
@media screen and (min-width: 1050px) { body > footer .main .contact { display: block; float: left; margin-right: 3.77358%; width: 15.09434%; }
  body > footer .main .contact:last-child { margin-right: 0; }
  body > footer .main .about { display: block; float: left; margin-right: 3.77358%; width: 33.96226%; }
  body > footer .main .about:last-child { margin-right: 0; }
  body > footer .main .previous { display: block; float: left; margin-right: 3.77358%; width: 43.39623%; margin-right: 0; float: right; }
  body > footer .main .previous:last-child { margin-right: 0; }
  body > footer .main .previous > * { display: block; float: left; margin-right: 8.69565%; width: 78.26087%; }
  body > footer .main .previous > *:last-child { margin-right: 0; }
  body > footer .main .credits { padding-top: 3.77358%; padding-right: 3.77358%; } }

@media screen and (max-width: 1049px) { body > nav { background-color: white; border-bottom: solid 1px #e6e6e6; } }
body > nav .background { background-color: white; }
@media screen and (max-width: 1049px) { body > nav > div:before { content: ""; display: block; width: 16.66667%; position: absolute; height: 55px; background-image: url("../../images/logo-2013.svg"); background-repeat: no-repeat; background-size: auto 27px; background-position: center; opacity: 0.0; -webkit-transition: all 0.25s linear; -moz-transition: all 0.25s linear; transition: all 0.25s linear; }
  .no-svg body > nav > div:before { background-image: url("../../images/logo-2013@2x.png"); }
  body > nav.wide > div:before { opacity: 1.0; } }
@media screen and (max-width: 699px) { body > nav > div:before { float: none; width: 55px; position: absolute; left: 50%; margin-left: -27.5px; } }
body > nav ul { font-size: 0.8em; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; }
@media screen and (min-width: 1050px) { body > nav ul { border-bottom: solid 1px #e6e6e6; } }
@media screen and (max-width: 699px) { body > nav li { text-align: center; }
  body > nav li + li { border-top: solid 1px #e6e6e6; } }
body > nav a { display: block; text-decoration: none; outline: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: #999999; }
body > nav a:hover, body > nav a:focus { color: #4d4d4d; }
body > nav a.current { color: #b99a54; }
body > nav a.register { color: #666666; font-weight: 600; }
body > nav a.register:hover, body > nav a.register:focus { color: #1a1a1a; }

@media screen and (max-width: 1049px) { body > header > div { padding-top: 10.25641%; padding-bottom: 10.25641%; background-image: url("../../images/diamonds_bg.png"); background-position: top center; background-size: auto 100%; } }
@media only screen and (max-width: 1049px) and (-webkit-min-device-pixel-ratio: 1.3), only screen and (max-width: 1049px) and (min--moz-device-pixel-ratio: 1.3), only screen and (max-width: 1049px) and (-o-min-device-pixel-ratio: 1.3 / 1), only screen and (max-width: 1049px) and (min-resolution: 125dpi), only screen and (max-width: 1049px) and (min-resolution: 1.3dppx) { body > header > div { background-image: url("../../images/diamonds_bg@2x.png"); } }
@media screen and (min-width: 1050px) { body > header .pattern { background-image: url("../../images/diamonds_bg.png"); background-position: center right; background-size: 160% auto; }
  body > header .pattern:after { background-color: rgba(242, 242, 242, 0); background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(242, 242, 242, 0)), color-stop(100%, #f2f2f2)); background-image: -webkit-linear-gradient(rgba(242, 242, 242, 0), #f2f2f2); background-image: linear-gradient(rgba(242, 242, 242, 0), #f2f2f2); } }
@media only screen and (min-width: 1050px) and (-webkit-min-device-pixel-ratio: 1.3), only screen and (min-width: 1050px) and (min--moz-device-pixel-ratio: 1.3), only screen and (min-width: 1050px) and (-o-min-device-pixel-ratio: 1.3 / 1), only screen and (min-width: 1050px) and (min-resolution: 125dpi), only screen and (min-width: 1050px) and (min-resolution: 1.3dppx) { body > header .pattern { background-image: url("../../images/diamonds_bg@2x.png"); } }
body > header .pattern p { font-size: 0.85em; text-transform: uppercase; letter-spacing: 0.3em; word-spacing: 0.15em; color: #999999; text-align: center; }
@media screen and (min-width: 700px) and (max-width: 1049px) { body > header .pattern p { padding-top: 2.5em; text-align: left; }
  body > header .pattern p:first-child { text-align: right; } }
@media screen and (max-width: 699px) { body > header .pattern figure { margin-top: 5.12821%; margin-bottom: 5.12821%; } }
@media screen and (min-width: 1050px) { body > header .pattern figure { margin-top: 3.5em; margin-bottom: 3.5em; } }
body > header .pattern figure img { display: block; margin-left: auto; margin-right: auto; height: 5em; }
@media screen and (min-width: 1050px) { body > header .pattern figure img { height: 8em; } }
body > header .main { color: #b99a54; line-height: 1.9em; }
@media screen and (max-width: 1049px) { body > header .main { text-align: center; padding-bottom: 0; } }
@media screen and (max-width: 699px) { body > header .main { padding-left: 10.25641%; padding-right: 10.25641%; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { body > header .main { padding-left: 5.12821%; padding-right: 5.12821%; } }
body > header .main h2 { font-weight: 400; font-size: 1.1em; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 0.25em; margin-bottom: 0.25em; }
@media screen and (max-width: 1049px) { body > header .main h2 { line-height: 1.6; letter-spacing: 0.1em; max-width: 25em; margin-left: auto; margin-right: auto; margin-top: 3.5em; margin-bottom: 3em; } }
@media screen and (max-width: 699px) { body > header .main h2 { margin-top: 7.69231%; margin-bottom: 2.5641%; } }
body > header .main p { font-weight: 300; color: #999999; max-width: 40em; }
@media screen and (max-width: 1049px) { body > header .main p { margin-left: auto; margin-right: auto; max-width: 35em; } }

@media screen and (min-width: 1050px) { .module > div { background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQIHWP49OnTfwAJhgPWqxlLWwAAAABJRU5ErkJggg=="); background-size: 29.48718% 1px; background-position: top left; background-repeat: repeat-y; } }

@media screen and (max-width: 1049px) { .module header { border-top: solid 1px #e6e6e6; border-bottom: solid 1px #e6e6e6; background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQIHWP49OnTfwAJhgPWqxlLWwAAAABJRU5ErkJggg=="); } }
.module header h2, .module header h1 { text-transform: uppercase; text-rendering: optimizeLegibility; }
@media screen and (min-width: 1050px) { .module header h2 { border-top: solid 1px white; padding-top: 3em; }
  .module header.sticky h2 { border-top-color: transparent; } }
.module header h2 { font-size: 0.9em; font-weight: 400; color: #666666; letter-spacing: 0.1em; margin-bottom: 0.5em; -webkit-transition: border-top 0.25s linear; -moz-transition: border-top 0.25s linear; transition: border-top 0.25s linear; }
.module header h2:last-child { margin-bottom: 0; }
.module header h2 .hour, .module header h2 .slash { color: #bfbfbf; font-weight: 400; }
.module header h1 { font-size: 2.1em; letter-spacing: 0.05em; font-weight: 200; color: #b99a54; line-height: 1.4em; }
@media screen and (max-width: 699px) { .module header h1 { margin-top: -0.2em; margin-bottom: 0.6em; } }
@media screen and (min-width: 700px) and (max-width: 1049px) { .module header h1 { margin-top: -0.3em; margin-bottom: 0.7em; } }
@media screen and (min-width: 1050px) { .module header h1 { text-indent: -0.07em; } }
.module header p { font-weight: 300; color: gray; line-height: 1.8; }
@media screen and (max-width: 399px) { .module header p { line-height: 1.65; } }
@media screen and (max-width: 699px) { .module header p { max-width: 32em; } }
@media screen and (min-width: 1050px) { .module header p { max-width: 22em; margin-top: 3.3em; } }
.module header p + p { margin-top: 1.5em; }
.module header p .foursquare-button { float: left; margin-right: 0.5em; position: relative; margin-top: 0.2em; }
@media screen and (max-width: 399px) { .module header p .foursquare-button { margin-top: -0.15em; } }
.module header p a { font-weight: 500; text-decoration: none; color: #b99a54; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; }
.module header p a:hover, .module header p a:focus { color: #4d4d4d; }
@media screen and (max-width: 699px) { .module header h2, .module header h1, .module header p { padding-right: 5.12821%; }
  .module header h2 { margin-bottom: 2.5641%; }
  .module header dl { margin-top: 5.12821%; } }
.module header dl { font-size: 0.85em; font-weight: 400; line-height: 1.5; color: #8c8c8c; text-transform: uppercase; letter-spacing: 0.1em; word-spacing: 0.1em; }
@media screen and (min-width: 1050px) { .module header dl { margin-top: 4.70588em; } }
.module header dt, .module header dd { border-top: solid 1px transparent; }
@media screen and (max-width: 1049px) { .module header dt, .module header dd { padding-top: 1.2em; padding-bottom: 1.2em; } }
@media screen and (min-width: 1050px) { .module header dt, .module header dd { padding-top: 1.4em; padding-bottom: 2.4em; } }
.module header dt { border-top-color: #bfbfbf; font-weight: 500; color: #737373; }
.module header dd { border-top-color: #cccccc; }
@media screen and (max-width: 1049px) { .module header dd { padding-right: 1.5em; } }
.module header dd .hour { padding-left: 0.2em; }
.module header dd a { text-decoration: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: inherit; }
.module header dd a:after { content: "\00a0\2192"; }
.module header dd a:hover, .module header dd a:focus { color: #4d4d4d; }

.main > h1 { font-size: 1.1em; line-height: 1.3; color: gray; text-transform: uppercase; letter-spacing: 0.1em; word-spacing: 0.1em; padding-top: 2.3em; padding-bottom: 3.7em; border-top: solid 1px #e6e6e6; margin-top: 7.27273em; }
@media screen and (max-width: 699px) { .main > h1 { padding-top: 1.5em; padding-bottom: 3em; } }
@media screen and (max-width: 699px) { .main > h1 { margin-top: 6em; } }
.main > h1:first-child { margin-top: 0; }

@media screen and (max-width: 699px) { .events > * > p:first-child, .places > * > h2, .events > * > h2, .places > * > h3, .events > * > h3, .events > * > div p, .places > * > div p, .events > * > div .video, .places > * > div .video { padding-right: 5.12821%; } }
.events > * + *, .places > * + * { margin-top: 4em; }
@media screen and (max-width: 699px) { .events > * + *, .places > * + * { margin-top: 10.25641%; } }

.events > * > div + h2, .places > * > div + h3, .events > * > aside + h2, .places > * > aside + h3 { margin-top: 2.3em; }
@media screen and (max-width: 699px) { .events > * > div + h2, .places > * > div + h3, .events > * > aside + h2, .places > * > aside + h3 { margin-top: 5.89744%; } }

.events > * > p:first-child, .places > * > h2 { text-transform: uppercase; font-size: 0.9em; letter-spacing: 0.15em; color: #4d4d4d; border-top: solid 1px #b99a54; padding-top: 3em; }
.events > * > p:first-child .hour, .places > * > h2 .hour, .events > * > p:first-child .slash, .places > * > h2 .slash { color: #b3b3b3; font-weight: 300; }
.events > * > p:first-child .slash, .places > * > h2 .slash { padding-left: 0.3em; padding-right: 0.3em; }
@media screen and (max-width: 699px) { .events > * > p:first-child, .places > * > h2 { padding-top: 1.5em; padding-bottom: 1.5em; } }
@media screen and (min-width: 700px) { .events > * > p:first-child, .places > * > h2 { height: 4em; overflow: visible; }
  .events > * > p:first-child .slash, .places > * > h2 .slash { display: block; height: 1.5em; visibility: hidden; } }

.events > * > h2, .places > * > h3 { font-size: 1.1em; line-height: 1.3; text-transform: uppercase; letter-spacing: 0.1em; word-spacing: 0.1em; color: #b99a54; border-top: solid 1px #e6e6e6; padding-top: 2.3em; }
@media screen and (max-width: 699px) { .events > * > h2, .places > * > h3 { padding-top: 1.5em; padding-right: 5.12821%; } }

.events > * > h3 { font-size: 0.9em; line-height: 1.4; text-transform: uppercase; letter-spacing: 0.1em; word-spacing: 0.1em; color: #cccccc; margin-top: 0.5em; margin-bottom: 2em; }
@media screen and (max-width: 399px) { .events > * > h3 .br { display: block; height: 0; visibility: hidden; } }
@media screen and (max-width: 699px) { .events > * > h3 { margin-bottom: 1.66667em; padding-right: 5.12821%; } }
.events > * > h3 a { text-decoration: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: #a6a6a6; }
.events > * > h3 a:hover, .events > * > h3 a:focus { color: #666666; }
.events > * > h3 .location:before { content: "\21B3\00a0"; color: #b99a54; }

.events > * > h4 { font-size: 0.9em; line-height: 1.3; font-weight: 400; color: #999999; text-transform: uppercase; letter-spacing: 0.1em; word-spacing: 0.1em; margin-top: 3em; margin-bottom: 0.5em; }

.events > * > div, .places > * > div { line-height: 1.8; font-weight: 300; color: #666666; }
@media screen and (max-width: 399px) { .events > * > div, .places > * > div { line-height: 1.65; } }
.events > * > div .video, .places > * > div .video { margin-bottom: 1.8em; }
@media screen and (max-width: 699px) { .events > * > div .video, .places > * > div .video { max-width: 38em; } }
.events > * > div p, .places > * > div p { max-width: 38em; }
.events > * > div p + p, .places > * > div p + p { margin-top: 1em; }
.events > * > div a, .places > * > div a { font-weight: 400; text-decoration: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: #b99a54; }
.events > * > div a:hover, .places > * > div a:hover, .events > * > div a:focus, .places > * > div a:focus { color: black; }

.events > * > div.bio { color: #b3b3b3; }
@media screen and (min-width: 700px) { .events > * > div.bio { margin-bottom: 3em; } }

@media screen and (max-width: 699px) { .events > * > aside, .places > * > aside { margin-top: 1em; } }
.events > * > aside ul, .places > * > aside ul { line-height: 1.8em; }
@media screen and (max-width: 699px) { .events > * > aside ul, .places > * > aside ul { *zoom: 1; }
  .events > * > aside ul:before, .places > * > aside ul:before, .events > * > aside ul:after, .places > * > aside ul:after { content: " "; display: table; }
  .events > * > aside ul:after, .places > * > aside ul:after { clear: both; } }
.events > * > aside li, .places > * > aside li { font-size: 0.8em; text-transform: uppercase; }
@media screen and (min-width: 700px) { .events > * > aside li, .places > * > aside li { line-height: 2.25em; } }
@media screen and (max-width: 699px) { .events > * > aside li, .places > * > aside li { float: left; }
  .events > * > aside li + li:before, .places > * > aside li + li:before { content: "/"; color: #cccccc; padding-left: 0.6em; padding-right: 0.6em; } }
.events > * > aside a, .places > * > aside a { text-decoration: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: #cccccc; }
@media screen and (min-width: 700px) { .events > * > aside a, .places > * > aside a { display: block; } }
.events > * > aside a:hover, .places > * > aside a:hover, .events > * > aside a:focus, .places > * > aside a:focus { color: gray; }
@media screen and (max-width: 699px) { .events > * > aside a, .places > * > aside a { color: #999999; }
  .events > * > aside a:hover, .places > * > aside a:hover, .events > * > aside a:focus, .places > * > aside a:focus { color: #4d4d4d; } }
.events > * > aside figure img, .places > * > aside figure img { display: block; max-width: 100%; }

@media screen and (max-width: 699px) { .events > * > aside.photo { display: none; } }
@media screen and (min-width: 700px) { .events > * > aside.photo { margin-top: -1.5em; } }

/* Sponsors */
.sponsors > * { border-top: solid 1px #e6e6e6; padding-top: 2em; padding-bottom: 4em; }
@media screen and (max-width: 699px) { .sponsors > * { padding-top: 1.5em; padding-bottom: 2em; } }
.sponsors > *.stray { padding-bottom: 0; }
.sponsors a { height: 4em; display: block; opacity: 0.5; }
@media screen and (max-width: 699px) { .sponsors a { height: 3em; } }
.sponsors a:hover, .sponsors a:focus { opacity: 1.0; }
.sponsors img { max-height: 100%; }

/* Footer */
body > footer .main > * { line-height: 1.65; font-weight: 300; color: gray; border-top: solid 1px #e6e6e6; }
@media screen and (max-width: 699px) { body > footer .main > * + * { margin-top: 5.12821%; } }
body > footer .main .credits { border-top: none; }
body > footer .main h3 { text-transform: uppercase; font-size: 0.9em; line-height: 1; letter-spacing: 0.15em; font-weight: 400; padding-top: 3em; padding-bottom: 3em; color: #666666; }
@media screen and (max-width: 699px) { body > footer .main h3 { padding-top: 1.5em; padding-bottom: 1.5em; } }
body > footer .main .credits { font-size: 0.85em; color: #b3b3b3; }
body > footer .main .credits a { color: #999999; }
body > footer .main .credits strong { text-transform: uppercase; font-weight: 500; margin-right: 1em; }
body > footer .main a { text-decoration: none; -webkit-transition: color 0.1s linear; -moz-transition: color 0.1s linear; transition: color 0.1s linear; color: #b99a54; }
body > footer .main a:hover, body > footer .main a:focus { color: black; }
body > footer .main .previous h4 { display: inline-block; width: 3em; font-weight: 400; }
body > footer .main .previous a { display: inline-block; margin-left: 1.2em; }

.events > *.non-speaker > p:first-child { border-top-color: #cccccc; }
.events > *.non-speaker > h2 { color: #b3b3b3; }

.places > * > h3 { margin-bottom: 0.5em; }
.places > * > aside { margin-right: 0; }
