/* === MAX Messenger Sticky Icon === */
#mmi-floating-icon {
    position: fixed;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;          /* круглая основа */
    background: transparent;
}

#mmi-floating-icon a {
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    outline: none;
    box-shadow: none;
}

/* Размер иконки (через переменную) */
#mmi-floating-icon .mmi-custom-icon,
#mmi-floating-icon .mmi-icon-svg {
    width: var(--mmi-icon-size, 60px);
    height: var(--mmi-icon-size, 60px);
    display: block;
    border-radius: 50%;         /* для квадратных картинок */
}

.mmi-icon-svg {
    width: 100%;
    height: 100%;
}

/* ========== АНИМАЦИИ ========== */
/* Базовая: длительность берётся из переменной */
#mmi-floating-icon[class*="mmi-animation-"] {
    animation-duration: var(--mmi-animation-speed, 1.5s);
    animation-iteration-count: infinite;
}

/* 1. ПУЛЬСАЦИЯ */
@keyframes mmi-pulse {
    0% { box-shadow: 0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.4); }
    70% { box-shadow: 0 0 0 15px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0); }
    100% { box-shadow: 0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0); }
}
#mmi-floating-icon.mmi-animation-pulse {
    animation-name: mmi-pulse;
}

/* 2. ВОЛНЫ (waves) — три расходящихся круга */
@keyframes mmi-waves {
    0% { box-shadow: 0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.4),
                     0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.3),
                     0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.2); }
    50% { box-shadow: 0 0 0 10px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0),
                      0 0 0 20px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0),
                      0 0 0 30px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0); }
    100% { box-shadow: 0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.4),
                       0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.3),
                       0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.2); }
}
#mmi-floating-icon.mmi-animation-waves {
    animation-name: mmi-waves;
}

/* 3. ЗОВ (ping) — быстрая вспышка с исчезновением */
@keyframes mmi-ping {
    0% { box-shadow: 0 0 0 0 rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.6); }
    75%, 100% { box-shadow: 0 0 0 20px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0); }
}
#mmi-floating-icon.mmi-animation-ping {
    animation-name: mmi-ping;
}

/* 4. ВРАЩЕНИЕ (spin) */
@keyframes mmi-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
#mmi-floating-icon.mmi-animation-spin {
    animation-name: mmi-spin;
    border-radius: 50%;         /* вращается только сам контейнер */
}
#mmi-floating-icon.mmi-animation-spin a {
    animation: inherit;        /* вращаем и ссылку, и иконку */
}

/* 5. ПОДПРЫГИВАНИЕ (bounce) */
@keyframes mmi-bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-15px); }
}
#mmi-floating-icon.mmi-animation-bounce {
    animation-name: mmi-bounce;
}

/* 6. МЯГКОЕ СВЕЧЕНИЕ (glow) — без движения, только тень */
@keyframes mmi-glow {
    0%, 100% { box-shadow: 0 0 10px 5px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.5); }
    50% { box-shadow: 0 0 20px 10px rgba(var(--mmi-animation-color-rgb, 0,191,165), 0.3); }
}
#mmi-floating-icon.mmi-animation-glow {
    animation-name: mmi-glow;
}