/*hcmc font family for ui elements*/
@font-face {
  font-family: 'ui-font';
  font-style: normal;
  font-weight: normal;
  src: local("ui-font"), url("../fonts/ui.woff2") format("woff2"); }

/*
	

    font-family: 'Roboto', sans-serif;

    font-family: 'Roboto Condensed', sans-serif;

*/
html, body, section, nav, article, aside, h1, h2, h3, h4, h5, h6, hgroup, header, footer, address, p, hr, pre, blockquote, ol, ul, li, dl, dt, dd, figure, figcaption, div, table, caption, form, fieldset {
  vertical-align: baseline;
  margin: 0;
  padding: 0; }

* {
  /* apply a natural box layout model to all elements; see http://www.paulirish.com/2012/box-sizing-border-box-ftw/ */
  box-sizing: border-box; }

*:before, *:after {
  /* apply a natural box layout model to all elements; see http://www.paulirish.com/2012/box-sizing-border-box-ftw/ */
  box-sizing: border-box; }

html {
  font-size: 1em; }

body {
  line-height: 1.45;
  color: #333; }

#contentContainer > section#content {
  margin-left: auto;
  margin-right: auto;
  max-width: 38rem; }

h1 {
  font-size: 1.75rem;
  /*28*/ }

h2 {
  font-size: 1.5rem;
  /*24*/ }

h3 {
  font-size: 1.3125rem;
  /*21*/ }

h4 {
  font-size: 1.125rem;
  /*18*/ }

h5 {
  font-size: 1rem; }

h6 {
  font-size: 1rem; }

p {
  font-size: 1rem;
  /*16*/ }

li {
  font-size: 1rem;
  /*16*/ }

blockquote {
  font-size: 1rem;
  /*16*/ }

@media screen and (min-width: 60em) {
  h2 {
    /*default*/ }
  h3 {
    /*default*/ }
  h4 {
    /*default*/ }
  p {
    font-size: 1.125rem;
    /*18*/ }
  li {
    font-size: 1.125rem; }
  blockquote {
    font-size: 1.125rem; } }

/*p:first-of-type {
	font-family: helvetica;
}*/
#content p, #content ul, #content ol, #schedule p, #schedule ul, #schedule ol {
  font-family: "Fira Sans", sans-serif, sans-serif;
  font-weight: 300;
  padding: 0 1em 0 1rem; }
  @media only screen and (min-width: 768px) {
    #content p, #content ul, #content ol, #schedule p, #schedule ul, #schedule ol {
      font-size: 1.125rem;
      padding: 0; } }

#content p, #schedule p {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.45rem;
  line-height: 1.4;
  -webkit-hyphens: auto;
      -ms-hyphens: auto;
          hyphens: auto;
  -webkit-hyphenate-limit-before: 3;
  -webkit-hyphenate-limit-after: 2;
  hyphenate-limit-lines: 2;
  hyphenate-limit-chars: 6 3 2;
  hyphenate-limit-zone: 8%; }

#content a, #content a:visited, #schedule a, #schedule a:visited {
  color: #006793;
  text-decoration: none;
  border-bottom: 1px solid #d1d1d1;
  word-wrap: break-word;
  overflow-wrap: break-word; }

#content h1, #content h2, #content h3, #content h4, #content h5, #schedule h1, #schedule h2, #schedule h3, #schedule h4, #schedule h5 {
  font-weight: 400;
  font-family: "Fira Sans", sans-serif, sans-serif;
  padding: 0 1rem 0 1rem; }
  @media only screen and (min-width: 768px) {
    #content h1, #content h2, #content h3, #content h4, #content h5, #schedule h1, #schedule h2, #schedule h3, #schedule h4, #schedule h5 {
      padding: 0; } }

#content h1, #schedule h1 {
  font-weight: 400;
  margin-bottom: 1.45rem;
  text-align: center; }

#content h2, #schedule h2 {
  font-weight: 400;
  line-height: 1.2;
  margin-top: 1.38em;
  margin-bottom: .55em; }

#content h3, #schedule h3 {
  font-weight: 400; }

#content h4, #schedule h4 {
  font-weight: 400;
  margin-bottom: .725rem; }

#content li, #schedule li {
  margin-bottom: .725rem;
  list-style-position: inside;
  text-indent: -1rem; }

