/* Cyberpunk Grid Styles */

.cyber-grid {
    background-size: 100px 100px;
    background-image:
        linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
    transform: perspective(500px) rotateX(60deg);
    transform-origin: center top;
    animation: grid-move 20s linear infinite;
}

.forge-grid {
    background-size: 100px 100px;
    background-image:
        linear-gradient(to right, rgba(252, 238, 10, 0.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(252, 238, 10, 0.05) 1px, transparent 1px);
    transform: perspective(500px) rotateX(60deg);
    transform-origin: center top;
    animation: grid-move 20s linear infinite;
}

.library-grid {
    background-size: 100px 100px;
    background-image:
        linear-gradient(to right, rgba(0, 240, 255, 0.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(0, 240, 255, 0.05) 1px, transparent 1px);
    transform: perspective(500px) rotateX(60deg);
    transform-origin: center top;
    animation: grid-move 20s linear infinite;
}

.oracle-grid {
    background-size: 100px 100px;
    background-image:
        linear-gradient(to right, rgba(255, 0, 160, 0.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 0, 160, 0.05) 1px, transparent 1px);
    transform: perspective(500px) rotateX(60deg);
    transform-origin: center top;
    animation: grid-move 20s linear infinite;
}

.wheel-grid {
    background-size: 100px 100px;
    background-image:
        linear-gradient(to right, rgba(255, 0, 60, 0.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 0, 60, 0.05) 1px, transparent 1px);
    transform: perspective(500px) rotateX(60deg);
    transform-origin: center top;
    animation: grid-move 20s linear infinite;
}

.grid-pulse {
    animation: grid-move 20s linear infinite, grid-pulse 4s ease-in-out infinite;
}

@keyframes grid-move {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: 0 100px;
    }
}

@keyframes grid-pulse {
    0% {
        opacity: 0.1;
    }
    50% {
        opacity: 0.2;
    }
    100% {
        opacity: 0.1;
    }
}