body {
  margin: 0;
  padding: 0;
  background: #000;
  overflow: hidden;
}

.pyro > .before, .pyro > .after {
  position: absolute;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  box-shadow: 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff, 0 0 #fff;
  -moz-animation: 1s bang ease-out infinite backwards, 1s gravity ease-in infinite backwards, 5s position linear infinite backwards;
  -webkit-animation: 1s bang ease-out infinite backwards, 1s gravity ease-in infinite backwards, 5s position linear infinite backwards;
  -o-animation: 1s bang ease-out infinite backwards, 1s gravity ease-in infinite backwards, 5s position linear infinite backwards;
  -ms-animation: 1s bang ease-out infinite backwards, 1s gravity ease-in infinite backwards, 5s position linear infinite backwards;
  animation: 1s bang ease-out infinite backwards, 1s gravity ease-in infinite backwards, 5s position linear infinite backwards;
}

.pyro > .after {
  -moz-animation-delay: 1.25s, 1.25s, 1.25s;
  -webkit-animation-delay: 1.25s, 1.25s, 1.25s;
  -o-animation-delay: 1.25s, 1.25s, 1.25s;
  -ms-animation-delay: 1.25s, 1.25s, 1.25s;
  animation-delay: 1.25s, 1.25s, 1.25s;
  -moz-animation-duration: 1.25s, 1.25s, 6.25s;
  -webkit-animation-duration: 1.25s, 1.25s, 6.25s;
  -o-animation-duration: 1.25s, 1.25s, 6.25s;
  -ms-animation-duration: 1.25s, 1.25s, 6.25s;
  animation-duration: 1.25s, 1.25s, 6.25s;
}

