
@keyframes glitch {
    0%, 100% { text-shadow: 2px 0 var(--cyber-cyan), -2px 0 var(--cyber-pink); }
    25% { text-shadow: -2px 0 var(--cyber-cyan), 2px 0 var(--cyber-pink); }
    50% { text-shadow: 2px 0 var(--cyber-pink), -2px 0 var(--cyber-cyan); }
    75% { text-shadow: -2px 0 var(--cyber-pink), 2px 0 var(--cyber-cyan); }
}

.glitch {
    animation: glitch 2s infinite;
}


.typing-effect::after {
    content: '_';
    animation: blink 1s infinite;
}

@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}

.cyber-grid {
    position: absolute;
    inset: 0;
    background-image: 
        linear-gradient(rgba(124, 58, 237, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124, 58, 237, 0.1) 1px, transparent 1px);
    background-size: 50px 50px;
    animation: gridMove 20s linear infinite;
}

.cyber-grid::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, transparent 0%, var(--cyber-black) 70%);
}

@keyframes gridMove {
    0% { transform: translate(0, 0); }
    100% { transform: translate(50px, 50px); }
}

.matrix-rain {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
    z-index: 1;
}

.laser-beams {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.laser-beam {
    position: absolute;
    background: var(--cyber-cyan);
    box-shadow: 0 0 10px var(--cyber-cyan), 0 0 20px var(--cyber-cyan);
    opacity: 0.35;
}

.laser-beam.horizontal {
    height: 1px;
    width: 100%;
    background: linear-gradient(90deg, transparent 0%, var(--cyber-cyan) 30%, var(--cyber-cyan) 70%, transparent 100%);
}

.laser-beam.vertical {
    width: 1px;
    height: 100%;
    background: linear-gradient(0deg, transparent 0%, var(--cyber-cyan) 30%, var(--cyber-cyan) 70%, transparent 100%);
}

@keyframes laserUp {
    0% { transform: translateY(100vh); opacity: 0; }
    10% { opacity: 0.35; }
    90% { opacity: 0.35; }
    100% { transform: translateY(-100vh); opacity: 0; }
}

@keyframes laserDown {
    0% { transform: translateY(-100vh); opacity: 0; }
    10% { opacity: 0.35; }
    90% { opacity: 0.35; }
    100% { transform: translateY(100vh); opacity: 0; }
}

@keyframes laserLeft {
    0% { transform: translateX(100vw); opacity: 0; }
    10% { opacity: 0.35; }
    90% { opacity: 0.35; }
    100% { transform: translateX(-100vw); opacity: 0; }
}

@keyframes laserRight {
    0% { transform: translateX(-100vw); opacity: 0; }
    10% { opacity: 0.35; }
    90% { opacity: 0.35; }
    100% { transform: translateX(100vw); opacity: 0; }
}

.hex-pattern {
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='50,10 80,30 80,70 50,90 20,70 20,30' fill='none' stroke='%237C3AED' stroke-width='0.5' opacity='0.1'/%3E%3C/svg%3E");
    background-size: 100px 100px;
    opacity: 0.05;
}



@keyframes neonGlow {
    0%, 100% { filter: drop-shadow(0 0 10px var(--cyber-purple)); }
    50% { filter: drop-shadow(0 0 20px var(--cyber-purple)) drop-shadow(0 0 30px var(--cyber-pink)); }
}

.neon-glow {
    animation: neonGlow 2s ease-in-out infinite;
}

.nav-links a,
.contact-item,
.stat-item,
.network-card,
.btn-stake {
    transition: all 0.3s ease;
}

.nav-links a:hover,
.contact-item:hover,
.stat-item:hover,
.btn-stake:hover {
    transform: translateY(-2px);
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    animation: fadeInUp 0.6s ease-out;
}

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

.slide-in-left {
    animation: slideInLeft 0.6s ease-out;
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.slide-in-right {
    animation: slideInRight 0.6s ease-out;
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

.pulse {
    animation: pulse 2s infinite;
}

@keyframes cyberBorder {
    0% { border-color: var(--cyber-purple); }
    25% { border-color: var(--cyber-cyan); }
    50% { border-color: var(--cyber-pink); }
    75% { border-color: var(--cyber-gold); }
    100% { border-color: var(--cyber-purple); }
}

.cyber-border-animate {
    animation: cyberBorder 4s linear infinite;
}

.contact-bg-grid {
    position: absolute;
    inset: 0;
    background-image: 
        linear-gradient(rgba(184, 134, 11, 0.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(184, 134, 11, 0.08) 1px, transparent 1px);
    background-size: 60px 60px;
    opacity: 0.6;
    z-index: 0;
    pointer-events: none;
}

.contact-bg-grid::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, transparent 0%, var(--surface-dark) 80%);
}