:root {
    --icon-color: #fff;
    --icon-hover: #fff;
    --background-color: #00c800;
    --background-hover: #009600
}

.icon {
    width: 48px;
    height: 48px;
    transform: scale(0.6) translate(20%, 20%);
    fill: var(--icon-color)
}

.float {
    position: fixed;
    cursor: pointer;
    width: 60px;
    height: 60px;
    bottom: 40px;
    right: 40px;
    transition: 1s;
    background-color: var(--background-color);
    border-radius: 50px;
    animation: pulse 3s infinite;
    -webkit-animation: pulse 3s infinite;
    -moz-animation: pulse 3s infinite;
    -o-animation: pulse 3s infinite;
    z-index: 99999
}

.float:hover {
    background-color: var(--background-hover)
}

.float:hover .icon {
    fill: var(--icon-hover)
}

@-webkit-keyframes pulse {
    0% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 1) }
    70% { -webkit-box-shadow: 0 0 0 20px rgba(0, 200, 0, 0) }
    100% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 0) }
}

@-o-keyframes pulse {
    0% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 1) }
    70% { -webkit-box-shadow: 0 0 0 20px rgba(0, 200, 0, 0) }
    100% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 0) }
}

@-ms-keyframes pulse {
    0% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 1) }
    70% { -webkit-box-shadow: 0 0 0 20px rgba(0, 200, 0, 0) }
    100% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 0) }
}

@-moz-keyframes pulse {
    0% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 1) }
    70% { -webkit-box-shadow: 0 0 0 20px rgba(0, 200, 0, 0) }
    100% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 0) }
}

@keyframes pulse {
    0% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 1) }
    70% { -webkit-box-shadow: 0 0 0 20px rgba(0, 200, 0, 0) }
    100% { -webkit-box-shadow: 0 0 0 0 rgba(0, 200, 0, 0) }
}