

/* loading */

.custom-loading-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: black;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

/* Estilo y animación sutil de pulso para tu logo */
.loading-logo {
    width: 800px; /* Ajusta el tamaño de tu logo aquí */
    height: auto;
    margin-bottom: 25px;
    animation: pulse-glow 2s infinite ease-in-out;
}

/* El fondo gris de la barra */
.loading-bar-container {
    width: 250px;
    height: 6px;
    background-color: #222;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 0 10px rgba(0, 255, 0, 0.1);
}

/* El relleno verde neón que Blazor irá llenando solo */
.loading-bar-fill {
    height: 100%;
    background-color: lime;
    box-shadow: 0 0 12px lime;
    /* 🚀 Truco clave: Blazor inyecta el porcentaje aquí automáticamente */
    width: var(--blazor-load-percentage, 0%);
    transition: width 0.1s ease-out;
}

/* Muestra el porcentaje de carga debajo (ej. 45%) */
.loading-text-percent {
    margin-top: 10px;
    color: white;
    font-family: monospace;
    font-size: 14px;
}

    .loading-text-percent::after {
        content: var(--blazor-load-percentage-text, "Loading...");
    }

/* Animación de pulso neón para el logo */
@keyframes pulse-glow {
    0%, 100% {
        transform: scale(1);
        filter: drop-shadow(0 0 5px rgba(0, 255, 0, 0.2));
    }

    50% {
        transform: scale(1.03);
        filter: drop-shadow(0 0 20px rgba(0, 255, 0, 0.6));
    }
}

/* loading */
/* loading2 */

.internal-loading-container {
    position: fixed; /* 🚀 Flota por encima de todo el diseño sin depender del padre */
    top: 0;
    left: 0;
    width: 100vw; /* 100% del ancho real de la ventana del navegador */
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: black;
    z-index: 9999;
}

/* Animación de pulso para el logo en cargas internas */
.loading-logo-spin {
    width: 600px;
    height: auto;
    margin-bottom: 20px;
    animation: pulse-glow 1.5s infinite ease-in-out;
}

/* Spinner circular con estética verde neón */
.spinner-neon {
    width: 40px;
    height: 40px;
    border: 4px solid #111;
    border-top: 4px solid lime; /* Brillo principal */
    border-radius: 50%;
    box-shadow: 0 0 10px lime;
    animation: spin 1s linear infinite;
}

.loading-text {
    margin-top: 15px;
    color: #666;
    font-family: monospace;
    font-size: 13px;
    letter-spacing: 1px;
}

/* Animación de rotación para el spinner */
@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* loading2 */


/* ---------NavMenu------------*/
.menu {
    width: 100%;
    height: 50px;
    background-color: rgba(2, 20, 1, 0.7);
    display: flex;
    justify-content: center;
    align-items: stretch;
    box-shadow: 1px 1px 12px lime;
    backdrop-filter: blur(3px);
    border-bottom: 1px solid lime;
}

    .menu nav {
        display: flex;
        align-items: stretch;
        height: 100%;
    }

        .menu nav a {
            height: 100%;
            padding: 0 15px;
            margin-left: 3px;
            display: flex;
            align-items: center;
            flex-direction: row;
            text-decoration: none;
            color: white;
            border: 1px solid transparent;
            transition: all 0.3s ease-in-out;
        }

            .menu nav a:hover {
                color: white;
                background-color: #151515;
                border: 1px solid lime;
                box-shadow: 2px 2px 25px lime;
            }

    .menu a.active {
        color: white;
        border: 1px solid lime;
        box-shadow: 2px 2px 25px lime;
        font-size: 18px;
    }

    .menu nav a.Search {
        margin-left: auto;
    }




/* ---------NavMenu------------*/


/* ---------game-card-------*/
.games-grid-container {
    display: grid;
    /* Cada tarjeta medirá mínimo 240px; si la pantalla es grande, se acomodan varias en fila */
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 25px;
    padding: 30px;
    background-color: rgba(0, 0, 0, 0);
}

/* 2. Tus estilos originales tal cual los programaste */
.game-card {
    /* Si tenías un width fijo aquí, bórralo o cámbialo a width: 100% para que Grid lo maneje */
    transition: all 0.3s ease;
    border: 1px solid lime;
    overflow: hidden;
    border-radius: 10px;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}

    .game-card:hover {
        box-shadow: 1px 1px 100px lime; /* ¡Ese brillo masivo se ve genial! */
        font-size: 25px;
    }

        .game-card:hover .game-picture {
            transform: scale(1.05);
        }

        .game-card:hover figcaption {
            transform: scale(1.08);
        }