#content b, #schedule b {
  font-weight: bold; }

#content blockquote, #schedule blockquote {
  font-family: "Fira Sans", sans-serif, serif;
  background-color: #e6e6e6;
  padding: .75rem; }

#content ul, #content ol, #schedule ul, #schedule ol {
  list-style-position: inside;
  margin-left: 1.45rem; }

#content li ul, #schedule li ul {
  margin-top: .5rem;
  margin-bottom: .5rem;
  padding-left: 1rem; }

.plain {
  list-style-type: none;
  margin-left: 0; }

small, .font_small {
  font-size: 0.889em; }

.smaller {
  font-size: 80%; }

.centered {
  text-align: center; }

@supports (text-decoration-skip-ink: auto) {
  section a, section a:visited {
    text-decoration-skip-ink: auto;
    -webkit-text-decoration: underline solid #d1d1d1;
            text-decoration: underline solid #d1d1d1;
    border-bottom: 0;
    color: #006793; } }

img.body {
  width: 225px;
  max-width: 225px;
  height: auto;
  margin-bottom: .5rem;
  margin-top: .5rem;
  float: none;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  @media only screen and (min-width: 960px) {
    img.body {
      float: left;
      margin: .5rem 1rem; } }

figure {
  margin: 1em;
  max-width: 38rem;
  text-align: center; }

figure img {
  width: 15.625rem;
  height: auto; }

.halfWidth {
  width: 7.81rem; }

figure.circle {
  box-sizing: content-box;
  -webkit-shape-outside: circle() padding-box;
          shape-outside: circle() padding-box;
  width: 100%;
  text-align: center; }

figure.circle img {
  width: 10em;
  height: 10em; }

figcaption {
  font-family: "Fira Sans", sans-serif;
  font-weight: 300;
  font-size: .75rem;
  font-style: italic;
  color: #828282; }

@media only screen and (min-width: 51.25rem) {
  figure {
    text-align: left;
    max-width: none; }
  figure.circle {
    width: 10em;
    position: relative;
    padding: 3rem; }
  figure.left {
    float: left;
    margin-left: -6.625rem; }
  figure.leftHalfMargin {
    float: left;
    margin-left: -3.3125rem; }
  figure.right {
    float: right;
    margin-right: -6.625rem; } }

@media only screen and (min-width: 73.25rem) {
  figure {
    margin-top: 0; }
  figure.left {
    margin-left: -17.625rem; }
  figure.leftHalfMargin {
    margin-left: -8.8125rem; }
  figure.right {
    margin-right: -17.625rem; } }

#schedule {
  width: 100%;
  max-width: 67.5rem;
  padding-left: 16px;
  padding-right: 16px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.5rem; }
  @media only screen and (min-width: 600px) {
    #schedule {
      padding-left: 1rem;
      padding-right: 1rem; } }
  #schedule table {
    width: 100%;
    margin: 0 auto;
    overflow-x: auto;
    border-collapse: collapse;
    box-sizing: border-box;
    background-color: #fff;
    border-collapse: collapse;
    border-radius: 5px;
    margin-bottom: 1.45rem; }
    @media only screen and (max-width: 600px) {
      #schedule table {
        border: 0;
        background-color: transparent;
        box-shadow: none; } }
  #schedule th {
    background-color: #fff;
    color: #545454;
    padding: .3rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
    border: 1px solid #c8c8c8;
    font-weight: bold;
    vertical-align: middle;
    font-size: 1rem;
    font-family: "Cousine", monospace;
    /*text-shadow: 0px 1px 1px rgba(0,0,0,25);*/ }
  @media only screen and (max-width: 600px) {
    #schedule thead {
      border: none;
      clip: rect(0 0 0 0);
      height: 1px;
      margin: -1px;
      overflow: hidden;
      padding: 0;
      position: absolute;
      width: 1px; } }
  #schedule thead td {
    vertical-align: middle;
    text-align: center;
    font-weight: bold;
    background-color: #F5F5F5; }
  #schedule th:hover {
    background-color: gainsboro; }
  #schedule .dob, #schedule .doe {
    min-width: 7rem; }
  #schedule th.sort-header::after {
    content: "\23f6";
    font-family: 'ui-font';
    position: relative;
    right: .5rem; }
  #schedule table a:link,
  #schedule table a:visited {
    color: #3068bb;
    text-decoration: none; }
  #schedule td {
    color: #4b4b4b;
    padding: .4rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
    border: 1px solid #c8c8c8;
    font-family: "Fira Sans", sans-serif, sans-serif;
    vertical-align: top; }
    @media only screen and (max-width: 600px) {
      #schedule td {
        display: block;
        text-align: right;
        vertical-align: middle;
        padding: .6rem;
        min-height: 2.75rem;
        border-bottom: 1px solid #c8c8c8;
        border-top: 0; } }
  #schedule td:before {
    /*
		* aria-label has no advantage, it won't be read inside a table
		content: attr(aria-label);
		*/ }
    @media only screen and (max-width: 600px) {
      #schedule td:before {
        content: attr(data-label);
        float: left;
        font-weight: bold;
        text-transform: uppercase;
        margin-right: 1em; } }
  @media only screen and (max-width: 600px) {
    #schedule td:first-child {
      border-top: 1px solid #c8c8c8; } }
  #schedule tr {
    background-color: transparent;
    -webkit-transition: background-color .2s ease;
    -o-transition: background-color .2s ease;
    transition: background-color .2s ease; }
    @media only screen and (max-width: 600px) {
      #schedule tr {
        border-bottom: 1px solid #ddd;
        display: block;
        text-align: right;
        margin-bottom: 2rem;
        box-shadow: 0 0 3px rgba(0, 0, 0, 0.1);
        background-color: #f4f4f4; } }
  @media only screen and (min-width: 600px) {
    #schedule tbody tr:hover {
      background-color: gainsboro; } }
  #schedule th.sort-header::-moz-selection {
    background: transparent; }
  #schedule th.sort-header::selection {
    background: transparent; }
  #schedule th.sort-header {
    cursor: pointer; }
  #schedule table th.sort-header:after {
    content: '';
    float: right;
    margin-top: 7px;
    border-width: 0 4px 4px;
    border-style: solid;
    border-color: #404040 transparent;
    visibility: hidden; }
  #schedule table th.sort-header:hover:after {
    visibility: visible; }
  #schedule table th.sort-up:after,
  #schedule table th.sort-down:after,
  #schedule table th.sort-down:hover:after {
    visibility: visible;
    opacity: 0.4; }
  #schedule table th.sort-up:after {
    border-bottom: none;
    border-width: 4px 4px 0; }
  #schedule .topLink {
    position: fixed;
    top: 70px;
    left: 0;
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    -webkit-transform-origin: top left;
            transform-origin: top left;
    text-align: center;
    font-family: 'Roboto', serif;
    color: red;
    margin-top: auto;
    font-size: 75%;
    z-index: 10; }
  #schedule .topLink a {
    display: block;
    padding: 2px 10px;
    background-color: #8F8F8F;
    color: #fff;
    text-decoration: none;
    text-align: center;
    -webkit-transition: all .5s ease-in-out;
    -o-transition: all .5s ease-in-out;
    transition: all .5s ease-in-out;
    font-family: "Fira Sans", sans-serif, sans-serif; }
  #schedule div#schedule h4 {
    text-align: center; }
  #schedule strong {
    font-weight: bold; }
  #schedule strong.chair {
    display: block; }
  #schedule .scheduleTitle {
    font-size: 1rem;
    margin-bottom: 0.725rem;
    display: inline-block; }
    @media only screen and (min-width: 60em) {
      #schedule .scheduleTitle {
        font-size: 1.125rem; } }

