/*
 * Styles.css - Reglas de diseño personalizadas y temas.
 * Trabaja junto a Bootstrap. Prioriza accesibilidad, performance y mantenibilidad.
 */

/* ========================================================================= */
/* 1) TOKENS BASE Y TEMAS POR SAGA                                            */
/* ========================================================================= */
:root {
  --bg: #0a0a0a;
  --surface: #161616;
  --text: #f2f2f2;
  --muted: #9aa0a6;
  --accent: #c0392b;
  --accent-2: #e74c3c;
  --success: #2ecc71;
  --error: #e74c3c;
  --glow: rgba(192, 57, 43, 0.35);
  --display-font: 'Inter', system-ui;
  --body-font: 'Inter', system-ui;
  --radius: 10px;
  --shadow: 0 8px 40px rgba(0, 0, 0, 0.35);
}

/* Paletas por saga (sólo colores) */
html[data-theme='pesadilla'] { --accent: #b11226; --accent-2: #0b6b0b; --glow: rgba(177, 18, 38, 0.35); }
html[data-theme='viernes13'] { --accent: #d32f2f; --accent-2: #3e4e50; --glow: rgba(211, 47, 47, 0.35); }
html[data-theme='alien']     { --accent: #39ff14; --accent-2: #0b0f14; --glow: rgba(57, 255, 20, 0.25); }
html[data-theme='chucky']    { --accent: #ff6a00; --accent-2: #0a58ff; --glow: rgba(255, 106, 0, 0.25); }

/* ========================================================================= */
/* 2) BASE                                                                    */
/* ========================================================================= */
html, body { height: 100%; }
body {
  background-color: var(--bg);
  color: var(--text);
  font-family: var(--body-font);
  font-size: 16px;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

h1, h2, h3 {
  font-family: var(--display-font);
  text-align: center;
  text-shadow: 0 0 8px var(--glow);
  margin: 0 0 1.5rem 0;
}

#app {
  width: 100%;
  max-width: 640px;
  margin: auto;
  padding: 20px;
  box-sizing: border-box;
  flex-grow: 1;
}

/* ========================================================================= */
/* 3) TARJETAS / ELEMENTOS COMUNES                                           */
/* ========================================================================= */
.card {
  position: relative;       /* base para overlays */
  box-shadow: var(--shadow);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover { transform: scale(1.02); box-shadow: 0 0 15px var(--glow); }
.card-img-top { border-radius: var(--radius) var(--radius) 0 0; }
.badge {
  display: inline-block;
  padding: .25em .5em;
  font-size: .75rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: .375rem;
}
.card[data-saga-id] { cursor: pointer; }

/* Overlay base (mínima) */
.card-img-overlay {
  position: absolute; inset: 0; padding: 1rem;
}
.card-img-overlay h3, .card-img-overlay p { margin: 0; }

/* ========================================================================= */
/* 4) SECCIONES                                                               */
/* ========================================================================= */
/* -- DESTACADOS (izquierda imagen llena) -- */
#destacados-container .card { height: 300px; overflow: hidden; }
#destacados-container .card .row,
#destacados-container .card .col-md-6 { height: 100%; }
#destacados-container .card .col-md-6:first-child { overflow: hidden; }
#destacados-container .card .col-md-6:first-child > img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* -- ESPECIALES y POOL: imagen de fondo + overlay de texto -- */
#especiales-container .card,
#pool-container .card {
  height: 220px;
  overflow: hidden;
}

#especiales-container .card .card-img-top,
#pool-container .card .card-img-top {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* Overlay específica (legible y pegada abajo) */
#especiales-container .card .card-img-overlay,
#pool-container .card .card-img-overlay {
  background: linear-gradient(to top, rgba(0,0,0,.85), rgba(0,0,0,0));
  display: flex; flex-direction: column; justify-content: flex-end; align-items: center;
  text-align: center;
  padding: .75rem 1rem;
}

/* Responsive: reduce altura en móviles */
@media (max-width: 576px) {
  #especiales-container .card,
  #pool-container .card { height: 180px; }
}

#especiales-container .card .card-body,
#pool-container .card .card-body { display: none !important; }

/* Contenedor consistente con el ancho de la app */
:root { --content-max: 640px; }            /* mismo valor que #app */
#app { max-width: var(--content-max); }    /* mantiene tu comportamiento actual */

.app-container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: 20px;                    /* igual que #app */
  box-sizing: border-box;
}

/* Marca e iconos del header */
.navbar .brand-img { height: 42px; width: auto; display: block; }
.navbar .nav-icon { width: 20px; height: 20px; fill: currentColor; opacity: .9; }

/* Responsive: logo más chico en XS */
@media (max-width: 575.98px){
  .navbar .brand-img { height: 28px; }
}

.navbar .nav-link:hover .nav-icon,
.navbar .nav-link:focus .nav-icon { opacity: 1; }

/* Ajuste de espaciado y foco accesible en links */
.navbar-nav .nav-link { padding: .5rem .75rem; }
.navbar-nav .nav-link:focus { outline: 2px solid rgba(255,255,255,.35); outline-offset: 2px; border-radius: .25rem; }

/* === RATING: calaveras === */
.rating .icon-skull { width: 14px; height: 14px; margin-right: 2px; vertical-align: -1px; color: #ffc107; fill: currentColor; }

/* Meta del destacado (calaveras, certificado, tiempo) */
.featured-meta { gap: .5rem; }
.featured-meta .meta { font-size: .85rem; padding: .2rem .5rem; background: rgba(0,0,0,.25); border-radius: 999px; display: inline-flex; align-items: center; gap: .35rem; }
.featured-meta .meta .icon { width: 14px; height: 14px; fill: currentColor; }

/* Título más chico */
.featured-title { font-size: 1.5rem; line-height: 1.2; }

/* Descripción: clamp a 3 líneas */
.featured-desc.clamp-2 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* Chips de subgéneros */
.chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.chip { font-size: .75rem; color: #e6e6e6; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); padding: .15rem .45rem; border-radius: 999px; }

/* CTA centrado y “pegado” abajo del panel derecho */
.featured-cta { text-align: center; margin-top: auto; margin-bottom: -1rem; }
#destacados-container .card .card-body{ justify-content: flex-start; }

/* Modal oscuro */
.modal-dark .modal-content {
  background: #1b1b1b;
  color: #f2f2f2;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 12px;
}
.modal-dark .modal-header { border-bottom-color: rgba(255,255,255,.08); }
.modal-dark .modal-footer { border-top-color: rgba(255,255,255,.08); }

/* Calaveras compactas dentro del modal */
.modal-dark .rating .icon-skull { width: 14px; height: 14px; margin-right: 2px; vertical-align: -1px; color:#ffc107; fill: currentColor; }

/* Chips */
.chips { display:flex; flex-wrap:wrap; gap:.35rem; }
.chip  { font-size:.75rem; color:#e6e6e6; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); padding:.15rem .45rem; border-radius:999px; }

/* HUD juego */
.game-hud { display:flex; align-items:center; justify-content:space-between; gap:.75rem; margin-bottom:.75rem; }
.hud-left, .hud-right { display:flex; align-items:center; gap:1rem; }
.timer-badge { background:#7a1e1e; color:#fff; border-radius:999px; padding:.25rem .55rem; font-weight:600; min-width:34px; text-align:center; }
.question-card .option-btn { text-align:left; }
.answer-expl { border-top:1px solid rgba(255,255,255,.15); margin-top:1rem; padding-top:.75rem; }

/* === POOL (Bootstrap Carousel) - tamaño consistente === */
:root { --pool-poster-h: 360px; }

#pool-container .pool-card img{
  width:100%; height:100%; object-fit:cover; display:block;
}

/* título con overlay suave */
#pool-container .pool-card h3{
  position:absolute; inset:auto 8px 8px 8px; margin:0;
  font-size:14px; font-weight:700; text-align:center;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.7));
  padding:.5rem .4rem; border-radius:8px;
}

/* altura responsive, sin romper el layout */
@media (max-width: 575.98px){ :root { --pool-poster-h: 320px; } }
@media (min-width: 1200px){ :root { --pool-poster-h: 400px; } }

/* === Modal de dificultad === */
.diff-option{
  border:1px solid rgba(255,255,255,.15);
  border-radius:12px;
  padding:.9rem 1rem;
  background:#13151a;
  display:flex; align-items:flex-start; gap:.75rem;
  cursor:pointer;
}
.diff-option:hover{ background:#161922; }
.diff-option:focus-visible{ outline:3px solid #e11d48; outline-offset:2px; }
.diff-option input{ margin-top:.2rem; }
.diff-option.disabled{ opacity:.45; cursor:not-allowed; }
.diff-option small{ color:#b6b6b6 }

/* Fase 2 — Layout cuando hay solo 2 opciones visibles */
.q-2 .option-btn{ font-size:1.1rem; padding:1rem 1.25rem; border-width:2px; }
.q-2 #options{ display:grid; grid-template-columns:1fr; gap:.85rem; }
@media (min-width:480px){ .q-2 #options{ grid-template-columns:1fr 1fr; } }

/* Pregunta con imagen en 2 columnas (md+) */
.question-card .qimg{
  aspect-ratio: 3 / 4;
  width: 100%;
  overflow: hidden;
  border-radius: 12px;
  background:#111;
}
.question-card .qimg > img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.option-btn.is-correct {
  background-color: #28a745 !important; /* verde */
  color: #fff !important;
  border-color: #28a745 !important;
}
.option-btn.is-wrong {
  background-color: #dc3545 !important; /* rojo */
  color: #fff !important;
  border-color: #dc3545 !important;
}

.answer-expl {
  margin-top: 0.75rem;
  padding: 0.75rem;
  border-radius: 0.35rem;
  font-size: 0.9rem;
}

/* Verde */
.answer-expl.expl-correct {
  border-left: 4px solid #28a745;
  background-color: rgba(40, 167, 69, 0.1);
  color: #d4edda;
}

/* Rojo */
.answer-expl.expl-wrong {
  border-left: 4px solid #dc3545;
  background-color: rgba(220, 53, 69, 0.1);
  color: #f8d7da;
}

/* Reglas personalizadas para el modal de la saga */
.saga-description {
    background-color: #212529; /* Un gris oscuro, similar a los componentes de Bootstrap */
    padding: 1rem;
    border-radius: 0.5rem;
    border: 1px solid #343a40; /* Un borde sutil para mayor definición */
    text-align: center;
    font-style: italic;
    font-family: 'Inter', system-ui; /* Usar la fuente base del diseño */
}

.saga-description h5 {
    margin-bottom: 0.5rem;
}

.saga-description-text {
    font-style: italic;
    font-size: 1.1rem;
    color: #f8f9fa; /* Color blanco */
    margin-bottom: 0.5rem;
}

.saga-stats {
    font-size: 0.9rem;
    color: #adb5bd; /* Gris claro */
}