.wapp-button {
    position: fixed;
    filter: drop-shadow(0 8px 12px rgba(0, 0, 0, .45));
    right: 32px;
    bottom: 32px;
    z-index: 999;
    perspective: 1000px;
    animation: imgPulse 7s ease-in-out infinite;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.wapp-text {
    position: relative;
    margin-top: 2px;
    background-color: #47a529;
    color: #fff;
    padding: 4px 8px;
    border-radius: 8px;
    overflow: hidden;
    z-index: 9;
    font-size: 14px;
}

.wapp-text:before {
    content: "";
    position: absolute;
    inset: -40%;
    width: 44px;
    background: linear-gradient(90deg,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, .75) 50%,
            rgba(255, 255, 255, 0) 100%);
    mix-blend-mode: screen;
    opacity: 0;
    pointer-events: none;
    animation: shineOverTxt 8s ease-in-out infinite;
    z-index: 99;
}

.wapp-img {
    position: relative;
    transform-style: preserve-3d;
    will-change: transform;
    width: 60px;
    height: 60px;
    overflow: hidden;
    transform-origin: center;
    clip-path: circle(48% at 50% 50%);
    -webkit-clip-path: circle(48% at 50% 50%);
    animation: img3DRotate 8.5s ease-in-out infinite;
    z-index: 19;

}

.wapp-img img {
    display: block;
    width: 100%;
    position: absolute;
    inset: 0;
    backface-visibility: hidden;
    position: relative;

}

.img-3dspin .back {
    transform: rotateY(180deg);
}

.wapp-img:after {
    content: "";
    position: absolute;
    inset: -40%;
    width: 44px;
    background: linear-gradient(90deg,
            rgba(255, 255, 255, 0) 0%,
            rgba(255, 255, 255, .75) 50%,
            rgba(255, 255, 255, 0) 100%);
    mix-blend-mode: screen;
    opacity: 0;
    pointer-events: none;
    animation: shineOver 10.5s ease-in-out infinite;
    z-index: 99;
}


@keyframes shineOver {

    0%,
    70% {
        opacity: 0;
        transform: translateX(-180%) rotate(45deg);
    }

    74% {
        opacity: 1;
    }

    80% {
        opacity: 1;
        transform: translateX(200%) rotate(18deg);
    }

    82%,
    100% {
        opacity: 0;
    }
}

@keyframes shineOverTxt {

    0%,
    70% {
        opacity: 0;
        transform: translateX(-100%) rotate(45deg);
    }

    74% {
        opacity: 1;
    }

    80% {
        opacity: 1;
        transform: translateX(350%) rotate(18deg);
    }

    82%,
    100% {
        opacity: 0;
    }
}

@keyframes imgPulse {

    0%,
    68% {
        transform: scale(1);
    }

    72% {
        transform: scale(1.12);
    }

    76% {
        transform: scale(1.00);
    }

    90% {
        transform: scale(1.16);
    }

    94% {
        transform: scale(1.00);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes img3DRotate {

    0%,
    60% {
        transform: rotateX(0deg) rotateY(0deg);
    }

    68% {
        transform: rotateX(16deg) rotateY(-32deg);
    }

    74% {
        transform: rotateX(-20deg) rotateY(44deg);
    }

    82% {
        transform: rotateX(0deg) rotateY(0deg);
    }

    100% {
        transform: rotateX(0deg) rotateY(0deg);
    }
}

@media (max-width: 1024px) {
    .wapp-button {
        right: 16px;
        bottom: 16px;
    }

    .wapp-text {
        display: flex;
    }

}