/* Nota: Modifiqué sutilmente los selectores compuestos para asegurar que Blazor los lea bien */
.game-card-figure {
    text-align: center;
    height: 100%;
    padding: 5px;
    border-radius: 10px;
    margin: 0px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.game-picture {
    width: 100%;
    height: 85%;
    object-fit: cover;
    transition: transform 0.5s ease;
    overflow: hidden;
    border-radius: 20px;
}

.game-card-figcaption {
    padding-top: 10px;
    font-size: 20px;
    color: white; /* Añadido para asegurar que resalte en el fondo negro */
    transition: transform 0.5s ease;
    margin-bottom: 20px;
}

/* ---------game-card-------*/

/* ---------Download page___*/

.download-box {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 40px auto;
    width: 100%;
    max-width: 800px;
    padding: 30px;
    border-radius: 10px;
    background-color: rgba(2, 20, 1, 0.7);
    box-shadow: 0px 0px 25px lime;
    color: white;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
}

    .download-box p {
        color: ghostwhite;
    }

.game-card-2 {
    width: 100%;
    height: 400px;
    border-radius: 10px;
    display: grid;
    place-items: center;
}


.game-picture-2 {
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    overflow: hidden;
    border-radius: 20px;
}

.description {
    display: inline-block;
    margin: 10px;
    max-width: 560px;
}

.divisor {
    width: 100%;
    border: none;
    height: 1px;
    background-color: lime;
    margin: 25px 0;
    box-shadow: 0 0 8px lime;
}
.divisor2 {
    width: 95%;
    border: none;
    height: 1px;
    background-color: lime;
    box-shadow: 0 0 8px lime;
}
.buttons-container {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
}

.download-btn {
    text-decoration: none;
    color: white;
    padding: 0%;
}
.imagen-descarga1 {
    width: 300px;
    height: auto;
    filter: drop-shadow(-5px 0px 10px rgba(6, 135, 201, 20));
    transition: all 0.3s ease;
}

.imagen-descarga:hover {
    transform: scale(1.3);
    filter: drop-shadow(0px 0px 25px rgba(199, 34, 42, 20));
}

.imagen-descarga1:hover {
    transform: scale(1.3);
    filter: drop-shadow(0px 0px 25px rgba(6, 135, 201, 20));
}

.imagen-descarga {
    width: 300px;
    height: auto;
    filter: drop-shadow(5px 0px 10px rgba(199, 34, 42, 20));
    transition: all 0.3s ease;
}

.imagen-descarga-fig {
    color: #c9c7c7;
    margin-top: 10px;
    font-size: 10px;
}

.game-requirements {
    width: 100%;
    max-width: 600px;
}

    .game-requirements h3 {
        text-align: left;
    }

    .game-requirements ul {
        list-style-type: none;
        display: block;
        text-align: left;
        padding: 0;
        margin: 15px 0;
    }

    .game-requirements li {
        margin-bottom: 10px;
        color: #c9c7c7;
        font-size: 16px;
    }

        .game-requirements li:before {
            content: "■  ";
            color: lime;
            font-size: 13px;
            text-shadow: 0 0 5px lime;
        }


/* ---------Download page___*/

/*----------galery__________*/
.gallery-container {
    width: 100%;
    max-width: 700px; /* Se acopla perfecto al ancho de tu sección de requisitos */
    margin: 20px auto;
    text-align: left;
}

    .gallery-container h3 {
        color: white;
        margin-bottom: 15px;
        font-size: 18px;
    }

/* El riel deslizable */
.gallery-slider {
    display: flex;
    gap: 15px; /* Espacio uniforme entre las imágenes */
    overflow-x: auto; /* Activa el deslizamiento horizontal si se desborda */
    scroll-behavior: smooth; /* Hace que cualquier salto o movimiento sea animado y suave */
    padding: 10px 20px;
    /* Propiedades modernas para un deslizamiento táctil ultra fluido en móviles/laptops */
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    cursor: pointer;
    user-select: none;
}

/* Cada tarjeta de imagen individual */
.gallery-item {
    flex: 0 0 80%; /* Cada imagen ocupa el 80% del ancho para que se vea grande */
    max-width: 450px; /* Evita que se vuelva gigante en monitores ultra anchos */
    height: 250px; /* Altura fija ideal para capturas panorámicas de juegos */
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(0, 255, 0, 0.2);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), border-color 0.3s;
    /* Hace que la imagen se "clave" magnéticamente al terminar de deslizar */
    scroll-snap-align: center;
}

    /* Efecto interactivo al pasar el mouse por encima */
    .gallery-item:hover {
        transform: scale(1.03); /* Pequeña animación bonita de acercamiento */
        border-color: lime; /* Se enciende en neón al hacer hover */
        box-shadow: 0 0 15px rgba(0, 255, 0, 0.3);
    }

    /* La imagen real dentro del contenedor */
    .gallery-item img {
        width: 100%;
        height: 100%;
        object-fit: cover; /* Evita que la captura se estire o se deforme */
        pointer-events: none; /* Evita que el usuario arrastre la imagen fantasma por error */
    }

