.wrapper
h1.glitch Glitch
View Compiled
*
margin: 0
padding: 0
body, html
width: 100%
height: 100%
background-color: black
.wrapper
width: 100%
height: 100%
display: flex
justify-content: center
align-items: center
h1.glitch
color: white
font-family: sans-serif
font-weight: 800
position: relative
font-size: 100px
padding: 30px
h1.glitch::before, h1.glitch::after
padding: 30px
color: white
content: "Glitch"
position: absolute
width: 100%
height: 100%
background: black
overflow: hidden
top: 0
h1.glitch::before
left: 3px
text-shadow: -2px 0 red
animation-name: glitch-animation-1
animation-duration: 2s
animation-timing-function: linear
animation-delay: 0s
animation-iteration-count: infinite
animation-direction: reverse-alternate
h1.glitch::after
left: -3px
text-shadow: -2px 0 blue
animation-name: glitch-animation-2
animation-duration: 2s
animation-timing-function: linear
animation-delay: 0s
animation-iteration-count: infinite
animation-direction: reverse-alternate
@keyframes glitch-animation-1
$steps: 20
@for $i from 0 through $steps
#{percentage($i*(1/$steps))}
clip: rect(random(150)+px, 350px, random(150)+px, 30px)
@keyframes glitch-animation-2
$steps: 20
@for $i from 0 through $steps
#{percentage($i*(1/$steps))}
clip: rect(random(150)+px, 350px, random(150)+px, 30px)
View Compiled
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.