*{margin:0;padding:0;} html,body{height:100%;width:100%;overflow:hidden;background:#0099CC;} #title{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); perspective-origin:50% 50%; perspective:300px; } h1{ text-align:center; font-size:12vmin; font-family: 'Open Sans', sans-serif; color:rgba(0,0,0,0.8); line-height:1em; transform:rotateY(50deg); transition:transform 2s; perspective:150px; perspective-origin:0% 50%; } h1:hover{ transform:rotateY(-20deg); } h1:after{ content:attr(data-content); position:absolute; left:0;top:0; transform-origin:50% 100%; transform:rotateX(-90deg); color:#0099CC; } #title:before{ content:''; position:absolute; top:-150%; left:10%; width:120%; height:220%; background:rgba(255,255,255,0.7); transform-origin: 0 0; transform: translateX(0) rotate(40deg) skewX(35deg); border-radius:0 0 100% 0; animation:light 5s; } @keyframes light{ from{opacity:0;} to{opacity:1;} }