/* --- ESTILIZAR LA BARRA DE DESPLAZAMIENTO (Scrollbar Neón) --- */
.gallery-slider::-webkit-scrollbar {
    height: 6px; /* Una barra delgada y elegante */
}

.gallery-slider::-webkit-scrollbar-track {
    background: rgba(2, 20, 1, 0.5);
    border-radius: 10px;
}

.gallery-slider::-webkit-scrollbar-thumb {
    background: rgba(0, 255, 0, 0.4); /* Verde neón semi-transparente */
    border-radius: 10px;
    transition: background 0.3s;
}

    .gallery-slider::-webkit-scrollbar-thumb:hover {
        background: lime; /* Se enciende full al interactuar */
    }

/* Texto de ayuda inferior */

.gallery-hint {
    text-align: center;
    font-size: 12px;
    color: #666;
    margin-top: 8px;
}
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    margin: 0;
    padding: 0;
    background-color: black;
    min-height: 100vh;
    position: relative;
}

#matrix-canvas {
    position: fixed; /* Se queda clavado al fondo aunque hagas scroll hacia abajo */
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1; /* 👈 CLAVE: Lo manda por detrás de todo tu HTML */
    pointer-events: none; /* Evita que el canvas intercepte los clics o arrastres del mouse */
}
/* ==========================================
   🔍 ESTILOS DEL BUSCADOR GENERAL (Home & Nav)
   ========================================== */

/* Buscador Fijo en el Home */
.search-home-container {
    position: relative;
    width: 100%;
    max-width: 550px;
    margin: 30px auto;
}

.search-box {
    display: flex;
    border: 1px solid lime;
    box-shadow: 0 0 10px rgba(0, 255, 0, 0.2);
    border-radius: 6px;
    overflow: hidden;
    background-color: #050505;
}

    .search-box input {
        flex: 1;
        background: transparent;
        border: none;
        padding: 12px 15px;
        color: white;
        font-size: 15px;
        outline: none;
    }

.btn-search-neon {
    background-color: #111;
    color: lime;
    border: none;
    border-left: 1px solid lime;
    padding: 0 20px;
    cursor: pointer;
    transition: all 0.3s ease;
}

    .btn-search-neon:hover {
        background-color: lime;
        color: black;
        box-shadow: 0 0 15px lime;
    }

/* Panel Desplegable de Sugerencias */
.suggestions-list, .suggestions-list-nav {
    position: absolute;
    top: 105%;
    left: 0;
    width: 100%;
    background-color: #0a0a0a;
    border: 1px solid lime;
    box-shadow: 0 5px 20px rgba(0, 255, 0, 0.3);
    border-radius: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
    z-index: 1000;
    max-height: 300px;
    overflow-y: auto;
}

    .suggestions-list li, .suggestions-list-nav li {
        display: flex;
        align-items: center;
        padding: 10px 15px;
        border-bottom: 1px solid #111;
        cursor: pointer;
        transition: background 0.2s;
        color: white;
    }

        .suggestions-list li:hover, .suggestions-list-nav li:hover {
            background-color: #151515;
            color: lime;
        }

        .suggestions-list li img, .suggestions-list-nav li img {
            width: 35px;
            height: 50px;
            object-fit: cover;
            border-radius: 4px;
            margin-right: 15px;
            border: 1px solid #333;
        }

