/* ===========================================================================
   MASTER.CSS
   Hoja de estilos unica de QUEVER. App web movil (PWA) para iPhone.
   Mobile-first, comentada y agrupada. Paleta tomada del logo (morado -> magenta).

   Desarrollado por Iñaki Serrano para Webcomunica.solutions
   ======================================================================== */

/* ---------------------------------------------------------------------------
   1. Variables de color (paleta del logo QUEVER: morado profundo -> magenta)
   ------------------------------------------------------------------------ */
:root {
    --fondo:        #fbf6f2;   /* crema cálido de fondo de la app */
    --superficie:   #ffffff;
    --borde:        #e4dfec;   /* borde neutro con matiz de marca */
    --texto:        #211b2e;
    --texto-suave:  #6f6880;
    --acento:       #2b1457;   /* morado profundo del logo (dominante) */
    --acento-claro: #3a1d70;   /* hover del morado */
    --acento-hondo: #1c0c3e;   /* morado mas oscuro del logo */
    --magenta:      #e0218a;   /* rosa/magenta del logo (acento) */
    --magenta-hondo:#b81570;   /* magenta presionado */
    --degradado:    linear-gradient(135deg, #2b1457 0%, #e0218a 100%); /* eje del logo */
    --nota:         #2b1457;   /* numero de nota en morado de marca */
    --barra-alto:   56px;
}

/* ---------------------------------------------------------------------------
   2. Base
   ------------------------------------------------------------------------ */
* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

html { -webkit-text-size-adjust: 100%; }

body {
    font-family: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background: var(--fondo);
    color: var(--texto);
    font-size: 15px;
    line-height: 1.5;
    /* Respeta el notch y la barra inferior del iPhone */
    padding-bottom: env(safe-area-inset-bottom);
}

a { color: var(--acento); text-decoration: none; }

/* ---------------------------------------------------------------------------
   2b. Tira de la barra de estado (iPhone en modo app instalada)
   Con apple-mobile-web-app-status-bar-style=black-translucent el contenido
   sube bajo el notch; esta tira fija pinta esa zona de magenta. En navegador
   normal env(safe-area-inset-top)=0, asi que la tira no ocupa nada.
   ------------------------------------------------------------------------ */
.barra-estado {
    position: fixed;
    top: 0; left: 0; right: 0;
    height: env(safe-area-inset-top);
    background: #F02D67;
    z-index: 50;
}

/* ---------------------------------------------------------------------------
   3. Banner de instalacion de la app (PWA)
   ------------------------------------------------------------------------ */
.instalar-app {
    background: #F02D67;
    color: #ffffff;
    text-align: center;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.6px;
    padding: 11px 16px;
    padding-top: calc(11px + env(safe-area-inset-top));
    cursor: pointer;
}
.instalar-app:active { background: #c81f53; }

/* ---------------------------------------------------------------------------
   3b. Cabecera fija superior
   ------------------------------------------------------------------------ */
.cabecera {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--fondo);
    color: var(--texto);
    padding: 12px 18px;
    padding-top: calc(12px + env(safe-area-inset-top));
    text-align: center;
}
.cabecera .logo { height: 82px; width: auto; max-width: 100%; display: block; margin: 0 auto; }

/* ---------------------------------------------------------------------------
   4. Contenedor
   ------------------------------------------------------------------------ */
.contenedor { padding: 16px; }

/* Barra de usuario (saludo + salir) */
.barra-usuario {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 16px;
    background: #ffffff;
    border-bottom: 1px solid var(--borde);
    font-size: 13px;
    color: var(--texto-suave);
}
.barra-usuario a { color: var(--acento); font-weight: 600; }

/* Pantalla de acceso */
.acceso {
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 8px;
    padding: 20px;
    max-width: 380px;
    margin: 10px auto 0;
}
.acceso-intro { font-size: 13px; line-height: 1.55; color: var(--texto-suave); margin-bottom: 16px; text-align: center; }
.acceso-error {
    background: #fbeaf0;
    border: 1px solid #e7b9cb;
    color: #a01b4b;
    font-size: 13px;
    padding: 10px 12px;
    border-radius: 6px;
    margin-bottom: 16px;
}
.boton.boton-secundario {
    background: #ffffff;
    color: var(--acento);
    border: 1px solid var(--borde);
    margin-top: 10px;
}
.boton.boton-secundario:active { background: #f1eef7; }

/* ---------------------------------------------------------------------------
   5. Barra de filtros plegable
   ------------------------------------------------------------------------ */
.barra-filtros {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 14px;
    cursor: pointer;
    user-select: none;
}
.barra-filtros span { font-size: 14px; font-weight: 600; color: var(--acento); }
.barra-filtros small { font-size: 12px; color: var(--texto-suave); }

.filtros {
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 18px;
}
.filtros.oculto { display: none; }

.campo { display: flex; flex-direction: column; margin-bottom: 14px; }
.campo label {
    font-size: 11px;
    color: var(--texto-suave);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.campo select,
.campo input {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--borde);
    border-radius: 6px;
    background: #fff;
    color: var(--texto);
    /* 16px evita el zoom automatico de Safari al enfocar */
    font-size: 16px;
    appearance: none;
    -webkit-appearance: none;
}
.campo select:focus,
.campo input:focus { outline: none; border-color: var(--magenta); box-shadow: 0 0 0 2px rgba(216,27,96,0.12); }

/* Dos campos por fila para el rango de nota y de año */
.fila { display: flex; gap: 12px; }
.fila .campo { flex: 1; }

.boton {
    width: 100%;
    background: var(--acento);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 13px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.2px;
    cursor: pointer;
}
.boton:active { background: var(--acento-claro); }

/* ---------------------------------------------------------------------------
   6. Resumen de resultados
   ------------------------------------------------------------------------ */
.resumen {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
}
.resumen .chip {
    background: #efe9f7;
    color: var(--acento);
    font-size: 12px;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 999px;
    white-space: nowrap;
}
.resumen .resumen-pag { font-size: 12px; color: var(--texto-suave); }

/* ---------------------------------------------------------------------------
   7. Rejilla de titulos (2 columnas en movil)
   ------------------------------------------------------------------------ */
.rejilla {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}

.tarjeta {
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.tarjeta .poster {
    width: 100%;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    background: #e6e8ec;
    display: block;
}
.tarjeta .sin-poster {
    width: 100%;
    aspect-ratio: 2 / 3;
    background: #e6e8ec;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--texto-suave);
    font-size: 12px;
    text-align: center;
    padding: 10px;
}
.tarjeta .poster-enlace { display: block; }
.tarjeta .poster-enlace:active .poster { opacity: 0.85; }
.tarjeta .cuerpo { padding: 10px; display: flex; flex-direction: column; gap: 5px; flex: 1; }
.tarjeta .titulo { font-size: 13px; font-weight: 600; line-height: 1.25; }
.tarjeta .meta   { font-size: 11px; color: var(--texto-suave); }
.plataformas-tarjeta { font-size: 10px; color: var(--texto-suave); line-height: 1.4; }
.plataformas-tarjeta a { color: var(--magenta); font-weight: 600; }

.notas { display: flex; gap: 6px; margin-top: auto; padding-top: 6px; }
.nota {
    flex: 1;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 4px;
    font-size: 11px;
    padding: 4px 4px;
    border-radius: 5px;
    border: 1px solid var(--borde);
    background: #f7f6fa;
    white-space: nowrap;
}
.nota .et { color: var(--texto-suave); font-size: 10px; letter-spacing: 0.3px; }
.nota strong { color: var(--nota); font-size: 12px; }

/* Boton de marcar como vista (secundario, sobrio) */
.btn-vista {
    margin-top: 8px;
    width: 100%;
    background: #ffffff;
    color: var(--acento);
    border: 1px solid var(--borde);
    border-radius: 6px;
    padding: 8px 6px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.4px;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.btn-vista:active { background: #f1eef7; }
.btn-vista:disabled { opacity: 0.5; }

/* Tarjeta ya vista (cuando se muestran las vistas) */
.tarjeta.es-vista .poster,
.tarjeta.es-vista .sin-poster { opacity: 0.55; }
.tarjeta.es-vista .btn-vista { background: #f1eef7; }

/* Animacion al desaparecer una tarjeta recien marcada */
.tarjeta.desaparece { opacity: 0; transform: scale(0.96); transition: opacity 0.2s, transform 0.2s; }

/* Checkbox de filtros */
.campo-check {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--texto);
    margin-bottom: 14px;
    cursor: pointer;
}
.campo-check input { width: 18px; height: 18px; accent-color: var(--magenta); }

/* ---------------------------------------------------------------------------
   8. Sin resultados
   ------------------------------------------------------------------------ */
.vacio {
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 8px;
    padding: 32px 20px;
    text-align: center;
    color: var(--texto-suave);
    font-size: 14px;
}

/* ---------------------------------------------------------------------------
   9. Paginacion
   ------------------------------------------------------------------------ */
.paginacion {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 20px;
}
.paginacion a {
    flex: 1;
    text-align: center;
    background: var(--superficie);
    border: 1px solid var(--borde);
    border-radius: 6px;
    padding: 12px;
    font-size: 14px;
    color: var(--acento);
}

/* ---------------------------------------------------------------------------
   10. Pie
   ------------------------------------------------------------------------ */
.pie {
    text-align: center;
    font-size: 12px;
    line-height: 1.6;
    color: var(--texto-suave);
    padding: 28px 24px;
    max-width: 460px;
    margin: 0 auto;
}
.pie strong { color: var(--acento); font-weight: 600; }
.pie a { color: var(--magenta); font-weight: 600; }

/* ---------------------------------------------------------------------------
   11. Pantallas grandes (tablet / escritorio): mas columnas y filtros en linea
   ------------------------------------------------------------------------ */
@media (min-width: 700px) {
    .contenedor { max-width: 1100px; margin: 0 auto; padding: 24px; }
    .rejilla { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 18px; }
    .filtros .grupo-campos { display: flex; flex-wrap: wrap; gap: 16px; }
    .filtros .grupo-campos .campo { flex: 1; min-width: 160px; margin-bottom: 0; }
    .boton { width: auto; padding: 12px 28px; margin-top: 14px; }
}