.splash {
  width: 100%;
  height: auto;
  background-image: url(../images/splashBg.jpg);
  background-size: cover;
  overflow: auto;
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  -webkit-box-flex: 1;
          flex: 1;
  -webkit-box-align: center;
          align-items: center;
  position: relative; }
  @media only screen and (min-height: 450px) and (min-width: 600px) {
    .splash {
      height: 100vh; } }

.splashCredit {
  text-align: center;
  font-family: "Fira Sans", sans-serif;
  color: white;
  font-size: 50%;
  font-style: italic;
  margin-top: auto; }
  @media only screen and (min-width: 600px) {
    .splashCredit {
      top: 375px; } }

.siteTitleText {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden; }

.orgLogo {
  width: 100px;
  height: auto;
  margin-top: 10px; }
  @media only screen and (min-width: 600px) {
    .orgLogo {
      margin-top: 30px; } }

#capiFlex {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  width: 100%;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-flex: 1;
          flex-grow: 1; }

#headingTopBoxOuter {
  width: 50rem;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-color: rgba(174, 217, 229, 0.3); }
  @media only screen and (min-width: 768px) {
    #headingTopBoxOuter {
      background-color: rgba(123, 181, 207, 0.33); } }

h1#siteTitleText {
  font-family: "Fira Sans", sans-serif;
  color: rgba(255, 255, 255, 0.95);
  margin-top: 30px;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  font-size: 2rem;
  margin-bottom: 0;
  font-weight: 700;
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  -webkit-box-pack: center;
          justify-content: center;
  width: 35rem;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 3rem;
  padding: 1rem 0;
  text-align: center;
  line-height: 1.4; }
  @media only screen and (min-width: 600px) {
    h1#siteTitleText {
      font-size: 3.5rem;
      margin-top: 0; } }
  @media only screen and (min-width: 900px) {
    h1#siteTitleText {
      font-size: 3.5rem; } }
  @media only screen and (min-width: 1000px) {
    h1#siteTitleText {
      font-size: 3.5rem; } }
  @media only screen and (min-width: 1100px) {
    h1#siteTitleText {
      font-size: 3.5rem; } }

