:root{ --white: #fff; --color: #ff14af; } .demo{ background: #e8e8e8; } .btn{ color: transparent; font-family: "Outfit", sans-serif; font-size: 18px; font-weight: 700; text-transform: capitalize; letter-spacing: 1px; padding: 8px 15px; border-radius: 0; border: none; overflow: hidden; position: relative; z-index: 1; transition: all 0.5s ease-in-out; } .btn:hover{ color: transparent; } .btn:before, .btn:after{ content: attr(data-hover); color: var(--color); background: var(--white); width: 100%; height: 100%; padding: 8px 15px; transform: translateX(-50%) translateY(0) scale(1.2); position: absolute; top: 0; left: 50%; transition: all 0.5s ease-in-out; } .btn:after{ color: var(--white); background: var(--color); transform: translateX(-50%) translateY(50px) scale(1.2); } .btn:hover:before{ transform: translateX(-50%) translateY(-50px) scale(0) rotate(120deg); } .btn:hover:after{ transform: translateX(-50%) translateY(0) scale(1.2); text-shadow: 0 0 5px rgb(37, 37, 37); } @media only screen and (max-width: 767px){ .btn{ margin-bottom: 30px; } }