/* open-sans-regular - latin */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: local("Open Sans Regular"), local("OpenSans-Regular"), url("../fonts/open-sans-v15-latin-regular.woff2") format("woff2"), url("../fonts/open-sans-v15-latin-regular.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* open-sans-600 - latin */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 600;
  src: local("Open Sans SemiBold"), local("OpenSans-SemiBold"), url("../fonts/open-sans-v15-latin-600.woff2") format("woff2"), url("../fonts/open-sans-v15-latin-600.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* open-sans-800 - latin */
@font-face {
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 800;
  src: local("Open Sans ExtraBold"), local("OpenSans-ExtraBold"), url("../fonts/open-sans-v15-latin-800.woff2") format("woff2"), url("../fonts/open-sans-v15-latin-800.woff") format("woff");
  /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
div#tmpl-wrapper > div {
  display: none;
  visibility: hidden;
}

.disable-select {
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
  /* supported by Chrome and Opera */
}

.upsidedown-logo {
  transform: scaleY(-1) scaleX(-1);
  width: 192px;
  height: 192px;
  margin: auto auto;
}

body {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: calc(var(--real-vh, 1vh) * 100);
  font-family: "Open Sans";
}
body div.root {
  min-height: calc(var(--real-vh, 1vh) * 100);
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  align-self: center;
  margin: 0;
  padding: 0;
  background-color: #fff5e4;
}
body div.root div#top-panel, body div.root div#bottom-panel {
  display: flex;
  flex-grow: 1;
  flex-shrink: 2;
  flex-direction: row;
  justify-content: flex-start;
  width: 100%;
  background-color: #ded6b7;
  color: #4c4646;
}
body div.root div#top-panel span.logo-text, body div.root div#bottom-panel span.logo-text {
  letter-spacing: 0px;
  font-weight: 800;
  font-size: 3vh;
  margin: 0.2rem 0 0.2rem 0.4rem;
}
body div.root div#top-panel button, body div.root div#bottom-panel button {
  flex-grow: 0;
  flex-shrink: 1;
}
body div.root div#bottom-panel {
  display: flex;
  justify-content: space-between;
  padding: 1vh 1vw 1vh 1vw;
}
body div.root div#bottom-panel .left-buttons {
  display: flex;
  flex-grow: 0;
  justify-content: flex-start;
  align-items: center;
}
body div.root div#bottom-panel .right-buttons {
  display: flex;
  flex-grow: 1;
  justify-content: flex-end;
  align-items: center;
}
body div.root div#middle-panel {
  display: flex;
  flex-grow: 98;
  flex-shrink: 1;
  flex-direction: column;
  color: #4c4646;
}
body div.root div#middle-panel .center-content {
  display: flex;
  justify-content: center;
}
body div.root div.button-well {
  background-color: #ded6b7;
}

.smalltext {
  font-size: 0.8em;
}

.center-text {
  text-align: center;
}

span.label {
  font-weight: 800;
}

span.numeric {
  text-align: right;
  justify-self: flex-end;
}

.readable-text {
  max-width: 40em;
}

div.padded-paragraph {
  box-sizing: border-box;
  margin: 0 1.5em 1.5em 1.5em;
  padding: 0;
  flex-grow: 1;
}
div.padded-paragraph.lead-paragraph {
  margin: 1.5em 1.5em 1.5em 1.5em;
}

div.instructions {
  display: flex;
  flex-grow: 1;
  flex-direction: column;
  justify-content: end;
  align-items: center;
}
div.instructions span.instructions {
  color: #707070;
  font-size: 0.9em;
  margin: 3em;
}

div.heading {
  display: flex;
  justify-content: space-around;
  margin: 10vh 0 2vh 0;
  font-size: 3vh;
  font-weight: 800;
}

.ad-banner-narrow {
  width: 320px;
  height: 50px;
  display: inline-block;
  margin: 0 auto;
}

.ad-banner-box {
  width: 336px;
  height: 280px;
  display: inline-block;
  margin: 0 auto;
}

.ad-banner-wide {
  width: 728px;
  height: 90px;
  display: inline-block;
  margin: 0 auto;
}

/* Config */
:root {
  --sk-size: 3vh;
  --sk-color: #4c4646;
}

/* Utility class for centering */
.sk-center {
  margin: auto;
}

/*  Plane

      <div class="sk-plane"></div>
 */
.sk-plane {
  width: var(--sk-size);
  height: var(--sk-size);
  background-color: var(--sk-color);
  animation: sk-plane 1.2s infinite ease-in-out;
}