.mainLine {
  line-height: .8;
  font-weight: 900; }

.subLine {
  font-size: 1rem;
  line-height: 1.1;
  font-weight: 400; }
  @media only screen and (min-width: 600px) {
    .subLine {
      font-size: 1.5rem; } }

.subLineJapanese {
  font-size: .9rem; }
  @media only screen and (min-width: 600px) {
    .subLineJapanese {
      font-size: 1.4rem; } }

#headingTopBoxOuter span:nth-of-type(4) {
  margin-top: 1rem; }

#headingTopBoxOuter span:nth-of-type(5) {
  margin-bottom: 0rem; }

#monstersOuterBox {
  width: 100%;
  -webkit-box-flex: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column; }

#monstersInnerBox {
  width: 50rem;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-color: rgba(174, 217, 229, 0.3);
  display: -webkit-box;
  display: flex;
  -webkit-box-flex: 1;
          flex: 1;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column; }

#monsterSanctum {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
          flex-direction: row;
  -webkit-box-pack: center;
          justify-content: center;
  padding-top: 1rem;
  -webkit-box-flex: 0;
          flex-grow: 0; }
  @media only screen and (min-height: 800px) and (min-width: 900px) {
    #monsterSanctum {
      -webkit-box-pack: center;
              justify-content: center; } }

span.desktopMonsters {
  width: 145px;
  height: auto;
  display: none;
  -webkit-transition: all .3s ease-in-out;
  -o-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out; }
  @media only screen and (min-height: 800px) and (min-width: 900px) {
    span.desktopMonsters {
      display: inline; } }

.desktopMonsters:hover {
  -webkit-transform: rotate(5deg);
          transform: rotate(5deg);
  cursor: pointer; }

span.desktopMonsters {
  margin-left: 0;
  width: 145px;
  text-align: center; }
  @media only screen and (min-height: 800px) and (min-width: 900px) {
    span.desktopMonsters {
      margin-left: 1rem; } }

#monsterSanctum a:link, #monsterSanctum a:visited {
  color: transparent;
  -webkit-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
  font-family: "Fira Sans", sans-serif;
  text-decoration: none;
  text-shadow: 0 1px 1px transparent; }

#monsterSanctum a:hover {
  color: #fff;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3); }

#monsterSanctum span:first-of-type {
  margin-left: 0; }

#monsterSanctum span:last-of-type {
  margin-left: 0; }

span.mobileMonsters {
  width: 275px;
  height: auto;
  display: inline; }
  @media only screen and (min-height: 800px) and (min-width: 900px) {
    span.mobileMonsters {
      display: none; } }

span.mobileMonsters img,
span.desktopMonsters img {
  width: 100%;
  height: auto; }

