.download {
  background: #171717;
  padding: 60px 15px 120px 15px;
  position: relative; }
  .download h2 {
    color: #F9E11E; }
  .download p, .download a:not(.btn) {
    color: #FFF; }
  .download .footer {
    background: #232323;
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(100% + 30px);
    margin: 0 -15px;
    min-height: 100px; }
    .download .footer img {
      width: 40vmin;
      height: 40vmin;
      margin-top: -40px; }

@media (min-width: 480px) {
  .footer {
    display: none; } }

@media (max-width: 480px) {
  .download {
    min-height: 100vh;
    overflow: hidden; } }

@media (max-width: 768px) {
  .download {
    padding: 15px 80px 120px 15px; } }

section.intro {
  height: calc(100vmin - 120px);
  min-height: 100vh;
  background: rgba(23, 23, 23, 0.4);
  position: relative;
  text-align: center; }
  section.intro .content {
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 30px;
    width: 100%; }
  section.intro h1 {
    color: #d7c21b;
    font-size: 9rem;
    line-height: 12rem;
    margin-bottom: 30px; }
    section.intro h1 span {
      width: auto;
      display: inline;
      padding: 0 15px;
      text-transform: uppercase;
      font-family: 'Alfa Slab One', cursive;
      font-size: 8rem;
      color: #171717;
      position: relative;
      background: #F9E11E; }
  section.intro p {
    font-size: 3rem;
    line-height: 4rem;
    font-weight: 300;
    color: #fff;
    opacity: 0.8;
    margin: 0 0 30px 0; }
  section.intro .cta {
    margin-bottom: 50px; }

@media (max-width: 768px) {
  section.intro {
    padding: 200px 0 100px 0;
    height: calc(100vmin - 250px);
    min-height: 100vh; }
    section.intro .content {
      padding: 0 15px; }
    section.intro h1 {
      font-size: 8rem;
      line-height: 7.5rem; }
      section.intro h1 span {
        padding: 0 8px;
        font-size: 5rem; }
    section.intro .btn:not(.btn-large) + .btn:not(.btn-large) {
      margin: 15px 0 0 0; }
    section.intro .cta {
      margin-bottom: 15px; } }

@media (max-width: 480px) {
  section.intro h1 {
    font-size: 3rem;
    line-height: 5rem; }
    section.intro h1 span {
      font-size: 3rem; }
  section.intro p {
    font-size: 2rem;
    line-height: 4rem; }
  .btn.btn-scroll-down {
    margin-bottom: 80px; } }

.about {
  background: #F9E11E;
  padding: 60px 15px 0 15px; }
  .about .screenshot {
    background: url("../../../img/static/rws/pixel_screenshot_top.png");
    height: 45vw;
    background-size: contain;
    background-position: center bottom;
    background-repeat: no-repeat;
    width: 100%; }

@media (max-width: 768px) {
  .about {
    padding: 15px 15px 0 15px; }
    .about .screenshot {
      height: 400px; } }

@media (max-width: 320px) {
  .about .screenshot {
    height: 340px; } }

@media (min-width: 992px) and (max-width: 1399px) {
  .about .screenshot {
    background: url("../../../img/static/rws/pixel_screenshot.png");
    width: 100%;
    height: 50vw;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat; } }

.onboarding-intro {
  padding: 60px 15px; }
  .onboarding-intro h2 {
    color: #F9E11E; }
  .onboarding-intro * {
    color: #FFF; }
  .onboarding-intro .progress {
    background: #F9E11E;
    height: 6px;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 0;
    box-shadow: none;
    width: 0; }

.onboarding {
  background: #F9E11E;
  padding: 60px 15px 0 15px;
  min-height: 600px; }
  .onboarding form {
    width: 100%;
    float: left; }
    .onboarding form input[type="text"], .onboarding form input[type="password"] {
      width: 100%;
      height: 6.5rem;
      padding: 10px 25px;
      font-size: 2rem;
      line-height: 4rem;
      margin-bottom: 30px;
      background: transparent;
      border: 2px solid #232323;
      color: #171717;
      font-weight: 500;
      border-radius: 0; }
      .onboarding form input[type="text"].invalid, .onboarding form input[type="password"].invalid {
        border-color: #b71700; }
    .onboarding form label {
      text-transform: uppercase;
      font-family: 'Alfa Slab One', cursive;
      font-size: 1.5rem;
      line-height: 3rem; }
    .onboarding form .validation.error {
      width: 100%;
      display: inline-block;
      background: #b71700;
      margin-bottom: 1rem;
      color: #F9E11E;
      padding: 5px 15px;
      border: 2px solid #b71700;
      font-size: 1.5rem;
      float: left; }
  .onboarding .content {
    margin-bottom: 30px; }
  .onboarding .question-form {
    width: 100%; }
    .onboarding .question-form h2, .onboarding .question-form .html-heading p {
      font-family: 'Alfa Slab One', cursive;
      font-size: 3rem;
      margin: 3rem 0 30px;
      color: #000; }
    .onboarding .question-form .html-heading * {
      font-family: 'Alfa Slab One', cursive;
      font-size: 3rem; }
    .onboarding .question-form .btn {
      margin: 30px 0; }
    .onboarding .question-form input[type="checkbox"], .onboarding .question-form input[type="radio"] {
      display: none; }
      .onboarding .question-form input[type="checkbox"] + label, .onboarding .question-form input[type="radio"] + label {
        margin: 0;
        min-height: 60px;
        cursor: pointer;
        position: relative;
        font-size: 2rem;
        line-height: 4rem;
        padding: 20px 0 20px 60px;
        width: 100%;
        border-bottom: 2px dashed #171717;
        text-transform: none;
        font-weight: normal !important;
        font-family: 'Chivo', sans-serif; }
        .onboarding .question-form input[type="checkbox"] + label:before, .onboarding .question-form input[type="radio"] + label:before {
          content: "";
          position: absolute;
          left: 0;
          top: 0;
          bottom: 0;
          height: 40px;
          width: 40px;
          margin: auto 0;
          background: #FFF;
          border: 2px solid #232323;
          border-radius: 50%; }
        .onboarding .question-form input[type="checkbox"] + label:after, .onboarding .question-form input[type="radio"] + label:after {
          content: "";
          position: absolute;
          left: 6px;
          top: 0;
          bottom: 0;
          margin: auto 0;
          height: 28px;
          width: 28px;
          border-radius: 50%;
          transition: background 200ms; }
      .onboarding .question-form input[type="checkbox"]:checked + label:before, .onboarding .question-form input[type="radio"]:checked + label:before {
        border-color: #232323; }
      .onboarding .question-form input[type="checkbox"]:checked + label:after, .onboarding .question-form input[type="radio"]:checked + label:after {
        background: #232323;
        transition: background 200ms; }

.onboarding-alt {
  background: rgba(0, 0, 0, 0.6);
  min-height: 100px; }
  .onboarding-alt h2 {
    color: #F9E11E; }
  .onboarding-alt * {
    color: #FFF; }

.onboarding-progress {
  position: absolute;
  top: 0;
  margin: 0;
  left: 0;
  height: 4px;
  background: transparent;
  display: inline-block;
  border-radius: 0;
  box-shadow: none;
  width: 100%; }
  .onboarding-progress span {
    float: left;
    height: 4px;
    display: inline-block; }
    .onboarding-progress span.past span, .onboarding-progress span.current span {
      width: 100%;
      background: #F9E11E; }
    .onboarding-progress span.current span {
      animation: animateProgress forwards 2s; }

@keyframes animateProgress {
  from {
    width: 0; }
  to {
    width: 100%; } }

@media (max-width: 768px) {
  .onboarding {
    min-height: 100px;
    padding: 15px 15px 0 15px; }
    .onboarding form input[type="text"], .onboarding form input[type="password"] {
      height: 5rem;
      padding: 10px 15px;
      font-size: 1.8rem;
      line-height: 3.6rem; }
    .onboarding .question-form input[type="checkbox"] + label, .onboarding .question-form input[type="radio"] + label {
      padding: 15px 0 15px 60px;
      font-size: 1.8rem;
      line-height: 3.6rem; } }

.statistics {
  padding: 12rem 0 1rem; }
  .statistics h1 {
    color: #FFF;
    font-size: 3rem;
    margin-bottom: 1em; }
  .statistics h2 {
    color: #F9E11E;
    font-size: 2rem; }
  .statistics p, .statistics small, .statistics ul {
    color: #FFF; }

.statistics-grid {
  width: 100%;
  float: left;
  margin: 0 0 1.5rem; }
  .statistics-grid .block {
    min-height: 12rem;
    width: 100%;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 3px;
    float: left; }
    .statistics-grid .block .score {
      margin-top: 2rem;
      color: #F9E11E;
      font-family: 'Alfa Slab One', cursive;
      font-size: 4rem;
      width: 100%;
      text-align: center;
      float: left; }
      .statistics-grid .block .score * {
        color: #F9E11E;
        font-family: 'Alfa Slab One', cursive; }
      .statistics-grid .block .score .large {
        font-size: 4rem; }
      .statistics-grid .block .score .small {
        font-size: 2.5rem; }
    .statistics-grid .block .label {
      font-family: 'Chivo', sans-serif;
      font-size: 2rem;
      line-height: 3rem;
      color: #FFF;
      width: 100%;
      font-weight: normal;
      text-align: center;
      float: left;
      margin-bottom: 2rem; }
      .statistics-grid .block .label.ellipsis {
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
        width: 100%; }

.statistics-list {
  width: 100%;
  float: left;
  margin: 0 0 1.5rem; }
  .statistics-list ul {
    margin: 0 0 1.5rem;
    padding: 0;
    width: 100%;
    float: left; }
    .statistics-list ul li {
      width: 100%;
      float: left;
      border-bottom: 2px solid #333333;
      padding: 1.5rem 1rem 1.5rem 6rem;
      position: relative;
      margin: 0;
      list-style-type: none;
      color: #FFF; }
      .statistics-list ul li a {
        color: #FFF; }
      .statistics-list ul li.highlight {
        background: #F9E11E;
        color: #000;
        border-radius: 3px; }
        .statistics-list ul li.highlight .score .view-details-icon {
          color: #000; }
        .statistics-list ul li.highlight a {
          color: #000; }
        .statistics-list ul li.highlight [class*="icon-"], .statistics-list ul li.highlight [class*="ion-"] {
          background: #000;
          color: #FFF; }
      .statistics-list ul li .row {
        float: left;
        width: calc(100% + 30px); }
      .statistics-list ul li .title {
        width: 100%;
        float: left;
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden; }
        .statistics-list ul li .title .row [class*="col-"] {
          text-overflow: ellipsis;
          white-space: nowrap;
          overflow: hidden; }
      .statistics-list ul li .score {
        font-family: 'Alfa Slab One', cursive; }
        .statistics-list ul li .score .view-details-icon {
          position: relative;
          background: none;
          width: 4rem;
          height: 3rem; }
      .statistics-list ul li [class*="icon-"], .statistics-list ul li [class*="ion-"] {
        position: absolute;
        left: 1rem;
        top: 0;
        bottom: 0;
        margin: auto 0;
        border-radius: 50%;
        width: 4rem;
        height: 4rem;
        background: #333333; }
        .statistics-list ul li [class*="icon-"]:before, .statistics-list ul li [class*="ion-"]:before {
          z-index: 1;
          position: absolute;
          font-size: 1em;
          width: 1em;
          height: 1em;
          top: 0;
          left: 0;
          right: 0;
          bottom: 0;
          text-align: center;
          margin: auto; }
        .statistics-list ul li [class*="icon-"] small, .statistics-list ul li [class*="ion-"] small {
          position: absolute;
          top: 0;
          bottom: 0;
          left: 0;
          right: 0;
          line-height: 2rem;
          width: 2rem;
          height: 2rem;
          text-align: center;
          margin: auto; }
      .statistics-list ul li .progress-bar {
        width: 100%;
        height: 0.5rem;
        position: absolute;
        background: transparent;
        bottom: -2px;
        right: 0; }
        .statistics-list ul li .progress-bar .bar {
          background: #F9E11E;
          height: 0.5rem;
          display: inline-block;
          position: absolute;
          left: 0;
          bottom: 0; }

.statistics-graph {
  width: 100%;
  float: left;
  margin: 0 0 1.5rem; }
  .statistics-graph .bar-container {
    padding: 1rem;
    float: left;
    position: relative;
    text-align: center;
    color: #FFF;
    overflow: hidden; }
    .statistics-graph .bar-container .bar-label {
      padding: 1rem 0;
      font-size: 1.75rem;
      width: 100%;
      float: left;
      text-align: center;
      position: relative;
      word-break: break-word; }
    .statistics-graph .bar-container .bar {
      margin-top: 4rem;
      display: inline-block;
      background: rgba(255, 255, 255, 0.15);
      height: 20rem;
      width: 100%;
      max-width: 100px;
      position: relative; }
      .statistics-graph .bar-container .bar:after {
        content: "";
        width: 1000%;
        height: 2px;
        background: #333333;
        position: absolute;
        left: -500%;
        bottom: 0; }
      .statistics-graph .bar-container .bar .fill {
        width: 100%;
        position: absolute;
        left: 0;
        bottom: 0;
        background: #F9E11E;
        border-radius: 3px 3px 0 0; }
    .statistics-graph .bar-container .bar-score {
      font-family: 'Alfa Slab One', cursive;
      font-size: 2rem;
      height: 4rem;
      color: #FFF;
      padding: 0.5rem;
      font-weight: normal;
      width: 100%;
      position: absolute;
      top: -4rem;
      left: 0;
      text-align: center;
      background: rgba(255, 255, 255, 0.15);
      border-radius: 3px 3px 0 0; }

.statistics-graph .btn-container,
.statistics-list .btn-container {
  width: 100%;
  float: left;
  margin-top: 2rem; }

@media (max-width: 768px) {
  .statistics-list ul li.highlight {
    border-radius: 0; } }

.btn {
  height: 6rem;
  padding: 10px 25px;
  background: transparent;
  border: 2px solid #171717;
  color: #171717;
  text-transform: uppercase;
  font-size: 2rem;
  line-height: 4rem;
  font-weight: 500;
  border-radius: 0;
  transition: all .3s ease-in-out;
  margin-bottom: 15px;
  box-shadow: none !important; }
  .btn:hover {
    background: #000;
    border: 2px solid #d7c21b;
    color: #F9E11E;
    transition: all .3s ease-in-out; }
  .btn:active {
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    outline: none !important;
    margin-top: 2px;
    margin-bottom: 13px;
    transition: all .1s ease-in-out; }
  .btn:focus {
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    outline: none !important; }
  .btn.btn-yellow-border {
    border: 2px solid #F9E11E;
    color: #F9E11E; }
    .btn.btn-yellow-border:hover {
      border: 2px solid #FFF;
      color: #FFF; }
  .btn.btn-black {
    color: #F9E11E;
    background: #171717; }
    .btn.btn-black:hover {
      border: 2px solid #000;
      background: #000;
      color: #FFF; }
  .btn.btn-yellow {
    font-size: 1.7rem;
    line-height: 2.6rem;
    background: #d7c21b;
    color: #000;
    padding: 5px 25px 5px 45px;
    max-width: 300px;
    word-break: break-word;
    white-space: normal;
    position: relative; }
    .btn.btn-yellow .rws {
      background: url("../../../img/static/rws/rws.png") no-repeat center center;
      height: 100%;
      width: 10%;
      background-size: 100%;
      background-position: center center;
      position: absolute;
      left: 0;
      top: 0; }
  .btn.btn-alt {
    background: #000;
    color: #FFF;
    opacity: 0.8; }
  .btn[class*='ion']:before {
    padding-right: 8px; }

.btn.btn-scroll-down {
  border: none;
  width: 100%;
  text-align: center;
  height: 80px;
  color: #FFF;
  border-radius: 0;
  font-size: 2.5rem;
  background: transparent;
  position: relative;
  transition: all .3s ease-in-out;
  opacity: 0;
  animation: fadeIn 1s 2s ease-in-out;
  animation-fill-mode: forwards; }
  .btn.btn-scroll-down:hover {
    background: transparent;
    transition: all .3s ease-in-out; }
    .btn.btn-scroll-down:hover:before {
      top: 60px;
      color: #d7c21b;
      transition: all .3s ease-in-out; }
  .btn.btn-scroll-down:before {
    position: absolute;
    top: 50px;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    display: inline-block;
    transition: all .3s ease-in-out; }

.btn-floating {
  position: absolute;
  right: 15px;
  top: 30px;
  z-index: 999; }

@media (max-width: 768px) {
  .btn {
    height: 5rem;
    padding: 5px 15px;
    border-radius: 0;
    line-height: 4rem; }
    .btn.btn-yellow {
      padding: 5px 10px 5px 30px !important;
      line-height: 2rem; }
      .btn.btn-yellow .rws {
        height: 100% !important;
        width: 6% !important; }
    .btn[class*='ion']:before {
      padding-right: 8px; }
  .btn.btn-scroll-down {
    font-size: 2rem; } }

@keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }

/*
 * Alerts
 */
.alert {
  position: fixed;
  border: 0;
  margin: 0;
  opacity: 0;
  border-radius: 0;
  left: 0;
  top: 0;
  min-height: 50px;
  width: 100%;
  font-size: 15px;
  font-weight: 300;
  z-index: 99;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  background-color: #F9E11E;
  color: #171717;
  animation-name: AnimateAlert;
  animation-duration: 8000ms;
  animation-direction: forward;
  padding: 15px 15px 15px 50px; }
  .alert:before {
    position: absolute;
    height: 30px;
    width: 30px;
    left: 10px;
    top: calc(50% - 15px);
    color: #F9E11E;
    text-align: center;
    line-height: 30px;
    font-size: 22px; }
  .alert.alert-success:before {
    color: #171717; }
  .alert.alert-danger:before {
    color: #b71700; }

@keyframes AnimateAlert {
  0% {
    opacity: 0; }
  10% {
    opacity: 0.9; }
  80% {
    opacity: 0.9; }
  100% {
    opacity: 0;
    display: none; } }

nav {
  width: 100%;
  background: rgba(0, 0, 0, 0.8);
  position: fixed;
  z-index: 999;
  height: 6rem;
  left: 0;
  top: 0;
  padding: 1.5rem 0; }
  nav h1, nav h1 a {
    font-size: 2rem;
    margin: 0;
    padding: 0.5rem 0;
    color: #FFF;
    font-family: 'Alfa Slab One', cursive;
    font-weight: normal;
    width: 100%;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden; }
    nav h1 a, nav h1 a a {
      padding: 0; }
      nav h1 a:before, nav h1 a a:before {
        margin-right: 1rem; }
      nav h1 a:hover, nav h1 a:active, nav h1 a a:hover, nav h1 a a:active {
        color: #F9E11E;
        text-decoration: none; }
  nav .btn {
    position: absolute;
    right: 0;
    top: 0;
    border-top: none !important;
    border-right: none !important;
    border-bottom: none !important;
    border-color: #333333 !important;
    margin: 0; }
    nav .btn:hover, nav .btn:active {
      background: #F9E11E !important;
      color: #000 !important; }

@media (max-width: 768px) {
  nav {
    height: 5rem;
    padding: 1rem 0; }
    nav .btn[class*='ion']:before {
      padding-right: 0; } }

* {
  font-family: 'Chivo', sans-serif; }

body {
  width: 100%;
  height: 100%;
  background-color: #000;
  font-size: 15px;
  min-height: 100vh; }
  body:before {
    content: "";
    background-image: url("../../../img/static/rws/intro.jpg");
    background-size: cover;
    background-position: top;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: -100; }
  body.gradient:after {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: -100;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, black 40%, black 100%); }

h1, h2, h3, h4, h2 a, h3 a, h4 a {
  font-family: 'Alfa Slab One', cursive; }

h1 {
  font-size: 6rem;
  margin: 3rem 0 1rem; }

h2 {
  font-size: 5rem;
  margin: 3rem 0 1rem; }

h3 {
  font-size: 2.5rem;
  margin: 3rem 0 0.5rem; }

h4 {
  font-size: 2rem;
  margin: 3rem 0 0.5rem; }

p {
  font-size: 1.8rem;
  line-height: 3rem; }
  p:last-of-type {
    margin-bottom: 30px; }
  p.lead {
    font-size: 2.2rem;
    line-height: 4rem; }

ul {
  font-size: 1.8rem;
  line-height: 3rem;
  margin-top: 0;
  margin-bottom: 2rem; }
  ul li {
    margin-bottom: 1rem; }

@media (max-width: 768px) {
  h2 {
    font-size: 4rem; }
  p {
    font-size: 1.8rem;
    line-height: 3.6rem; }
    p.lead {
      font-size: 2.2rem;
      line-height: 3.6rem; } }

@media (max-width: 480px) {
  h2 {
    font-size: 3rem; }
  p {
    font-size: 1.5rem;
    line-height: 3.2rem; }
    p.lead {
      font-size: 2rem;
      line-height: 3.4rem; }
  .text-xs-center {
    text-align: center !important; } }
