:root {
    --azul-oscuro: #27327c;
    --azul-claro: #e8f2fb;
    --texto: #25314e;
    --sombra: 0 18px 30px rgba(0, 0, 0, 0.20);
}
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    color: var(--texto);
    background: #feffff;
}
body.pagina-login{
    min-height:100vh; 
    display:grid; 
    place-items:center; 
    background: linear-gradient(135deg, #f7f8fc 0%, #b8c3df 45%, #3050a7 100%)
}
.titulo-formulario--login{
    font-size:2.25rem; 
    margin-bottom:24px;
}

a { color: inherit; text-decoration: none; }
.contenedor { width: min(1180px, calc(100% - 48px)); margin: 0 auto; }
.barra-superior {
    background: #fff;
    min-height: 96px;
    display: flex;
    align-items: center;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.barra-superior__contenido {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.marca { font-weight: 800; color: var(--azul-oscuro); font-size: 1.45rem; }
.navegacion { display: flex; align-items: center; gap: 56px; flex-wrap: wrap; }
.navegacion a { color: var(--azul-oscuro); font-size: 1.15rem; font-weight: 700; transition: transform .2s ease, opacity .2s ease; }
.navegacion a:hover { transform: translateY(-1px); opacity: .85; }
.hero-inicio {
    min-height: 650px;
    background-image: linear-gradient(rgba(11, 11, 11, 0.274), rgba(255,255,255,0.10)), url('../img/fondo-nav.png');
    background-size: cover; background-position: center; position: relative; display: grid; place-items: center;
}
.hero-inicio::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(255,255,255,.12), rgba(255,255,255,.02)); }
.hero-inicio__contenido { position: relative; text-align: center; color: #fff; max-width: 900px; padding: 40px 18px; }
.hero-inicio__titulo { margin: 0 0 24px; font-size: clamp(3.5rem, 7vw, 3.6rem); line-height: .95; font-weight: 900; }
.hero-inicio__texto { margin: 0; font-size: 1.4rem; line-height: 1.45; text-shadow: 0 1px 8px rgba(0,0,0,.18); }
.seccion { padding: 54px 0 72px; }
.titulo-seccion { margin: 18px 0 18px; color: var(--azul-oscuro); font-size: clamp(1rem, 4vw, 2.5rem); font-weight: 900; line-height: 1.05; }
.titulo-seccion--centrado { text-align: center; }
.subtitulo-seccion { margin: 0 0 34px; text-align: center; font-size: 1.15rem; color: #232323; }
.rejilla-juegos { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 40px; align-items: stretch; }
.tarjeta-juego, .tarjeta-detalle, .tarjeta-listado, .tarjeta-formulario { background: #fff; border-radius: 14px; box-shadow: var(--sombra); }
.tarjeta-juego { overflow: hidden; border: 1px solid rgba(42,58,140,.45); transform: translateY(0); transition: transform .22s ease, box-shadow .22s ease; }
.tarjeta-juego:hover { transform: translateY(-8px); box-shadow: 0 24px 36px rgba(0,0,0,.24); }
.tarjeta-juego__imagen { background: #fff; width: 100%; aspect-ratio: 1.02 / 0.75; display: grid; place-items: center; padding: 10px 12px; }
.tarjeta-juego__imagen img { width: 80%; height: 80%; object-fit: contain; transition: transform .22s ease; }
.tarjeta-juego:hover .tarjeta-juego__imagen img { transform: scale(1.05); }
.tarjeta-juego__cuerpo { background: var(--azul-claro); padding: 16px 16px 18px; min-height: 180px; display: flex; flex-direction: column; gap: 12px; }
.nombre-juego { margin: 0; color: var(--azul-oscuro); font-weight: 800; font-size: 1.1rem; }
.descripcion-juego { margin: 0; font-size: 1rem; line-height: 1.45; }
.boton {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: none; border-radius: 999px; cursor: pointer; font-weight: 800; transition: transform .2s ease, box-shadow .2s ease; white-space: nowrap;
}
.boton:hover { transform: translateY(-2px); }
.boton--contorno { border: 2px solid var(--azul-oscuro); background: transparent; color: var(--azul-oscuro); padding: 8px 14px; align-self: flex-start; font-size: 1rem; }
.boton--principal { background: var(--azul-oscuro); color: #fff; padding: 14px 26px; box-shadow: 0 12px 18px rgba(39,50,124,.25); font-size: 1.1rem; }
.boton--claro { 
    background: var(--azul-claro); color: var(--azul-oscuro); padding: 14px 28px; 
}
.boton-login{
    width:100%; 
    font-size:1.05rem; 
    padding:13px 22px;
}
.footer-pagina { 
    background: #ddeaf6; 
    padding: 14px 0; 
    text-align: center; 
    color: var(--azul-oscuro); 
    font-size: .95rem; 
}
.contenedor-detalles { padding: 48px 0 70px; }
.distribucion-detalles { display: grid; grid-template-columns: 1.7fr 1fr; gap: 34px; align-items: start; }
.columna-principal { display: flex; flex-direction: column; gap: 30px; }
.tarjeta-detalle { display: grid; grid-template-columns: .95fr 1.05fr; overflow: hidden; }
.tarjeta-detalle__imagen { background: #fff; min-height: 275px; display: grid; place-items: center; padding: 22px; border-right: 1px solid rgba(48,64,141,.12); }
.tarjeta-detalle__imagen img { width: 100%; height: 100%; max-height: 220px; object-fit: contain; }
.tarjeta-detalle__contenido { background: var(--azul-claro); padding: 24px 22px 18px; display: flex; flex-direction: column; justify-content: space-between; gap: 18px; }
.etiqueta-detalle { margin: 0 0 10px; color: var(--azul-oscuro); font-weight: 800; font-size: 1.1rem; }
.texto-detalle { margin: 0; font-size: 1.02rem; line-height: 1.55; }
.tarjeta-listado { background: var(--azul-claro); overflow: hidden; }
.tarjeta-listado__titulo { margin: 0; padding: 24px 18px 18px; text-align: center; color: var(--azul-oscuro); font-size: 1.35rem; font-weight: 800; }
.elemento-prestamo { padding: 22px 18px; border-top: 1px solid rgba(37,49,78,.45); }
.elemento-prestamo p { margin: 0 0 10px; color: #374a69; font-size: 1rem; font-weight: 700; }
.fila-botones-detalle { display: flex; gap: 14px; flex-wrap: wrap; }
.fila-botones-detalle .boton--principal { min-width: 190px; }
.formulario-centrado { padding: 50px 0 68px; }
.tarjeta-formulario { width: min(840px, 100%); padding: 40px 36px 34px; }
.tarjeta-formulario--login { width: min(390px, calc(100% - 32px)); padding: 36px 30px 28px; }
.titulo-formulario { margin: 0 0 30px; color: var(--azul-oscuro); font-size: clamp(1rem, 4vw, 2.5rem); line-height: 1; font-weight: 900; }
.campo-formulario { margin-bottom: 14px; }
.campo-formulario label { display: block; margin-bottom: 8px; color: var(--azul-oscuro); font-size: 1.05rem; font-weight: 500; }
.campo-formulario input, .campo-formulario textarea, .campo-formulario select {
    width: 100%; border: 1.8px solid rgba(39,50,124,.9); border-radius: 8px; padding: 12px 14px; font-size: 1rem; outline: none; background: #fff; color: #1d2238;
}
.campo-formulario input:focus, .campo-formulario textarea:focus, .campo-formulario select:focus { box-shadow: 0 0 0 3px rgba(80,102,201,.12); }
.campo-formulario textarea { min-height: 70px; resize: vertical; }
.campo-formulario input[readonly] { background: #f7f9ff; cursor: not-allowed; }
.grupo-imagen { margin-top: 16px; }
.grupo-imagen__fila { display: grid; grid-template-columns: 182px 1fr; gap: 18px; align-items: center; }
.vista-imagen { width: 182px; height: 160px; border: 1.8px solid rgba(39,50,124,.55); display: grid; place-items: center; overflow: hidden; background: #fff; }
.vista-imagen img { width: 100%; height: 100%; object-fit: contain; }
.entrada-archivo { display: grid; gap: 10px; }
.entrada-archivo__fila { display: grid; grid-template-columns: 1.1fr 1.7fr; gap: 0; border: 1.8px solid rgba(39,50,124,.8); border-radius: 8px; overflow: hidden; }
.boton-archivo { background: #fff; color: #8a95ad; border-right: 1.8px solid rgba(39,50,124,.8); padding: 12px 16px; text-align: center; font-weight: 700; cursor: pointer; }
.texto-archivo { background: var(--azul-claro); color: #7d889f; padding: 12px 16px; font-weight: 700; display: flex; align-items: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.entrada-archivo input[type="file"] { display: none; }
.fila-acciones-formulario { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 24px; }
.fila-acciones-formulario .boton--principal, .fila-acciones-formulario .boton--suave { min-width: 190px; }
.formulario-login { display: grid; gap: 18px; }
.formulario-login .campo-formulario input { height: 42px; }
.texto-ayuda-login { margin: 6px 0 0; text-align: center; color: var(--azul-oscuro); font-size: .8rem; line-height: 1.25; }
.mensaje-estado { margin: 0 0 16px; padding: 12px 16px; border-radius: 10px; background: #eef4ff; color: var(--azul-oscuro); border: 1px solid rgba(39,50,124,.16); }
.etiqueta-pequeña { display: inline-block; margin-bottom: 8px; color: var(--azul-oscuro); font-weight: 800; }
@media (max-width: 1024px) {
    .rejilla-juegos, .distribucion-detalles { grid-template-columns: 1fr; }
    .tarjeta-detalle { grid-template-columns: 1fr; }
    .tarjeta-detalle__imagen { border-right: none; border-bottom: 1px solid rgba(48,64,141,.12); }
    .contenedor { width: min(100% - 28px, 1180px); }
}
@media (max-width: 760px) {
    .barra-superior__contenido { flex-direction: column; align-items: flex-start; padding: 16px 0; }
    .navegacion { gap: 22px; }
    .hero-inicio { min-height: 420px; }
    .hero-inicio__texto { font-size: 1.1rem; }
    .tarjeta-formulario { padding: 28px 18px; }
    .grupo-imagen__fila, .entrada-archivo__fila { grid-template-columns: 1fr; }
    .boton-archivo { border-right: none; border-bottom: 1.8px solid rgba(39,50,124,.8); }
}


/* =========================
   MEJORAS RESPONSIVE
========================= */

html, body{
    width: 100%;
    overflow-x: hidden;
}

body{
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main{
    flex: 1;
}

.barra-superior{
    width: 100%;
}

.barra-superior__contenido{
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 14px 24px;
}

.navegacion{
    justify-content: center;
}

.footer-pagina{
    margin-top: auto;
    width: 100%;
}

.hero-inicio__contenido{
    width: 100%;
}

.rejilla-juegos{
    width: 100%;
}

.tarjeta-juego{
    width: 100%;
}

/* =========================
   PANTALLAS GRANDES
========================= */

@media (min-width: 1400px){

    .contenedor{
        max-width: 1280px;
    }

    .barra-superior__contenido{
        max-width: 1280px;
    }

    .navegacion{
        gap: 34px;
    }

    .hero-inicio{
        min-height: 720px;
    }
}

/* =========================
   TABLETS
========================= */

@media (max-width: 900px){

    .rejilla-juegos{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .distribucion-detalles{
        grid-template-columns: 1fr;
    }

    .fila-botones-detalle{
        justify-content: center;
    }
}

/* =========================
   CELULARES
========================= */

@media (max-width: 600px){

    .barra-superior__contenido{
        align-items: center;
        text-align: center;
    }

    .navegacion{
        width: 100%;
        justify-content: center;
        gap: 18px;
    }

    .rejilla-juegos{
        grid-template-columns: 1fr;
    }

    .hero-inicio__titulo{
        font-size: clamp(2.3rem, 8vw, 3rem);
    }

    .hero-inicio__texto{
        font-size: 1rem;
    }

    .fila-botones-detalle,
    .fila-acciones-formulario{
        flex-direction: column;
    }

    .fila-botones-detalle .boton--principal,
    .fila-acciones-formulario .boton--principal,
    .fila-acciones-formulario .boton--suave{
        width: 100%;
    }

    .tarjeta-formulario--login{
        width: calc(100% - 24px);
    }
}