#whereWhenContainer {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  -webkit-box-align: center;
          align-items: center;
  margin-top: 1rem;
  padding-bottom: 1rem;
  width: 20rem;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 1rem;
  background-color: rgba(122, 180, 207, 0.3); }
  @media only screen and (min-width: 600px) {
    #whereWhenContainer {
      background-color: rgba(122, 180, 207, 0.6);
      border-radius: 5px; } }

#whereWhenContainer span:nth-of-type(2) {
  margin-bottom: .5rem; }

span.splashWhereWhenLarge {
  color: rgba(255, 255, 255, 0.95);
  font-family: "Fira Sans", sans-serif;
  font-size: 1.1rem;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  text-align: center;
  line-height: 1.2;
  font-weight: normal; }
  @media only screen and (min-width: 768px) {
    span.splashWhereWhenLarge {
      font-size: 1.1rem; } }

span.splashWhereWhenSmall {
  color: rgba(255, 255, 255, 0.95);
  font-family: "Fira Sans", sans-serif;
  font-size: 1.1rem;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
  text-align: center;
  line-height: 1.2;
  font-weight: normal; }
  @media only screen and (min-width: 768px) {
    span.splashWhereWhenSmall {
      font-size: 1.1rem; } }

.splashNav {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
          flex-direction: row;
  -webkit-box-pack: center;
          justify-content: center;
  -webkit-box-flex: initial;
          flex: initial;
  background-color: #7bb5cf;
  margin-top: 0;
  display: block;
  width: 100%; }

.splashNav ul {
  display: none; }
  @media only screen and (min-width: 768px) {
    .splashNav ul {
      list-style-position: inside;
      list-style-type: none;
      margin: 2.125rem 0 2.125rem 0;
      padding: 0;
      display: -webkit-box;
      display: flex;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
              flex-direction: row;
      -webkit-box-pack: center;
              justify-content: center;
      flex-wrap: wrap;
      -webkit-box-align: start;
              align-items: flex-start; } }
  @media only screen and (min-width: 768px) and (min-width: 768px) {
    .splashNav ul {
      margin: .5rem 1rem .5rem 1rem; } }
  @media only screen and (min-width: 768px) {
      .splashNav ul li {
        background-image: url(../images/transparent.png);
        background-size: 0 2px;
        background-repeat: no-repeat;
        background-position: bottom center;
        margin-bottom: 0;
        -webkit-transition: all .2s ease-in-out;
        -o-transition: all .2s ease-in-out;
        transition: all .2s ease-in-out; }
      .splashNav ul li:hover {
        background-image: url(../images/white.png);
        background-size: 90% 2px;
        background-repeat: repeat-x;
        background-position: bottom center;
        background-repeat: no-repeat; }
      .splashNav ul li:first-of-type {
        margin-left: 0; } }

.splashNav a, .splashNav a:visited {
  text-decoration: none;
  color: #fff;
  font-weight: 400;
  font-family: "Fira Sans", sans-serif;
  text-transform: uppercase;
  font-size: 1rem;
  letter-spacing: 1px;
  padding: .4rem;
  text-shadow: 0px 1px 1px rgba(0, 0, 0, 0.1); }
  @media only screen and (min-width: 900px) {
    .splashNav a, .splashNav a:visited {
      letter-spacing: 2px;
      font-size: 1.125rem; } }

.splashNav a:hover {
  text-decoration: none; }

.sponsorsContainerSplash {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  bottom: 0;
  max-height: 500px;
  background-color: white;
  margin-top: auto;
  padding: 1rem .25rem; }

.fullWidth {
  width: 100%;
  text-align: center;
  margin-bottom: 1rem; }

.fullWidth .logo {
  width: 100%;
  max-width: 420px;
  height: auto;
  margin-bottom: .725rem; }

.sshrc {
  width: 90%;
  max-width: 600px;
  height: auto;
  display: none; }
  @media only screen and (min-width: 600px) {
    .sshrc {
      display: inline; } }

.sshrcStacked {
  width: 90%;
  max-width: 300px;
  height: auto;
  display: inline; }
  @media only screen and (min-width: 600px) {
    .sshrcStacked {
      display: none; } }

.japanFoundation {
  width: 100px;
  height: auto;
  margin-left: 0; }
  @media only screen and (min-width: 600px) {
    .japanFoundation {
      margin-left: .5rem; } }

