.link{ font-family: 'Secular One', sans-serif; font-size: 24px; font-weight: 400; line-height: 24px; letter-spacing: 1px; text-transform: capitalize; padding: 6px 6px; display: inline-block; overflow: hidden; position: relative; z-index: 1; transition: all 0.3s; } .link:focus, .link:hover{ color: #fff; text-shadow: 2px 2px 3px rgba(0,0,0,0.5); } .link:before, .link:after{ content: attr(data-hover); width: 100%; height: 100%; padding: 6px 6px; position: absolute; top: 0; left: 0; transition: all 0.3s; } .link:before{ color: #fff; background: #000; transform: translateX(0%); } .link:after{ color: #fff; background: linear-gradient(to right,#3d8361,#1c6758); transform: translateX(-100%); } .link:hover:before{ transform: translateX(100%); } .link:hover:after{ transform: translateX(0%); } @media only screen and (max-width: 767px){ .link{ margin-bottom: 30px; } }