


.hvr-grow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-grow:hover, .hvr-grow:focus, .hvr-grow:active {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

/* Shrink */
.hvr-shrink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-shrink:hover, .hvr-shrink:focus, .hvr-shrink:active {
  -webkit-transform: scale(0.9);
  transform: scale(0.9);
}

/* Pulse */
@-webkit-keyframes hvr-pulse {
  25% {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }

  75% {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
  }
}

@keyframes hvr-pulse {
  25% {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }

  75% {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
  }
}

.hvr-pulse {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-pulse:hover, .hvr-pulse:focus, .hvr-pulse:active {
  -webkit-animation-name: hvr-pulse;
  animation-name: hvr-pulse;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

/* Pulse Grow */
@-webkit-keyframes hvr-pulse-grow {
  to {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@keyframes hvr-pulse-grow {
  to {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

.hvr-pulse-grow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-pulse-grow:hover, .hvr-pulse-grow:focus, .hvr-pulse-grow:active {
  -webkit-animation-name: hvr-pulse-grow;
  animation-name: hvr-pulse-grow;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
  animation-direction: alternate;
}

/* Pulse Shrink */
@-webkit-keyframes hvr-pulse-shrink {
  to {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
  }
}

@keyframes hvr-pulse-shrink {
  to {
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
  }
}

.hvr-pulse-shrink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-pulse-shrink:hover, .hvr-pulse-shrink:focus, .hvr-pulse-shrink:active {
  -webkit-animation-name: hvr-pulse-shrink;
  animation-name: hvr-pulse-shrink;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
  animation-direction: alternate;
}

/* Push */
@-webkit-keyframes hvr-push {
  50% {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }

  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes hvr-push {
  50% {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }

  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

.hvr-push {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-push:hover, .hvr-push:focus, .hvr-push:active {
  -webkit-animation-name: hvr-push;
  animation-name: hvr-push;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Pop */
@-webkit-keyframes hvr-pop {
  50% {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
  }
}

@keyframes hvr-pop {
  50% {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
  }
}

.hvr-pop {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-pop:hover, .hvr-pop:focus, .hvr-pop:active {
  -webkit-animation-name: hvr-pop;
  animation-name: hvr-pop;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  cursor:pointer;
}

/* Bounce In */
.hvr-bounce-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-in:hover, .hvr-bounce-in:focus, .hvr-bounce-in:active {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
  transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

/* Bounce Out */
.hvr-bounce-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-out:hover, .hvr-bounce-out:focus, .hvr-bounce-out:active {
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
  -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
  transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

/* Rotate */
.hvr-rotate {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-rotate:hover, .hvr-rotate:focus, .hvr-rotate:active {
  -webkit-transform: rotate(4deg);
  transform: rotate(4deg);
}

/* Grow Rotate */
.hvr-grow-rotate {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-grow-rotate:hover, .hvr-grow-rotate:focus, .hvr-grow-rotate:active {
  -webkit-transform: scale(1.1) rotate(4deg);
  transform: scale(1.1) rotate(4deg);
}

/* Float */
.hvr-float {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-float:hover, .hvr-float:focus, .hvr-float:active {
  -webkit-transform: translateY(-8px);
  transform: translateY(-8px);
}

/* Sink */
.hvr-sink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-sink:hover, .hvr-sink:focus, .hvr-sink:active {
  -webkit-transform: translateY(8px);
  transform: translateY(8px);
}

/* Bob */
@-webkit-keyframes hvr-bob {
  0% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }

  50% {
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px);
  }

  100% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }
}

@keyframes hvr-bob {
  0% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }

  50% {
    -webkit-transform: translateY(-4px);
    transform: translateY(-4px);
  }

  100% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }
}

@-webkit-keyframes hvr-bob-float {
  100% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }
}

@keyframes hvr-bob-float {
  100% {
    -webkit-transform: translateY(-8px);
    transform: translateY(-8px);
  }
}

.hvr-bob {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-bob:hover, .hvr-bob:focus, .hvr-bob:active {
  -webkit-animation-name: hvr-bob-float, hvr-bob;
  animation-name: hvr-bob-float, hvr-bob;
  -webkit-animation-duration: .3s, 1.5s;
  animation-duration: .3s, 1.5s;
  -webkit-animation-delay: 0s, .3s;
  animation-delay: 0s, .3s;
  -webkit-animation-timing-function: ease-out, ease-in-out;
  animation-timing-function: ease-out, ease-in-out;
  -webkit-animation-iteration-count: 1, infinite;
  animation-iteration-count: 1, infinite;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-direction: normal, alternate;
  animation-direction: normal, alternate;
}

/* Hang */
@-webkit-keyframes hvr-hang {
  0% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }

  50% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
  }

  100% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }
}

@keyframes hvr-hang {
  0% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }

  50% {
    -webkit-transform: translateY(4px);

    transform: translateY(4px);
  }

  100% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }
}

@-webkit-keyframes hvr-hang-sink {
  100% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }
}

@keyframes hvr-hang-sink {
  100% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }
}

.hvr-hang {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-hang:hover, .hvr-hang:focus, .hvr-hang:active {
  -webkit-animation-name: hvr-hang-sink, hvr-hang;
  animation-name: hvr-hang-sink, hvr-hang;
  -webkit-animation-duration: .3s, 1.5s;
  animation-duration: .3s, 1.5s;
  -webkit-animation-delay: 0s, .3s;
  animation-delay: 0s, .3s;
  -webkit-animation-timing-function: ease-out, ease-in-out;
  animation-timing-function: ease-out, ease-in-out;
  -webkit-animation-iteration-count: 1, infinite;
  animation-iteration-count: 1, infinite;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-direction: normal, alternate;
  animation-direction: normal, alternate;
}

/* Skew */
.hvr-skew {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-skew:hover, .hvr-skew:focus, .hvr-skew:active {
  -webkit-transform: skew(-10deg);
  transform: skew(-10deg);
}

/* Skew Forward */
.hvr-skew-forward {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
.hvr-skew-forward:hover, .hvr-skew-forward:focus, .hvr-skew-forward:active {
  -webkit-transform: skew(-10deg);
  transform: skew(-10deg);
}

/* Skew Backward */
.hvr-skew-backward {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
.hvr-skew-backward:hover, .hvr-skew-backward:focus, .hvr-skew-backward:active {
  -webkit-transform: skew(10deg);
  transform: skew(10deg);
}

/* Wobble Vertical */
@-webkit-keyframes hvr-wobble-vertical {
  16.65% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }

  33.3% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }

  49.95% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
  }

  66.6% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  83.25% {
    -webkit-transform: translateY(1px);
    transform: translateY(1px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes hvr-wobble-vertical {
  16.65% {
    -webkit-transform: translateY(8px);
    transform: translateY(8px);
  }

  33.3% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }

  49.95% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
  }

  66.6% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  83.25% {
    -webkit-transform: translateY(1px);
    transform: translateY(1px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.hvr-wobble-vertical {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-wobble-vertical:hover, .hvr-wobble-vertical:focus, .hvr-wobble-vertical:active {
  -webkit-animation-name: hvr-wobble-vertical;
  animation-name: hvr-wobble-vertical;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble Horizontal */
@-webkit-keyframes hvr-wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(8px);
    transform: translateX(8px);
  }

  33.3% {
    -webkit-transform: translateX(-6px);
    transform: translateX(-6px);
  }

  49.95% {
    -webkit-transform: translateX(4px);
    transform: translateX(4px);
  }

  66.6% {
    -webkit-transform: translateX(-2px);
    transform: translateX(-2px);
  }

  83.25% {
    -webkit-transform: translateX(1px);
    transform: translateX(1px);
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes hvr-wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(8px);
    transform: translateX(8px);
  }

  33.3% {
    -webkit-transform: translateX(-6px);
    transform: translateX(-6px);
  }

  49.95% {
    -webkit-transform: translateX(4px);
    transform: translateX(4px);
  }

  66.6% {
    -webkit-transform: translateX(-2px);
    transform: translateX(-2px);
  }

  83.25% {
    -webkit-transform: translateX(1px);
    transform: translateX(1px);
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

.hvr-wobble-horizontal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-wobble-horizontal:hover, .hvr-wobble-horizontal:focus, .hvr-wobble-horizontal:active {
  -webkit-animation-name: hvr-wobble-horizontal;
  animation-name: hvr-wobble-horizontal;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble To Bottom Right */
@-webkit-keyframes hvr-wobble-to-bottom-right {
  16.65% {
    -webkit-transform: translate(8px, 8px);
    transform: translate(8px, 8px);
  }

  33.3% {
    -webkit-transform: translate(-6px, -6px);
    transform: translate(-6px, -6px);
  }

  49.95% {
    -webkit-transform: translate(4px, 4px);
    transform: translate(4px, 4px);
  }

  66.6% {
    -webkit-transform: translate(-2px, -2px);
    transform: translate(-2px, -2px);
  }

  83.25% {
    -webkit-transform: translate(1px, 1px);
    transform: translate(1px, 1px);
  }

  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

@keyframes hvr-wobble-to-bottom-right {
  16.65% {
    -webkit-transform: translate(8px, 8px);
    transform: translate(8px, 8px);
  }

  33.3% {
    -webkit-transform: translate(-6px, -6px);
    transform: translate(-6px, -6px);
  }

  49.95% {
    -webkit-transform: translate(4px, 4px);
    transform: translate(4px, 4px);
  }

  66.6% {
    -webkit-transform: translate(-2px, -2px);
    transform: translate(-2px, -2px);
  }

  83.25% {
    -webkit-transform: translate(1px, 1px);
    transform: translate(1px, 1px);
  }

  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

.hvr-wobble-to-bottom-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-wobble-to-bottom-right:hover, .hvr-wobble-to-bottom-right:focus, .hvr-wobble-to-bottom-right:active {
  -webkit-animation-name: hvr-wobble-to-bottom-right;
  animation-name: hvr-wobble-to-bottom-right;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble To Top Right */
@-webkit-keyframes hvr-wobble-to-top-right {
  16.65% {
    -webkit-transform: translate(8px, -8px);
    transform: translate(8px, -8px);
  }

  33.3% {
    -webkit-transform: translate(-6px, 6px);
    transform: translate(-6px, 6px);
  }

  49.95% {
    -webkit-transform: translate(4px, -4px);
    transform: translate(4px, -4px);
  }

  66.6% {
    -webkit-transform: translate(-2px, 2px);
    transform: translate(-2px, 2px);
  }

  83.25% {
    -webkit-transform: translate(1px, -1px);
    transform: translate(1px, -1px);
  }

  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

@keyframes hvr-wobble-to-top-right {
  16.65% {
    -webkit-transform: translate(8px, -8px);
    transform: translate(8px, -8px);
  }

  33.3% {
    -webkit-transform: translate(-6px, 6px);
    transform: translate(-6px, 6px);
  }

  49.95% {
    -webkit-transform: translate(4px, -4px);
    transform: translate(4px, -4px);
  }

  66.6% {
    -webkit-transform: translate(-2px, 2px);
    transform: translate(-2px, 2px);
  }

  83.25% {
    -webkit-transform: translate(1px, -1px);
    transform: translate(1px, -1px);
  }

  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

.hvr-wobble-to-top-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-wobble-to-top-right:hover, .hvr-wobble-to-top-right:focus, .hvr-wobble-to-top-right:active {
  -webkit-animation-name: hvr-wobble-to-top-right;
  animation-name: hvr-wobble-to-top-right;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble Top */
@-webkit-keyframes hvr-wobble-top {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

@keyframes hvr-wobble-top {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

.hvr-wobble-top {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
.hvr-wobble-top:hover, .hvr-wobble-top:focus, .hvr-wobble-top:active {
  -webkit-animation-name: hvr-wobble-top;
  animation-name: hvr-wobble-top;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble Bottom */
@-webkit-keyframes hvr-wobble-bottom {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

@keyframes hvr-wobble-bottom {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

.hvr-wobble-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transform-origin: 100% 0;
  transform-origin: 100% 0;
}
.hvr-wobble-bottom:hover, .hvr-wobble-bottom:focus, .hvr-wobble-bottom:active {
  -webkit-animation-name: hvr-wobble-bottom;
  animation-name: hvr-wobble-bottom;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Wobble Skew */
@-webkit-keyframes hvr-wobble-skew {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

@keyframes hvr-wobble-skew {
  16.65% {
    -webkit-transform: skew(-12deg);
    transform: skew(-12deg);
  }

  33.3% {
    -webkit-transform: skew(10deg);
    transform: skew(10deg);
  }

  49.95% {
    -webkit-transform: skew(-6deg);
    transform: skew(-6deg);
  }

  66.6% {
    -webkit-transform: skew(4deg);
    transform: skew(4deg);
  }

  83.25% {
    -webkit-transform: skew(-2deg);
    transform: skew(-2deg);
  }

  100% {
    -webkit-transform: skew(0);
    transform: skew(0);
  }
}

.hvr-wobble-skew {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-wobble-skew:hover, .hvr-wobble-skew:focus, .hvr-wobble-skew:active {
  -webkit-animation-name: hvr-wobble-skew;
  animation-name: hvr-wobble-skew;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Buzz */
@-webkit-keyframes hvr-buzz {
  50% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  100% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }
}

@keyframes hvr-buzz {
  50% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  100% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }
}

.hvr-buzz {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-buzz:hover, .hvr-buzz:focus, .hvr-buzz:active {
  -webkit-animation-name: hvr-buzz;
  animation-name: hvr-buzz;
  -webkit-animation-duration: 0.15s;
  animation-duration: 0.15s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

/* Buzz Out */
@-webkit-keyframes hvr-buzz-out {
  10% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  20% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  30% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  40% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  50% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  60% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  70% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  80% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  90% {
    -webkit-transform: translateX(1px) rotate(0);
    transform: translateX(1px) rotate(0);
  }

  100% {
    -webkit-transform: translateX(-1px) rotate(0);
    transform: translateX(-1px) rotate(0);
  }
}

@keyframes hvr-buzz-out {
  10% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  20% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  30% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  40% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  50% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  60% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  70% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  80% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  90% {
    -webkit-transform: translateX(1px) rotate(0);
    transform: translateX(1px) rotate(0);
  }

  100% {
    -webkit-transform: translateX(-1px) rotate(0);
    transform: translateX(-1px) rotate(0);
  }
}

.hvr-buzz-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
}
.hvr-buzz-out:hover, .hvr-buzz-out:focus, .hvr-buzz-out:active {
  -webkit-animation-name: hvr-buzz-out;
  animation-name: hvr-buzz-out;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* BACKGROUND TRANSITIONS */
/* Fade */
.hvr-fade {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;
  -webkit-transition-duration: 0.7s;
  transition-duration: 0.7s;
  -webkit-transition-property: color, background-color;
  transition-property: color, background-color;
}
.hvr-fade:hover, .hvr-fade:focus, .hvr-fade:active {
  background-color:rgb(235,245,230);
}

/* Back Pulse */
@-webkit-keyframes hvr-back-pulse {
  50% {
    background-color: rgba(65,160,10, 0.75);
  }
}

@keyframes hvr-back-pulse {
  50% {
    background-color: rgba(65,160,10, 0.75);
  }
}

.hvr-back-pulse {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-property: color, background-color;
  transition-property: color, background-color;
}
.hvr-back-pulse:hover, .hvr-back-pulse:focus, .hvr-back-pulse:active {
  -webkit-animation-name: hvr-back-pulse;
  animation-name: hvr-back-pulse;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-delay: 0.5s;
  animation-delay: 0.5s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  background-color: rgb(65,160,10);
  color: white;
}

/* Sweep To Right */
.hvr-sweep-to-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-sweep-to-right:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgb(255,255,255);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-sweep-to-right:hover, .hvr-sweep-to-right:focus, .hvr-sweep-to-right:active {
  color: white;
}
.hvr-sweep-to-right:hover:before, .hvr-sweep-to-right:focus:before, .hvr-sweep-to-right:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

/* Sweep To Left */
.hvr-sweep-to-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-sweep-to-left:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgb(83,178,83);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-sweep-to-left:hover, .hvr-sweep-to-left:focus, .hvr-sweep-to-left:active {
  color: white;
}
.hvr-sweep-to-left:hover:before, .hvr-sweep-to-left:focus:before, .hvr-sweep-to-left:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

/* Sweep To Bottom */
.hvr-sweep-to-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-sweep-to-bottom:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgba(0,0,0,.05);
  color:
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50% 0;
  transform-origin: 50% 0;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-sweep-to-bottom:hover, .hvr-sweep-to-bottom:focus, .hvr-sweep-to-bottom:active {
  color: white;
}
.hvr-sweep-to-bottom:hover:before, .hvr-sweep-to-bottom:focus:before, .hvr-sweep-to-bottom:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
}

/* Sweep To Top */
.hvr-sweep-to-top {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-sweep-to-top:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgb(255,255,255);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-sweep-to-top:hover, .hvr-sweep-to-top:focus, .hvr-sweep-to-top:active {
  color: white;
}
.hvr-sweep-to-top:hover:before, .hvr-sweep-to-top:focus:before, .hvr-sweep-to-top:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
}

/* Bounce To Right */
.hvr-bounce-to-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-to-right:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgba(0,85,155,1);
  color:rgb(255,255,255);
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 40%;
  transform-origin: 0 40%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-bounce-to-right:hover, .hvr-bounce-to-right:focus, .hvr-bounce-to-right:active {
  color: white;
}
.hvr-bounce-to-right:hover:before, .hvr-bounce-to-right:focus:before, .hvr-bounce-to-right:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}
.hvr-bounce-to-right a:hover {
	color:white !important;
}

/* Bounce To Left */
.hvr-bounce-to-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-to-left:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #2098d1;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-bounce-to-left:hover, .hvr-bounce-to-left:focus, .hvr-bounce-to-left:active {
  color: white;
}
.hvr-bounce-to-left:hover:before, .hvr-bounce-to-left:focus:before, .hvr-bounce-to-left:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}

/* Bounce To Bottom */
.hvr-bounce-to-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-to-bottom:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:rgb(65,160,10);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50% 0;
  transform-origin: 50% 0;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-bounce-to-bottom:hover, .hvr-bounce-to-bottom:focus, .hvr-bounce-to-bottom:active {
  color: white;
  background:rgb(65,160,10);
}
.hvr-bounce-to-bottom:hover:before, .hvr-bounce-to-bottom:focus:before, .hvr-bounce-to-bottom:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}

/* Bounce To Top */
.hvr-bounce-to-top {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}
.hvr-bounce-to-top:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgb(65,160,10);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-bounce-to-top:hover, .hvr-bounce-to-top:focus, .hvr-bounce-to-top:active {
  color: white;
  background: rgb(65,160,10);
}
.hvr-bounce-to-top:hover:before, .hvr-bounce-to-top:focus:before, .hvr-bounce-to-top:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  background: rgb(65,160,10);
}

/* Radial Out */
.hvr-radial-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
  background: #e1e1e1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-radial-out:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #2098d1;
  border-radius: 100%;
  -webkit-transform: scale(0);
  transform: scale(0);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-radial-out:hover, .hvr-radial-out:focus, .hvr-radial-out:active {
  color: white;
}
.hvr-radial-out:hover:before, .hvr-radial-out:focus:before, .hvr-radial-out:active:before {
  -webkit-transform: scale(2);
  transform: scale(2);
}

/* Radial In */
.hvr-radial-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
  background: #2098d1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-radial-in:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #e1e1e1;
  border-radius: 100%;
  -webkit-transform: scale(2);
  transform: scale(2);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-radial-in:hover, .hvr-radial-in:focus, .hvr-radial-in:active {
  color: white;
}
.hvr-radial-in:hover:before, .hvr-radial-in:focus:before, .hvr-radial-in:active:before {
  -webkit-transform: scale(0);
  transform: scale(0);
}

/* Rectangle In */
.hvr-rectangle-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background: #2098d1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-rectangle-in:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #e1e1e1;
  -webkit-transform: scale(1);
  transform: scale(1);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-rectangle-in:hover, .hvr-rectangle-in:focus, .hvr-rectangle-in:active {
  color: white;
}
.hvr-rectangle-in:hover:before, .hvr-rectangle-in:focus:before, .hvr-rectangle-in:active:before {
  -webkit-transform: scale(0);
  transform: scale(0);
}

/* Rectangle Out */
.hvr-rectangle-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background: #e1e1e1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-rectangle-out:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #2098d1;
  -webkit-transform: scale(0);
  transform: scale(0);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-rectangle-out:hover, .hvr-rectangle-out:focus, .hvr-rectangle-out:active {
  color: white;
}
.hvr-rectangle-out:hover:before, .hvr-rectangle-out:focus:before, .hvr-rectangle-out:active:before {
  -webkit-transform: scale(1);
  transform: scale(1);
}

/* Shutter In Horizontal */
.hvr-shutter-in-horizontal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background: #2098d1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-shutter-in-horizontal:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #e1e1e1;
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-shutter-in-horizontal:hover, .hvr-shutter-in-horizontal:focus, .hvr-shutter-in-horizontal:active {
  color: white;
}
.hvr-shutter-in-horizontal:hover:before, .hvr-shutter-in-horizontal:focus:before, .hvr-shutter-in-horizontal:active:before {
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
}

/* Shutter Out Horizontal */
.hvr-shutter-out-horizontal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background: #e1e1e1;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-shutter-out-horizontal:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #2098d1;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-shutter-out-horizontal:hover, .hvr-shutter-out-horizontal:focus, .hvr-shutter-out-horizontal:active {
  color: white;
}
.hvr-shutter-out-horizontal:hover:before, .hvr-shutter-out-horizontal:focus:before, .hvr-shutter-out-horizontal:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}

/* Shutter In Vertical */
.hvr-shutter-in-vertical {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background: #FFF;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.2s;
  transition-duration: 0.2s;
}
.hvr-shutter-in-vertical:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #FFF;
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-shutter-in-vertical:hover, .hvr-shutter-in-vertical:focus, .hvr-shutter-in-vertical:active {
  color: white;
  background-color:#00559b;
}
.hvr-shutter-in-vertical:hover:before, .hvr-shutter-in-vertical:focus:before, .hvr-shutter-in-vertical:active:before {
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
}

/* Shutter Out Vertical */
.hvr-shutter-out-vertical {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  background:rgb(255,255,255);
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-shutter-out-vertical:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background:rgb(255,255,255);
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-shutter-out-vertical:hover, .hvr-shutter-out-vertical:focus, .hvr-shutter-out-vertical:active {
  color: white;
  background:rgb(65,160,10);
}
.hvr-shutter-out-vertical:hover:before, .hvr-shutter-out-vertical:focus:before, .hvr-shutter-out-vertical:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
}

/* BORDER TRANSITIONS */
/* Border Fade */
.hvr-border-fade {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow;
  transition-property: box-shadow;
  box-shadow: inset 0 0 0 4px #e1e1e1, 0 0 1px rgba(0, 0, 0, 0);
  /* Hack to improve aliasing on mobile/tablet devices */
}
.hvr-border-fade:hover, .hvr-border-fade:focus, .hvr-border-fade:active {
  box-shadow: inset 0 0 0 4px #2098d1, 0 0 1px rgba(0, 0, 0, 0);
  /* Hack to improve aliasing on mobile/tablet devices */
}

/* Hollow */
.hvr-hollow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: background;
  transition-property: background;
  box-shadow: inset 0 0 0 4px #e1e1e1, 0 0 1px rgba(0, 0, 0, 0);
  /* Hack to improve aliasing on mobile/tablet devices */
}
.hvr-hollow:hover, .hvr-hollow:focus, .hvr-hollow:active {
  background: none;
}

/* Trim */
.hvr-trim {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-trim:before {
  content: '';
  position: absolute;
  border: white solid 4px;
  top: 4px;
  left: 4px;
  right: 4px;
  bottom: 4px;
  opacity: 0;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: opacity;
  transition-property: opacity;
}
.hvr-trim:hover:before, .hvr-trim:focus:before, .hvr-trim:active:before {
  opacity: 1;
}

/* Ripple Out */
@-webkit-keyframes hvr-ripple-out {
  100% {
    top: -12px;
    right: -12px;
    bottom: -12px;
    left: -12px;
    opacity: 0;
  }
}

@keyframes hvr-ripple-out {
  100% {
    top: -12px;
    right: -12px;
    bottom: -12px;
    left: -12px;
    opacity: 0;
  }
}

.hvr-ripple-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-ripple-out:before {
  content: '';
  position: absolute;
  border: #e1e1e1 solid 1px;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
}
.hvr-ripple-out:hover:before, .hvr-ripple-out:focus:before, .hvr-ripple-out:active:before {
  -webkit-animation-name: hvr-ripple-out;
  animation-name: hvr-ripple-out;
}

/* Ripple In */
@-webkit-keyframes hvr-ripple-in {
  100% {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 1;
  }
}

@keyframes hvr-ripple-in {
  100% {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 1;
  }
}

.hvr-ripple-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-ripple-in:before {
  content: '';
  position: absolute;
  border: #e1e1e1 solid 4px;
  top: -12px;
  right: -12px;
  bottom: -12px;
  left: -12px;
  opacity: 0;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
}
.hvr-ripple-in:hover:before, .hvr-ripple-in:focus:before, .hvr-ripple-in:active:before {
  -webkit-animation-name: hvr-ripple-in;
  animation-name: hvr-ripple-in;
}

/* Outline Out */
.hvr-outline-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-outline-out:before {
  content: '';
  position: absolute;
  border: #e1e1e1 solid 4px;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: top, right, bottom, left;
  transition-property: top, right, bottom, left;
}
.hvr-outline-out:hover:before, .hvr-outline-out:focus:before, .hvr-outline-out:active:before {
  top: -8px;
  right: -8px;
  bottom: -8px;
  left: -8px;
}

/* Outline In */

.hvr-outline-in {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-outline-in:before {
  pointer-events: none;
  content: '';
  position: absolute;
  border: #e1e1e1 solid 4px;
  top: -16px;
  right: -16px;
  bottom: -16px;
  left: -16px;
  opacity: 0;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: top, right, bottom, left;
  transition-property: top, right, bottom, left;
}
.hvr-outline-in:hover:before, .hvr-outline-in:focus:before, .hvr-outline-in:active:before {
  top: -8px;
  right: -8px;
  bottom: -8px;
  left: -8px;
  opacity: 1;
}

/* Round Corners */
.hvr-round-corners {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: border-radius;
  transition-property: border-radius;
}
.hvr-round-corners:hover, .hvr-round-corners:focus, .hvr-round-corners:active {
  border-radius: 1em;
}

/* Underline From Left */
.hvr-underline-from-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow-y:auto;
}
.hvr-underline-from-left:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 100%;
  bottom: 0;
  background:#f0a00a;
  height:5px;
  -webkit-transition-property: right;
  transition-property: right;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-underline-from-left:hover:before, .hvr-underline-from-left:focus:before, .hvr-underline-from-left:active:before {
  right: 0;
}

/* Underline From Center */
.hvr-underline-from-center {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-underline-from-center:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 50%;
  right: 50%;
  bottom: 0;
  background: #2098d1;
  height: 2px;
  -webkit-transition-property: left, right;
  transition-property: left, right;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-underline-from-center:hover:before, .hvr-underline-from-center:focus:before, .hvr-underline-from-center:active:before {
  left: 0;
  right: 0;
}

/* Underline From Right */
.hvr-underline-from-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(255, 255, 255, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  position: relative;
  overflow: hidden;
}
.hvr-underline-from-right:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 100%;
  right: 0;
  bottom: 0;
  background:rgb(65,160,10);
  height:2px;
  -webkit-transition-property: left;
  transition-property: left;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-underline-from-right:hover:before, .hvr-underline-from-right:focus:before, .hvr-underline-from-right:active:before {
  left: 0;
}

/* Overline From Left */
.hvr-overline-from-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-overline-from-left:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 100%;
  top: 0;
  background: #2098d1;
  height: 4px;
  -webkit-transition-property: right;
  transition-property: right;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-overline-from-left:hover:before, .hvr-overline-from-left:focus:before, .hvr-overline-from-left:active:before {
  right: 0;
}

/* Overline From Center */
.hvr-overline-from-center {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-overline-from-center:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 50%;
  right: 50%;
  top: 0;
  background: #2098d1;
  height: 4px;
  -webkit-transition-property: left, right;
  transition-property: left, right;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-overline-from-center:hover:before, .hvr-overline-from-center:focus:before, .hvr-overline-from-center:active:before {
  left: 0;
  right: 0;
}

/* Overline From Right */
.hvr-overline-from-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-overline-from-right:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 100%;
  right: 0;
  top: 0;
  background: #2098d1;
  height: 4px;
  -webkit-transition-property: left;
  transition-property: left;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-overline-from-right:hover:before, .hvr-overline-from-right:focus:before, .hvr-overline-from-right:active:before {
  left: 0;
}

/* Reveal */
.hvr-reveal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-reveal:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  border-color: rgb(255,255,255);
  border-style: solid;
  border-width: 0;
  -webkit-transition-property: border-width;
  transition-property: border-width;
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-reveal:hover:before, .hvr-reveal:focus:before, .hvr-reveal:active:before {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  border-width: 8px;
}

/* Underline Reveal */
.hvr-underline-reveal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-underline-reveal:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgb(255,255,255);
  height: 2px;
  -webkit-transform: translateY(4px);
  transform: translateY(4px);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-underline-reveal:hover:before, .hvr-underline-reveal:focus:before, .hvr-underline-reveal:active:before {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

/* Overline Reveal */
.hvr-overline-reveal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  overflow: hidden;
}
.hvr-overline-reveal:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  top: 0;
  background: #2098d1;
  height: 4px;
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-overline-reveal:hover:before, .hvr-overline-reveal:focus:before, .hvr-overline-reveal:active:before {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

/* SHADOW/GLOW TRANSITIONS */
/* Glow */
.hvr-glow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow;
  transition-property: box-shadow;
}
.hvr-glow:hover, .hvr-glow:focus, .hvr-glow:active {
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.7);
}

/* Shadow */
.hvr-shadow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow;
  transition-property: box-shadow;
}
.hvr-shadow:hover, .hvr-shadow:focus, .hvr-shadow:active {
  box-shadow: 0 10px 10px -10px rgba(0, 0, 0, 0.5);
}

/* Grow Shadow */
.hvr-grow-shadow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow, transform;
  transition-property: box-shadow, transform;
}
.hvr-grow-shadow:hover, .hvr-grow-shadow:focus, .hvr-grow-shadow:active {
  box-shadow: 0 10px 10px -10px rgba(0, 0, 0, 0.5);
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

/* Box Shadow Outset */
.hvr-box-shadow-outset {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow;
  transition-property: box-shadow;
}
.hvr-box-shadow-outset:hover, .hvr-box-shadow-outset:focus, .hvr-box-shadow-outset:active {
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.6);
}

/* Box Shadow Inset */
.hvr-box-shadow-inset {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: box-shadow;
  transition-property: box-shadow;
  box-shadow: inset 0 0 0 rgba(0, 0, 0, 0.6), 0 0 1px rgba(0, 0, 0, 0);
  /* Hack to improve aliasing on mobile/tablet devices */
}
.hvr-box-shadow-inset:hover, .hvr-box-shadow-inset:focus, .hvr-box-shadow-inset:active {
  box-shadow: inset 2px 2px 2px rgba(0, 0, 0, 0.6), 0 0 1px rgba(0, 0, 0, 0);
  /* Hack to improve aliasing on mobile/tablet devices */
}

/* Float Shadow */
.hvr-float-shadow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-float-shadow:before {
  pointer-events: none;
  position: absolute;
  z-index: -1;
  content: '';
  top: 100%;
  left: 5%;
  height: 10px;
  width: 90%;
  opacity: 0;
  background: -webkit-radial-gradient(center, ellipse, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0) 80%);
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0) 80%);
  /* W3C */
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform, opacity;
  transition-property: transform, opacity;
}
.hvr-float-shadow:hover, .hvr-float-shadow:focus, .hvr-float-shadow:active {
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
  /* move the element up by 5px */
}
.hvr-float-shadow:hover:before, .hvr-float-shadow:focus:before, .hvr-float-shadow:active:before {
  opacity: 1;
  -webkit-transform: translateY(5px);
  transform: translateY(5px);
  /* move the element down by 5px (it will stay in place because it's attached to the element that also moves up 5px) */
}

/* Shadow Radial */
.hvr-shadow-radial {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-shadow-radial:before, .hvr-shadow-radial:after {
  pointer-events: none;
  position: absolute;
  content: '';
  left: 0;
  width: 100%;
  box-sizing: border-box;
  background-repeat: no-repeat;
  height: 5px;
  opacity: 0;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: opacity;
  transition-property: opacity;
}
.hvr-shadow-radial:before {
  bottom: 100%;
  background: -webkit-radial-gradient(50% 150%, ellipse, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 80%);
  background: radial-gradient(ellipse at 50% 150%, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 80%);
}
.hvr-shadow-radial:after {
  top: 100%;
  background: -webkit-radial-gradient(50% -50%, ellipse, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 80%);
  background: radial-gradient(ellipse at 50% -50%, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 80%);
}
.hvr-shadow-radial:hover:before, .hvr-shadow-radial:focus:before, .hvr-shadow-radial:active:before, .hvr-shadow-radial:hover:after, .hvr-shadow-radial:focus:after, .hvr-shadow-radial:active:after {
  opacity: 1;
}

/* SPEECH BUBBLES */
/* Bubble Top */
.hvr-bubble-top {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-bubble-top:before {
  pointer-events: none;
  position: absolute;
  z-index: -1;
  content: '';
  border-style: solid;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  left: calc(50% - 10px);
  top: 0;
  border-width: 0 10px 10px 10px;
  border-color: transparent transparent #e1e1e1 transparent;
}
.hvr-bubble-top:hover:before, .hvr-bubble-top:focus:before, .hvr-bubble-top:active:before {
  -webkit-transform: translateY(-10px);
  transform: translateY(-10px);
}

/* Bubble Right */
.hvr-bubble-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-bubble-right:before {
  pointer-events: none;
  position: absolute;
  z-index: -1;
  content: '';
  border-style: solid;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  top: calc(50% - 10px);
  right: 0;
  border-width: 10px 0 10px 10px;
  border-color: transparent transparent transparent #e1e1e1;
}
.hvr-bubble-right:hover:before, .hvr-bubble-right:focus:before, .hvr-bubble-right:active:before {
  -webkit-transform: translateX(10px);
  transform: translateX(10px);
}

/* Bubble Bottom */
.hvr-bubble-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-bubble-bottom:before {
  pointer-events: none;
  position: absolute;
  z-index: -1;
  content: '';
  border-style: solid;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  left: calc(50% - 10px);
  bottom: 0;
  border-width: 10px 10px 0 10px;
  border-color: #e1e1e1 transparent transparent transparent;
}
.hvr-bubble-bottom:hover:before, .hvr-bubble-bottom:focus:before, .hvr-bubble-bottom:active:before {
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
}

/* Bubble Left */
.hvr-bubble-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-bubble-left:before {
  pointer-events: none;
  position: absolute;
  z-index: -1;
  content: '';
  border-style: solid;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  top: calc(50% - 10px);
  left: 0;
  border-width: 10px 10px 10px 0;
  border-color: transparent #e1e1e1 transparent transparent;
}
.hvr-bubble-left:hover:before, .hvr-bubble-left:focus:before, .hvr-bubble-left:active:before {
  -webkit-transform: translateX(-10px);
  transform: translateX(-10px);
}

/* Bubble Float Top */
.hvr-bubble-float-top {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-top:before {
  position: absolute;
  z-index: -1;
  content: '';
  left: calc(50% - 10px);
  top: 0;
  border-style: solid;
  border-width: 0 10px 10px 10px;
  border-color: transparent transparent #e1e1e1 transparent;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-top:hover, .hvr-bubble-float-top:focus, .hvr-bubble-float-top:active {
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
}
.hvr-bubble-float-top:hover:before, .hvr-bubble-float-top:focus:before, .hvr-bubble-float-top:active:before {
  -webkit-transform: translateY(-10px);
  transform: translateY(-10px);
}

/* Bubble Float Right */
.hvr-bubble-float-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-right:before {
  position: absolute;
  z-index: -1;
  top: calc(50% - 10px);
  right: 0;
  content: '';
  border-style: solid;
  border-width: 10px 0 10px 10px;
  border-color: transparent transparent transparent #e1e1e1;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-right:hover, .hvr-bubble-float-right:focus, .hvr-bubble-float-right:active {
  -webkit-transform: translateX(-10px);
  transform: translateX(-10px);
}
.hvr-bubble-float-right:hover:before, .hvr-bubble-float-right:focus:before, .hvr-bubble-float-right:active:before {
  -webkit-transform: translateX(10px);
  transform: translateX(10px);
}

/* Bubble Float Bottom */
.hvr-bubble-float-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-bottom:before {
  position: absolute;
  z-index: -1;
  content: '';
  left: calc(50% - 10px);
  bottom: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #e1e1e1 transparent transparent transparent;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-bottom:hover, .hvr-bubble-float-bottom:focus, .hvr-bubble-float-bottom:active {
  -webkit-transform: translateY(-10px);
  transform: translateY(-10px);
}
.hvr-bubble-float-bottom:hover:before, .hvr-bubble-float-bottom:focus:before, .hvr-bubble-float-bottom:active:before {
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
}

/* Bubble Float Left */
.hvr-bubble-float-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-left:before {
  position: absolute;
  z-index: -1;
  content: '';
  top: calc(50% - 10px);
  left: 0;
  border-style: solid;
  border-width: 10px 10px 10px 0;
  border-color: transparent #e1e1e1 transparent transparent;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
}
.hvr-bubble-float-left:hover, .hvr-bubble-float-left:focus, .hvr-bubble-float-left:active {
  -webkit-transform: translateX(10px);
  transform: translateX(10px);
}
.hvr-bubble-float-left:hover:before, .hvr-bubble-float-left:focus:before, .hvr-bubble-float-left:active:before {
  -webkit-transform: translateX(-10px);
  transform: translateX(-10px);
}

/* ICONS */
/* Icon Back */
.hvr-icon-back {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-left: 2.2em;
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
}
.hvr-icon-back:before {
  content: "\f137";
  position: absolute;
  left: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-back:hover:before, .hvr-icon-back:focus:before, .hvr-icon-back:active:before {
  -webkit-transform: translateX(-4px);
  transform: translateX(-4px);
}

/* Icon Forward */
.hvr-icon-forward {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
}
.hvr-icon-forward:before {
  content: "\f138";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.1s;
  transition-duration: 0.1s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-forward:hover:before, .hvr-icon-forward:focus:before, .hvr-icon-forward:active:before {
  -webkit-transform: translateX(4px);
  transform: translateX(4px);
}

/* Icon Down */
@-webkit-keyframes hvr-icon-down {
  0%,
  50%,
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  25%,
  75% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

@keyframes hvr-icon-down {
  0%,
  50%,
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  25%,
  75% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

/* Icon Down */
.hvr-icon-down {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-down:before {
  content: "\f01a";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-down:hover:before, .hvr-icon-down:focus:before, .hvr-icon-down:active:before {
  -webkit-animation-name: hvr-icon-down;
  animation-name: hvr-icon-down;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

/* Icon Up */
@-webkit-keyframes hvr-icon-up {
  0%,
  50%,
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  25%,
  75% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

@keyframes hvr-icon-up {
  0%,
  50%,
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }

  25%,
  75% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

/* Icon Up */
.hvr-icon-up {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-up:before {
  content: "\f01b";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-up:hover:before, .hvr-icon-up:focus:before, .hvr-icon-up:active:before {
  -webkit-animation-name: hvr-icon-up;
  animation-name: hvr-icon-up;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

/* Icon Spin */
.hvr-icon-spin {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-spin:before {
  content: "\f021";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-in-out;
  transition-timing-function: ease-in-out;
}
.hvr-icon-spin:hover:before, .hvr-icon-spin:focus:before, .hvr-icon-spin:active:before {
  -webkit-transform: rotate(360deg);
  transform: rotate(360deg);
}

/* Icon Drop */
@-webkit-keyframes hvr-icon-drop {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 0;
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
  }

  51%,
  100% {
    opacity: 1;
  }
}

@keyframes hvr-icon-drop {
  0% {
    opacity: 0;
  }

  50% {
    opacity: 0;
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
  }

  51%,
  100% {
    opacity: 1;
  }
}

/* Icon Drop */
.hvr-icon-drop {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-drop:before {
  content: "\f041";
  position: absolute;
  right: 1em;
  opacity: 1;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-drop:hover:before, .hvr-icon-drop:focus:before, .hvr-icon-drop:active:before {
  opacity: 0;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-animation-name: hvr-icon-drop;
  animation-name: hvr-icon-drop;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-delay: 0.3s;
  animation-delay: 0.3s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  animation-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}

/* Icon Fade */
.hvr-icon-fade {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-fade:before {
  content: "\f00c";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-property: color;
  transition-property: color;
}
.hvr-icon-fade:hover:before, .hvr-icon-fade:focus:before, .hvr-icon-fade:active:before {
  color: #0F9E5E;
}

/* Icon Float Away */
@-webkit-keyframes hvr-icon-float-away {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: translateY(-1em);
    transform: translateY(-1em);
  }
}

@keyframes hvr-icon-float-away {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: translateY(-1em);
    transform: translateY(-1em);
  }
}

/* Icon Float Away */
.hvr-icon-float-away {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-float-away:before, .hvr-icon-float-away:after {
  content: "\f055";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
}
.hvr-icon-float-away:after {
  opacity: 0;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
.hvr-icon-float-away:hover:after, .hvr-icon-float-away:focus:after, .hvr-icon-float-away:active:after {
  -webkit-animation-name: hvr-icon-float-away;
  animation-name: hvr-icon-float-away;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

/* Icon Sink Away */
@-webkit-keyframes hvr-icon-sink-away {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: translateY(1em);
    transform: translateY(1em);
  }
}

@keyframes hvr-icon-sink-away {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    -webkit-transform: translateY(1em);
    transform: translateY(1em);
  }
}

/* Icon Sink Away */
.hvr-icon-sink-away {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-sink-away:before, .hvr-icon-sink-away:after {
  content: "\f056";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-sink-away:after {
  opacity: 0;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
.hvr-icon-sink-away:hover:after, .hvr-icon-sink-away:focus:after, .hvr-icon-sink-away:active:after {
  -webkit-animation-name: hvr-icon-sink-away;
  animation-name: hvr-icon-sink-away;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

/* Icon Grow */
.hvr-icon-grow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-grow:before {
  content: "\f118";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-grow:hover:before, .hvr-icon-grow:focus:before, .hvr-icon-grow:active:before {
  -webkit-transform: scale(1.3) translateZ(0);
  transform: scale(1.3) translateZ(0);
}

/* Icon Shrink */
.hvr-icon-shrink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-shrink:before {
  content: "\f119";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-shrink:hover:before, .hvr-icon-shrink:focus:before, .hvr-icon-shrink:active:before {
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
}

/* Icon Pulse */
@-webkit-keyframes hvr-icon-pulse {
  25% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }

  75% {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }
}

@keyframes hvr-icon-pulse {
  25% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }

  75% {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }
}

.hvr-icon-pulse {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-pulse:before {
  content: "\f015";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-pulse:hover:before, .hvr-icon-pulse:focus:before, .hvr-icon-pulse:active:before {
  -webkit-animation-name: hvr-icon-pulse;
  animation-name: hvr-icon-pulse;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

/* Icon Pulse Grow */
@-webkit-keyframes hvr-icon-pulse-grow {
  to {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
}

@keyframes hvr-icon-pulse-grow {
  to {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
}

.hvr-icon-pulse-grow {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-pulse-grow:before {
  content: "\f015";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-pulse-grow:hover:before, .hvr-icon-pulse-grow:focus:before, .hvr-icon-pulse-grow:active:before {
  -webkit-animation-name: hvr-icon-pulse-grow;
  animation-name: hvr-icon-pulse-grow;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
  animation-direction: alternate;
}

/* Icon Pulse Shrink */
@-webkit-keyframes hvr-icon-pulse-shrink {
  to {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }
}

@keyframes hvr-icon-pulse-shrink {
  to {
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
  }
}

.hvr-icon-pulse-shrink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
}
.hvr-icon-pulse-shrink:before {
  content: "\f015";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-pulse-shrink:hover:before, .hvr-icon-pulse-shrink:focus:before, .hvr-icon-pulse-shrink:active:before {
  -webkit-animation-name: hvr-icon-pulse-shrink;
  animation-name: hvr-icon-pulse-shrink;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
  animation-direction: alternate;
}

/* Icon Push */
@-webkit-keyframes hvr-icon-push {
  50% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
  }
}

@keyframes hvr-icon-push {
  50% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
  }
}

.hvr-icon-push {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-push:before {
  content: "\f006";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-push:hover:before, .hvr-icon-push:focus:before, .hvr-icon-push:active:before {
  -webkit-animation-name: hvr-icon-push;
  animation-name: hvr-icon-push;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Icon Pop */
@-webkit-keyframes hvr-icon-pop {
  50% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
  }
}

@keyframes hvr-icon-pop {
  50% {
    -webkit-transform: scale(1.5);
    transform: scale(1.5);
  }
}

.hvr-icon-pop {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-pop:before {
  content: "\f005";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-pop:hover:before, .hvr-icon-pop:focus:before, .hvr-icon-pop:active:before {
  -webkit-animation-name: hvr-icon-pop;
  animation-name: hvr-icon-pop;
  -webkit-animation-duration: 0.3s;
  animation-duration: 0.3s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Icon Bounce */
.hvr-icon-bounce {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-bounce:before {
  content: "\f087";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-bounce:hover:before, .hvr-icon-bounce:focus:before, .hvr-icon-bounce:active:before {
  -webkit-transform: scale(1.5);
  transform: scale(1.5);
  -webkit-transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
  transition-timing-function: cubic-bezier(0.47, 2.02, 0.31, -0.36);
}

/* Icon Rotate */
.hvr-icon-rotate {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-rotate:before {
  content: "\f0c6";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-rotate:hover:before, .hvr-icon-rotate:focus:before, .hvr-icon-rotate:active:before {
  -webkit-transform: rotate(20deg);
  transform: rotate(20deg);
}

/* Icon Grow Rotate */
.hvr-icon-grow-rotate {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-grow-rotate:before {
  content: "\f095";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-grow-rotate:hover:before, .hvr-icon-grow-rotate:focus:before, .hvr-icon-grow-rotate:active:before {
  -webkit-transform: scale(1.5) rotate(12deg);
  transform: scale(1.5) rotate(12deg);
}

/* Icon Float */
.hvr-icon-float {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-float:before {
  content: "\f01b";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-float:hover:before, .hvr-icon-float:focus:before, .hvr-icon-float:active:before {
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
}

/* Icon Sink */
.hvr-icon-sink {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-sink:before {
  content: "\f01a";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: transform;
  transition-property: transform;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.hvr-icon-sink:hover:before, .hvr-icon-sink:focus:before, .hvr-icon-sink:active:before {
  -webkit-transform: translateY(4px);
  transform: translateY(4px);
}

/* Icon Bob */
@-webkit-keyframes hvr-icon-bob {
  0% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }

  50% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  100% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

@keyframes hvr-icon-bob {
  0% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }

  50% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  100% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

@-webkit-keyframes hvr-icon-bob-float {
  100% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

@keyframes hvr-icon-bob-float {
  100% {
    -webkit-transform: translateY(-6px);
    transform: translateY(-6px);
  }
}

.hvr-icon-bob {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-bob:before {
  content: "\f077";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-bob:hover:before, .hvr-icon-bob:focus:before, .hvr-icon-bob:active:before {
  -webkit-animation-name: hvr-icon-bob-float, hvr-icon-bob;
  animation-name: hvr-icon-bob-float, hvr-icon-bob;
  -webkit-animation-duration: .3s, 1.5s;
  animation-duration: .3s, 1.5s;
  -webkit-animation-delay: 0s, .3s;
  animation-delay: 0s, .3s;
  -webkit-animation-timing-function: ease-out, ease-in-out;
  animation-timing-function: ease-out, ease-in-out;
  -webkit-animation-iteration-count: 1, infinite;
  animation-iteration-count: 1, infinite;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-direction: normal, alternate;
  animation-direction: normal, alternate;
}

/* Icon Hang */
@-webkit-keyframes hvr-icon-hang {
  0% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }

  50% {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }

  100% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

@keyframes hvr-icon-hang {
  0% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }

  50% {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }

  100% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

@-webkit-keyframes hvr-icon-hang-sink {
  100% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

@keyframes hvr-icon-hang-sink {
  100% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }
}

.hvr-icon-hang {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-hang:before {
  content: "\f078";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-hang:hover:before, .hvr-icon-hang:focus:before, .hvr-icon-hang:active:before {
  -webkit-animation-name: hvr-icon-hang-sink, hvr-icon-hang;
  animation-name: hvr-icon-hang-sink, hvr-icon-hang;
  -webkit-animation-duration: .3s, 1.5s;
  animation-duration: .3s, 1.5s;
  -webkit-animation-delay: 0s, .3s;
  animation-delay: 0s, .3s;
  -webkit-animation-timing-function: ease-out, ease-in-out;
  animation-timing-function: ease-out, ease-in-out;
  -webkit-animation-iteration-count: 1, infinite;
  animation-iteration-count: 1, infinite;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-direction: normal, alternate;
  animation-direction: normal, alternate;
}

/* Icon Wobble Horizontal */
@-webkit-keyframes hvr-icon-wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(6px);
    transform: translateX(6px);
  }

  33.3% {
    -webkit-transform: translateX(-5px);
    transform: translateX(-5px);
  }

  49.95% {
    -webkit-transform: translateX(4px);
    transform: translateX(4px);
  }

  66.6% {
    -webkit-transform: translateX(-2px);
    transform: translateX(-2px);
  }

  83.25% {
    -webkit-transform: translateX(1px);
    transform: translateX(1px);
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes hvr-icon-wobble-horizontal {
  16.65% {
    -webkit-transform: translateX(6px);
    transform: translateX(6px);
  }

  33.3% {
    -webkit-transform: translateX(-5px);
    transform: translateX(-5px);
  }

  49.95% {
    -webkit-transform: translateX(4px);
    transform: translateX(4px);
  }

  66.6% {
    -webkit-transform: translateX(-2px);
    transform: translateX(-2px);
  }

  83.25% {
    -webkit-transform: translateX(1px);
    transform: translateX(1px);
  }

  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

.hvr-icon-wobble-horizontal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-wobble-horizontal:before {
  content: "\f061";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-wobble-horizontal:hover:before, .hvr-icon-wobble-horizontal:focus:before, .hvr-icon-wobble-horizontal:active:before {
  -webkit-animation-name: hvr-icon-wobble-horizontal;

  animation-name: hvr-icon-wobble-horizontal;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Icon Wobble Vertical */
@-webkit-keyframes hvr-icon-wobble-vertical {
  16.65% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }

  33.3% {
    -webkit-transform: translateY(-5px);
    transform: translateY(-5px);
  }

  49.95% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
  }

  66.6% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  83.25% {
    -webkit-transform: translateY(1px);
    transform: translateY(1px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes hvr-icon-wobble-vertical {
  16.65% {
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
  }

  33.3% {
    -webkit-transform: translateY(-5px);
    transform: translateY(-5px);
  }

  49.95% {
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
  }

  66.6% {
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
  }

  83.25% {
    -webkit-transform: translateY(1px);
    transform: translateY(1px);
  }

  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

.hvr-icon-wobble-vertical {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-wobble-vertical:before {
  content: "\f062";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-wobble-vertical:hover:before, .hvr-icon-wobble-vertical:focus:before, .hvr-icon-wobble-vertical:active:before {
  -webkit-animation-name: hvr-icon-wobble-vertical;
  animation-name: hvr-icon-wobble-vertical;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* Icon Buzz */
@-webkit-keyframes hvr-icon-buzz {
  50% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  100% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }
}

@keyframes hvr-icon-buzz {
  50% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  100% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }
}

.hvr-icon-buzz {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-buzz:before {
  content: "\f017";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-buzz:hover:before, .hvr-icon-buzz:focus:before, .hvr-icon-buzz:active:before {
  -webkit-animation-name: hvr-icon-buzz;
  animation-name: hvr-icon-buzz;
  -webkit-animation-duration: 0.15s;
  animation-duration: 0.15s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

/* Icon Buzz Out */
@-webkit-keyframes hvr-icon-buzz-out {
  10% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  20% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  30% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  40% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  50% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  60% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  70% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  80% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  90% {
    -webkit-transform: translateX(1px) rotate(0);
    transform: translateX(1px) rotate(0);
  }

  100% {
    -webkit-transform: translateX(-1px) rotate(0);
    transform: translateX(-1px) rotate(0);
  }
}

@keyframes hvr-icon-buzz-out {
  10% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  20% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  30% {
    -webkit-transform: translateX(3px) rotate(2deg);
    transform: translateX(3px) rotate(2deg);
  }

  40% {
    -webkit-transform: translateX(-3px) rotate(-2deg);
    transform: translateX(-3px) rotate(-2deg);
  }

  50% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  60% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  70% {
    -webkit-transform: translateX(2px) rotate(1deg);
    transform: translateX(2px) rotate(1deg);
  }

  80% {
    -webkit-transform: translateX(-2px) rotate(-1deg);
    transform: translateX(-2px) rotate(-1deg);
  }

  90% {
    -webkit-transform: translateX(1px) rotate(0);
    transform: translateX(1px) rotate(0);
  }

  100% {
    -webkit-transform: translateX(-1px) rotate(0);
    transform: translateX(-1px) rotate(0);
  }
}

.hvr-icon-buzz-out {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  padding-right: 2.2em;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hvr-icon-buzz-out:before {
  content: "\f023";
  position: absolute;
  right: 1em;
  padding: 0 1px;
  font-family: FontAwesome;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.hvr-icon-buzz-out:hover:before, .hvr-icon-buzz-out:focus:before, .hvr-icon-buzz-out:active:before {
  -webkit-animation-name: hvr-icon-buzz-out;
  animation-name: hvr-icon-buzz-out;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}

/* CURLS */
/* Curl Top Left */
.hvr-curl-top-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-curl-top-left:before {
  pointer-events: none;
  position: absolute;
  content: '';
  height: 0;
  width: 0;
  top: 0;
  left: 0;
  background: white;
  /* IE9 */
  background: linear-gradient(135deg, white 45%, #aaaaaa 50%, #cccccc 56%, white 80%);
  filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#ffffff', endColorstr='#000000');
  /*For IE7-8-9*/
  z-index: 1000;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.4);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: width, height;
  transition-property: width, height;
}
.hvr-curl-top-left:hover:before, .hvr-curl-top-left:focus:before, .hvr-curl-top-left:active:before {
  width: 25px;
  height: 25px;
}

/* Curl Top Right */
.hvr-curl-top-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-curl-top-right:before {
  pointer-events: none;
  position: absolute;
  content: '';
  height: 0;
  width: 0;
  top: 0;
  right: 0;
  background: white;
  /* IE9 */
  background: linear-gradient(225deg, white 45%, #aaaaaa 50%, #cccccc 56%, white 80%);
  box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.4);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: width, height;
  transition-property: width, height;
}
.hvr-curl-top-right:hover:before, .hvr-curl-top-right:focus:before, .hvr-curl-top-right:active:before {
  width: 25px;
  height: 25px;
}

/* Curl Bottom Right */
.hvr-curl-bottom-right {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-curl-bottom-right:before {
  pointer-events: none;
  position: absolute;
  content: '';
  height: 0;
  width: 0;
  bottom: 0;
  right: 0;
  background: white;
  /* IE9 */
  background: linear-gradient(315deg, white 45%, #aaaaaa 50%, #cccccc 56%, white 80%);
  box-shadow: -1px -1px 1px rgba(0, 0, 0, 0.4);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: width, height;
  transition-property: width, height;
}
.hvr-curl-bottom-right:hover:before, .hvr-curl-bottom-right:focus:before, .hvr-curl-bottom-right:active:before {
  width: 25px;
  height: 25px;
}

/* Curl Bottom Left */
.hvr-curl-bottom-left {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
}
.hvr-curl-bottom-left:before {
  pointer-events: none;
  position: absolute;
  content: '';
  height: 0;
  width: 0;
  bottom: 0;
  left: 0;
  background: white;
  /* IE9 */
  background: linear-gradient(45deg, white 45%, #aaaaaa 50%, #cccccc 56%, white 80%);
  box-shadow: 1px -1px 1px rgba(0, 0, 0, 0.4);
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-property: width, height;
  transition-property: width, height;
}
.hvr-curl-bottom-left:hover:before, .hvr-curl-bottom-left:focus:before, .hvr-curl-bottom-left:active:before {
  width: 25px;
  height:25px;
}









/* ----- ALL ANIMATION ----- */


.treed {
  -webkit-perspective: 600;
  -moz-perspective: 600;
  -o-perspective: 600;
  -ms-perspective: 600;
  perspective: 600;
}
.portrait {
  content: "";
  display: block;
  position: absolute;
  width: 92%;
  height: 64%;
  z-index: 1000;
  top: 9px;
  left: 9px;
}
.befores,
.legend-down:before,
.legend-up:before,
.legend-left:before,
.legend-right:before,
.legend-flip:before,
.portrait-before:before,
.portrait-blur:before,
.scale-before:before {
  content: "";
  display: block;
  position: absolute;
  width: 92%;
  height: 64%;
  z-index: 1000;
  top: 9px;
  left: 9px;
}
.all-animation,
.all-animation * {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
/***** Especials ******/
.dance {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: dance 1 2s linear;
  -moz-animation: dance 1 2s linear;
  -ms-animation: dance 1 2s linear;
  -o-animation: dance 1 2s linear;
  animation: dance 1 2s linear;
}
@-webkit-keyframes dance {
  0%, 10%, 20% {
    -webkit-transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    -webkit-transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    -webkit-transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    -webkit-transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-moz-keyframes dance {
  0%, 10%, 20% {
    -moz-transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    -moz-transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    -moz-transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    -moz-transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-ms-keyframes dance {
  0%, 10%, 20% {
    -ms-transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    -ms-transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    -ms-transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    -ms-transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-o-keyframes dance {
  0%, 10%, 20% {
    -o-transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    -o-transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    -o-transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    -o-transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-moz-keyframes dance {
  0%, 10%, 20% {
    transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-webkit-keyframes dance {
  0%, 10%, 20% {
    transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@-o-keyframes dance {
  0%, 10%, 20% {
    transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
@keyframes dance {
  0%, 10%, 20% {
    transform: rotateZ(10deg);
  }
  5%, 15%, 25% {
    transform: rotateZ(-10deg);
  }
  35%, 60%, 100% {
    transform: scale(1) rotateZ(0deg);
    box-shadow: inset 0 0 0 0 transparent;
  }
  40% {
    transform: scale(1.3);
    box-shadow: inset 0 0 0 0;
    box-shadow: inset 0 0 0 2px rgba(0,0,0,0.1);
  }
}
.journal {
  -webkit-animation: journal 1 2s ease-in;
  -moz-animation: journal 1 2s ease-in;
  -ms-animation: journal 1 2s ease-in;
  -o-animation: journal 1 2s ease-in;
  animation: journal 1 2s ease-in;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes journal {
  0% {
    -webkit-transform: scale(0) rotate(-360deg);
  }
  80% {
    -webkit-transform: scale(0.5) rotate(-180deg);
  }
  100% {
    -webkit-transform: scale(1) rotate(0);
  }
}
@-moz-keyframes journal {
  0% {
    -moz-transform: scale(0) rotate(-360deg);
  }
  80% {
    -moz-transform: scale(0.5) rotate(-180deg);
  }
  100% {
    -moz-transform: scale(1) rotate(0);
  }
}
@-ms-keyframes journal {
  0% {
    -ms-transform: scale(0) rotate(-360deg);
  }
  80% {
    -ms-transform: scale(0.5) rotate(-180deg);
  }
  100% {
    -ms-transform: scale(1) rotate(0);
  }
}
@-o-keyframes journal {
  0% {
    -o-transform: scale(0) rotate(-360deg);
  }
  80% {
    -o-transform: scale(0.5) rotate(-180deg);
  }
  100% {
    -o-transform: scale(1) rotate(0);
  }
}
@-moz-keyframes journal {
  0% {
    transform: scale(0) rotate(-360deg);
  }
  80% {
    transform: scale(0.5) rotate(-180deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
@-webkit-keyframes journal {
  0% {
    transform: scale(0) rotate(-360deg);
  }
  80% {
    transform: scale(0.5) rotate(-180deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
@-o-keyframes journal {
  0% {
    transform: scale(0) rotate(-360deg);
  }
  80% {
    transform: scale(0.5) rotate(-180deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
@keyframes journal {
  0% {
    transform: scale(0) rotate(-360deg);
  }
  80% {
    transform: scale(0.5) rotate(-180deg);
  }
  100% {
    transform: scale(1) rotate(0);
  }
}
.pulse {
  -webkit-animation: pulse infinite alternate linear 0.5s;
  -moz-animation: pulse infinite alternate linear 0.5s;
  -ms-animation: pulse infinite alternate linear 0.5s;
  -o-animation: pulse infinite alternate linear 0.5s;
  animation: pulse infinite alternate linear 0.5s;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.05);
  }
}
@-moz-keyframes pulse {
  0% {
    -moz-transform: scale(1);
  }
  100% {
    -moz-transform: scale(1.05);
  }
}
@-ms-keyframes pulse {
  0% {
    -ms-transform: scale(1);
  }
  100% {
    -ms-transform: scale(1.05);
  }
}
@-o-keyframes pulse {
  0% {
    -o-transform: scale(1);
  }
  100% {
    -o-transform: scale(1.05);
  }
}
@-moz-keyframes pulse {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
@-webkit-keyframes pulse {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
@-o-keyframes pulse {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.05);
  }
}
.pulse-slow {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: pulseSlow infinite alternate 1s ease-in-out;
  -moz-animation: pulseSlow infinite alternate 1s ease-in-out;
  -ms-animation: pulseSlow infinite alternate 1s ease-in-out;
  -o-animation: pulseSlow infinite alternate 1s ease-in-out;
  animation: pulseSlow infinite alternate 1s ease-in-out;
}
@-webkit-keyframes pulseSlow {
  0% {
    -webkit-transform: scale(1);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(0.85);
    opacity: 0.5;
  }
}
@-moz-keyframes pulseSlow {
  0% {
    -moz-transform: scale(1);
    opacity: 1;
  }
  100% {
    -moz-transform: scale(0.85);
    opacity: 0.5;
  }
}
@-ms-keyframes pulseSlow {
  0% {
    -ms-transform: scale(1);
    opacity: 1;
  }
  100% {
    -ms-transform: scale(0.85);
    opacity: 0.5;
  }
}
@-o-keyframes pulseSlow {
  0% {
    -o-transform: scale(1);
    opacity: 1;
  }
  100% {
    -o-transform: scale(0.85);
    opacity: 0.5;
  }
}
@-moz-keyframes pulseSlow {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(0.85);
    opacity: 0.5;
  }
}
@-webkit-keyframes pulseSlow {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(0.85);
    opacity: 0.5;
  }
}
@-o-keyframes pulseSlow {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(0.85);
    opacity: 0.5;
  }
}
@keyframes pulseSlow {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(0.85);
    opacity: 0.5;
  }
}
.jamp {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: jamp 1s linear;
  -moz-animation: jamp 1s linear;
  -ms-animation: jamp 1s linear;
  -o-animation: jamp 1s linear;
  animation: jamp 1s linear;
}
@-webkit-keyframes jamp {
  0% {
    -webkit-transform: translateY(0);
  }
  10% {
    -webkit-transform: translateY(-50px);
  }
  25% {
    -webkit-transform: translateY(-50px) scale(1.1);
  }
  35% {
    -webkit-transform: translateY(-50px) scale(1);
  }
  45% {
    -webkit-transform: translateY(-50px) scale(1.2);
  }
  55% {
    -webkit-transform: translateY(-50px) scale(1);
  }
  65% {
    -webkit-transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    -webkit-transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    -webkit-transform: translate(0, 0px) scale(1);
  }
  100% {
    -webkit-transform: translate(0, 0);
  }
}
@-moz-keyframes jamp {
  0% {
    -moz-transform: translateY(0);
  }
  10% {
    -moz-transform: translateY(-50px);
  }
  25% {
    -moz-transform: translateY(-50px) scale(1.1);
  }
  35% {
    -moz-transform: translateY(-50px) scale(1);
  }
  45% {
    -moz-transform: translateY(-50px) scale(1.2);
  }
  55% {
    -moz-transform: translateY(-50px) scale(1);
  }
  65% {
    -moz-transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    -moz-transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    -moz-transform: translate(0, 0px) scale(1);
  }
  100% {
    -moz-transform: translate(0, 0);
  }
}
@-ms-keyframes jamp {
  0% {
    -ms-transform: translateY(0);
  }
  10% {
    -ms-transform: translateY(-50px);
  }
  25% {
    -ms-transform: translateY(-50px) scale(1.1);
  }
  35% {
    -ms-transform: translateY(-50px) scale(1);
  }
  45% {
    -ms-transform: translateY(-50px) scale(1.2);
  }
  55% {
    -ms-transform: translateY(-50px) scale(1);
  }
  65% {
    -ms-transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    -ms-transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    -ms-transform: translate(0, 0px) scale(1);
  }
  100% {
    -ms-transform: translate(0, 0);
  }
}
@-o-keyframes jamp {
  0% {
    -o-transform: translateY(0);
  }
  10% {
    -o-transform: translateY(-50px);
  }
  25% {
    -o-transform: translateY(-50px) scale(1.1);
  }
  35% {
    -o-transform: translateY(-50px) scale(1);
  }
  45% {
    -o-transform: translateY(-50px) scale(1.2);
  }
  55% {
    -o-transform: translateY(-50px) scale(1);
  }
  65% {
    -o-transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    -o-transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    -o-transform: translate(0, 0px) scale(1);
  }
  100% {
    -o-transform: translate(0, 0);
  }
}
@-moz-keyframes jamp {
  0% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(-50px);
  }
  25% {
    transform: translateY(-50px) scale(1.1);
  }
  35% {
    transform: translateY(-50px) scale(1);
  }
  45% {
    transform: translateY(-50px) scale(1.2);
  }
  55% {
    transform: translateY(-50px) scale(1);
  }
  65% {
    transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    transform: translate(0, 0px) scale(1);
  }
  100% {
    transform: translate(0, 0);
  }
}
@-webkit-keyframes jamp {
  0% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(-50px);
  }
  25% {
    transform: translateY(-50px) scale(1.1);
  }
  35% {
    transform: translateY(-50px) scale(1);
  }
  45% {
    transform: translateY(-50px) scale(1.2);
  }
  55% {
    transform: translateY(-50px) scale(1);
  }
  65% {
    transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    transform: translate(0, 0px) scale(1);
  }
  100% {
    transform: translate(0, 0);
  }
}
@-o-keyframes jamp {
  0% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(-50px);
  }
  25% {
    transform: translateY(-50px) scale(1.1);
  }
  35% {
    transform: translateY(-50px) scale(1);
  }
  45% {
    transform: translateY(-50px) scale(1.2);
  }
  55% {
    transform: translateY(-50px) scale(1);
  }
  65% {
    transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    transform: translate(0, 0px) scale(1);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes jamp {
  0% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(-50px);
  }
  25% {
    transform: translateY(-50px) scale(1.1);
  }
  35% {
    transform: translateY(-50px) scale(1);
  }
  45% {
    transform: translateY(-50px) scale(1.2);
  }
  55% {
    transform: translateY(-50px) scale(1);
  }
  65% {
    transform: translate(150px, -50px) scale(0.8);
  }
  85% {
    transform: translate(150px, -50px) scale(1.2);
  }
  95% {
    transform: translate(0, 0px) scale(1);
  }
  100% {
    transform: translate(0, 0);
  }
}
.four-rock {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: fourRock 1 2s ease-out;
  -moz-animation: fourRock 1 2s ease-out;
  -ms-animation: fourRock 1 2s ease-out;
  -o-animation: fourRock 1 2s ease-out;
  animation: fourRock 1 2s ease-out;
}
@-webkit-keyframes fourRock {
  0% {
    -webkit-transform-origin: 0 0;
  }
  5% {
    -webkit-transform: scale(0.5);
  }
  10% {
    -webkit-transform: scale(0.5);
  }
  15% {
    -webkit-transform: scale(0.5) translateX(130px);
  }
  20% {
    -webkit-transform: scale(0.5) translateX(130px);
  }
  25% {
    -webkit-transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    -webkit-transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    -webkit-transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    -webkit-transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-moz-keyframes fourRock {
  0% {
    -moz-transform-origin: 0 0;
  }
  5% {
    -moz-transform: scale(0.5);
  }
  10% {
    -moz-transform: scale(0.5);
  }
  15% {
    -moz-transform: scale(0.5) translateX(130px);
  }
  20% {
    -moz-transform: scale(0.5) translateX(130px);
  }
  25% {
    -moz-transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    -moz-transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    -moz-transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    -moz-transform: scale(1);
  }
  100% {
    -moz-transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-ms-keyframes fourRock {
  0% {
    -ms-transform-origin: 0 0;
  }
  5% {
    -ms-transform: scale(0.5);
  }
  10% {
    -ms-transform: scale(0.5);
  }
  15% {
    -ms-transform: scale(0.5) translateX(130px);
  }
  20% {
    -ms-transform: scale(0.5) translateX(130px);
  }
  25% {
    -ms-transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    -ms-transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    -ms-transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    -ms-transform: scale(1);
  }
  100% {
    -ms-transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-o-keyframes fourRock {
  0% {
    -o-transform-origin: 0 0;
  }
  5% {
    -o-transform: scale(0.5);
  }
  10% {
    -o-transform: scale(0.5);
  }
  15% {
    -o-transform: scale(0.5) translateX(130px);
  }
  20% {
    -o-transform: scale(0.5) translateX(130px);
  }
  25% {
    -o-transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    -o-transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    -o-transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    -o-transform: scale(1);
  }
  100% {
    -o-transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-moz-keyframes fourRock {
  0% {
    transform-origin: 0 0;
  }
  5% {
    transform: scale(0.5);
  }
  10% {
    transform: scale(0.5);
  }
  15% {
    transform: scale(0.5) translateX(130px);
  }
  20% {
    transform: scale(0.5) translateX(130px);
  }
  25% {
    transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-webkit-keyframes fourRock {
  0% {
    transform-origin: 0 0;
  }
  5% {
    transform: scale(0.5);
  }
  10% {
    transform: scale(0.5);
  }
  15% {
    transform: scale(0.5) translateX(130px);
  }
  20% {
    transform: scale(0.5) translateX(130px);
  }
  25% {
    transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@-o-keyframes fourRock {
  0% {
    transform-origin: 0 0;
  }
  5% {
    transform: scale(0.5);
  }
  10% {
    transform: scale(0.5);
  }
  15% {
    transform: scale(0.5) translateX(130px);
  }
  20% {
    transform: scale(0.5) translateX(130px);
  }
  25% {
    transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
@keyframes fourRock {
  0% {
    transform-origin: 0 0;
  }
  5% {
    transform: scale(0.5);
  }
  10% {
    transform: scale(0.5);
  }
  15% {
    transform: scale(0.5) translateX(130px);
  }
  20% {
    transform: scale(0.5) translateX(130px);
  }
  25% {
    transform: scale(0.5) translate(130px, 130px);
  }
  30% {
    transform: scale(0.5) translate(0px, 130px);
  }
  35% {
    transform: scale(0.5) translate(0px, 0px);
  }
  40% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
    -webkit-transform-origin: 0 0;
  }
}
/***** Bounce ******/
.enter-up-bounce {
  -webkit-animation: enterUpBounce .3s ease-in forwards;
  -moz-animation: enterUpBounce .3s ease-in forwards;
  -ms-animation: enterUpBounce .3s ease-in forwards;
  -o-animation: enterUpBounce .3s ease-in forwards;
  animation: enterUpBounce .3s ease-in forwards;
}
@-webkit-keyframes enterUpBounce {
  0% {
    -webkit-transform: translateY(-200px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -webkit-transform: translateY(0px);
  }
  70% {
    -webkit-transform: translateY(-100px);
  }
  100% {
    -webkit-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterUpBounce {
  0% {
    -moz-transform: translateY(-200px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -moz-transform: translateY(0px);
  }
  70% {
    -moz-transform: translateY(-100px);
  }
  100% {
    -moz-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes enterUpBounce {
  0% {
    -ms-transform: translateY(-200px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -ms-transform: translateY(0px);
  }
  70% {
    -ms-transform: translateY(-100px);
  }
  100% {
    -ms-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterUpBounce {
  0% {
    -o-transform: translateY(-200px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -o-transform: translateY(0px);
  }
  70% {
    -o-transform: translateY(-100px);
  }
  100% {
    -o-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterUpBounce {
  0% {
    transform: translateY(-200px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(-100px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes enterUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@keyframes enterUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(-15px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
.enter-double-up-bounce {
  -webkit-animation: enterDoubleUpBounce 1s ease-in forwards;
  -moz-animation: enterDoubleUpBounce 1s ease-in forwards;
  -ms-animation: enterDoubleUpBounce 1s ease-in forwards;
  -o-animation: enterDoubleUpBounce 1s ease-in forwards;
  animation: enterDoubleUpBounce 1s ease-in forwards;
}
@-webkit-keyframes enterDoubleUpBounce {
  0% {
    -webkit-transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    -webkit-transform: translateY(0);
  }
  40% {
    -webkit-transform: translateY(-15px);
  }
  50% {
    -webkit-transform: translateY(0);
  }
  60% {
    -webkit-transform: translateY(-5px);
  }
  70%, 100% {
    -webkit-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterDoubleUpBounce {
  0% {
    -moz-transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    -moz-transform: translateY(0);
  }
  40% {
    -moz-transform: translateY(-15px);
  }
  50% {
    -moz-transform: translateY(0);
  }
  60% {
    -moz-transform: translateY(-5px);
  }
  70%, 100% {
    -moz-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes enterDoubleUpBounce {
  0% {
    -ms-transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    -ms-transform: translateY(0);
  }
  40% {
    -ms-transform: translateY(-15px);
  }
  50% {
    -ms-transform: translateY(0);
  }
  60% {
    -ms-transform: translateY(-5px);
  }
  70%, 100% {
    -ms-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterDoubleUpBounce {
  0% {
    -o-transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    -o-transform: translateY(0);
  }
  40% {
    -o-transform: translateY(-15px);
  }
  50% {
    -o-transform: translateY(0);
  }
  60% {
    -o-transform: translateY(-5px);
  }
  70%, 100% {
    -o-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterDoubleUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-15px);
  }
  50% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(-5px);
  }
  70%, 100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes enterDoubleUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-15px);
  }
  50% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(-5px);
  }
  70%, 100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }

}
@-o-keyframes enterDoubleUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-15px);
  }
  50% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(-5px);
  }
  70%, 100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@keyframes enterDoubleUpBounce {
  0% {
    transform: translateY(-80px);
    opacity: 0;
    visibility: hidden;
  }
  30% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-15px);
  }
  50% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(-5px);
  }
  70%, 100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
.enter-down-bounce {
  -webkit-animation: enterDownBounce 1s ease-in forwards;
  -moz-animation: enterDownBounce 1s ease-in forwards;
  -ms-animation: enterDownBounce 1s ease-in forwards;
  -o-animation: enterDownBounce 1s ease-in forwards;
  animation: enterDownBounce 1s ease-in forwards;
}
@-webkit-keyframes enterDownBounce {
  0% {
    -webkit-transform: translateY(150px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -webkit-transform: translateY(0px);
  }
  70% {
    -webkit-transform: translateY(20px);
  }
  100% {
    -webkit-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterDownBounce {
  0% {
    -moz-transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -moz-transform: translateY(0px);
  }
  70% {
    -moz-transform: translateY(20px);
  }
  100% {
    -moz-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes enterDownBounce {
  0% {
    -ms-transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -ms-transform: translateY(0px);
  }
  70% {
    -ms-transform: translateY(20px);
  }
  100% {
    -ms-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterDownBounce {
  0% {
    -o-transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -o-transform: translateY(0px);
  }
  70% {
    -o-transform: translateY(20px);
  }
  100% {
    -o-transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterDownBounce {
  0% {
    transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes enterDownBounce {
  0% {
    transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterDownBounce {
  0% {
    transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
@keyframes enterDownBounce {
  0% {
    transform: translateY(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateY(0px);
  }
  70% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}
.enter-left-bounce {
  -webkit-animation: enterLeftBounce 0.6s ease-in forwards;
  -moz-animation: enterLeftBounce 0.6s ease-in forwards;
  -ms-animation: enterLeftBounce 0.6s ease-in forwards;
  -o-animation: enterLeftBounce 0.6s ease-in forwards;
  animation: enterLeftBounce 0.6s ease-in forwards;
}
@-webkit-keyframes enterLeftBounce {
  0% {
    -webkit-transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -webkit-transform: translateX(0px);
  }
  70% {
    -webkit-transform: translateX(-10px);
  }
  100% {
    -webkit-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterLeftBounce {
  0% {
    -moz-transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -moz-transform: translateX(0px);
  }
  70% {
    -moz-transform: translateX(-10px);
  }
  100% {
    -moz-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes enterLeftBounce {
  0% {
    -ms-transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -ms-transform: translateX(0px);
  }
  70% {
    -ms-transform: translateX(-10px);
  }
  100% {
    -ms-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterLeftBounce {
  0% {
    -o-transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -o-transform: translateX(0px);
  }
  70% {
    -o-transform: translateX(-10px);
  }
  100% {
    -o-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterLeftBounce {
  0% {
    transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes enterLeftBounce {
  0% {
    transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterLeftBounce {
  0% {
    transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@keyframes enterLeftBounce {
  0% {
    transform: translateX(-80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(-10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
.enter-right-bounce {
  -webkit-animation: enterRightBounce 0.6s ease-in forwards;
  -moz-animation: enterRightBounce 0.6s ease-in forwards;
  -ms-animation: enterRightBounce 0.6s ease-in forwards;
  -o-animation: enterRightBounce 0.6s ease-in forwards;
  animation: enterRightBounce 0.6s ease-in forwards;
}
@-webkit-keyframes enterRightBounce {
  0% {
    -webkit-transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -webkit-transform: translateX(0px);
  }
  70% {
    -webkit-transform: translateX(10px);
  }
  100% {
    -webkit-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterRightBounce {
  0% {
    -moz-transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -moz-transform: translateX(0px);
  }
  70% {
    -moz-transform: translateX(10px);
  }
  100% {
    -moz-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes enterRightBounce {
  0% {
    -ms-transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -ms-transform: translateX(0px);
  }
  70% {
    -ms-transform: translateX(10px);
  }
  100% {
    -ms-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterRightBounce {
  0% {
    -o-transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    -o-transform: translateX(0px);
  }
  70% {
    -o-transform: translateX(10px);
  }
  100% {
    -o-transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes enterRightBounce {
  0% {
    transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes enterRightBounce {
  0% {
    transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes enterRightBounce {
  0% {
    transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
@keyframes enterRightBounce {
  0% {
    transform: translateX(80px);
    opacity: 0;
    visibility: hidden;
  }
  50% {
    transform: translateX(0px);
  }
  70% {
    transform: translateX(10px);
  }
  100% {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
  }
}
.scale-bounce {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: scaleBounce 0.6s ease-in-out;
  -moz-animation: scaleBounce 0.6s ease-in-out;
  -ms-animation: scaleBounce 0.6s ease-in-out;
  -o-animation: scaleBounce 0.6s ease-in-out;
  animation: scaleBounce 0.6s ease-in-out;
}
@-webkit-keyframes scaleBounce {
  0% {
    -webkit-transform: scale(1.5);
    opacity: 0;
  }
  50% {
    -webkit-transform: scale(1);
  }
  70% {
    -webkit-transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
  }
}
@-moz-keyframes scaleBounce {
  0% {
    -moz-transform: scale(1.5);
    opacity: 0;
  }
  50% {
    -moz-transform: scale(1);
  }
  70% {
    -moz-transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -moz-transform: scale(1);
  }
}
@-o-keyframes scaleBounce {
  0% {
    -o-transform: scale(1.5);
    opacity: 0;
  }
  50% {
    -o-transform: scale(1);
  }
  70% {
    -o-transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -o-transform: scale(1);
  }
}
@-ms-keyframes scaleBounce {
  0% {
    -ms-transform: scale(1.5);
    opacity: 0;
  }
  50% {
    -ms-transform: scale(1);
  }
  70% {
    -ms-transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -ms-transform: scale(1);
  }
}
@-moz-keyframes scaleBounce {
  0% {
    transform: scale(1.5);
    opacity: 0;
  }
  50% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@-webkit-keyframes scaleBounce {
  0% {
    transform: scale(1.5);
    opacity: 0;
  }
  50% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@-o-keyframes scaleBounce {
  0% {
    transform: scale(1.5);
    opacity: 0;
  }
  50% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes scaleBounce {
  0% {
    transform: scale(1.5);
    opacity: 0;
  }
  50% {
    transform: scale(1);
  }
  70% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.jump-bounce {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: jumpBounce 1 1.5s ease-out;
  -moz-animation: jumpBounce 1 1.5s ease-out;
  -ms-animation: jumpBounce 1 1.5s ease-out;
  -o-animation: jumpBounce 1 1.5s ease-out;
  animation: jumpBounce 1 1.5s ease-out;
}
@-webkit-keyframes jumpBounce {
  10% {
    -webkit-transform: translateY(-100px);
  }
  20%, 35%, 50% {
    -webkit-transform: translateY(0px);
  }
  25% {
    -webkit-transform: translateY(-40px);
  }
  40% {
    -webkit-transform: translateY(-10px);
  }
}
@-moz-keyframes jumpBounce {
  10% {
    -moz-transform: translateY(-100px);
  }
  20%, 35%, 50% {
    -moz-transform: translateY(0px);
  }
  25% {
    -moz-transform: translateY(-40px);
  }
  40% {
    -moz-transform: translateY(-10px);
  }
}
@-o-keyframes jumpBounce {
  10% {
    -ms-transform: translateY(-100px);
  }
  20%, 35%, 50% {
    -ms-transform: translateY(0px);
  }
  25% {
    -ms-transform: translateY(-40px);
  }
  40% {
    -ms-transform: translateY(-10px);
  }
}
@-o-keyframes jumpBounce {
  10% {
    -o-transform: translateY(-100px);
  }
  20%, 35%, 50% {
    -o-transform: translateY(0px);
  }
  25% {
    -o-transform: translateY(-40px);
  }
  40% {
    -o-transform: translateY(-10px);
  }
}
@-moz-keyframes jumpBounce {
  10% {
    transform: translateY(-100px);
  }
  20%, 35%, 50% {
    transform: translateY(0px);
  }
  25% {
    transform: translateY(-40px);
  }
  40% {
    transform: translateY(-10px);
  }
}
@-webkit-keyframes jumpBounce {
  10% {
    transform: translateY(-100px);
  }
  20%, 35%, 50% {
    transform: translateY(0px);
  }
  25% {
    transform: translateY(-40px);
  }
  40% {
    transform: translateY(-10px);
  }
}
@-o-keyframes jumpBounce {
  10% {
    transform: translateY(-100px);
  }
  20%, 35%, 50% {
    transform: translateY(0px);
  }
  25% {
    transform: translateY(-40px);
  }
  40% {
    transform: translateY(-10px);
  }
}
@keyframes jumpBounce {
  10% {
    transform: translateY(-100px);
  }
  20%, 35%, 50% {
    transform: translateY(0px);
  }
  25% {
    transform: translateY(-40px);
  }
  40% {
    transform: translateY(-10px);
  }
}
/***** Perspective ******/
.tree-flip {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: treeFlip 1 1s ease-in-out;
  -moz-animation: treeFlip 1 1s ease-in-out;
  -ms-animation: treeFlip 1 1s ease-in-out;
  -o-animation: treeFlip 1 1s ease-in-out;
  animation: treeFlip 1 1s ease-in-out;
  -webkit-transform: rotateY(-90deg);
  -moz-transform: rotateY(-90deg);
  -ms-transform: rotateY(-90deg);
  -o-transform: rotateY(-90deg);
  transform: rotateY(-90deg);
  -webkit-transform-origin: 0 0;
  -moz-transform-origin: 0 0;
  -o-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
}
@-webkit-keyframes treeFlip {
  0% {
    -webkit-transform: rotateY(0);
  }
  100% {
    -webkit-transform: rotateY(-90deg);
  }
}
@-moz-keyframes treeFlip {
  0% {
    -moz-transform: rotateY(0);
  }
  100% {
    -moz-transform: rotateY(-90deg);
  }
}
@-ms-keyframes treeFlip {
  0% {
    -ms-transform: rotateY(0);
  }
  100% {
    -ms-transform: rotateY(-90deg);
  }
}
@-o-keyframes treeFlip {
  0% {
    -o-transform: rotateY(0);
  }
  100% {
    -o-transform: rotateY(-90deg);
  }
}
@-moz-keyframes treeFlip {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(-90deg);
  }
}
@-webkit-keyframes treeFlip {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(-90deg);
  }
}
@-o-keyframes treeFlip {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(-90deg);
  }
}
@keyframes treeFlip {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(-90deg);
  }
}
.tree-flip-right {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: treeFlipRight 1 1s ease-in-out;
  -moz-animation: treeFlipRight 1 1s ease-in-out;
  -ms-animation: treeFlipRight 1 1s ease-in-out;
  -o-animation: treeFlipRight 1 1s ease-in-out;
  animation: treeFlipRight 1 1s ease-in-out;
  -webkit-transform: rotateY(90deg);
  -moz-transform: rotateY(90deg);
  -ms-transform: rotateY(90deg);
  -o-transform: rotateY(90deg);
  transform: rotateY(90deg);
  -webkit-transform-origin: 100% 0;
  -moz-transform-origin: 100% 0;
  -o-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0;
}
@-webkit-keyframes treeFlipRight {
  0% {
    -webkit-transform: rotateY(0);
  }
  100% {
    -webkit-transform: rotateY(90deg);
  }
}
@-moz-keyframes treeFlipRight {
  0% {
    -moz-transform: rotateY(0);
  }
  100% {
    -moz-transform: rotateY(90deg);
  }
}
@-ms-keyframes treeFlipRight {
  0% {
    -ms-transform: rotateY(0);
  }
  100% {
    -ms-transform: rotateY(90deg);
  }
}
@-o-keyframes treeFlipRight {
  0% {
    -o-transform: rotateY(0);
  }
  100% {
    -o-transform: rotateY(90deg);
  }
}
@-moz-keyframes treeFlipRight {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(90deg);
  }
}
@-webkit-keyframes treeFlipRight {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(90deg);
  }
}
@-o-keyframes treeFlipRight {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(90deg);
  }
}
@keyframes treeFlipRight {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(90deg);
  }
}
.tree-flip-up {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: treeFlipUp 1 1s ease-in-out;
  -moz-animation: treeFlipUp 1 1s ease-in-out;
  -ms-animation: treeFlipUp 1 1s ease-in-out;
  -o-animation: treeFlipUp 1 1s ease-in-out;
  animation: treeFlipUp 1 1s ease-in-out;
  -webkit-transform: rotateX(90deg);
  -moz-transform: rotateX(90deg);
  -ms-transform: rotateX(90deg);
  -o-transform: rotateX(90deg);
  transform: rotateX(90deg);
  -webkit-transform-origin: 100% 0;
  -moz-transform-origin: 100% 0;
  -o-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0;
}
@-webkit-keyframes treeFlipUp {
  0% {
    -webkit-transform: rotateX(0);
  }
  100% {
    -webkit-transform: rotateX(90deg);
  }
}
@-moz-keyframes treeFlipUp {
  0% {
    -moz-transform: rotateX(0);
  }
  100% {
    -moz-transform: rotateX(90deg);
  }
}
@-ms-keyframes treeFlipUp {
  0% {
    -ms-transform: rotateX(0);
  }
  100% {
    -ms-transform: rotateX(90deg);
  }
}
@-o-keyframes treeFlipUp {
  0% {
    -o-transform: rotateX(0);
  }
  100% {
    -o-transform: rotateX(90deg);
  }
}
@-moz-keyframes treeFlipUp {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(90deg);
  }
}
@-webkit-keyframes treeFlipUp {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(90deg);
  }
}
@-o-keyframes treeFlipUp {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(90deg);
  }
}
@keyframes treeFlipUp {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(90deg);
  }
}
.tree-flip-down {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: treeFlipDown 1 1s ease-in-out;
  -moz-animation: treeFlipDown 1 1s ease-in-out;
  -ms-animation: treeFlipDown 1 1s ease-in-out;
  -o-animation: treeFlipDown 1 1s ease-in-out;
  animation: treeFlipDown 1 1s ease-in-out;
  -webkit-transform: rotateX(90deg);
  -moz-transform: rotateX(90deg);
  -ms-transform: rotateX(90deg);
  -o-transform: rotateX(90deg);
  transform: rotateX(90deg);
  -webkit-transform-origin: 0 100%;
  -moz-transform-origin: 0 100%;
  -o-transform-origin: 0 100%;
  -ms-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
@-webkit-keyframes treeFlipDown {
  0% {
    -webkit-transform: rotateX(0);
  }
  100% {
    -webkit-transform: rotateX(-90deg);
  }
}
@-moz-keyframes treeFlipDown {
  0% {
    -moz-transform: rotateX(0);
  }
  100% {
    -moz-transform: rotateX(-90deg);
  }
}
@-ms-keyframes treeFlipDown {
  0% {
    -ms-transform: rotateX(0);
  }
  100% {
    -ms-transform: rotateX(-90deg);
  }
}
@-o-keyframes treeFlipDown {
  0% {
    -o-transform: rotateX(0);
  }
  100% {
    -o-transform: rotateX(-90deg);
  }
}
@-moz-keyframes treeFlipDown {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(-90deg);
  }
}
@-webkit-keyframes treeFlipDown {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(-90deg);
  }
}
@-o-keyframes treeFlipDown {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(-90deg);
  }
}
@keyframes treeFlipDown {
  0% {
    transform: rotateX(0);
  }
  100% {
    transform: rotateX(-90deg);
  }
}
.flip-left-bounce {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: flipLeftBounce 1s ease-in-out;
  -moz-animation: flipLeftBounce 1s ease-in-out;
  -ms-animation: flipLeftBounce 1s ease-in-out;
  -o-animation: flipLeftBounce 1s ease-in-out;
  animation: flipLeftBounce 1s ease-in-out;
}
@-webkit-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    -webkit-transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    -webkit-transform: rotateY(-5deg);
  }
  80% {
    -webkit-transform: rotateY(20deg);
  }
  100% {
    -webkit-transform: rotateY(0deg);
  }
}
@-moz-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    -moz-transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    -moz-transform: rotateY(-5deg);
  }
  80% {
    -moz-transform: rotateY(20deg);
  }
  100% {
    -moz-transform: rotateY(0deg);
  }
}
@-ms-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    -ms-transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    -ms-transform: rotateY(-5deg);
  }
  80% {
    -ms-transform: rotateY(20deg);
  }
  100% {
    -ms-transform: rotateY(0deg);
  }
}
@-o-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    -o-transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    -o-transform: rotateY(-5deg);
  }
  80% {
    -o-transform: rotateY(20deg);
  }
  100% {
    -o-transform: rotateY(0deg);
  }
}
@-moz-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(-5deg);
  }
  80% {
    transform: rotateY(20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@-webkit-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(-5deg);
  }
  80% {
    transform: rotateY(20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@-o-keyframes flipLeftBounce {
  0% {
    opacity: 0;
    transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(-5deg);
  }
  80% {
    transform: rotateY(20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@keyframes flipLeftBounce {
  0% {
    opacity: 0;
    transform: rotateY(70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(-5deg);
  }
  80% {
    transform: rotateY(20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
.flip-right-bounce {
  -webkit-animation: flipRightBounce 1s ease-in-out;
  -moz-animation: flipRightBounce 1s ease-in-out;
  -ms-animation: flipRightBounce 1s ease-in-out;
  -o-animation: flipRightBounce 1s ease-in-out;
  animation: flipRightBounce 1s ease-in-out;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes flipRightBounce {
  0% {
    opacity: 0;
    -webkit-transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    -webkit-transform: rotateY(5deg);
  }
  80% {
    -webkit-transform: rotateY(-20deg);
  }
  100% {
    -webkit-transform: rotateY(0deg);
  }
}
@-moz-keyframes flipRightBounce {
  0% {
    opacity: 0;
    -moz-transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    -moz-transform: rotateY(5deg);
  }
  80% {
    -moz-transform: rotateY(-20deg);
  }
  100% {
    -moz-transform: rotateY(0deg);
  }
}
@-ms-keyframes flipRightBounce {
  0% {
    opacity: 0;
    -ms-transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    -ms-transform: rotateY(5deg);
  }
  80% {
    -ms-transform: rotateY(-20deg);
  }
  100% {
    -ms-transform: rotateY(0deg);
  }
}
@-o-keyframes flipRightBounce {
  0% {
    opacity: 0;
    -o-transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    -o-transform: rotateY(5deg);
  }
  80% {
    -o-transform: rotateY(-20deg);
  }
  100% {
    -o-transform: rotateY(0deg);
  }
}
@-moz-keyframes flipRightBounce {
  0% {
    opacity: 0;
    transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(5deg);
  }
  80% {
    transform: rotateY(-20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@-webkit-keyframes flipRightBounce {
  0% {
    opacity: 0;
    transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(5deg);
  }
  80% {
    transform: rotateY(-20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@-o-keyframes flipRightBounce {
  0% {
    opacity: 0;
    transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(5deg);
  }
  80% {
    transform: rotateY(-20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
@keyframes flipRightBounce {
  0% {
    opacity: 0;
    transform: rotateY(-70deg);
  }
  50% {
    opacity: 1;
    transform: rotateY(5deg);
  }
  80% {
    transform: rotateY(-20deg);
  }
  100% {
    transform: rotateY(0deg);
  }
}
.rotate-flip {
  -webkit-animation: rotateFlip 1 1s linear;
  -moz-animation: rotateFlip 1 1s linear;
  -ms-animation: rotateFlip 1 1s linear;
  -o-animation: rotateFlip 1 1s linear;
  animation: rotateFlip 1 1s linear;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes rotateFlip {
  0% {
    -webkit-transform-origin: 50%;
  }
  40% {
    -webkit-transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    -webkit-transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    -webkit-transform: rotateY(0deg);
    opacity: 1;
  }
}
@-moz-keyframes rotateFlip {
  0% {
    -moz-transform-origin: 50%;
  }
  40% {
    -moz-transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    -moz-transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    -moz-transform: rotateY(0deg);
    opacity: 1;
  }
}
@-ms-keyframes rotateFlip {
  0% {
    -ms-transform-origin: 50%;
  }
  40% {
    -ms-transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    -ms-transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    -ms-transform: rotateY(0deg);
    opacity: 1;
  }
}
@-o-keyframes rotateFlip {
  0% {
    -o-transform-origin: 50%;
  }
  40% {
    -o-transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    -o-transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    -o-transform: rotateY(0deg);
    opacity: 1;
  }
}
@-moz-keyframes rotateFlip {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateY(0deg);
    opacity: 1;
  }
}
@-webkit-keyframes rotateFlip {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateY(0deg);
    opacity: 1;
  }
}
@-o-keyframes rotateFlip {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateY(0deg);
    opacity: 1;
  }
}
@keyframes rotateFlip {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateY(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateY(0deg);
    opacity: 1;
  }
}
/***** Fadding Entrances ******/
.flip-left {
  -webkit-animation: flipLeft 1 1s ease-out;
  -moz-animation: flipLeft 1 1s ease-out;
  -ms-animation: flipLeft 1 1s ease-out;
  -o-animation: flipLeft 1 1s ease-out;
  animation: flipLeft 1 1s ease-out;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes flipLeft {
  0% {
    -webkit-transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    -webkit-transform: translateX(0);
    opacity: 1;
  }
}
@-moz-keyframes flipLeft {
  0% {
    -moz-transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    -moz-transform: translateX(0);
    opacity: 1;
  }
}
@-ms-keyframes flipLeft {
  0% {
    -ms-transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    -ms-transform: translateX(0);
    opacity: 1;
  }
}
@-o-keyframes flipLeft {
  0% {
    -o-transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    -o-transform: translateX(0);
    opacity: 1;
  }
}
@-moz-keyframes flipLeft {
  0% {
    transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@-webkit-keyframes flipLeft {
  0% {
    transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@-o-keyframes flipLeft {
  0% {
    transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes flipLeft {
  0% {
    transform: translateX(-100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
.flip-right {
  -webkit-animation: flipRight 1 1s ease-out;
  -moz-animation: flipRight 1 1s ease-out;
  -ms-animation: flipRight 1 1s ease-out;
  -o-animation: flipRight 1 1s ease-out;
  animation: flipRight 1 1s ease-out;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes flipRight {
  0% {
    -webkit-transform: translateX(100px);
    opacity: 0;
  }
  70% {
    -webkit-transform: translateX(0);
    opacity: 1;
  }
}
@-moz-keyframes flipRight {
  0% {
    -moz-transform: translateX(100px);
    opacity: 0;
  }
  70% {
    -moz-transform: translateX(0);
    opacity: 1;
  }
}
@-ms-keyframes flipRight {
  0% {
    -ms-transform: translateX(100px);
    opacity: 0;
  }
  70% {
    -ms-transform: translateX(0);
    opacity: 1;
  }
}
@-o-keyframes flipRight {
  0% {
    -o-transform: translateX(100px);
    opacity: 0;
  }
  70% {
    -o-transform: translateX(0);
    opacity: 1;
  }
}
@-moz-keyframes flipRight {
  0% {
    transform: translateX(100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@-webkit-keyframes flipRight {
  0% {
    transform: translateX(100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@-o-keyframes flipRight {
  0% {
    transform: translateX(100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes flipRight {
  0% {
    transform: translateX(100px);
    opacity: 0;
  }
  70% {
    transform: translateX(0);
    opacity: 1;
  }
}
.flip-top {
  -webkit-animation: flipTop 1 1s ease-out;
  -moz-animation: flipTop 1 1s ease-out;
  -ms-animation: flipTop 1 1s ease-out;
  -o-animation: flipTop 1 1s ease-out;
  animation: flipTop 1 1s ease-out;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes flipTop {
  0% {
    -webkit-transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    -webkit-transform: translateY(0);
    opacity: 1;
  }
}
@-moz-keyframes flipTop {
  0% {
    -moz-transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    -moz-transform: translateY(0);
    opacity: 1;
  }
}
@-ms-keyframes flipTop {
  0% {
    -ms-transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    -ms-transform: translateY(0);
    opacity: 1;
  }
}
@-o-keyframes flipTop {
  0% {
    -o-transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    -o-transform: translateY(0);
    opacity: 1;
  }
}
@-moz-keyframes flipTop {
  0% {
    transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    transform: translateY(0);
    opacity: 1;
  }
}
@-webkit-keyframes flipTop {
  0% {
    transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    transform: translateY(0);
    opacity: 1;
  }
}
@-o-keyframes flipTop {
  0% {
    transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes flipTop {
  0% {
    transform: translateY(-100px);
    opacity: 0;
  }
  70% {
    transform: translateY(0);
    opacity: 1;
  }
}
.flip-bottom {
  -webkit-animation: flipBottom 1 1s ease-out;
  -moz-animation: flipBottom 1 1s ease-out;
  -ms-animation: flipBottom 1 1s ease-out;
  -o-animation: flipBottom 1 1s ease-out;
  animation: flipBottom 1 1s ease-out;
  opacity: 1 !important;
  visibility: visible !important;
}
@-webkit-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-moz-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-ms-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-o-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-moz-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-webkit-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@-o-keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes flipBottom {
  0% {
    transform: translateY(100px);
    opacity: 0;
  }
  70% {
    transform: translateY(30px);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
  }
}
/***** Rotate ******/
.rotate-flip-down {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-animation: rotateFlipDown 1 1s linear;
  -moz-animation: rotateFlipDown 1 1s linear;
  -ms-animation: rotateFlipDown 1 1s linear;
  -o-animation: rotateFlipDown 1 1s linear;
  animation: rotateFlipDown 1 1s linear;
}
@-webkit-keyframes rotateFlipDown {
  0% {
    -webkit-transform-origin: 50%;
  }
  40% {
    -webkit-transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    -webkit-transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    -webkit-transform: rotateX(0deg);
    opacity: 1;
  }
}
@-moz-keyframes rotateFlipDown {
  0% {
    -moz-transform-origin: 50%;
  }
  40% {
    -moz-transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    -moz-transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    -moz-transform: rotateX(0deg);
    opacity: 1;
  }
}
@-ms-keyframes rotateFlipDown {
  0% {
    -ms-transform-origin: 50%;
  }
  40% {
    -ms-transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    -ms-transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    -ms-transform: rotateX(0deg);
    opacity: 1;
  }
}
@-o-keyframes rotateFlipDown {
  0% {
    -o-transform-origin: 50%;
  }
  40% {
    -o-transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    -o-transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    -o-transform: rotateX(0deg);
    opacity: 1;
  }
}
@-moz-keyframes rotateFlipDown {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}
@-webkit-keyframes rotateFlipDown {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}
@-o-keyframes rotateFlipDown {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}
@keyframes rotateFlipDown {
  0% {
    transform-origin: 50%;
  }
  40% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  60% {
    transform: rotateX(70deg);
    opacity: 0;
  }
  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}
.rotate-down-bounce {
  -webkit-transform-origin: 0 0;
  -moz-transform-origin: 0 0;
  -o-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
  opacity: 0;
  visibility: hidden;
  -webkit-animation: rotateDowBounce 1 2s ease-in;
  -moz-animation: rotateDowBounce 1 2s ease-in;
  -ms-animation: rotateDowBounce 1 2s ease-in;
  -o-animation: rotateDowBounce 1 2s ease-in;
  animation: rotateDowBounce 1 2s ease-in;
}
@-webkit-keyframes rotateDowBounce {
  0% {
    -webkit-transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    -webkit-transform: rotate(25deg);
  }
  40% {
    -webkit-transform: rotate(30deg);
  }
  10%, 30%, 50% {
    -webkit-transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    -webkit-transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-moz-keyframes rotateDowBounce {
  0% {
    -moz-transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    -moz-transform: rotate(25deg);
  }
  40% {
    -moz-transform: rotate(30deg);
  }
  10%, 30%, 50% {
    -moz-transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    -moz-transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-ms-keyframes rotateDowBounce {
  0% {
    -ms-transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    -ms-transform: rotate(25deg);
  }
  40% {
    -ms-transform: rotate(30deg);
  }
  10%, 30%, 50% {
    -ms-transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    -ms-transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-o-keyframes rotateDowBounce {
  0% {
    -o-transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    -o-transform: rotate(25deg);
  }
  40% {
    -o-transform: rotate(30deg);
  }
  10%, 30%, 50% {
    -o-transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    -o-transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-moz-keyframes rotateDowBounce {
  0% {
    transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    transform: rotate(25deg);
  }
  40% {
    transform: rotate(30deg);
  }
  10%, 30%, 50% {
    transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-webkit-keyframes rotateDowBounce {
  0% {
    transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    transform: rotate(25deg);
  }
  40% {
    transform: rotate(30deg);
  }
  10%, 30%, 50% {
    transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@-o-keyframes rotateDowBounce {
  0% {
    transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    transform: rotate(25deg);
  }
  40% {
    transform: rotate(30deg);
  }
  10%, 30%, 50% {
    transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
@keyframes rotateDowBounce {
  0% {
    transform: rotate(0deg);
    opacity: 1;
    visibility: visible;
  }
  20% {
    transform: rotate(25deg);
  }
  40% {
    transform: rotate(30deg);
  }
  10%, 30%, 50% {
    transform: rotate(40deg);
    opacity: 1;
    visibility: visible;
  }
  80%, 100% {
    transform: rotate(30deg) translateY(310px) translateX(230px);
    opacity: 0;
    visibility: hidden;
  }
}
.rotate-out {
  opacity: 0;
  visibility: hidden;
  -webkit-animation: rotateOut 1 1.5s ease-out;
  -moz-animation: rotateOut 1 1.5s ease-out;
  -ms-animation: rotateOut 1 1.5s ease-out;
  -o-animation: rotateOut 1 1.5s ease-out;
  animation: rotateOut 1 1.5s ease-out;
}
@-webkit-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -webkit-transform: scale(0) rotateY(189deg);
  }
}
@-moz-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -moz-transform: scale(0) rotateY(189deg);
  }
}
@-ms-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -ms-transform: scale(0) rotateY(189deg);
  }
}
@-o-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -o-transform: scale(0) rotateY(189deg);
  }
}
@-moz-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: scale(0) rotateY(189deg);
  }
}
@-webkit-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: scale(0) rotateY(189deg);
  }
}
@-o-keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: scale(0) rotateY(189deg);
  }
}
@keyframes rotateOut {
  0% {
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: scale(0) rotateY(189deg);
  }
}
/***** Agreccives ******/
.flash-bang {
  -webkit-animation: flashBang 1 2s linear forwards;
  -moz-animation: flashBang 1 2s linear forwards;
  -ms-animation: flashBang 1 2s linear forwards;
  -o-animation: flashBang 1 2s linear forwards;
  animation: flashBang 1 2s linear forwards;
}
@-webkit-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-ms-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-moz-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-webkit-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@-o-keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
@keyframes flashBang {
  0%, 20% {
    opacity: 0;
    visibility: hidden;
  }
  10%, 30%, 100% {
    opacity: 1;
    visibility: visible;
  }
}
.bomba {
  -webkit-animation: bomba 1 1s ease-out forwards;
  -moz-animation: bomba 1 1s ease-out forwards;
  -ms-animation: bomba 1 1s ease-out forwards;
  -o-animation: bomba 1 1s ease-out forwards;
  animation: bomba 1 1s ease-out forwards;
}
@-webkit-keyframes bomba {
  0% {
    -webkit-transform-origin: -50% 0%;
    -webkit-transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -webkit-transform: rotateZ(-210deg);
    -webkit-transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-moz-keyframes bomba {
  0% {
    -moz-transform-origin: -50% 0%;
    -moz-transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -moz-transform: rotateZ(-210deg);
    -moz-transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-o-keyframes bomba {
  0% {
    -o-transform-origin: -50% 0%;
    -o-transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -o-transform: rotateZ(-210deg);
    -o-transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-ms-keyframes bomba {
  0% {
    -ms-transform-origin: -50% 0%;
    -ms-transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    -ms-transform: rotateZ(-210deg);
    -ms-transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-moz-keyframes bomba {
  0% {
    transform-origin: -50% 0%;
    transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: rotateZ(-210deg);
    transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-webkit-keyframes bomba {
  0% {
    transform-origin: -50% 0%;
    transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: rotateZ(-210deg);
    transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@-o-keyframes bomba {
  0% {
    transform-origin: -50% 0%;
    transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: rotateZ(-210deg);
    transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
@keyframes bomba {
  0% {
    transform-origin: -50% 0%;
    transform: rotateZ(0);
    opacity: 1;
    visibility: visible;
  }
  50%, 100% {
    transform: rotateZ(-210deg);
    transform-origin: -20% 0%;
  }
  47%, 100% {
    opacity: 0;
    visibility: hidden;
  }
}
/***** Legends ******/
.legend-down,
.legend-down:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.legend-down:before {
  background: rgba(0,0,0,0.5);
  -webkit-animation: legendDown 1 0.5s ease-out;
  -moz-animation: legendDown 1 0.5s ease-out;
  -ms-animation: legendDown 1 0.5s ease-out;
  -o-animation: legendDown 1 0.5s ease-out;
  animation: legendDown 1 0.5s ease-out;
}
@-webkit-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-moz-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-ms-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-o-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-moz-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-webkit-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-o-keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@keyframes legendDown {
  0% {
    top: 0;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
.legend-up,
.legend-up:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.legend-up:before {
  background: rgba(0,0,0,0.5);
  -webkit-animation: legendUp 1 0.5s ease-out;
  -moz-animation: legendUp 1 0.5s ease-out;
  -ms-animation: legendUp 1 0.5s ease-out;
  -o-animation: legendUp 1 0.5s ease-out;
  animation: legendUp 1 0.5s ease-out;
}
@-webkit-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-moz-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-ms-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-o-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-moz-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-webkit-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@-o-keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
@keyframes legendUp {
  0% {
    top: 70%;
    height: 0;
  }
  100% {
    height: 64%;
    top: 9px;
  }
}
.legend-left,
.legend-left:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.legend-left:before {
  background: rgba(0,0,0,0.5);
  -webkit-animation: legendLeft 1 0.5s ease-out;
  -moz-animation: legendLeft 1 0.5s ease-out;
  -ms-animation: legendLeft 1 0.5s ease-out;
  -o-animation: legendLeft 1 0.5s ease-out;
  animation: legendLeft 1 0.5s ease-out;
}
@-webkit-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-moz-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-ms-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-o-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-moz-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-webkit-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-o-keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@keyframes legendLeft {
  0% {
    left: 0%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
.legend-right,
.legend-right:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.legend-right:before {
  background: rgba(0,0,0,0.5);
  -webkit-animation: legendRight 1 0.5s ease-out;
  -moz-animation: legendRight 1 0.5s ease-out;
  -ms-animation: legendRight 1 0.5s ease-out;
  -o-animation: legendRight 1 0.5s ease-out;
  animation: legendRight 1 0.5s ease-out;
}
@-webkit-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-moz-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-ms-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-o-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-moz-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-webkit-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@-o-keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
@keyframes legendRight {
  0% {
    left: 100%;
    width: 0;
  }
  100% {
    left: 9px;
    width: 92%;
  }
}
.legend-flip,
.legend-flip:before {
  opacity: 1 !important;
  visibility: visible !important;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  -o-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-perspective: 600;
  -moz-perspective: 600;
  -ms-perspective: 600;
  perspective: 600;
}
.legend-flip {
  -webkit-animation: legendFlip 1.2s ease-out;
  -moz-animation: legendFlip 1.2s ease-out;
  -ms-animation: legendFlip 1.2s ease-out;
  -o-animation: legendFlip 1.2s ease-out;
  animation: legendFlip 1.2s ease-out;
  -webkit-transform: rotateY(-180deg);
  -moz-transform: rotateY(-180deg);
  -ms-transform: rotateY(-180deg);
  -o-transform: rotateY(-180deg);
  transform: rotateY(-180deg);
}
.legend-flip:before {
  -webkit-animation: legendFlipBefore 1.2s ease-out;
  -moz-animation: legendFlipBefore 1.2s ease-out;
  -ms-animation: legendFlipBefore 1.2s ease-out;
  -o-animation: legendFlipBefore 1.2s ease-out;
  animation: legendFlipBefore 1.2s ease-out;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #00d7d7;
  content: "";
  z-index: 1000;
}
@-webkit-keyframes legendFlipBefore {
  0% {
    -webkit-transform: rotateY(-180deg);
  }
  60% {
    -webkit-transform: rotateY(30deg);
  }
  80% {
    -webkit-transform: rotateY(-30deg);
  }
  100% {
    -webkit-transform: rotateY(0);
  }
}
@-moz-keyframes legendFlipBefore {
  0% {
    -moz-transform: rotateY(-180deg);
  }
  60% {
    -moz-transform: rotateY(30deg);
  }
  80% {
    -moz-transform: rotateY(-30deg);
  }
  100% {
    -moz-transform: rotateY(0);
  }
}
@-ms-keyframes legendFlipBefore {
  0% {
    -ms-transform: rotateY(-180deg);
  }
  60% {
    -ms-transform: rotateY(30deg);
  }
  80% {
    -ms-transform: rotateY(-30deg);
  }
  100% {
    -ms-transform: rotateY(0);
  }
}
@-o-keyframes legendFlipBefore {
  0% {
    -o-transform: rotateY(-180deg);
  }
  60% {
    -o-transform: rotateY(30deg);
  }
  80% {
    -o-transform: rotateY(-30deg);
  }
  100% {
    -o-transform: rotateY(0);
  }
}
@-webkit-keyframes legendFlip {
  0% {
    -webkit-transform: rotateY(0);
  }
  60% {
    -webkit-transform: rotateY(-210deg);
  }
  100% {
    -webkit-transform: rotateY(-150deg);
  }
  100% {
    -webkit-transform: rotateY(-180deg);
  }
}
@-moz-keyframes legendFlip {
  0% {
    -moz-transform: rotateY(0);
  }
  60% {
    -moz-transform: rotateY(-210deg);
  }
  100% {
    -moz-transform: rotateY(-150deg);
  }
  100% {
    -moz-transform: rotateY(-180deg);
  }
}
@-ms-keyframes legendFlip {
  0% {
    -ms-transform: rotateY(0);
  }
  60% {
    -ms-transform: rotateY(-210deg);
  }
  100% {
    -ms-transform: rotateY(-150deg);
  }
  100% {
    -ms-transform: rotateY(-180deg);
  }
}
@-o-keyframes legendFlip {
  0% {
    -o-transform: rotateY(0);
  }
  60% {
    -o-transform: rotateY(-210deg);
  }
  100% {
    -o-transform: rotateY(-150deg);
  }
  100% {
    -o-transform: rotateY(-180deg);
  }
}
@-moz-keyframes legendFlipBefore {
  0% {
    transform: rotateY(-180deg);
  }
  60% {
    transform: rotateY(30deg);
  }
  80% {
    transform: rotateY(-30deg);
  }
  100% {
    transform: rotateY(0);
  }
}
@-webkit-keyframes legendFlipBefore {
  0% {
    transform: rotateY(-180deg);
  }
  60% {
    transform: rotateY(30deg);
  }
  80% {
    transform: rotateY(-30deg);
  }
  100% {
    transform: rotateY(0);
  }
}
@-o-keyframes legendFlipBefore {
  0% {
    transform: rotateY(-180deg);
  }
  60% {
    transform: rotateY(30deg);
  }
  80% {
    transform: rotateY(-30deg);
  }
  100% {
    transform: rotateY(0);
  }
}
@keyframes legendFlipBefore {
  0% {
    transform: rotateY(-180deg);
  }
  60% {
    transform: rotateY(30deg);
  }
  80% {
    transform: rotateY(-30deg);
  }
  100% {
    transform: rotateY(0);
  }
}
@-moz-keyframes legendFlip {
  0% {
    transform: rotateY(0);
  }
  60% {
    transform: rotateY(-210deg);
  }
  100% {
    transform: rotateY(-150deg);
  }
  100% {
    transform: rotateY(-180deg);
  }
}
@-webkit-keyframes legendFlip {
  0% {
    transform: rotateY(0);
  }
  60% {
    transform: rotateY(-210deg);
  }
  100% {
    transform: rotateY(-150deg);
  }
  100% {
    transform: rotateY(-180deg);
  }
}
@-o-keyframes legendFlip {
  0% {
    transform: rotateY(0);
  }
  60% {
    transform: rotateY(-210deg);
  }
  100% {
    transform: rotateY(-150deg);
  }
  100% {
    transform: rotateY(-180deg);
  }
}
@keyframes legendFlip {
  0% {
    transform: rotateY(0);
  }
  60% {
    transform: rotateY(-210deg);
  }
  100% {
    transform: rotateY(-150deg);
  }
  100% {
    transform: rotateY(-180deg);
  }
}
/***** Portrait ******/
.portrait-before,
.portrait-before:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.portrait-before:before {
  box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
  -webkit-animation: portraitBefore 1 0.3s ease-out;
  -moz-animation: portraitBefore 1 0.3s ease-out;
  -ms-animation: portraitBefore 1 0.3s ease-out;
  -o-animation: portraitBefore 1 0.3s ease-out;
  animation: portraitBefore 1 0.3s ease-out;
}
@-webkit-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-moz-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-ms-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-o-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-moz-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-webkit-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-o-keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@keyframes portraitBefore {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 0 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
.portrait-blur,
.portrait-blur:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.portrait-blur:before {
  box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
  -webkit-animation: portraitBlur 1 0.6s ease-out;
  -moz-animation: portraitBlur 1 0.6s ease-out;
  -ms-animation: portraitBlur 1 0.6s ease-out;
  -o-animation: portraitBlur 1 0.6s ease-out;
  animation: portraitBlur 1 0.6s ease-out;
}
@-webkit-keyframes portraitBlur {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-moz-keyframes portraitBlur {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-ms-keyframes portraitBlur {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
@-o-keyframes portraitBlur {
  0% {
    box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
    width: 100%;
    height: 74%;
    top: 0;
    left: 0;
  }
  100% {
    box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
    width: 92%;
    height: 64%;
    top: 9px;
    left: 9px;
  }
}
keyframes portraitBlur 0% {
  box-shadow: inset 0 0 0 0 rgba(0,0,0,0.5);
  width: 100%;
  height: 74%;
  top: 0;
  left: 0;
}
keyframes portraitBlur 100% {
  box-shadow: inset 0 0 100px 100px rgba(0,0,0,0.5);
  width: 92%;
  height: 64%;
  top: 9px;
  left: 9px;
}
.scale-before,
.scale-before:before {
  opacity: 1 !important;
  visibility: visible !important;
}
.scale-before:before {
  background: rgba(0,0,0,0.5);
  -webkit-animation: scaleBefore 1 0.5s ease-out;
  -moz-animation: scaleBefore 1 0.5s ease-out;
  -ms-animation: scaleBefore 1 0.5s ease-out;
  -o-animation: scaleBefore 1 0.5s ease-out;
  animation: scaleBefore 1 0.5s ease-out;
}
@-webkit-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-moz-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-ms-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-o-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-moz-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-webkit-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@-o-keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
@keyframes scaleBefore {
  0% {
    -webkit-transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
  }
}
/***** Infinites ******/
.rotate-row {
  opacity: 1 !important;
  -webkit-animation: rotateRow infinite alternate 3s linear;
  -moz-animation: rotateRow infinite alternate 3s linear;
  -ms-animation: rotateRow infinite alternate 3s linear;
  -o-animation: rotateRow infinite alternate 3s linear;
  animation: rotateRow infinite alternate 3s linear;
}
@-webkit-keyframes rotateRow {
  0%, 10% {
    -webkit-transform: translateY(0);
  }
  5% {
    -webkit-transform: translateY(-20px);
  }
  100% {
    -webkit-transform: rotate(20000deg) translateY(0px);
  }
}
@-moz-keyframes rotateRow {
  0%, 10% {
    -moz-transform: translateY(0);
  }
  5% {
    -moz-transform: translateY(-20px);
  }
  100% {
    -moz-transform: rotate(20000deg) translateY(0px);
  }
}
@-ms-keyframes rotateRow {
  0%, 10% {
    -ms-transform: translateY(0);
  }
  5% {
    -ms-transform: translateY(-20px);
  }
  100% {
    -ms-transform: rotate(20000deg) translateY(0px);
  }
}
@-o-keyframes rotateRow {
  0%, 10% {
    -ms-transform: translateY(0);
  }
  5% {
    -ms-transform: translateY(-20px);
  }
  100% {
    -o-transform: rotate(20000deg) translateY(0px);
  }
}
@-keyframes rotateRow {
  0%,
  10% {
    transform: translateY(0);
  }
  5% {
    transform: translateY(-20px);
  }
  100% {
    transform: rotate(20000deg) translateY(0px);
  }
}
/********************* Components ***********************/
.all-animation label {
  display: block;
}
.all-animation ul {
  width: 100%;
}
.all-animation ul,
.all-animation li {
  list-style: none;
}
.all-animation input[type="checkbox"],
.all-animation input[type="radio"] {
  display: none;
}
.all-animation.check-in label:after,
.all-animation.box-check label:after {
  content: "";
  -webkit-transform: rotateZ(-36deg) translateY(-10px) translateX(24px);
  -moz-transform: rotateZ(-36deg) translateY(-10px) translateX(24px);
  -ms-transform: rotateZ(-36deg) translateY(-10px) translateX(24px);
  -o-transform: rotateZ(-36deg) translateY(-10px) translateX(24px);
  transform: rotateZ(-36deg) translateY(-10px) translateX(24px);
  display: block;
}
.all-animation.check-in label:before,
.all-animation.box-check label:before,
.all-animation.check-in label:after,
.all-animation.box-check label:after {
  width: 3px;
  height: 100%;
  background: #d21414;
  -webkit-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -moz-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -ms-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -o-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
}
.all-animation.check-in label:before,
.all-animation.box-check label:before {
  -webkit-transform: rotateZ(38deg) translateY(-7px) translateX(11px);
  -moz-transform: rotateZ(38deg) translateY(-7px) translateX(11px);
  -ms-transform: rotateZ(38deg) translateY(-7px) translateX(11px);
  -o-transform: rotateZ(38deg) translateY(-7px) translateX(11px);
  transform: rotateZ(38deg) translateY(-7px) translateX(11px);
}
.all-animation.check-in input:checked ~ label:before,
.all-animation.box-check input:checked ~ label:before,
.all-animation.check-in input:checked ~ label:after,
.all-animation.box-check input:checked ~ label:after {
  background: #46d946;
}
.all-animation.check-in input:checked ~ label:before,
.all-animation.box-check input:checked ~ label:before {
  height: 100%;
  -webkit-transform: rotateZ(38deg) translateY(-17px) translateX(14px);
  -moz-transform: rotateZ(38deg) translateY(-17px) translateX(14px);
  -ms-transform: rotateZ(38deg) translateY(-17px) translateX(14px);
  -o-transform: rotateZ(38deg) translateY(-17px) translateX(14px);
  transform: rotateZ(38deg) translateY(-17px) translateX(14px);
}
.all-animation.check-in input:checked ~ label:after,
.all-animation.box-check input:checked ~ label:after {
  height: 61%;
  -webkit-transform: rotateZ(-36deg) translateY(-10px) translateX(21px);
  -moz-transform: rotateZ(-36deg) translateY(-10px) translateX(21px);
  -ms-transform: rotateZ(-36deg) translateY(-10px) translateX(21px);
  -o-transform: rotateZ(-36deg) translateY(-10px) translateX(21px);
  transform: rotateZ(-36deg) translateY(-10px) translateX(21px);
}
.all-animation.box-check label:before,
.all-animation.box-check label:after {
  height: 72%;
}
.all-animation.box-check label:before {
  -webkit-transform: rotateZ(31deg) translateY(-3px) translateX(11px);
  -moz-transform: rotateZ(31deg) translateY(-3px) translateX(11px);
  -ms-transform: rotateZ(31deg) translateY(-3px) translateX(11px);
  -o-transform: rotateZ(31deg) translateY(-3px) translateX(11px);
  transform: rotateZ(31deg) translateY(-3px) translateX(11px);
}
.all-animation.box-check label:after {
  -webkit-transform: rotateZ(-30deg) translateY(-7px) translateX(16px);
  -moz-transform: rotateZ(-30deg) translateY(-7px) translateX(16px);
  -ms-transform: rotateZ(-30deg) translateY(-7px) translateX(16px);
  -o-transform: rotateZ(-30deg) translateY(-7px) translateX(16px);
  transform: rotateZ(-30deg) translateY(-7px) translateX(16px);
}
.all-animation.check-in label,
.all-animation.box-check label {
  height: 28px;
  max-width: 28px;
}
.all-animation.check-in label,
.all-animation.box-check label,
.all-animation.puft-in label,
.all-animation.puft-out label,
.all-animation.puft-left label,
.all-animation.puft-right label,
.all-animation.puft-top label,
.all-animation.puft-bottom label {
  position: relative;
  cursor: pointer;
  width: 100%;
  padding: 2px;
}
.all-animation.check-in label:before,
.all-animation.box-check label:before,
.all-animation.puft-in label:before,
.all-animation.puft-out label:before,
.all-animation.puft-left label:before,
.all-animation.puft-right label:before,
.all-animation.puft-top label:before,
.all-animation.puft-bottom label:before {
  content: "";
}
.all-animation.check-in label:before,
.all-animation.box-check label:before,
.all-animation.puft-in label:before,
.all-animation.puft-out label:before,
.all-animation.puft-left label:before,
.all-animation.puft-right label:before,
.all-animation.puft-top label:before,
.all-animation.puft-bottom label:before {
  display: block;
  border-radius: 3px;
}
.all-animation.puft-in label,
.all-animation.puft-out label,
.all-animation.puft-left label,
.all-animation.puft-right label,
.all-animation.puft-top label,
.all-animation.puft-bottom label {
  max-width: 28px;
  height: 28px;
}
.all-animation.puft-in label,
.all-animation.puft-out label,
.all-animation.puft-left label,
.all-animation.puft-right label,
.all-animation.puft-top label,
.all-animation.puft-bottom label,
.all-animation.box-check label {
  background: #fcfff4;
  background: -webkit-linear-gradient(top, #fff 0%, #dfe5d7 40%, #fff 100%);
  background: -moz-linear-gradient(top, #fff 0%, #dfe5d7 40%, #fff 100%);
  background: -ms-linear-gradient(top, #fff 0%, #dfe5d7 40%, #fff 100%);
  background: -o-linear-gradient(top, #fff 0%, #dfe5d7 40%, #fff 100%);
  background: linear-gradient(top, #fff 0%, #dfe5d7 40%, #fff 100%);
  box-shadow: inset 0px 1px 1px #fff, 0px 1px 3px rgba(0,0,0,0.5);
}
.all-animation.puft-left.inverted label:before,
.all-animation.puft-right.inverted label:before,
.all-animation.puft-top.inverted label:before,
.all-animation.puft-bottom.inverted label:before {
  background: #1d9b72;
}
.all-animation.puft-left.danger label:before,
.all-animation.puft-right.danger label:before,
.all-animation.puft-top.danger label:before,
.all-animation.puft-bottom.danger label:before {
  background: #d21414;
}
.all-animation.puft-left.info label:before,
.all-animation.puft-right.info label:before,
.all-animation.puft-top.info label:before,
.all-animation.puft-bottom.info label:before {
  background: #f90;
}
.all-animation.puft-left label,
.all-animation.puft-right label,
.all-animation.puft-top label,
.all-animation.puft-bottom label {
  overflow: hidden;
}
.all-animation.puft-left label:before,
.all-animation.puft-right label:before,
.all-animation.puft-top label:before,
.all-animation.puft-bottom label:before {
  background: #46d946;
  -webkit-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -moz-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -ms-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  -o-transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
  transition: cubic-bezier(0.55, 0.085, 0.68, 0.53) all 0.2s;
}
.all-animation.puft-left input:checked ~ label:before,
.all-animation.puft-right input:checked ~ label:before,
.all-animation.puft-top input:checked ~ label:before,
.all-animation.puft-bottom input:checked ~ label:before {
  height: 100%;
  width: 100%;
}
.all-animation.puft-top label:before,
.all-animation.puft-bottom label:before {
  height: 0;
  width: 100%;
}
.all-animation.puft-bottom label:before {
  -webkit-transform: translateY(28px);
  -moz-transform: translateY(28px);
  -ms-transform: translateY(28px);
  -o-transform: translateY(28px);
  transform: translateY(28px);
}
.all-animation.puft-bottom input:checked ~ label:before {
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
  transform: translateY(0);
}
.all-animation.puft-left label:before,
.all-animation.puft-right label:before {
  width: 0;
  height: 100%;
}
.all-animation.puft-left input:checked ~ label:before,
.all-animation.puft-right input:checked ~ label:before {
  -webkit-transform: translateX(0);
  -moz-transform: translateX(0);
  -ms-transform: translateX(0);
  -o-transform: translateX(0);
  transform: translateX(0);
}
.all-animation.puft-right label:before {
  -webkit-transform: translateX(28px);
  -moz-transform: translateX(28px);
  -ms-transform: translateX(28px);
  -o-transform: translateX(28px);
  transform: translateX(28px);
}
.all-animation.puft-in.inverted label:before,
.all-animation.puft-out.inverted label:before {
  box-shadow: inset 0 0 0 0 #1d9b72;
}
.all-animation.puft-in.inverted input:checked ~ label:before,
.all-animation.puft-out.inverted input:checked ~ label:before {
  box-shadow: inset 0 0 67px 4px #1d9b72;
}
.all-animation.puft-in.danger label:before,
.all-animation.puft-out.danger label:before {
  box-shadow: inset 0 0 0 0 #d21414;
}
.all-animation.puft-in.danger input:checked ~ label:before,
.all-animation.puft-out.danger input:checked ~ label:before {
  box-shadow: inset 0 0 67px 4px #d21414;
}
.all-animation.puft-in.info label:before,
.all-animation.puft-out.info label:before {
  box-shadow: inset 0 0 0 0 #f90;
}
.all-animation.puft-in.info input:checked ~ label:before,
.all-animation.puft-out.info input:checked ~ label:before {
  box-shadow: inset 0 0 67px 4px #f90;
}
.all-animation.puft-in label:before,
.all-animation.puft-out label:before {
  width: 100%;
  height: 100%;
  box-shadow: inset 0 0 0 0 #46d946;
  -webkit-transition: all ease-out 0.2s;
  -moz-transition: all ease-out 0.2s;
  -ms-transition: all ease-out 0.2s;
  -o-transition: all ease-out 0.2s;
  transition: all ease-out 0.2s;
}
.all-animation.puft-in input:checked ~ label:before,
.all-animation.puft-out input:checked ~ label:before {
  box-shadow: inset 0 0 67px 4px #46d946;
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
  -webkit-transition: all ease-out 0.2s;
  -moz-transition: all ease-out 0.2s;
  -ms-transition: all ease-out 0.2s;
  -o-transition: all ease-out 0.2s;
  transition: all ease-out 0.2s;
}
.all-animation.puft-in label:before {
  -webkit-transform: scale(1.2);
  -moz-transform: scale(1.2);
  -ms-transform: scale(1.2);
  -o-transform: scale(1.2);
  transform: scale(1.2);
}
.all-animation.puft-out label:before {
  -webkit-transform: scale(0.2);
  -moz-transform: scale(0.2);
  -ms-transform: scale(0.2);
  -o-transform: scale(0.2);
  transform: scale(0.2);
}
.all-animation.triggerOnOf label,
.all-animation.trigger label {
  -webkit-transition: all ease-out 0.1s;
  -moz-transition: all ease-out 0.1s;
  -ms-transition: all ease-out 0.1s;
  -o-transition: all ease-out 0.1s;
  transition: all ease-out 0.1s;
  padding-top: 3px;
  display: block;
  padding-left: 60px;
  position: relative;
}
.all-animation.triggerOnOf label:after,
.all-animation.trigger label:after {
  width: 20px;
  height: 20px;
  border-radius: 100%;
  background: #fff;
  border: solid 1px #e1e0e0;
  cursor: pointer;
  position: absolute;
  top: 2px;
  left: -2px;
}
.all-animation.triggerOnOf label:before,
.all-animation.trigger label:before,
.all-animation.triggerOnOf label:after,
.all-animation.trigger label:after {
  -webkit-transition: all linear 0.2s;
  -moz-transition: all linear 0.2s;
  -ms-transition: all linear 0.2s;
  -o-transition: all linear 0.2s;
  transition: all linear 0.2s;
  content: "";
  display: block;
}
.all-animation.triggerOnOf label:hover:before,
.all-animation.trigger label:hover:before {
  background: #d4d4d4;
}
.all-animation.triggerOnOf label:before,
.all-animation.trigger label:before {
  width: 50px;
}
.all-animation.triggerOnOf input:checked ~ label:after,
.all-animation.trigger input:checked ~ label:after {
  -webkit-transform: translateX(32px);
  -moz-transform: translateX(32px);
  -ms-transform: translateX(32px);
  -o-transform: translateX(32px);
  transform: translateX(32px);
}
.all-animation.triggerOnOf input:checked ~ label:before,
.all-animation.trigger input:checked ~ label:before {
  background: #46d946;
}
.all-animation.triggerOnOf label:before {
  height: 19px;
  position: absolute;
  left: 0;
  top: 3px;
  border: solid 1px #f0f0f0;
  border-radius: 10px;
  background: #f0f0f0;
  cursor: pointer;
}
.all-animation.triggerOnOf input:checked ~ label {
  color: #46d946;
}
.all-animation.triggerOnOf.inverted input:checked ~ label {
  color: #1d9b72;
}
.all-animation.triggerOnOf.inverted input:checked ~ label:before {
  background: #1d9b72;
}
.all-animation.triggerOnOf.danger input:checked ~ label {
  color: #d21414;
}
.all-animation.triggerOnOf.danger input:checked ~ label:before {
  background: #d21414;
}
.all-animation.triggerOnOf.info input:checked ~ label {
  color: #f90;
}
.all-animation.triggerOnOf.info input:checked ~ label:before {
  background: #f90;
}
.all-animation.trigger label:before {
  border-top: solid 2px #ccc;
  position: absolute;
  left: 0;
  top: 12px;
}
.all-animation.tab-panel ul,
.all-animation.tab-slide-panel ul {
  position: relative;
  margin-bottom: 20px;
  border-bottom: solid 1px #ccc;
}
.all-animation.tab-panel ul:after,
.all-animation.tab-slide-panel ul:after {
  clear: both;
  content: "";
  display: block;
}
.all-animation.tab-panel li,
.all-animation.tab-slide-panel li {
  float: left;
}
.all-animation.tab-panel label,
.all-animation.tab-slide-panel label {
  padding: 10px 20px;
  border: solid 1px transparent;
  margin-bottom: -1px;
  border-top-left-radius: 5px;
  background: transparent;
  border-top-right-radius: 5px;
  cursor: pointer;
  font-size: 14px;
}
.all-animation.tab-panel div,
.all-animation.tab-slide-panel div {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  border-radius: 5px;
  left: 0;
  width: 100%;
  background: #e7e6e6 none repeat scroll 0% 0%;
  margin-top: 0;
  padding: 14px;
  border: 1px solid #ccc;
  font-size: 14px;
}
.all-animation.tab-panel li:first-child div,
.all-animation.tab-slide-panel li:first-child div {
  border-top-left-radius: 0;
}
.all-animation.tab-panel input:checked ~ label,
.all-animation.tab-slide-panel input:checked ~ label {
  border: solid 1px #ccc;
  border-bottom: none;
  background: #e7e6e6 none repeat scroll 0% 0%;
  z-index: 222;
  position: relative;
}
.all-animation.tab-panel input:checked ~ label,
.all-animation.tab-slide-panel input:checked ~ label,
.all-animation.tab-panel div,
.all-animation.tab-slide-panel div {
  color: #a4a4a4 !important;
}
.all-animation.tab-panel input:checked ~ div,
.all-animation.tab-slide-panel input:checked ~ div {
  opacity: 1;
  visibility: visible;
}
.all-animation.tab-panel div {
  -webkit-transition: all ease-out 0.3s;
  -moz-transition: all ease-out 0.3s;
  -ms-transition: all ease-out 0.3s;
  -o-transition: all ease-out 0.3s;
  transition: all ease-out 0.3s;
}
.all-animation.tab-panel input:checked ~ div {
  -webkit-transition-duration: 0.6s;
  -moz-transition-duration: 0.6s;
  -ms-transition-duration: 0.6s;
  -o-transition-duration: 0.6s;
  transition-duration: 0.6s;
  -webkit-transition-delay: 0.4s;
  -moz-transition-delay: 0.4s;
  -ms-transition-delay: 0.4s;
  -o-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
.all-animation.tab-slide-panel div {
  height: 0;
  padding: 0 10px;
  overflow: hidden;
  -webkit-transition: padding ease-out 0.3s;
  -moz-transition: padding ease-out 0.3s;
  -ms-transition: padding ease-out 0.3s;
  -o-transition: padding ease-out 0.3s;
  transition: padding ease-out 0.3s;
}
.all-animation.tab-slide-panel input:checked ~ div {
  opacity: 1;
  padding: 15px 10px;
  height: inherit;
}
.all-animation.menu-box {
  box-shadow: 0 0 0 1px rgba(39,41,43,0.15), 0 1px 2px 0 rgba(0,0,0,0.05);
}
.all-animation.menu-box li {
  position: relative;
}
.all-animation.menu-box label {
  color: #9b9b9b !important;
  cursor: pointer;
  margin: 0;
  font-weight: 400;
  background: #fff;
  border-bottom: solid 1px rgba(39,41,43,0.15);
  -webkit-transition: all ease-out 0.2s;
  -moz-transition: all ease-out 0.2s;
  -ms-transition: all ease-out 0.2s;
  -o-transition: all ease-out 0.2s;
  transition: all ease-out 0.2s;
  padding: 5px 15px;
  font-size: 15px;
}
.all-animation.menu-box label:before {
  content: attr(data-count);
  position: absolute;
  padding: 4px 6px 7px;
  font-size: 14px;
  line-height: 10px;
  margin: 3px;
  right: 10px;
  top: 2px;
  color: #fff;
  background: #ccc;
}
.all-animation.menu-box label:after {
  width: 2px;
  content: "";
  position: absolute;
  height: 100%;
  left: 0;
  top: 0;
}
.all-animation.menu-box label.update:before {
  background: #1d9b72;
}
.all-animation.menu-box label.info:before {
  background: #f90;
}
.all-animation.menu-box label.danger:before {
  background: #d21414;
}
.all-animation.menu-box label._search:before {
  background: transparent;
  content: '';
}
.all-animation.menu-box label:hover {
  background: #f3f3f3;
}
.all-animation.menu-box i {
  float: right;
  color: #ccc !important;
}
.all-animation.menu-box label:after,
.all-animation.menu-box i {
  -webkit-transition: all ease-out 0.2s;
  -moz-transition: all ease-out 0.2s;
  -ms-transition: all ease-out 0.2s;
  -o-transition: all ease-out 0.2s;
  transition: all ease-out 0.2s;
}
.all-animation.menu-box li:last-child label {
  border-bottom: none;
}
.all-animation.menu-box input:checked ~ label:after {
  background: #333;
}
.all-animation.menu-box input.info:checked ~ label:after {
  background: #f90;
}
.all-animation.menu-box input.danger:checked ~ label:after {
  background: #d21414;
}
.all-animation.menu-box input:checked ~ label.update {
  color: #1d9b72;
}
.all-animation.menu-box input:checked ~ label.update:after {
  background: #1d9b72;
}
.all-animation.menu-box input:checked ~ label {
  background: #f3f3f3;
}
.all-animation.menu-box input:checked ~ label i {
  color: #333;
}
.all-animation.menu-list label {
  padding: 5px 0;
  box-shadow: inset -2px 0px 0 #f4f4f4;
  cursor: pointer;
  margin: 0;
}
.all-animation.menu-list input:checked ~ label {
  box-shadow: inset -2px 0px 0 #1d9b72;
}
.all-animation.menu-list input.danger:checked ~ label {
  box-shadow: inset -2px 0px 0 #d21414;
}
.all-animation.menu-list input.on:checked ~ label {
  box-shadow: inset -2px 0px 0 #46d946;
}
.all-animation.menu-list input.info:checked ~ label {
  box-shadow: inset -2px 0px 0 #f90;
}
.all-animation.acordeon label,
.all-animation.double-acordeon label {
  position: relative;
  border-radius: 5px;
  box-shadow: 0 0 0 1px #fff, 0 1px 2px 0 #fff;
  padding: 10px 15px;
  margin-top: 5px;
  cursor: pointer;
}
.all-animation.acordeon label:first-child,
.all-animation.double-acordeon label:first-child {
  margin-top: 0;
}
.all-animation.acordeon label:hover,
.all-animation.double-acordeon label:hover {
  color: #9b9b9b !important;
  font-weight: 400;
  background: #f3f3f3;
}
.all-animation.acordeon label:before,
.all-animation.double-acordeon label:before {
  content: "";
  width: 0;
  height: 0;
  border: solid 7px transparent;
  border-top-color: #fff;
  position: absolute;
  right: 11px;
  top: 17px;
}
.all-animation.acordeon label,
.all-animation.double-acordeon label,
.all-animation.acordeon label:before,
.all-animation.double-acordeon label:before,
.all-animation.acordeon div,
.all-animation.double-acordeon div {
  -webkit-transition: all ease-out 0.3s;
  -moz-transition: all ease-out 0.3s;
  -ms-transition: all ease-out 0.3s;
  -o-transition: all ease-out 0.3s;
  transition: all ease-out 0.3s;
}
.all-animation.acordeon div,
.all-animation.double-acordeon div {
  opacity: 0;
  overflow: hidden;
  padding: 0 0;
  height: 0;
}
.all-animation.acordeon div,
.all-animation.double-acordeon div,
.all-animation.acordeon div *,
.all-animation.double-acordeon div * {
  color: #9b9b9b !important;
  font-weight: 400;
}
.all-animation.acordeon input:checked ~ label,
.all-animation.double-acordeon input:checked ~ label {
  background: #f3f3f3;
  color: #9b9b9b !important;
  font-weight: 400;
}
.all-animation.acordeon input:checked ~ label:before,
.all-animation.double-acordeon input:checked ~ label:before {
  border-top-color: #9b9b9b;
  -webkit-transform-origin: 50% 50%;
  -moz-transform-origin: 50% 50%;
  -ms-transform-origin: 50% 50%;
  -o-transform-origin: 50% 50%;
  transform-origin: 50% 50%;
  -webkit-transform: rotateZ(180deg) translateY(8px);
  -moz-transform: rotateZ(180deg) translateY(8px);
  -ms-transform: rotateZ(180deg) translateY(8px);
  -o-transform: rotateZ(180deg) translateY(8px);
  transform: rotateZ(180deg) translateY(8px);
}
.all-animation.acordeon input:checked ~ label div,
.all-animation.double-acordeon input:checked ~ label div {
  height: auto;
  opacity: 1;
  padding: 20px 0;
}














/*
   Animation example, for spinners
*/
.animate-spin {
  -moz-animation: spin 2s infinite linear;
  -o-animation: spin 2s infinite linear;
  -webkit-animation: spin 2s infinite linear;
  animation: spin 2s infinite linear;
  display: inline-block;
}
@-moz-keyframes spin {
  0% {
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -moz-transform: rotate(359deg);
    -o-transform: rotate(359deg);
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@-webkit-keyframes spin {
  0% {
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -moz-transform: rotate(359deg);
    -o-transform: rotate(359deg);
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@-o-keyframes spin {
  0% {
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -moz-transform: rotate(359deg);
    -o-transform: rotate(359deg);
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@-ms-keyframes spin {
  0% {
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -moz-transform: rotate(359deg);
    -o-transform: rotate(359deg);
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@keyframes spin {
  0% {
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  100% {
    -moz-transform: rotate(359deg);
    -o-transform: rotate(359deg);
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