#spirits:target ~ div li.spirits {
  color: red; }

#animals:target ~ div li.animals {
  color: red; }

main.internal {
  position: relative;
  overflow: auto;
  width: 100vw;
  height: 100vh;
  -webkit-overflow-scrolling: touch;
  background-color: #fff; }

main.internal section#content {
  width: 100%;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto; }

.ribbon {
  width: 100%;
  height: 15px;
  background-color: #e8e8e8;
  margin-bottom: 1.5rem; }

section.participant {
  overflow: auto;
  padding: 0 1rem; }

section#content section.participant:nth-child(odd) {
  background-color: #efefef; }

section#content section.participant:last-of-type {
  margin-bottom: 1.45rem; }

header {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  z-index: 10;
  padding: .25rem .5rem;
  background-color: transparent; }
  @media only screen and (min-width: 600px) {
    header {
      padding: .5rem;
      -webkit-box-pack: center;
              justify-content: center;
      margin-left: auto;
      margin-right: auto; } }

header .logoContainer a, header .logoContainer a:visited {
  text-decoration: none;
  padding: 0; }

.internalMonsters {
  width: 125px;
  height: auto;
  padding: .25rem 0; }
  @media only screen and (min-width: 600px) {
    .internalMonsters {
      width: 175px; } }

.internalTitle {
  text-align: center;
  font-family: "Fira Sans", sans-serif;
  font-weight: bold;
  line-height: 1;
  font-size: 1.125rem;
  padding: 0 .25rem;
  color: #575757;
  margin-bottom: .3rem; }
  @media only screen and (min-width: 600px) {
    .internalTitle {
      font-size: 1.5rem; } }

.subHeaderInternal {
  text-align: center;
  font-family: "Fira Sans", sans-serif;
  font-size: 1rem;
  padding: 0 .25rem;
  color: #575757; }
  @media only screen and (min-width: 600px) {
    .subHeaderInternal {
      font-size: 1rem; } }

.navInternal {
  background-color: #7bb5cf;
  margin-bottom: 1rem; }
  @media only screen and (min-width: 768px) {
    .navInternal {
      position: static;
      top: 0;
      display: -webkit-box;
      display: flex;
      flex-wrap: wrap;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
              flex-direction: row;
      -webkit-box-pack: center;
              justify-content: center;
      -webkit-box-align: center;
              align-items: center;
      margin-bottom: 1.5rem;
      margin-left: auto;
      margin-right: auto;
      width: 100%;
      background-color: transparent; } }

.navInternal ul {
  display: none; }
  @media only screen and (min-width: 768px) {
    .navInternal ul {
      list-style-type: none;
      margin: .5rem 1rem .5rem 1rem;
      display: -webkit-box;
      display: flex;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
              flex-direction: row;
      -webkit-box-pack: center;
              justify-content: center;
      flex-wrap: wrap;
      -webkit-box-align: center;
              align-items: center;
      padding: 0; }
      .navInternal ul li {
        background-image: url(../images/transparent.png);
        background-size: 0 2px;
        background-repeat: no-repeat;
        background-position: bottom center;
        margin-bottom: 0;
        -webkit-transition: all .2s ease-in-out;
        -o-transition: all .2s ease-in-out;
        transition: all .2s ease-in-out; }
      .navInternal ul li:last-of-type {
        margin-right: 0; }
      .navInternal ul li.active {
        background-image: url(../images/grey.png);
        background-size: 100% 2px;
        background-repeat: repeat-x;
        background-position: bottom center; }
      .navInternal ul li.active:hover {
        background-size: 100% 2px; }
      .navInternal ul li:hover {
        background-image: url(../images/grey.png);
        background-size: 90% 2px;
        background-repeat: repeat-x;
        background-position: bottom center;
        background-repeat: no-repeat; } }

.navInternal a, navInternal a:visited {
  text-decoration: none;
  color: #3f3f3f;
  font-weight: 300;
  font-family: "Fira Sans", sans-serif;
  text-transform: uppercase;
  font-size: 1rem;
  padding: .4rem;
  letter-spacing: 1px; }
  @media only screen and (min-width: 900px) {
    .navInternal a, navInternal a:visited {
      font-size: 1.125rem;
      letter-spacing: 2px; } }
  @media only screen and (min-width: 1100px) {
    .navInternal a, navInternal a:visited {
      font-size: 1.125rem; } }

.navInternal a:hover {
  text-decoration: none; }

#contentContainer.internal > section {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.5rem; }
  @media only screen and (min-width: 600px) {
    #contentContainer.internal > section {
      padding: 0;
      margin-bottom: 3rem; } }