@keyframes sk-plane {
  0% {
    transform: perspective(120px) rotateX(0deg) rotateY(0deg);
  }
  50% {
    transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
  }
  100% {
    transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
  }
}
/*  Chase

      <div class="sk-chase">
        <div class="sk-chase-dot"></div>
        <div class="sk-chase-dot"></div>
        <div class="sk-chase-dot"></div>
        <div class="sk-chase-dot"></div>
        <div class="sk-chase-dot"></div>
        <div class="sk-chase-dot"></div>
      </div>
 */
.sk-chase {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
  animation: sk-chase 2.5s infinite linear both;
}

.sk-chase-dot {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  animation: sk-chase-dot 2s infinite ease-in-out both;
}

.sk-chase-dot:before {
  content: "";
  display: block;
  width: 25%;
  height: 25%;
  background-color: var(--sk-color);
  border-radius: 100%;
  animation: sk-chase-dot-before 2s infinite ease-in-out both;
}

.sk-chase-dot:nth-child(1) {
  animation-delay: -1.1s;
}

.sk-chase-dot:nth-child(2) {
  animation-delay: -1s;
}

.sk-chase-dot:nth-child(3) {
  animation-delay: -0.9s;
}

.sk-chase-dot:nth-child(4) {
  animation-delay: -0.8s;
}

.sk-chase-dot:nth-child(5) {
  animation-delay: -0.7s;
}

.sk-chase-dot:nth-child(6) {
  animation-delay: -0.6s;
}

.sk-chase-dot:nth-child(1):before {
  animation-delay: -1.1s;
}

.sk-chase-dot:nth-child(2):before {
  animation-delay: -1s;
}

.sk-chase-dot:nth-child(3):before {
  animation-delay: -0.9s;
}

.sk-chase-dot:nth-child(4):before {
  animation-delay: -0.8s;
}

.sk-chase-dot:nth-child(5):before {
  animation-delay: -0.7s;
}

.sk-chase-dot:nth-child(6):before {
  animation-delay: -0.6s;
}

@keyframes sk-chase {
  100% {
    transform: rotate(360deg);
  }
}
@keyframes sk-chase-dot {
  80%, 100% {
    transform: rotate(360deg);
  }
}
@keyframes sk-chase-dot-before {
  50% {
    transform: scale(0.4);
  }
  100%, 0% {
    transform: scale(1);
  }
}
/*  Bounce

      <div class="sk-bounce">
        <div class="sk-bounce-dot"></div>
        <div class="sk-bounce-dot"></div>
      </div>
  */
.sk-bounce {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
}

.sk-bounce-dot {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: var(--sk-color);
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;
  animation: sk-bounce 2s infinite cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

.sk-bounce-dot:nth-child(2) {
  animation-delay: -1s;
}

@keyframes sk-bounce {
  0%, 100% {
    transform: scale(0);
  }
  45%, 55% {
    transform: scale(1);
  }
}
/*  Wave

      <div class="sk-wave">
        <div class="sk-wave-rect"></div>
        <div class="sk-wave-rect"></div>
        <div class="sk-wave-rect"></div>
        <div class="sk-wave-rect"></div>
        <div class="sk-wave-rect"></div>
      </div>
 */
.sk-wave {
  width: var(--sk-size);
  height: var(--sk-size);
  display: flex;
  justify-content: space-between;
}

.sk-wave-rect {
  background-color: var(--sk-color);
  height: 100%;
  width: 15%;
  animation: sk-wave 1.2s infinite ease-in-out;
}

.sk-wave-rect:nth-child(1) {
  animation-delay: -1.2s;
}

.sk-wave-rect:nth-child(2) {
  animation-delay: -1.1s;
}

.sk-wave-rect:nth-child(3) {
  animation-delay: -1s;
}

.sk-wave-rect:nth-child(4) {
  animation-delay: -0.9s;
}

.sk-wave-rect:nth-child(5) {
  animation-delay: -0.8s;
}

@keyframes sk-wave {
  0%, 40%, 100% {
    transform: scaleY(0.4);
  }
  20% {
    transform: scaleY(1);
  }
}
/*  Pulse

      <div class="sk-pulse"></div>
 */
.sk-pulse {
  width: var(--sk-size);
  height: var(--sk-size);
  background-color: var(--sk-color);
  border-radius: 100%;
  animation: sk-pulse 1.2s infinite cubic-bezier(0.455, 0.03, 0.515, 0.955);
}

@keyframes sk-pulse {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
    opacity: 0;
  }
}
/*  Flow

      <div class="sk-flow">
        <div class="sk-flow-dot"></div>
        <div class="sk-flow-dot"></div>
        <div class="sk-flow-dot"></div>
      </div>
 */
.sk-flow {
  width: calc(var(--sk-size) * 1.3);
  height: calc(var(--sk-size) * 1.3);
  display: flex;
  justify-content: space-between;
}

