/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }
  blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

button {
  background: none;
  color: inherit;
  border: none;
  padding: 0;
  cursor: pointer;
  outline: inherit; }

br {
  clear: both; }

/*!
 * animate.css -https://daneden.github.io/animate.css/
 * Version - 3.7.2
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2019 Daniel Eden
 */
@-webkit-keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }
  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }
  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }
  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }
  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

@keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }
  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }
  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }
  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }
  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }

.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand; }

@-webkit-keyframes shake {
  from,
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  10%,
  30%,
  50%,
  70%,
  90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }
  20%,
  40%,
  60%,
  80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); } }

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both; }

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite; }

.animated.delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s; }

.animated.delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s; }

.animated.delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s; }

.animated.delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s; }

.animated.delay-5s {
  -webkit-animation-delay: 5s;
  animation-delay: 5s; }

.animated.fast {
  -webkit-animation-duration: 800ms;
  animation-duration: 800ms; }

.animated.faster {
  -webkit-animation-duration: 500ms;
  animation-duration: 500ms; }

.animated.slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s; }

.animated.slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s; }

@media (print), (prefers-reduced-motion: reduce) {
  .animated {
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-transition-duration: 1ms !important;
    transition-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important; } }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
  padding: 0;
  margin: 0;
  min-height: 100vh;
  min-width: 100vw; }

div.control-container {
  z-index: 0;
  margin-top: 10px;
  padding-bottom: 20px; }

div.control-container div.amplitude-play-pause {
  width: 74px;
  height: 74px;
  cursor: pointer;
  float: left;
  margin-left: 30px; }

div.control-container div.amplitude-play-pause.amplitude-paused {
  background: url("/assets/img/play.svg");
  background-size: cover; }

div.control-container div.amplitude-play-pause.amplitude-playing {
  background: url("/assets/img/pause.svg");
  background-size: cover; }

div.control-container div.meta-container {
  float: left;
  width: calc(100% - 134px);
  text-align: left;
  color: white;
  padding-left: 30px;
  margin-top: 10px; }

div.control-container div.meta-container span[data-amplitude-song-info="name"] {
  font-size: 18px;
  color: #fff;
  display: block;
  margin-bottom: 0.4em; }

div.control-container div.meta-container span[data-amplitude-song-info="artist"] {
  font-weight: 100;
  font-size: 14px;
  color: #fff;
  display: block; }

div.control-container:after {
  content: "";
  display: table;
  clear: both; }

@media screen and (max-width: 39.9375em) {
  div.control-container div.amplitude-play-pause {
    background-size: cover;
    width: 64px;
    height: 64px;
    margin-left: 10px; }
  div.control-container div.meta-container {
    width: calc(100% - 94px);
    padding-left: 20px; } }

div.time-container {
  opacity: 0.5;
  font-weight: 100;
  font-size: 12px;
  color: #fff;
  height: 15px; }

div.time-container span.current-time {
  float: left;
  margin-left: 5px; }

div.time-container span.duration {
  float: right;
  margin-right: 5px; }

progress.amplitude-song-played-progress {
  background-color: #313252;
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 5px;
  display: block;
  cursor: pointer;
  border: none; }

progress.amplitude-song-played-progress:not([value]) {
  background-color: #313252; }

progress[value]::-webkit-progress-bar {
  background-color: #313252; }

progress[value]::-moz-progress-bar {
  background-color: #00a0ff; }

progress[value]::-webkit-progress-value {
  background-color: #00a0ff; }

div.bottom-container {
  background-color: #222;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px; }

div#single-song-player {
  border-radius: 10px;
  margin: auto;
  padding-top: 50px;
  width: 80%;
  max-width: 460px;
  -webkit-font-smoothing: antialiased; }

div#single-song-player img[data-amplitude-song-info="cover_art_url"] {
  width: 100%;
  display: block;
  border-top-right-radius: 10px;
  border-top-left-radius: 10px; }

.notice {
  max-width: 400px;
  width: 80%;
  margin: auto; }
  .notice img {
    max-width: 100%;
    height: auto;
    width: 100%; }

.title {
  position: fixed;
  top: 8px;
  left: 20px;
  z-index: -1;
  transform: rotateZ(-20deg);
  display: inline-block;
  font-size: 40px;
  background: #222;
  color: white;
  padding: 11px 21px; }

.intro {
  position: fixed;
  width: 100vw;
  height: 100vh;
  background: #222;
  color: white;
  font-size: 20vw;
  z-index: 1;
  display: flex;
  top: 0;
  transition: top 0.5s ease-in-out; }
  .intro .text-container {
    margin: auto; }
  .intro.hide {
    top: -100vh; }

.foot {
  color: gray;
  text-align: center;
  margin: 30px auto 0 auto; }
  .foot a, .foot .separator {
    opacity: 0.4;
    transition: opacity 0.2s ease-in-out;
    text-decoration: none; }
  .foot a:hover {
    opacity: 1;
    color: #222; }
  .foot img {
    width: 20px;
    height: auto;
    display: inline-block;
    vertical-align: sub; }
  .foot span {
    color: #222;
    margin: 0 5px; }
