/**
 * Fancy Menu Animations
 * Additional fancy effects for the menu
 */

/* 3D Hover Effect */
.menu-item-3d {
    perspective: 1000px;
}

.menu-item-3d a {
    display: inline-block;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    transform-style: preserve-3d;
}

.menu-item-3d a:hover {
    transform: rotateX(10deg) rotateY(-10deg) translateZ(20px);
    box-shadow: -10px 10px 20px rgba(0,0,0,0.1);
}

/* Glowing Effect */
.menu-item-glow a {
    position: relative;
}

.menu-item-glow a::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
    border-radius: 9999px;
    z-index: -1;
    opacity: 0;
    filter: blur(5px);
    transition: opacity 0.3s ease;
}

.menu-item-glow a:hover::before {
    opacity: 0.7;
}

/* Bounce Effect */
@keyframes bounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-5px);
    }
}

.menu-item-bounce a:hover {
    animation: bounce 0.5s ease infinite;
}

/* Shake Effect */
@keyframes shake {
    0%, 100% {
        transform: translateX(0);
    }
    25% {
        transform: translateX(-5px);
    }
    75% {
        transform: translateX(5px);
    }
}

.menu-item-shake a:hover {
    animation: shake 0.3s ease;
}

/* Flip Effect */
.menu-item-flip {
    perspective: 1000px;
}

.menu-item-flip a {
    transition: transform 0.5s ease;
    transform-style: preserve-3d;
}

.menu-item-flip a:hover {
    transform: rotateY(180deg);
}

/* Pulse Effect */
@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(3, 129, 153, 0.7);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(3, 129, 153, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(3, 129, 153, 0);
    }
}

.menu-item-pulse a:hover {
    animation: pulse 1.5s infinite;
}

/* Swing Effect */
@keyframes swing {
    20% {
        transform: rotate(15deg);
    }
    40% {
        transform: rotate(-10deg);
    }
    60% {
        transform: rotate(5deg);
    }
    80% {
        transform: rotate(-5deg);
    }
    100% {
        transform: rotate(0deg);
    }
}

.menu-item-swing a:hover {
    animation: swing 1s ease;
}

/* Rubber Band Effect */
@keyframes rubberBand {
    0% {
        transform: scale(1);
    }
    30% {
        transform: scale(1.25);
    }
    40% {
        transform: scale(0.75);
    }
    50% {
        transform: scale(1.15);
    }
    65% {
        transform: scale(0.95);
    }
    75% {
        transform: scale(1.05);
    }
    100% {
        transform: scale(1);
    }
}

.menu-item-rubber a:hover {
    animation: rubberBand 1s ease;
}

/* Wobble Effect */
@keyframes wobble {
    0% {
        transform: translateX(0%);
    }
    15% {
        transform: translateX(-25%) rotate(-5deg);
    }
    30% {
        transform: translateX(20%) rotate(3deg);
    }
    45% {
        transform: translateX(-15%) rotate(-3deg);
    }
    60% {
        transform: translateX(10%) rotate(2deg);
    }
    75% {
        transform: translateX(-5%) rotate(-1deg);
    }
    100% {
        transform: translateX(0%);
    }
}

.menu-item-wobble a:hover {
    animation: wobble 1s ease;
}

/* Jello Effect */
@keyframes jello {
    0%, 11.1%, 100% {
        transform: none;
    }
    22.2% {
        transform: skewX(-12.5deg) skewY(-12.5deg);
    }
    33.3% {
        transform: skewX(6.25deg) skewY(6.25deg);
    }
    44.4% {
        transform: skewX(-3.125deg) skewY(-3.125deg);
    }
    55.5% {
        transform: skewX(1.5625deg) skewY(1.5625deg);
    }
    66.6% {
        transform: skewX(-0.78125deg) skewY(-0.78125deg);
    }
    77.7% {
        transform: skewX(0.390625deg) skewY(0.390625deg);
    }
    88.8% {
        transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
    }
}

.menu-item-jello a:hover {
    animation: jello 1s ease;
}

/* Heartbeat Effect */
@keyframes heartbeat {
    0% {
        transform: scale(1);
    }
    14% {
        transform: scale(1.3);
    }
    28% {
        transform: scale(1);
    }
    42% {
        transform: scale(1.3);
    }
    70% {
        transform: scale(1);
    }
}

.menu-item-heartbeat a:hover {
    animation: heartbeat 1.5s ease infinite;
}

/* Fancy dropdown animations */
.sub-menu {
    animation: fadeInDown 0.3s ease;
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.sub-menu .menu-item {
    animation: slideIn 0.3s ease;
    animation-fill-mode: both;
}

.sub-menu .menu-item:nth-child(1) { animation-delay: 0.05s; }
.sub-menu .menu-item:nth-child(2) { animation-delay: 0.1s; }
.sub-menu .menu-item:nth-child(3) { animation-delay: 0.15s; }
.sub-menu .menu-item:nth-child(4) { animation-delay: 0.2s; }
.sub-menu .menu-item:nth-child(5) { animation-delay: 0.25s; }
.sub-menu .menu-item:nth-child(6) { animation-delay: 0.3s; }
.sub-menu .menu-item:nth-child(7) { animation-delay: 0.35s; }
.sub-menu .menu-item:nth-child(8) { animation-delay: 0.4s; }

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