.sk-flow-dot {
  width: 25%;
  height: 25%;
  background-color: var(--sk-color);
  border-radius: 50%;
  animation: sk-flow 1.4s cubic-bezier(0.455, 0.03, 0.515, 0.955) 0s infinite both;
}

.sk-flow-dot:nth-child(1) {
  animation-delay: -0.3s;
}

.sk-flow-dot:nth-child(2) {
  animation-delay: -0.15s;
}

@keyframes sk-flow {
  0%, 80%, 100% {
    transform: scale(0.3);
  }
  40% {
    transform: scale(1);
  }
}
/*  Swing

      <div class="sk-swing">
        <div class="sk-swing-dot"></div>
        <div class="sk-swing-dot"></div>
      </div>
 */
.sk-swing {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
  animation: sk-swing 1.8s infinite linear;
}

.sk-swing-dot {
  width: 45%;
  height: 45%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  background-color: var(--sk-color);
  border-radius: 100%;
  animation: sk-swing-dot 2s infinite ease-in-out;
}

.sk-swing-dot:nth-child(2) {
  top: auto;
  bottom: 0;
  animation-delay: -1s;
}

@keyframes sk-swing {
  100% {
    transform: rotate(360deg);
  }
}
@keyframes sk-swing-dot {
  0%, 100% {
    transform: scale(0.2);
  }
  50% {
    transform: scale(1);
  }
}
/*  Circle

      <div class="sk-circle">
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
        <div class="sk-circle-dot"></div>
      </div>
 */
.sk-circle {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
}