/* --- Barra Desplegable Flotante del Menú --- */
.menu-search-trigger {
    background: transparent;
    border: none;
    color: white;
    padding: 0 15px;
    cursor: pointer;
    display: flex;
    align-items: center;
    height: 100%;
    transition: all 0.3s;
}

    .menu-search-trigger:hover {
        background-color: #151515;
        color: lime;
    }

.nav-search-overlay {
    position: absolute; /* 🚀 Cambiado de fixed a absolute para anclarse al menú */
    top: -60px; /* Escondido justo detrás del navbar */
    left: 50%;
    transform: translateX(-50%); /* Alineado al borde derecho del menú (cerca del botón Search) */
    width: 320px; /* 🚀 Un ancho contenido y estético, ya no ocupa el 100% */
    height: 50px;
    background-color: #050505;
    border: 1px solid lime;
    border-top: none; /* Evita doble borde con el navbar */
    box-shadow: 0 5px 15px rgba(0, 255, 0, 0.3);
    border-radius:8px; /* Redondeado elegante abajo */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2000;
    transition: top 0.3s ease-in-out;
}

    /* Cuando se activa, cae exactamente debajo del navbar de 50px */
    .nav-search-overlay.active {
        top: 55px;
    }

/* Caja de texto del menú interna */
.nav-search-box {
    width: 90%;
    display: flex;
    align-items: center;
}

    .nav-search-box input {
        flex: 1;
        background: #000;
        border: 1px solid #222;
        padding: 6px 12px;
        color: white;
        font-size: 14px;
        border-radius: 4px;
        outline: none;
    }

        .nav-search-box input:focus {
            border-color: lime;
            box-shadow: 0 0 5px rgba(0, 255, 0, 0.5);
        }

.btn-close-search {
    background: transparent;
    border: none;
    color: #555;
    font-size: 16px;
    margin-left: 10px;
    cursor: pointer;
}

    .btn-close-search:hover {
        color: red;
    }

/* 🚀 Ajuste de la lista de sugerencias flotantes del menú */
.suggestions-list-nav {
    position: absolute;
    top: 105%; /* Se despliega justo debajo de la pequeña barra */
    left: 0;
    width: 100%; /* Mismo ancho de 320px que la barra */
    background-color: #0a0a0a;
    border: 1px solid lime;
    box-shadow: 0 5px 20px rgba(0, 255, 0, 0.4);
    border-radius: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
    z-index: 2001;
    max-height: 250px;
    overflow-y: auto;
}
/* logo */
.home-logo-container {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px; /* Separación de 20px entre el logo y la barra de búsqueda */
}

/* Estilo del logo con la animación cyberpunk */
.home-loading-logo {
    width: 800px; /* Tamaño ideal para el encabezado, puedes ajustarlo si quieres */
    height: auto;
    /* Reutilizamos la animación de pulso que se mueva de forma infinita y suave */
    animation: pulse-glow 2s infinite ease-in-out;
    user-select: none; /* Evita que el usuario arrastre la imagen por error */
}

/* 🟢 ESTILOS DE PAGINACIÓN */
.pagination-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    margin-top: 40px;
    margin-bottom: 40px;
    flex-wrap: wrap;
    padding: 20px;
}

.pagination-btn {
    background-color: #1a1a1a;
    color: #00ff00;
    border: 2px solid #00ff00;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    transition: all 0.3s ease;
}

.pagination-btn:hover:not(:disabled) {
    background-color: #00ff00;
    color: #000;
    box-shadow: 0 0 15px #00ff00;
}

.pagination-btn:disabled {
    background-color: #333;
    color: #666;
    border-color: #666;
    cursor: not-allowed;
    opacity: 0.5;
}

.pagination-numbers {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}

.pagination-number {
    background-color: #1a1a1a;
    color: #888;
    border: 2px solid #444;
    width: 40px;
    height: 40px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pagination-number:hover {
    border-color: #00ff00;
    color: #00ff00;
}

.pagination-number.active {
    background-color: #00ff00;
    color: #000;
    border-color: #00ff00;
    box-shadow: 0 0 10px #00ff00;
}

/* Responsive para móviles */
@media (max-width: 768px) {
    .pagination-container {
        gap: 10px;
        margin-top: 30px;
        margin-bottom: 30px;
    }

    .pagination-btn {
        padding: 8px 15px;
        font-size: 12px;
    }

    .pagination-number {
        width: 35px;
        height: 35px;
        font-size: 12px;
    }
}
}