@-webkit-keyframes bang {
  to {
    box-shadow: 81px -208.6666666667px #ff00d0, -81px -116.6666666667px #0011ff, -212px -25.6666666667px #ff001a, 209px -178.6666666667px #00aaff, -128px -385.6666666667px #3c00ff, 124px -317.6666666667px #ff2600, 33px -277.6666666667px #ddff00, 130px -49.6666666667px #0004ff, 211px -233.6666666667px #ff9500, 30px -132.6666666667px #ff0004, -130px -158.6666666667px #ffe600, 107px -198.6666666667px #ff0048, 155px 13.3333333333px #0099ff, -153px -397.6666666667px #00ffd0, -189px -294.6666666667px #fffb00, -180px -128.6666666667px #00ffcc, 15px -194.6666666667px #ff4800, -107px -160.6666666667px #ff000d, -184px -64.6666666667px #00aeff, -3px -233.6666666667px #aeff00, -61px -325.6666666667px #ff1500, 153px -85.6666666667px #00b3ff, 95px -178.6666666667px #fb00ff, 204px 34.3333333333px #00ff3c, -215px 31.3333333333px #0009ff, -36px -291.6666666667px #d000ff, -43px -34.6666666667px #00ffc8, 184px -306.6666666667px #0048ff, -5px -140.6666666667px #ff0040, 180px -300.6666666667px #95ff00, -174px -56.6666666667px #04ff00, -118px -11.6666666667px #e6ff00, -220px -209.6666666667px #e6ff00, 237px -125.6666666667px #ff1a00, -124px -287.6666666667px #ff5100, -100px -334.6666666667px magenta, -150px -35.6666666667px #bf00ff, -62px 59.3333333333px #00ffee, 95px -95.6666666667px #00ff1a, -105px -88.6666666667px #ff1500, 24px -57.6666666667px #ff1a00, 226px 44.3333333333px #bfff00, 160px -210.6666666667px #b700ff, -167px -26.6666666667px #00ff88, 195px -125.6666666667px #ff0009, -37px -144.6666666667px #ff005e, -50px 3.3333333333px #00d5ff, 54px -10.6666666667px #00e6ff, -58px -151.6666666667px #00ff09, -108px -1.6666666667px #00a6ff, -206px -221.6666666667px #ff00e1;
  }
}
@-moz-keyframes bang {
  to {
    box-shadow: 81px -208.6666666667px #ff00d0, -81px -116.6666666667px #0011ff, -212px -25.6666666667px #ff001a, 209px -178.6666666667px #00aaff, -128px -385.6666666667px #3c00ff, 124px -317.6666666667px #ff2600, 33px -277.6666666667px #ddff00, 130px -49.6666666667px #0004ff, 211px -233.6666666667px #ff9500, 30px -132.6666666667px #ff0004, -130px -158.6666666667px #ffe600, 107px -198.6666666667px #ff0048, 155px 13.3333333333px #0099ff, -153px -397.6666666667px #00ffd0, -189px -294.6666666667px #fffb00, -180px -128.6666666667px #00ffcc, 15px -194.6666666667px #ff4800, -107px -160.6666666667px #ff000d, -184px -64.6666666667px #00aeff, -3px -233.6666666667px #aeff00, -61px -325.6666666667px #ff1500, 153px -85.6666666667px #00b3ff, 95px -178.6666666667px #fb00ff, 204px 34.3333333333px #00ff3c, -215px 31.3333333333px #0009ff, -36px -291.6666666667px #d000ff, -43px -34.6666666667px #00ffc8, 184px -306.6666666667px #0048ff, -5px -140.6666666667px #ff0040, 180px -300.6666666667px #95ff00, -174px -56.6666666667px #04ff00, -118px -11.6666666667px #e6ff00, -220px -209.6666666667px #e6ff00, 237px -125.6666666667px #ff1a00, -124px -287.6666666667px #ff5100, -100px -334.6666666667px magenta, -150px -35.6666666667px #bf00ff, -62px 59.3333333333px #00ffee, 95px -95.6666666667px #00ff1a, -105px -88.6666666667px #ff1500, 24px -57.6666666667px #ff1a00, 226px 44.3333333333px #bfff00, 160px -210.6666666667px #b700ff, -167px -26.6666666667px #00ff88, 195px -125.6666666667px #ff0009, -37px -144.6666666667px #ff005e, -50px 3.3333333333px #00d5ff, 54px -10.6666666667px #00e6ff, -58px -151.6666666667px #00ff09, -108px -1.6666666667px #00a6ff, -206px -221.6666666667px #ff00e1;
  }
}
@-o-keyframes bang {
  to {
    box-shadow: 81px -208.6666666667px #ff00d0, -81px -116.6666666667px #0011ff, -212px -25.6666666667px #ff001a, 209px -178.6666666667px #00aaff, -128px -385.6666666667px #3c00ff, 124px -317.6666666667px #ff2600, 33px -277.6666666667px #ddff00, 130px -49.6666666667px #0004ff, 211px -233.6666666667px #ff9500, 30px -132.6666666667px #ff0004, -130px -158.6666666667px #ffe600, 107px -198.6666666667px #ff0048, 155px 13.3333333333px #0099ff, -153px -397.6666666667px #00ffd0, -189px -294.6666666667px #fffb00, -180px -128.6666666667px #00ffcc, 15px -194.6666666667px #ff4800, -107px -160.6666666667px #ff000d, -184px -64.6666666667px #00aeff, -3px -233.6666666667px #aeff00, -61px -325.6666666667px #ff1500, 153px -85.6666666667px #00b3ff, 95px -178.6666666667px #fb00ff, 204px 34.3333333333px #00ff3c, -215px 31.3333333333px #0009ff, -36px -291.6666666667px #d000ff, -43px -34.6666666667px #00ffc8, 184px -306.6666666667px #0048ff, -5px -140.6666666667px #ff0040, 180px -300.6666666667px #95ff00, -174px -56.6666666667px #04ff00, -118px -11.6666666667px #e6ff00, -220px -209.6666666667px #e6ff00, 237px -125.6666666667px #ff1a00, -124px -287.6666666667px #ff5100, -100px -334.6666666667px magenta, -150px -35.6666666667px #bf00ff, -62px 59.3333333333px #00ffee, 95px -95.6666666667px #00ff1a, -105px -88.6666666667px #ff1500, 24px -57.6666666667px #ff1a00, 226px 44.3333333333px #bfff00, 160px -210.6666666667px #b700ff, -167px -26.6666666667px #00ff88, 195px -125.6666666667px #ff0009, -37px -144.6666666667px #ff005e, -50px 3.3333333333px #00d5ff, 54px -10.6666666667px #00e6ff, -58px -151.6666666667px #00ff09, -108px -1.6666666667px #00a6ff, -206px -221.6666666667px #ff00e1;
  }
}
@-ms-keyframes bang {
  to {
    box-shadow: 81px -208.6666666667px #ff00d0, -81px -116.6666666667px #0011ff, -212px -25.6666666667px #ff001a, 209px -178.6666666667px #00aaff, -128px -385.6666666667px #3c00ff, 124px -317.6666666667px #ff2600, 33px -277.6666666667px #ddff00, 130px -49.6666666667px #0004ff, 211px -233.6666666667px #ff9500, 30px -132.6666666667px #ff0004, -130px -158.6666666667px #ffe600, 107px -198.6666666667px #ff0048, 155px 13.3333333333px #0099ff, -153px -397.6666666667px #00ffd0, -189px -294.6666666667px #fffb00, -180px -128.6666666667px #00ffcc, 15px -194.6666666667px #ff4800, -107px -160.6666666667px #ff000d, -184px -64.6666666667px #00aeff, -3px -233.6666666667px #aeff00, -61px -325.6666666667px #ff1500, 153px -85.6666666667px #00b3ff, 95px -178.6666666667px #fb00ff, 204px 34.3333333333px #00ff3c, -215px 31.3333333333px #0009ff, -36px -291.6666666667px #d000ff, -43px -34.6666666667px #00ffc8, 184px -306.6666666667px #0048ff, -5px -140.6666666667px #ff0040, 180px -300.6666666667px #95ff00, -174px -56.6666666667px #04ff00, -118px -11.6666666667px #e6ff00, -220px -209.6666666667px #e6ff00, 237px -125.6666666667px #ff1a00, -124px -287.6666666667px #ff5100, -100px -334.6666666667px magenta, -150px -35.6666666667px #bf00ff, -62px 59.3333333333px #00ffee, 95px -95.6666666667px #00ff1a, -105px -88.6666666667px #ff1500, 24px -57.6666666667px #ff1a00, 226px 44.3333333333px #bfff00, 160px -210.6666666667px #b700ff, -167px -26.6666666667px #00ff88, 195px -125.6666666667px #ff0009, -37px -144.6666666667px #ff005e, -50px 3.3333333333px #00d5ff, 54px -10.6666666667px #00e6ff, -58px -151.6666666667px #00ff09, -108px -1.6666666667px #00a6ff, -206px -221.6666666667px #ff00e1;
  }
}
@keyframes bang {
  to {
    box-shadow: 81px -208.6666666667px #ff00d0, -81px -116.6666666667px #0011ff, -212px -25.6666666667px #ff001a, 209px -178.6666666667px #00aaff, -128px -385.6666666667px #3c00ff, 124px -317.6666666667px #ff2600, 33px -277.6666666667px #ddff00, 130px -49.6666666667px #0004ff, 211px -233.6666666667px #ff9500, 30px -132.6666666667px #ff0004, -130px -158.6666666667px #ffe600, 107px -198.6666666667px #ff0048, 155px 13.3333333333px #0099ff, -153px -397.6666666667px #00ffd0, -189px -294.6666666667px #fffb00, -180px -128.6666666667px #00ffcc, 15px -194.6666666667px #ff4800, -107px -160.6666666667px #ff000d, -184px -64.6666666667px #00aeff, -3px -233.6666666667px #aeff00, -61px -325.6666666667px #ff1500, 153px -85.6666666667px #00b3ff, 95px -178.6666666667px #fb00ff, 204px 34.3333333333px #00ff3c, -215px 31.3333333333px #0009ff, -36px -291.6666666667px #d000ff, -43px -34.6666666667px #00ffc8, 184px -306.6666666667px #0048ff, -5px -140.6666666667px #ff0040, 180px -300.6666666667px #95ff00, -174px -56.6666666667px #04ff00, -118px -11.6666666667px #e6ff00, -220px -209.6666666667px #e6ff00, 237px -125.6666666667px #ff1a00, -124px -287.6666666667px #ff5100, -100px -334.6666666667px magenta, -150px -35.6666666667px #bf00ff, -62px 59.3333333333px #00ffee, 95px -95.6666666667px #00ff1a, -105px -88.6666666667px #ff1500, 24px -57.6666666667px #ff1a00, 226px 44.3333333333px #bfff00, 160px -210.6666666667px #b700ff, -167px -26.6666666667px #00ff88, 195px -125.6666666667px #ff0009, -37px -144.6666666667px #ff005e, -50px 3.3333333333px #00d5ff, 54px -10.6666666667px #00e6ff, -58px -151.6666666667px #00ff09, -108px -1.6666666667px #00a6ff, -206px -221.6666666667px #ff00e1;
  }
}
@-webkit-keyframes gravity {
  to {
    transform: translateY(200px);
    -moz-transform: translateY(200px);
    -webkit-transform: translateY(200px);
    -o-transform: translateY(200px);
    -ms-transform: translateY(200px);
    opacity: 0;
  }
}
@-moz-keyframes gravity {
  to {
    transform: translateY(200px);
    -moz-transform: translateY(200px);
    -webkit-transform: translateY(200px);
    -o-transform: translateY(200px);
    -ms-transform: translateY(200px);
    opacity: 0;
  }
}
@-o-keyframes gravity {
  to {
    transform: translateY(200px);
    -moz-transform: translateY(200px);
    -webkit-transform: translateY(200px);
    -o-transform: translateY(200px);
    -ms-transform: translateY(200px);
    opacity: 0;
  }
}
@-ms-keyframes gravity {
  to {
    transform: translateY(200px);
    -moz-transform: translateY(200px);
    -webkit-transform: translateY(200px);
    -o-transform: translateY(200px);
    -ms-transform: translateY(200px);
    opacity: 0;
  }
}
@keyframes gravity {
  to {
    transform: translateY(200px);
    -moz-transform: translateY(200px);
    -webkit-transform: translateY(200px);
    -o-transform: translateY(200px);
    -ms-transform: translateY(200px);
    opacity: 0;
  }
}
@-webkit-keyframes position {
  0%, 19.9% {
    margin-top: 10%;
    margin-left: 40%;
  }
  20%, 39.9% {
    margin-top: 40%;
    margin-left: 30%;
  }
  40%, 59.9% {
    margin-top: 20%;
    margin-left: 70%;
  }
  60%, 79.9% {
    margin-top: 30%;
    margin-left: 20%;
  }
  80%, 99.9% {
    margin-top: 30%;
    margin-left: 80%;
  }
}
@-moz-keyframes position {
  0%, 19.9% {
    margin-top: 10%;
    margin-left: 40%;
  }
  20%, 39.9% {
    margin-top: 40%;
    margin-left: 30%;
  }
  40%, 59.9% {
    margin-top: 20%;
    margin-left: 70%;
  }
  60%, 79.9% {
    margin-top: 30%;
    margin-left: 20%;
  }
  80%, 99.9% {
    margin-top: 30%;
    margin-left: 80%;
  }
}
@-o-keyframes position {
  0%, 19.9% {
    margin-top: 10%;
    margin-left: 40%;
  }
  20%, 39.9% {
    margin-top: 40%;
    margin-left: 30%;
  }
  40%, 59.9% {
    margin-top: 20%;
    margin-left: 70%;
  }
  60%, 79.9% {
    margin-top: 30%;
    margin-left: 20%;
  }
  80%, 99.9% {
    margin-top: 30%;
    margin-left: 80%;
  }
}
@-ms-keyframes position {
  0%, 19.9% {
    margin-top: 10%;
    margin-left: 40%;
  }
  20%, 39.9% {
    margin-top: 40%;
    margin-left: 30%;
  }
  40%, 59.9% {
    margin-top: 20%;
    margin-left: 70%;
  }
  60%, 79.9% {
    margin-top: 30%;
    margin-left: 20%;
  }
  80%, 99.9% {
    margin-top: 30%;
    margin-left: 80%;
  }
}
@keyframes position {
  0%, 19.9% {
    margin-top: 10%;
    margin-left: 40%;
  }
  20%, 39.9% {
    margin-top: 40%;
    margin-left: 30%;
  }
  40%, 59.9% {
    margin-top: 20%;
    margin-left: 70%;
  }
  60%, 79.9% {
    margin-top: 30%;
    margin-left: 20%;
  }
  80%, 99.9% {
    margin-top: 30%;
    margin-left: 80%;
  }
}