.sk-circle-dot {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.sk-circle-dot:before {
  content: "";
  display: block;
  width: 15%;
  height: 15%;
  background-color: var(--sk-color);
  border-radius: 100%;
  animation: sk-circle 1.2s infinite ease-in-out both;
}

.sk-circle-dot:nth-child(1) {
  transform: rotate(30deg);
}

.sk-circle-dot:nth-child(2) {
  transform: rotate(60deg);
}

.sk-circle-dot:nth-child(3) {
  transform: rotate(90deg);
}

.sk-circle-dot:nth-child(4) {
  transform: rotate(120deg);
}

.sk-circle-dot:nth-child(5) {
  transform: rotate(150deg);
}

.sk-circle-dot:nth-child(6) {
  transform: rotate(180deg);
}

.sk-circle-dot:nth-child(7) {
  transform: rotate(210deg);
}

.sk-circle-dot:nth-child(8) {
  transform: rotate(240deg);
}

.sk-circle-dot:nth-child(9) {
  transform: rotate(270deg);
}

.sk-circle-dot:nth-child(10) {
  transform: rotate(300deg);
}

.sk-circle-dot:nth-child(11) {
  transform: rotate(330deg);
}

.sk-circle-dot:nth-child(1):before {
  animation-delay: -1.1s;
}

.sk-circle-dot:nth-child(2):before {
  animation-delay: -1s;
}

.sk-circle-dot:nth-child(3):before {
  animation-delay: -0.9s;
}

.sk-circle-dot:nth-child(4):before {
  animation-delay: -0.8s;
}

.sk-circle-dot:nth-child(5):before {
  animation-delay: -0.7s;
}

.sk-circle-dot:nth-child(6):before {
  animation-delay: -0.6s;
}

.sk-circle-dot:nth-child(7):before {
  animation-delay: -0.5s;
}

.sk-circle-dot:nth-child(8):before {
  animation-delay: -0.4s;
}

.sk-circle-dot:nth-child(9):before {
  animation-delay: -0.3s;
}

.sk-circle-dot:nth-child(10):before {
  animation-delay: -0.2s;
}

.sk-circle-dot:nth-child(11):before {
  animation-delay: -0.1s;
}

@keyframes sk-circle {
  0%, 80%, 100% {
    transform: scale(0);
  }
  40% {
    transform: scale(1);
  }
}
/*  Circle Fade

      <div class="sk-circle-fade">
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
        <div class="sk-circle-fade-dot"></div>
      </div>
 */
.sk-circle-fade {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
}

.sk-circle-fade-dot {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.sk-circle-fade-dot:before {
  content: "";
  display: block;
  width: 15%;
  height: 15%;
  background-color: var(--sk-color);
  border-radius: 100%;
  animation: sk-circle-fade 1.2s infinite ease-in-out both;
}

.sk-circle-fade-dot:nth-child(1) {
  transform: rotate(30deg);
}

.sk-circle-fade-dot:nth-child(2) {
  transform: rotate(60deg);
}

.sk-circle-fade-dot:nth-child(3) {
  transform: rotate(90deg);
}

.sk-circle-fade-dot:nth-child(4) {
  transform: rotate(120deg);
}

.sk-circle-fade-dot:nth-child(5) {
  transform: rotate(150deg);
}

.sk-circle-fade-dot:nth-child(6) {
  transform: rotate(180deg);
}

.sk-circle-fade-dot:nth-child(7) {
  transform: rotate(210deg);
}

.sk-circle-fade-dot:nth-child(8) {
  transform: rotate(240deg);
}

.sk-circle-fade-dot:nth-child(9) {
  transform: rotate(270deg);
}

.sk-circle-fade-dot:nth-child(10) {
  transform: rotate(300deg);
}

.sk-circle-fade-dot:nth-child(11) {
  transform: rotate(330deg);
}

.sk-circle-fade-dot:nth-child(1):before {
  animation-delay: -1.1s;
}

.sk-circle-fade-dot:nth-child(2):before {
  animation-delay: -1s;
}

.sk-circle-fade-dot:nth-child(3):before {
  animation-delay: -0.9s;
}

.sk-circle-fade-dot:nth-child(4):before {
  animation-delay: -0.8s;
}

.sk-circle-fade-dot:nth-child(5):before {
  animation-delay: -0.7s;
}

.sk-circle-fade-dot:nth-child(6):before {
  animation-delay: -0.6s;
}

.sk-circle-fade-dot:nth-child(7):before {
  animation-delay: -0.5s;
}

.sk-circle-fade-dot:nth-child(8):before {
  animation-delay: -0.4s;
}

.sk-circle-fade-dot:nth-child(9):before {
  animation-delay: -0.3s;
}

.sk-circle-fade-dot:nth-child(10):before {
  animation-delay: -0.2s;
}

.sk-circle-fade-dot:nth-child(11):before {
  animation-delay: -0.1s;
}

@keyframes sk-circle-fade {
  0%, 39%, 100% {
    opacity: 0;
    transform: scale(0.6);
  }
  40% {
    opacity: 1;
    transform: scale(1);
  }
}
/*  Grid

    <div class="sk-grid">
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
      <div class="sk-grid-cube"></div>
    </div>
 */
.sk-grid {
  width: var(--sk-size);
  height: var(--sk-size);
  /* Cube positions
   * 1 2 3
   * 4 5 6
   * 7 8 9
   */
}

.sk-grid-cube {
  width: 33.33%;
  height: 33.33%;
  background-color: var(--sk-color);
  float: left;
  animation: sk-grid 1.3s infinite ease-in-out;
}

.sk-grid-cube:nth-child(1) {
  animation-delay: 0.2s;
}

.sk-grid-cube:nth-child(2) {
  animation-delay: 0.3s;
}

.sk-grid-cube:nth-child(3) {
  animation-delay: 0.4s;
}

.sk-grid-cube:nth-child(4) {
  animation-delay: 0.1s;
}

.sk-grid-cube:nth-child(5) {
  animation-delay: 0.2s;
}

.sk-grid-cube:nth-child(6) {
  animation-delay: 0.3s;
}

.sk-grid-cube:nth-child(7) {
  animation-delay: 0s;
}

.sk-grid-cube:nth-child(8) {
  animation-delay: 0.1s;
}

.sk-grid-cube:nth-child(9) {
  animation-delay: 0.2s;
}

@keyframes sk-grid {
  0%, 70%, 100% {
    transform: scale3D(1, 1, 1);
  }
  35% {
    transform: scale3D(0, 0, 1);
  }
}
/*  Fold

      <div class="sk-fold">
        <div class="sk-fold-cube"></div>
        <div class="sk-fold-cube"></div>
        <div class="sk-fold-cube"></div>
        <div class="sk-fold-cube"></div>
      </div>
 */
.sk-fold {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
  transform: rotateZ(45deg);
}

.sk-fold-cube {
  float: left;
  width: 50%;
  height: 50%;
  position: relative;
  transform: scale(1.1);
}

.sk-fold-cube:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--sk-color);
  animation: sk-fold 2.4s infinite linear both;
  transform-origin: 100% 100%;
}

.sk-fold-cube:nth-child(2) {
  transform: scale(1.1) rotateZ(90deg);
}

.sk-fold-cube:nth-child(4) {
  transform: scale(1.1) rotateZ(180deg);
}

.sk-fold-cube:nth-child(3) {
  transform: scale(1.1) rotateZ(270deg);
}

.sk-fold-cube:nth-child(2):before {
  animation-delay: 0.3s;
}

.sk-fold-cube:nth-child(4):before {
  animation-delay: 0.6s;
}

.sk-fold-cube:nth-child(3):before {
  animation-delay: 0.9s;
}

