/* /assets/css/transition.split.css
   TRANSICIÓN GLOBAL (SPLIT)
   Clases usadas por JS:
   - body.split-in    => cierra (mitades al centro)
   - body.split-lock  => bloquea scroll y clicks
   - html.split-entry => al entrar, arranca cerrado y luego abre
*/

.split-cover {
    position: fixed;
    inset: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    z-index: 99999;
    pointer-events: none;
}

/*
  CLAVE: hacemos que ambas mitades usen “la misma imagen de fondo”
  dividiéndola en 2:
  - background-size: 200% 100%
  - left muestra la mitad izquierda (background-position: 0% 0%)
  - right muestra la mitad derecha (background-position: 100% 0%)
*/
.split-cover__half {
    /* Fondo unificado (continuo) */
    background:
        radial-gradient(60% 60% at 50% 0%, rgba(124, 92, 255, .26), transparent 60%),
        radial-gradient(55% 55% at 70% 10%, rgba(0, 186, 255, .18), transparent 65%),
        linear-gradient(180deg, #0b0d12, #090b10);

    background-repeat: no-repeat;
    background-size: 200% 100%;
    will-change: transform;
    transition: transform .7s ease-in-out;
}

/* Cada mitad muestra su “trozo” del mismo fondo */
.split-cover__left {
    transform: translateX(-101%);
    background-position: 0% 0%;
    border-right: none;
    /* quitamos la línea para que no se note la unión */
}

.split-cover__right {
    transform: translateX(101%);
    background-position: 100% 0%;
    border-left: none;
    /* quitamos la línea */
}

/* CERRAR (cubrir pantalla) */
body.split-in .split-cover__left,
body.split-in .split-cover__right {
    transform: translateX(0);
}

/* Bloqueo durante transición */
body.split-lock {
    overflow: hidden;
}

/* bloquea clicks sobre el contenido mientras anima */
body.split-lock .split-cover {
    pointer-events: auto;
}

/* Entrada: la página destino arranca con el overlay cerrado (sin transición),
   y luego JS remueve html.split-entry para que "abra". */
html.split-entry body {
    overflow: hidden;
}

html.split-entry .split-cover__half {
    transition: none !important;
}

html.split-entry .split-cover__left,
html.split-entry .split-cover__right {
    transform: translateX(0) !important;
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce) {
    .split-cover__half {
        transition: none !important;
    }
}