#contentContainer > section::before {
  content: "";
  background-color: #e6e6e6;
  width: 100%;
  height: 1px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  margin-bottom: 1rem; }
  @media only screen and (min-width: 600px) {
    #contentContainer > section::before {
      margin-bottom: 2rem; } }

#contentContainer > section::after {
  content: "";
  background-color: #e6e6e6;
  width: 40%;
  height: 1px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  margin-bottom: 2rem;
  position: relative;
  top: 2rem; }

.greenConference {
  background-color: #79b5d7;
  padding: 1rem;
  color: #fff;
  font-size: 1rem; }

.registrationLink {
  width: 10rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center; }

#content a.register:link,
#content a.register:visited {
  color: #fff;
  background-color: #2880b2;
  display: block;
  text-decoration: none;
  padding: 1rem;
  font-family: "Fira Sans", sans-serif, sans-serif;
  -webkit-transition: all .3s ease-in-out;
  -o-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
  border-bottom: none; }

#content a.register:hover {
  background-color: #215f83; }

#content h2.border {
  border-top: 1px solid #f0f0f0;
  padding-top: .725rem;
  font-size: 1.3125rem;
  margin-top: 0; }

#content h4.abstractActivate {
  font-size: 1rem;
  cursor: pointer; }

#content h4.abstractActivate:hover {
  text-decoration: underline; }

.bio, .abstract {
  display: none; }

#content h2.bioActivate {
  cursor: pointer;
  color: #ce7666;
  margin-bottom: 0; }

h2.bioActivate:hover {
  text-decoration: underline; }

h2.bioOpened + div.bio {
  display: block; }

h4.abstractOpened + div.abstract {
  display: block; }

.slideOutMenu {
  position: fixed;
  top: 0;
  bottom: 0;
  width: 256px;
  min-height: 100vh;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  z-index: 0;
  display: none;
  background-color: #4b819c; }

.slideout-menu-left {
  left: 0; }

.slideout-menu-right {
  right: 0; }

.slideout-panel {
  position: relative;
  z-index: 1;
  background-color: #FFF;
  /* A background-color is required */
  min-height: 100vh; }

.slideout-open,
.slideout-open body,
.slideout-open .slideout-panel {
  overflow: hidden; }

.slideout-open .slideout-menu {
  display: block; }

.panel:before {
  content: '';
  display: block;
  background-color: transparent;
  -webkit-transition: background-color 0.5s ease-in-out;
  -o-transition: background-color 0.5s ease-in-out;
  transition: background-color 0.5s ease-in-out; }

.panel-open:before {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 99; }

.slideOutMenu ul {
  list-style-type: none;
  font-family: "Roboto Condensed", sans-serif;
  color: #fff;
  margin-left: 30px;
  margin-top: 2rem; }
  .slideOutMenu ul li {
    padding-left: 7px;
    border-left: 3px solid transparent; }
  .slideOutMenu ul li.active {
    border-left: 3px solid #fff; }

.slideOutMenu a, slideOutMenu a:visited {
  text-decoration: none;
  color: #fff;
  font-size: 1.4rem; }

.toggleButtonMobile {
  font-family: 'ui-font';
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  background-color: transparent;
  font-size: 2.5rem;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 10px; }
  @media only screen and (min-width: 768px) {
    .toggleButtonMobile {
      display: none; } }

.internal .toggleButtonMobile {
  font-size: 30px;
  width: 40px;
  height: 40px;
  display: table-cell;
  vertical-align: middle;
  border-radius: 5px;
  background-color: #fff;
  top: 5px;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.2);
  padding: 0; }
  @media only screen and (min-width: 768px) {
    .internal .toggleButtonMobile {
      display: none; } }

.splash .toggleButtonMobile {
  color: #fff;
  font-size: 4rem;
  padding: 0; }
  @media only screen and (min-width: 768px) {
    .splash .toggleButtonMobile {
      display: none; } }
