/* Amazing glitch effect by Isaac Daud */
/* https://codepen.io/cipherbeta/pen/YLdVjw */

@import url('https://fonts.googleapis.com/css?family=Montserrat:100');
 html, body, h1 {
	 padding: 0;
	 margin: 0;
}
 #app {
	 background: #0a0a0a;
	 height: 100vh;
	 width: 100%;
	 margin: 0;
	 padding: 0;
	 display: flex;
	 flex-direction: column;
	 justify-content: center;
	 align-items: center;
	 background: linear-gradient(rgba(10, 10, 10, .6), rgba(0, 0, 0, .9)), repeating-linear-gradient(0, transparent, transparent 2px, black 3px, black 3px), url('https://images.unsplash.com/photo-1506399558188-acca6f8cbf41?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ&s=7118759521e3184778a3b5e010e202c6');
	 background-size: cover;
	 background-position: center;
	 z-index: 1;
}
 #wrapper {
	 text-align: center;
}
 .sub {
	 color: #64dcdc;
	 letter-spacing: 1em;
}
/* Our mixin positions a copy of our text directly on our existing text, while also setting content to the appropriate text set in the data-text attribute. */
 .glitch {
	 position: relative;
	 color: white;
	 font-size: 4em;
	 letter-spacing: 0.2em;
	/* Animation provies a slight random skew. Check bottom of doc for more information on how to random skew. */
	 animation: glitch-skew 1s infinite linear alternate-reverse;
}
 .glitch::before {
	 content: attr(data-text);
	 position: absolute;
	 top: 0;
	 left: 0;
	 width: 100%;
	 height: 100%;
	 left: 2px;
	 text-shadow: -2px 0 #ff00c1;
	/* Creates an initial clip for our glitch. This works in a typical top,right,bottom,left fashion and creates a mask to only show a certain part of the glitch at a time. */
	 clip: rect(44px, 450px, 56px, 0);
	/* Runs our glitch-anim defined below to run in a 5s loop, infinitely, with an alternating animation to keep things fresh. */
	 animation: glitch-anim 5s infinite linear alternate-reverse;
}
 .glitch::after {
	 content: attr(data-text);
	 position: absolute;
	 top: 0;
	 left: 0;
	 width: 100%;
	 height: 100%;
	 left: -2px;
	 text-shadow: -2px 0 #00fff9, 2px 2px #ff00c1;
	 animation: glitch-anim2 1s infinite linear alternate-reverse;
}
/* Creates an animation with 20 steaps. For each step, it calculates a percentage for the specific step. It then generates a random clip box to be used for the random glitch effect. Also adds a very subtle skew to change the 'thickness' of the glitch.*/
 @keyframes glitch-anim {
	 0% {
		 clip: rect(96px, 9999px, 35px, 0);
		 transform: skew(0.61deg);
	}
	 5% {
		 clip: rect(45px, 9999px, 35px, 0);
		 transform: skew(0.7deg);
	}
	 10% {
		 clip: rect(50px, 9999px, 41px, 0);
		 transform: skew(0.22deg);
	}
	 15% {
		 clip: rect(93px, 9999px, 8px, 0);
		 transform: skew(0.99deg);
	}
	 20% {
		 clip: rect(34px, 9999px, 60px, 0);
		 transform: skew(0.68deg);
	}
	 25% {
		 clip: rect(76px, 9999px, 39px, 0);
		 transform: skew(0.78deg);
	}
	 30% {
		 clip: rect(72px, 9999px, 97px, 0);
		 transform: skew(0.68deg);
	}
	 35% {
		 clip: rect(57px, 9999px, 69px, 0);
		 transform: skew(0.28deg);
	}
	 40% {
		 clip: rect(41px, 9999px, 40px, 0);
		 transform: skew(0.87deg);
	}
	 45% {
		 clip: rect(7px, 9999px, 98px, 0);
		 transform: skew(0.93deg);
	}
	 50% {
		 clip: rect(16px, 9999px, 18px, 0);
		 transform: skew(0.72deg);
	}
	 55% {
		 clip: rect(95px, 9999px, 92px, 0);
		 transform: skew(0.35deg);
	}
	 60% {
		 clip: rect(78px, 9999px, 96px, 0);
		 transform: skew(0.01deg);
	}
	 65% {
		 clip: rect(67px, 9999px, 21px, 0);
		 transform: skew(0.07deg);
	}
	 70% {
		 clip: rect(54px, 9999px, 75px, 0);
		 transform: skew(0.73deg);
	}
	 75% {
		 clip: rect(73px, 9999px, 2px, 0);
		 transform: skew(0.87deg);
	}
	 80% {
		 clip: rect(17px, 9999px, 24px, 0);
		 transform: skew(0.47deg);
	}
	 85% {
		 clip: rect(11px, 9999px, 65px, 0);
		 transform: skew(0.67deg);
	}
	 90% {
		 clip: rect(4px, 9999px, 52px, 0);
		 transform: skew(0.71deg);
	}
	 95% {
		 clip: rect(38px, 9999px, 47px, 0);
		 transform: skew(0.64deg);
	}
	 100% {
		 clip: rect(1px, 9999px, 99px, 0);
		 transform: skew(0.74deg);
	}
}
 @keyframes glitch-anim2 {
	 0% {
		 clip: rect(49px, 9999px, 12px, 0);
		 transform: skew(0.87deg);
	}
	 5% {
		 clip: rect(28px, 9999px, 68px, 0);
		 transform: skew(0.96deg);
	}
	 10% {
		 clip: rect(50px, 9999px, 14px, 0);
		 transform: skew(0.01deg);
	}
	 15% {
		 clip: rect(61px, 9999px, 74px, 0);
		 transform: skew(0.38deg);
	}
	 20% {
		 clip: rect(56px, 9999px, 99px, 0);
		 transform: skew(0.76deg);
	}
	 25% {
		 clip: rect(39px, 9999px, 50px, 0);
		 transform: skew(0.37deg);
	}
	 30% {
		 clip: rect(47px, 9999px, 24px, 0);
		 transform: skew(0.46deg);
	}
	 35% {
		 clip: rect(2px, 9999px, 49px, 0);
		 transform: skew(0.95deg);
	}
	 40% {
		 clip: rect(48px, 9999px, 90px, 0);
		 transform: skew(0.96deg);
	}
	 45% {
		 clip: rect(62px, 9999px, 61px, 0);
		 transform: skew(0.35deg);
	}
	 50% {
		 clip: rect(67px, 9999px, 66px, 0);
		 transform: skew(0.52deg);
	}
	 55% {
		 clip: rect(46px, 9999px, 40px, 0);
		 transform: skew(0.65deg);
	}
	 60% {
		 clip: rect(86px, 9999px, 31px, 0);
		 transform: skew(0.67deg);
	}
	 65% {
		 clip: rect(85px, 9999px, 33px, 0);
		 transform: skew(0.57deg);
	}
	 70% {
		 clip: rect(57px, 9999px, 36px, 0);
		 transform: skew(0.48deg);
	}
	 75% {
		 clip: rect(5px, 9999px, 100px, 0);
		 transform: skew(0.84deg);
	}
	 80% {
		 clip: rect(35px, 9999px, 3px, 0);
		 transform: skew(0.53deg);
	}
	 85% {
		 clip: rect(51px, 9999px, 98px, 0);
		 transform: skew(0.32deg);
	}
	 90% {
		 clip: rect(63px, 9999px, 18px, 0);
		 transform: skew(0.88deg);
	}
	 95% {
		 clip: rect(19px, 9999px, 36px, 0);
		 transform: skew(0.69deg);
	}
	 100% {
		 clip: rect(29px, 9999px, 80px, 0);
		 transform: skew(0.7deg);
	}
}
 @keyframes glitch-skew {
	 0% {
		 transform: skew(5deg);
	}
	 10% {
		 transform: skew(-4deg);
	}
	 20% {
		 transform: skew(4deg);
	}
	 30% {
		 transform: skew(-1deg);
	}
	 40% {
		 transform: skew(1deg);
	}
	 50% {
		 transform: skew(-2deg);
	}
	 60% {
		 transform: skew(-2deg);
	}
	 70% {
		 transform: skew(3deg);
	}
	 80% {
		 transform: skew(2deg);
	}
	 90% {
		 transform: skew(-2deg);
	}
	 100% {
		 transform: skew(-1deg);
	}
}

/* Amazing image glitch effect */
