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 75.3333333333px #00ff80, 76px 29.3333333333px #00ff8c, -214px -63.6666666667px #11ff00, 25px -206.6666666667px #ff0022, -142px -206.6666666667px #009dff, 227px -404.6666666667px #00e1ff, 60px 27.3333333333px #00ffa6, -213px -210.6666666667px #ff00ea, 3px -324.6666666667px #11ff00, 176px 55.3333333333px #ff0026, 220px -407.6666666667px #22ff00, 154px -70.6666666667px #6a00ff, 200px -29.6666666667px #99ff00, -96px -104.6666666667px #ffd900, 36px -13.6666666667px #ffae00, 116px -327.6666666667px #e6ff00, -121px -362.6666666667px #00ff7b, -129px -358.6666666667px #ff0011, 166px -178.6666666667px #ff6200, 224px -112.6666666667px #62ff00, 208px 41.3333333333px #d000ff, -77px -252.6666666667px #ff8400, -23px 5.3333333333px #006aff, -128px -190.6666666667px #9dff00, 177px 68.3333333333px #00ff77, 22px -394.6666666667px #ff0015, 221px -366.6666666667px #00ffbb, -137px -20.6666666667px #00ffea, 239px -98.6666666667px #2bff00, 76px -181.6666666667px #8000ff, 89px -386.6666666667px #ff00e6, 153px -187.6666666667px #0900ff, 15px -405.6666666667px #ff0066, 96px -175.6666666667px #ff0004, -120px 9.3333333333px #00ff2f, 173px -351.6666666667px #0900ff, 127px -388.6666666667px #ffae00, -242px -177.6666666667px #1a00ff, 173px -333.6666666667px #22ff00, 157px -196.6666666667px #ff4000, -230px -339.6666666667px #aeff00, 183px -408.6666666667px #ff00a6, 172px -109.6666666667px #8c00ff, 119px -392.6666666667px #00ff1e, -137px -106.6666666667px #ff6200, 145px -347.6666666667px #fbff00, 233px -229.6666666667px #b300ff, 172px -10.6666666667px #ff1100, 65px -303.6666666667px #1100ff, -191px -406.6666666667px #ff0048, 200px -18.6666666667px #ea00ff;
    }
}
@-moz-keyframes bang {
    to {
        box-shadow: 81px 75.3333333333px #00ff80, 76px 29.3333333333px #00ff8c, -214px -63.6666666667px #11ff00, 25px -206.6666666667px #ff0022, -142px -206.6666666667px #009dff, 227px -404.6666666667px #00e1ff, 60px 27.3333333333px #00ffa6, -213px -210.6666666667px #ff00ea, 3px -324.6666666667px #11ff00, 176px 55.3333333333px #ff0026, 220px -407.6666666667px #22ff00, 154px -70.6666666667px #6a00ff, 200px -29.6666666667px #99ff00, -96px -104.6666666667px #ffd900, 36px -13.6666666667px #ffae00, 116px -327.6666666667px #e6ff00, -121px -362.6666666667px #00ff7b, -129px -358.6666666667px #ff0011, 166px -178.6666666667px #ff6200, 224px -112.6666666667px #62ff00, 208px 41.3333333333px #d000ff, -77px -252.6666666667px #ff8400, -23px 5.3333333333px #006aff, -128px -190.6666666667px #9dff00, 177px 68.3333333333px #00ff77, 22px -394.6666666667px #ff0015, 221px -366.6666666667px #00ffbb, -137px -20.6666666667px #00ffea, 239px -98.6666666667px #2bff00, 76px -181.6666666667px #8000ff, 89px -386.6666666667px #ff00e6, 153px -187.6666666667px #0900ff, 15px -405.6666666667px #ff0066, 96px -175.6666666667px #ff0004, -120px 9.3333333333px #00ff2f, 173px -351.6666666667px #0900ff, 127px -388.6666666667px #ffae00, -242px -177.6666666667px #1a00ff, 173px -333.6666666667px #22ff00, 157px -196.6666666667px #ff4000, -230px -339.6666666667px #aeff00, 183px -408.6666666667px #ff00a6, 172px -109.6666666667px #8c00ff, 119px -392.6666666667px #00ff1e, -137px -106.6666666667px #ff6200, 145px -347.6666666667px #fbff00, 233px -229.6666666667px #b300ff, 172px -10.6666666667px #ff1100, 65px -303.6666666667px #1100ff, -191px -406.6666666667px #ff0048, 200px -18.6666666667px #ea00ff;
    }
}
@-o-keyframes bang {
    to {
        box-shadow: 81px 75.3333333333px #00ff80, 76px 29.3333333333px #00ff8c, -214px -63.6666666667px #11ff00, 25px -206.6666666667px #ff0022, -142px -206.6666666667px #009dff, 227px -404.6666666667px #00e1ff, 60px 27.3333333333px #00ffa6, -213px -210.6666666667px #ff00ea, 3px -324.6666666667px #11ff00, 176px 55.3333333333px #ff0026, 220px -407.6666666667px #22ff00, 154px -70.6666666667px #6a00ff, 200px -29.6666666667px #99ff00, -96px -104.6666666667px #ffd900, 36px -13.6666666667px #ffae00, 116px -327.6666666667px #e6ff00, -121px -362.6666666667px #00ff7b, -129px -358.6666666667px #ff0011, 166px -178.6666666667px #ff6200, 224px -112.6666666667px #62ff00, 208px 41.3333333333px #d000ff, -77px -252.6666666667px #ff8400, -23px 5.3333333333px #006aff, -128px -190.6666666667px #9dff00, 177px 68.3333333333px #00ff77, 22px -394.6666666667px #ff0015, 221px -366.6666666667px #00ffbb, -137px -20.6666666667px #00ffea, 239px -98.6666666667px #2bff00, 76px -181.6666666667px #8000ff, 89px -386.6666666667px #ff00e6, 153px -187.6666666667px #0900ff, 15px -405.6666666667px #ff0066, 96px -175.6666666667px #ff0004, -120px 9.3333333333px #00ff2f, 173px -351.6666666667px #0900ff, 127px -388.6666666667px #ffae00, -242px -177.6666666667px #1a00ff, 173px -333.6666666667px #22ff00, 157px -196.6666666667px #ff4000, -230px -339.6666666667px #aeff00, 183px -408.6666666667px #ff00a6, 172px -109.6666666667px #8c00ff, 119px -392.6666666667px #00ff1e, -137px -106.6666666667px #ff6200, 145px -347.6666666667px #fbff00, 233px -229.6666666667px #b300ff, 172px -10.6666666667px #ff1100, 65px -303.6666666667px #1100ff, -191px -406.6666666667px #ff0048, 200px -18.6666666667px #ea00ff;
    }
}
@-ms-keyframes bang {
    to {
        box-shadow: 81px 75.3333333333px #00ff80, 76px 29.3333333333px #00ff8c, -214px -63.6666666667px #11ff00, 25px -206.6666666667px #ff0022, -142px -206.6666666667px #009dff, 227px -404.6666666667px #00e1ff, 60px 27.3333333333px #00ffa6, -213px -210.6666666667px #ff00ea, 3px -324.6666666667px #11ff00, 176px 55.3333333333px #ff0026, 220px -407.6666666667px #22ff00, 154px -70.6666666667px #6a00ff, 200px -29.6666666667px #99ff00, -96px -104.6666666667px #ffd900, 36px -13.6666666667px #ffae00, 116px -327.6666666667px #e6ff00, -121px -362.6666666667px #00ff7b, -129px -358.6666666667px #ff0011, 166px -178.6666666667px #ff6200, 224px -112.6666666667px #62ff00, 208px 41.3333333333px #d000ff, -77px -252.6666666667px #ff8400, -23px 5.3333333333px #006aff, -128px -190.6666666667px #9dff00, 177px 68.3333333333px #00ff77, 22px -394.6666666667px #ff0015, 221px -366.6666666667px #00ffbb, -137px -20.6666666667px #00ffea, 239px -98.6666666667px #2bff00, 76px -181.6666666667px #8000ff, 89px -386.6666666667px #ff00e6, 153px -187.6666666667px #0900ff, 15px -405.6666666667px #ff0066, 96px -175.6666666667px #ff0004, -120px 9.3333333333px #00ff2f, 173px -351.6666666667px #0900ff, 127px -388.6666666667px #ffae00, -242px -177.6666666667px #1a00ff, 173px -333.6666666667px #22ff00, 157px -196.6666666667px #ff4000, -230px -339.6666666667px #aeff00, 183px -408.6666666667px #ff00a6, 172px -109.6666666667px #8c00ff, 119px -392.6666666667px #00ff1e, -137px -106.6666666667px #ff6200, 145px -347.6666666667px #fbff00, 233px -229.6666666667px #b300ff, 172px -10.6666666667px #ff1100, 65px -303.6666666667px #1100ff, -191px -406.6666666667px #ff0048, 200px -18.6666666667px #ea00ff;
    }
}
@keyframes bang {
    to {
        box-shadow: 81px 75.3333333333px #00ff80, 76px 29.3333333333px #00ff8c, -214px -63.6666666667px #11ff00, 25px -206.6666666667px #ff0022, -142px -206.6666666667px #009dff, 227px -404.6666666667px #00e1ff, 60px 27.3333333333px #00ffa6, -213px -210.6666666667px #ff00ea, 3px -324.6666666667px #11ff00, 176px 55.3333333333px #ff0026, 220px -407.6666666667px #22ff00, 154px -70.6666666667px #6a00ff, 200px -29.6666666667px #99ff00, -96px -104.6666666667px #ffd900, 36px -13.6666666667px #ffae00, 116px -327.6666666667px #e6ff00, -121px -362.6666666667px #00ff7b, -129px -358.6666666667px #ff0011, 166px -178.6666666667px #ff6200, 224px -112.6666666667px #62ff00, 208px 41.3333333333px #d000ff, -77px -252.6666666667px #ff8400, -23px 5.3333333333px #006aff, -128px -190.6666666667px #9dff00, 177px 68.3333333333px #00ff77, 22px -394.6666666667px #ff0015, 221px -366.6666666667px #00ffbb, -137px -20.6666666667px #00ffea, 239px -98.6666666667px #2bff00, 76px -181.6666666667px #8000ff, 89px -386.6666666667px #ff00e6, 153px -187.6666666667px #0900ff, 15px -405.6666666667px #ff0066, 96px -175.6666666667px #ff0004, -120px 9.3333333333px #00ff2f, 173px -351.6666666667px #0900ff, 127px -388.6666666667px #ffae00, -242px -177.6666666667px #1a00ff, 173px -333.6666666667px #22ff00, 157px -196.6666666667px #ff4000, -230px -339.6666666667px #aeff00, 183px -408.6666666667px #ff00a6, 172px -109.6666666667px #8c00ff, 119px -392.6666666667px #00ff1e, -137px -106.6666666667px #ff6200, 145px -347.6666666667px #fbff00, 233px -229.6666666667px #b300ff, 172px -10.6666666667px #ff1100, 65px -303.6666666667px #1100ff, -191px -406.6666666667px #ff0048, 200px -18.6666666667px #ea00ff;
    }
}
@-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%;
    }
}