@keyframes sk-fold {
  0%, 10% {
    transform: perspective(140px) rotateX(-180deg);
    opacity: 0;
  }
  25%, 75% {
    transform: perspective(140px) rotateX(0deg);
    opacity: 1;
  }
  90%, 100% {
    transform: perspective(140px) rotateY(180deg);
    opacity: 0;
  }
}
/*  Wander

      <div class="sk-wander">
        <div class="sk-wander-cube"></div>
        <div class="sk-wander-cube"></div>
        <div class="sk-wander-cube"></div>
        <div class="sk-wander-cube"></div>
      </div>
 */
.sk-wander {
  width: var(--sk-size);
  height: var(--sk-size);
  position: relative;
}

.sk-wander-cube {
  background-color: var(--sk-color);
  width: 20%;
  height: 20%;
  position: absolute;
  top: 0;
  left: 0;
  --sk-wander-distance: calc(var(--sk-size) * 0.75);
  animation: sk-wander 2s ease-in-out -2s infinite both;
}

.sk-wander-cube:nth-child(2) {
  animation-delay: -0.5s;
}

.sk-wander-cube:nth-child(3) {
  animation-delay: -1s;
}

@keyframes sk-wander {
  0% {
    transform: rotate(0deg);
  }
  25% {
    transform: translateX(var(--sk-wander-distance)) rotate(-90deg) scale(0.6);
  }
  50% {
    /* Make FF rotate in the right direction */
    transform: translateX(var(--sk-wander-distance)) translateY(var(--sk-wander-distance)) rotate(-179deg);
  }
  50.1% {
    transform: translateX(var(--sk-wander-distance)) translateY(var(--sk-wander-distance)) rotate(-180deg);
  }
  75% {
    transform: translateX(0) translateY(var(--sk-wander-distance)) rotate(-270deg) scale(0.6);
  }
  100% {
    transform: rotate(-360deg);
  }
}
div#explainer-view.root div#middle-panel div#explainer-text {
  align-self: center;
}
div#explainer-view.root div#middle-panel div#splash-wrapper {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: flex-start;
  width: 100%;
  box-sizing: border-box;
  padding: 0;
  user-select: none;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper {
  display: inline-block;
  margin: 0 auto;
  padding: 0 0 2rem 0;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper {
  position: relative;
  flex-grow: 1;
  margin: 2rem auto;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper div.logo-talk-bubble {
  background-color: #FF6336;
  color: #4c4646;
  border-radius: 8px;
  width: 10rem;
  height: 4rem;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper div.logo-talk-bubble:before {
  position: absolute;
  content: "";
  right: 100%;
  margin-right: -0.7rem;
  margin-bottom: 0.5rem;
  bottom: 0px;
  width: 0;
  height: 0;
  border-top: 14px solid transparent;
  border-right: 30px solid #FF6336;
  border-bottom: 14px solid transparent;
  -webkit-transform: rotate(330deg);
  -moz-transform: rotate(330deg);
  -ms-transform: rotate(330deg);
  -o-transform: rotate(330deg);
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper div.logo-talk-bubble div.logo-word {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  font-size: 2.5rem;
  font-weight: bold;
  text-align: center;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(1) {
  margin-right: 4rem;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(1) div.logo-talk-bubble {
  animation: pulse 800ms;
  animation-delay: 0ms;
  animation-iteration-count: 1;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(2) {
  margin-left: 4rem;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(2) div.logo-talk-bubble {
  animation: pulse 800ms;
  animation-delay: 500ms;
  animation-iteration-count: 1;
  transform: scaleX(-1);
  background-color: #4c4646;
  color: #FF6336;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(2) div.logo-talk-bubble:before {
  border-right-color: #4c4646;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(2) div.logo-talk-bubble div.logo-word {
  transform: scaleX(-1);
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(3) {
  margin-right: 4rem;
}
div#explainer-view.root div#middle-panel div#splash-wrapper div#splash-inner-wrapper div.logo-talk-bubble-wrapper:nth-child(3) div.logo-talk-bubble {
  animation: pulse 800ms;
  animation-delay: 1000ms;
  animation-iteration-count: 1;
}

div {
  box-sizing: border-box;
}

body .flex-form {
  display: flex;
  flex-direction: column;
}
body .flex-form .form-row {
  display: flex;
  flex-direction: row;
  margin: 0.25em 0 0.25em 0;
}
body .flex-form .form-col {
  display: flex;
  flex-direction: row;
  flex-grow: 1;
  align-items: center;
}
body .flex-form .form-col.half-width {
  min-width: 50%;
  max-width: 50%;
  padding: 0;
  margin: 0;
}
body .flex-form .form-col.quarter-width {
  min-width: 25%;
  max-width: 25%;
  padding: 0;
  margin: 0;
}
body .flex-form .form-col.golden-width32 {
  min-width: 32%;
  max-width: 32%;
  padding: 0;
  margin: 0;
}
body .flex-form .form-col.golden-width68 {
  min-width: 68%;
  max-width: 68%;
  padding: 0;
  margin: 0;
}
body form.team-form {
  height: 50vh;
  font-size: 16px;
  margin: auto auto;
}
body form.team-form label {
  font-weight: bold;
  color: #4c4646;
  margin: 0 1em 0 0;
}
body form.team-form input[type=text] {
  background-color: #ddd5d4;
  color: #4c4646;
  border: 1px solid #555555;
  font-size: 16px;
  padding: 2px;
  width: 98%;
  height: 1.05em;
}
body form.team-form input[type=text]:focus {
  background-color: #ded6b7;
  border: 1px solid #FF6336;
}
body form.team-form div.team-form {
  display: block;
  margin: auto auto;
}
body form.team-form input#round-duration-value {
  width: auto;
  max-width: 4em;
}
body div#game.root div#top-panel div#round-banner {
  font-size: 3vh;
  font-weight: 800;
}
body div#game.root div#bottom-panel span#countdown-timer {
  color: #4c4646;
  font-weight: bold;
  font-size: 3vh;
}
body div#game.root div#middle-panel span#category-title {
  font-size: 3vh;
  font-weight: 600;
  margin: 1em 1em 0 1em;
}
body div#game.root div#middle-panel div#thing-list ol {
  margin: 3vh 0 0 3vw;
  list-style: none;
  counter-reset: li;
}
body div#game.root div#middle-panel div#thing-list ol li {
  counter-increment: li;
  margin-top: 0.75vh;
  margin-bottom: 0;
}
body div#game.root div#middle-panel div#thing-list ol li::before {
  font-size: 3vh;
  color: #4c4646;
  content: counter(li) ".";
  text-align: right;
  display: inline-block;
  width: 4vh;
  margin-left: -4vh;
  margin-right: 2vh;
}
body div#game.root div#middle-panel div#thing-list div.name-item {
  font-size: 3vh;
  width: 85%;
  display: inline-flex;
  cursor: pointer;
}
body div#game.root div#middle-panel div#thing-list div.name-item div.ni-status {
  display: inline-block;
}
body div#game.root div#middle-panel div#thing-list div.name-item div.ni-status span {
  display: inline;
}
body div#game.root div#middle-panel div#thing-list div.name-item div.ni-status button {
  font-size: inherit;
  background-color: transparent;
  border-width: 0;
}
body div#game.root div#middle-panel div#thing-list div.name-item[data-status=pending] button, body div#game.root div#middle-panel div#thing-list div.name-item[data-status=pending] span.ni-name {
  color: #b0b0b0;
  font-weight: bold;
}
body div#game.root div#middle-panel div#thing-list div.name-item[data-status=guessed] button, body div#game.root div#middle-panel div#thing-list div.name-item[data-status=guessed] span.ni-name {
  color: #FF6336;
  font-weight: bold;
}
body div#game.root div#middle-panel div#thing-list.disallow-toggle div.name-item[data-status=pending] button, body div#game.root div#middle-panel div#thing-list.disallow-toggle div.name-item[data-status=pending] span.ni-name {
  text-decoration: line-through;
}

