@charset "UTF-8";
.speakers {
  padding: 3rem; }
  .speakers ul {
    display: flex;
    flex-wrap: wrap; }
    .speakers ul li {
      width: 100%;
      text-align: center;
      padding-top: 2.5rem; }
      @media screen and (min-width: 641px) {
        .speakers ul li {
          width: 50%;
          text-align: left; } }
      .speakers ul li div {
        vertical-align: top;
        display: inline-block; }
      .speakers ul li .speaker-info {
        font-family: tablet-gothic, sans-serif;
        font-style: normal;
        font-weight: 200;
        line-height: 130%;
        width: 100%; }
        @media screen and (min-width: 641px) {
          .speakers ul li .speaker-info {
            width: 40%;
            padding: 0 1.5rem; } }
        .speakers ul li .speaker-info h3 {
          color: #fd4d5b;
          font-weight: bold;
          font-size: 1.3rem; }
        .speakers ul li .speaker-info p {
          font-size: 0.8rem;
          padding-top: 0.7rem; }
      .speakers ul li img {
        border-radius: 50%;
        width: 50%;
        border: 5px solid #febabb; }
        @media screen and (min-width: 641px) {
          .speakers ul li img {
            width: 33%; } }
        .speakers ul li img:hover {
          border-top-color: #ff4a57;
          border-right-color: #ff4a57;
          border-bottom-color: #ff4a57;
          border-left-color: #ff4a57;
          transition: border-color 0.55s ease-in; }

.sponsors {
  padding: 3rem; }
  .sponsors li {
    display: inline;
    margin: 0.5rem; }
    .sponsors li a {
      text-decoration: none; }
    .sponsors li img {
      width: 150px;
      margin: 1rem; }
      @media screen and (min-width: 1020px) {
        .sponsors li img {
          width: 200px; } }
  .sponsors .premiere img {
    width: 150px;
    margin: 1rem; }
    @media screen and (min-width: 1020px) {
      .sponsors .premiere img {
        width: 200px; } }

#schedule {
  margin: 0 auto;
  width: 80%; }
  #schedule .sessions {
    vertical-align: middle;
    font-family: tablet-gothic, sans-serif;
    color: #000;
    padding: 1rem;
    font-size: 1rem;
    text-align: left; }
    #schedule .sessions .session {
      margin-bottom: 3rem; }
    #schedule .sessions.times {
      offset-rotate: 20.1deg;
      transform: rotate(-10deg); }
    #schedule .sessions h2 {
      font-size: 1.5rem; }
    #schedule .sessions h3 {
      font-weight: bold;
      color: black; }
    #schedule .sessions .presenter {
      font-style: italic;
      font-weight: 300;
      font-size: 0.75rem;
      margin-bottom: 1rem;
      margin-top: 0.2rem; }
    #schedule .sessions .abstract {
      font-weight: 300;
      font-size: 0.9rem;
      margin-bottom: 3rem;
      line-height: 1.25; }
      #schedule .sessions .abstract p {
        padding-bottom: 1rem; }
      #schedule .sessions .abstract ul {
        margin-left: 0.5rem; }
        #schedule .sessions .abstract ul li {
          padding-top: 1rem; }

.description {
  display: none;
  margin: 0 auto;
  width: 80%;
  padding: 3rem;
  line-height: 1.5;
  text-align: justify;
  font-family: tablet-gothic, sans-serif;
  font-style: normal;
  font-weight: 200; }
  .description a {
    color: #fd4d5b; }
  @media screen and (min-width: 1020px) {
    .description {
      display: block; } }
  @media screen and (min-width: 641px) and (max-width: 1019px) {
    .description {
      font-size: 0.7rem; } }
  @media screen and (min-width: 1400px) {
    .description {
      font-size: 1rem; } }
  @media screen and (min-width: 2560px) {
    .description {
      font-size: 2rem; } }

.content h2 {
  font-family: tablet-gothic, sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 2.5rem;
  padding: 1.5rem;
  display: inline-block;
  position: relative; }
  .content h2 .fascinator {
    position: absolute;
    left: 79%;
    bottom: -17px;
    z-index: -1;
    float: right;
    display: inline; }
    @media screen and (max-width: 640px) {
      .content h2 .fascinator {
        display: none; } }
    .content h2 .fascinator img {
      height: 80px; }
  @media screen and (max-width: 640px) {
    .content h2 {
      font-size: 1.5rem; } }

.title {
  width: 75%;
  font-family: monospace;
  text-align: center;
  margin: 0 auto;
  font-size: 1rem; }
  @media screen and (min-width: 641px) {
    .title {
      width: 60%; }
      .title h2 {
        font-size: 1.8rem; }
      .title h3 {
        font-size: 1.3rem; } }
  .title h2 {
    padding: 1.5rem 0;
    font-family: monospace; }
  .title h3 {
    font-weight: bold; }
  .title .logo {
    width: 75%; }

.meta {
  padding: 3rem;
  font-family: monospace; }
  .meta img {
    padding-top: 1rem;
    width: 60px; }

button {
  background-color: #fd4d5b;
  color: white;
  padding: 0.75rem;
  border: 0;
  margin: 0.75rem;
  font-size: 1.5rem;
  font-family: monospace;
  text-transform: uppercase;
  cursor: pointer; }
  @media screen and (min-width: 1020px) {
    button {
      margin-top: 2rem; } }

.content {
  padding: 1rem;
  text-align: center; }
  @media screen and (min-width: 1020px) {
    .content {
      width: 60%;
      margin: 0 auto; } }

footer {
  background-color: #fd4d5b;
  color: white;
  padding: 2.5rem;
  text-align: center; }
  footer a {
    color: white;
    text-decoration: none;
    font-family: monospace;
    font-size: 1.5rem;
    line-height: 1.5; }
  footer li {
    padding: 1rem; }
    @media screen and (min-width: 1020px) {
      footer li {
        display: inline-block; } }

.grassy {
  background-image: url("../images/elements/grass.png");
  background-size: 50%;
  background-repeat: no-repeat;
  background-position: calc(0%) calc(100%); }

nav {
  background-color: #fd4d5b;
  color: white;
  padding: 2rem;
  text-align: center;
  margin-bottom: 2rem; }
  nav a {
    color: white;
    text-decoration: none;
    font-family: monospace;
    font-size: 1.5rem;
    line-height: 1.5; }
  nav li {
    padding: 1rem;
    display: inline-block; }
    nav li:before {
      content: "⬆ "; }

.force-visible {
  display: inherit; }
