* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html,
body {
    display: grid;
    height: 100%;
    place-items: center;
    background: #e8e8e8;
}

.container {
    display: inline-block;
    position: relative;
    overflow: hidden;
    background: #000;
    color: #fff;
    padding: 1rem 2rem;
    font-weight: 900;
    text-transform: uppercase;
    cursor: pointer;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 100%;
}

.container::before {
    content: '';
    position: absolute;
    inset: 0;
    background: #fff;
    clip-path: polygon(100% 0, 100% 100%, 0% 100%, 100% 100%);
    transition: clip-path .3s ease;
}

.container:hover:before {
    clip-path: polygon(100% 0, 0 0, 0% 100%, 100% 100%);
}

.text {
    position: relative;
    mix-blend-mode: difference;
    display: block;
}

.container:hover .text {
    animation: move-up .3s ease forwards;
}

@keyframes move-up {
    0% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(80%);
    }

    51% {
        transform: translateY(-80%);
    }

    100% {
        transform: translateY(0);
    }
}