/*
 * Copyright (c) 2012 Thibaut Courouble
 * http://www.cssflow.com
 *
 * Licensed under the MIT License:
 * http://www.opensource.org/licenses/mit-license.php
 *
 * View the Sass/SCSS source at:
 * http://www.cssflow.com/snippets/multi-colored-push-buttons/demo/scss
 *
 * Original PSD by Marian Mraz: http://goo.gl/9Il5d
 */
.button {
  display: inline-block;
  position: relative;
  height: 33px;
  line-height: 33px;
  padding: 0 15px;
  font-size: 15px;
  color: white;
  text-decoration: none;
  text-shadow: 0 -1px rgba(0, 0, 0, 0.3);
  border: 2px solid;
  border-radius: 7px;
  outline: 0;
  -webkit-box-shadow: 0 2px 1px rgba(0, 0, 0, 0.25);
  box-shadow: 0 2px 1px rgba(0, 0, 0, 0.25);
}

.button:before, .button:after {
  content: "";
  position: absolute;
}

.button:before {
  top: -5px;
  bottom: -5px;
  left: -5px;
  right: -5px;
  z-index: -1;
  border-radius: 9px;
}

.button:after {
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-bottom: 0;
  border-radius: 7px;
}

.column.red {
  background: #d04022;
}

