 
                      Syntax and What it Does.
Animation in CSS helps you manipulate an element on your website in a stylish way. Whether you want an element to bounce up and down ten times, or continuously change colors, Keyframes help you do that.
Syntax
.yourCustomClassOrID{
                        animation-name: myAnimationName;
                        animation-duration: 6s ; /* or 6000ms */
 animation-iteration-count: 2; /* or infinite */
 animation-direction: normal; /* or alternate */
 animation-delay: 1s; /* or 1000ms */
 animation-fill-mode: both; /* or backwards, forwards, none */
 animation-timing-function: ease; /* or ease-in, ease-out, ease-in-out, linear, cubic-bezier()*/}
However, there is a shorthand for this property, and it goes like this:
.yourCustomClassOrID{
                        animation: myAnimationName duration delay iteration-count direction fill-mode;}
                        Order doesn’t matter if you don’t have your duration and delay set, otherwise you have to follow this order.
To start styling your animation, we use the @keyframes rule, which is what manipulates the element from one style to another:
@keyframes myAnimationName{
                        from{ color: white }
                        to{ color: red }
                        /*From white color to red color within the duration you set in the animation property */}
Sounds easy right? Well, for this property, you also need to include prefixes to support cross-browser compatibility, and the way you initialize prefixes is the following:
.yourCustomeClassOrID{
                        -webkit-animation: myAnimationName 3s infinite; /* Safari 4.0 – 8.0 */
 -o-animation: myAnimationName 3s infinite;  /* Opera 12.0+ */
 -moz-animation: myAnimationName 3s infinite;  /* FireFox 5.0+ */
 animation: myAnimationName 3s infinite; /* IE 10.0+ */}
@-webkit-keyframes yourAnimationName{
                        0%{ background-color: red }
                        50%{ background: yellow }
                        100%{ background: blue }
                        }
@-moz-keyframes yourAnimationName{
                        0%{ background-color: red }
                        50%{ background: yellow }
                        100%{ background: blue }
                        }
@-o-keyframes yourAnimationName{
                        0%{ background-color: red }
                        50%{ background: yellow }
                        100%{ background: blue }
                        }
@keyframes yourAnimationName{
                        0%{ background-color: red }
                        50%{ background: yellow }
                        100%{ background: blue }
                        }
                        /*Any % from 0% to 100% can be used to set intervals between each animation*/
Animation Example
This concludes Animating with keyframes. The only limit to animating with keyframes is your imagination, so go out and and start animating!