.button.primary {
  background: #FF6336;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #FF6336 0%, #ce4c27 50%);
  background-image: -moz-linear-gradient(top, #FF6336 0%, #ce4c27 50%);
  background-image: -o-linear-gradient(top, #FF6336 0% #ce4c27 50%);
  background-image: linear-gradient(to bottom, #FF6336 0%, #ce4c27 50%);
}

.button.primary:active {
  background: #FF6336;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: -moz-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: -o-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: linear-gradient(to bottom, #ce4c27 0%, #FF6336 50%);
}

.button.primary.disabled {
  background: #aaaaaa;
  border-color: #999999 #888888 #555555;
  background-image: -webkit-linear-gradient(top, #aaaaaa 0%, #888888 50%);
  background-image: -moz-linear-gradient(top, #aaaaaa 0%, #888888 50%);
  background-image: -o-linear-gradient(top, #aaaaaa 0% #888888 50%);
  background-image: linear-gradient(to bottom, #aaaaaa 0%, #888888 50%);
}

.button.secondary {
  background: #468EB5;
  border-color: #276D93 #175D83 #074D73;
  background-image: -webkit-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: -moz-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: -o-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: linear-gradient(to bottom, #468EB5 0%, #2978A2 50%);
}

.button.secondary:active {
  background: #468EB5;
  border-color: #276D93 #175D83 #074D73;
  background-image: -webkit-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: -moz-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: -o-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: linear-gradient(to bottom, #2978A2 0%, #468EB5 50%);
}

.button.red {
  background: #d02e17;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: -moz-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: -o-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: linear-gradient(to bottom, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
}

.button.red:before {
  background: #ee442c;
  background-image: -webkit-linear-gradient(top, #b32511, #f3533c);
  background-image: -moz-linear-gradient(top, #b32511, #f3533c);
  background-image: -o-linear-gradient(top, #b32511, #f3533c);
  background-image: linear-gradient(to bottom, #b32511, #f3533c);
}

.button.red:active {
  background: #e63b1b;
  background-image: -webkit-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: -moz-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: -o-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: linear-gradient(to bottom, #a9110b 0%, #de3819 60%, #e63b1b 100%);
}

.button.red:active:after {
  border-color: #e63b1b;
}

.lt-ie9 .button:before {
  display: none;
}

.button.small {
  padding: 0px 4px 0px 4px;
}

div#next-round.root span.card-title {
  text-align: center;
  margin: 0 1rem 0 1rem 0;
}
div#next-round.root button#select-next-card {
  background: transparent;
  border: none;
  margin: 0 0 -0.15em 0.75em;
  font-size: 1.2em;
  padding: 0;
}

/*
 * Copyright (c) 2012 Thibaut Courouble
 * http://www.cssflow.com
 *
 * Licensed under the MIT License:
 * http://www.opensource.org/licenses/mit-license.php
 *
 * View the Sass/SCSS source at:
 * http://www.cssflow.com/snippets/multi-colored-push-buttons/demo/scss
 *
 * Original PSD by Marian Mraz: http://goo.gl/9Il5d
 */
.button {
  display: inline-block;
  position: relative;
  height: 33px;
  line-height: 33px;
  padding: 0 15px;
  font-size: 15px;
  color: white;
  text-decoration: none;
  text-shadow: 0 -1px rgba(0, 0, 0, 0.3);
  border: 2px solid;
  border-radius: 7px;
  outline: 0;
  -webkit-box-shadow: 0 2px 1px rgba(0, 0, 0, 0.25);
  box-shadow: 0 2px 1px rgba(0, 0, 0, 0.25);
}

.button:before, .button:after {
  content: "";
  position: absolute;
}

.button:before {
  top: -5px;
  bottom: -5px;
  left: -5px;
  right: -5px;
  z-index: -1;
  border-radius: 9px;
}

.button:after {
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-bottom: 0;
  border-radius: 7px;
}

.column.red {
  background: #d04022;
}

.button.primary {
  background: #FF6336;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #FF6336 0%, #ce4c27 50%);
  background-image: -moz-linear-gradient(top, #FF6336 0%, #ce4c27 50%);
  background-image: -o-linear-gradient(top, #FF6336 0% #ce4c27 50%);
  background-image: linear-gradient(to bottom, #FF6336 0%, #ce4c27 50%);
}

.button.primary:active {
  background: #FF6336;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: -moz-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: -o-linear-gradient(top, #ce4c27 0%, #FF6336 50%);
  background-image: linear-gradient(to bottom, #ce4c27 0%, #FF6336 50%);
}

.button.primary.disabled {
  background: #aaaaaa;
  border-color: #999999 #888888 #555555;
  background-image: -webkit-linear-gradient(top, #aaaaaa 0%, #888888 50%);
  background-image: -moz-linear-gradient(top, #aaaaaa 0%, #888888 50%);
  background-image: -o-linear-gradient(top, #aaaaaa 0% #888888 50%);
  background-image: linear-gradient(to bottom, #aaaaaa 0%, #888888 50%);
}

.button.secondary {
  background: #468EB5;
  border-color: #276D93 #175D83 #074D73;
  background-image: -webkit-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: -moz-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: -o-linear-gradient(top, #468EB5 0%, #2978A2 50%);
  background-image: linear-gradient(to bottom, #468EB5 0%, #2978A2 50%);
}

.button.secondary:active {
  background: #468EB5;
  border-color: #276D93 #175D83 #074D73;
  background-image: -webkit-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: -moz-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: -o-linear-gradient(top, #2978A2 0%, #468EB5 50%);
  background-image: linear-gradient(to bottom, #2978A2 0%, #468EB5 50%);
}

.button.red {
  background: #d02e17;
  border-color: #942110 #902010 #741a0d;
  background-image: -webkit-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: -moz-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: -o-linear-gradient(top, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
  background-image: linear-gradient(to bottom, #e74a29 0%, #e6451b 50%, #d02e17 50%, #b3150b 100%);
}

.button.red:before {
  background: #ee442c;
  background-image: -webkit-linear-gradient(top, #b32511, #f3533c);
  background-image: -moz-linear-gradient(top, #b32511, #f3533c);
  background-image: -o-linear-gradient(top, #b32511, #f3533c);
  background-image: linear-gradient(to bottom, #b32511, #f3533c);
}

.button.red:active {
  background: #e63b1b;
  background-image: -webkit-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: -moz-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: -o-linear-gradient(top, #a9110b 0%, #de3819 60%, #e63b1b 100%);
  background-image: linear-gradient(to bottom, #a9110b 0%, #de3819 60%, #e63b1b 100%);
}

.button.red:active:after {
  border-color: #e63b1b;
}

.lt-ie9 .button:before {
  display: none;
}

.button.small {
  padding: 0px 4px 0px 4px;
}

div.progress-area {
  width: 100%;
}
div.progress-area div.progress-outer {
  position: relative;
  width: 100%;
  height: 3em;
  background-color: #b0b0b0;
  border: 3px solid #FF6336;
}
div.progress-area div.progress-outer div.progress-inner {
  position: absolute;
  width: 50%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: #FF6336;
  border-width: 0;
  z-index: 9;
}
div.progress-area div.progress-outer div.progress-text {
  position: absolute;
  width: 100%;
  top: 0.5em;
  left: 0;
  padding: 0;
  line-height: 100%;
  vertical-align: middle;
  text-align: center;
  font-weight: bold;
  color: #4c4646;
  z-index: 99;
}

div.raised-outer-box {
  border-style: solid;
  border-width: 0;
  padding: 0;
  margin: 0;
  border-color: #888;
}
div.raised-outer-box.raised-box-top {
  border-top-width: 1px;
}
div.raised-outer-box.raised-box-bottom {
  border-bottom-width: 1px;
}
div.raised-outer-box.raised-box-left {
  border-left-width: 1px;
}
div.raised-outer-box.raised-box-right {
  border-right-width: 1px;
}

div.raised-inner-box {
  border-style: solid;
  border-width: 0;
  padding: 0;
  margin: 0;
  border-color: #aaa;
}
div.raised-inner-box.raised-box-top {
  border-top-width: 1px;
}
div.raised-inner-box.raised-box-bottom {
  border-bottom-width: 1px;
}
div.raised-inner-box.raised-box-left {
  border-left-width: 1px;
}
div.raised-inner-box.raised-box-right {
  border-right-width: 1px;
}

.scoreboard {
  display: flex;
  flex-direction: column;
  flex-grow: 0;
  align-items: center;
}
.scoreboard table {
  table-layout: fixed;
}
.scoreboard table .team-score span.team-name {
  text-align: left;
  margin: 0 0 0 0;
  padding: 0;
}
.scoreboard table .team-score span.team-points {
  margin: 0 0 0 3em;
  padding: 0;
}
.scoreboard table .team-score span.team-points-delta {
  margin: 0 0 0 1em;
  padding: 0;
  font-size: 70%;
}

#submission-view div.items-wrapper {
  margin: 1rem;
}
#submission-view div.title-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: start;
  margin: 1rem;
}
#submission-view div.title-wrapper input.title {
  display: inline-block;
  width: 96%;
  margin: 1rem 0 0 0;
}
#submission-view input[type=text] {
  background-color: #ddd5d4;
  border: 0.1rem solid #4c4646;
  padding: 0.4rem;
  margin: 0.3rem;
}
#submission-view input[type=text]:focus {
  background-color: #f0f0f0;
}

/*# sourceMappingURL=app.css.map */
