/* screens.css — específico do encrucillado: home, play, results, ranking, como, legal */

/* ========== HOME ========== */
.pantalla--home { justify-content: space-between; }
.pantalla--home .pantalla__cabeceira { margin-top: var(--espazo-xl); }

.titulo-xogo {
  font-size: clamp(2.3rem, 5vw + 0.5rem, 3rem);
  color: var(--cor-verde-escuro);
  line-height: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: var(--espazo-s);
}
.titulo-xogo__acento {
  color: var(--cor-area);
  font-size: 0.45em;
  font-style: italic;
  font-weight: 400;
  margin-top: 0.4em;
  letter-spacing: 0.02em;
}
.subtitulo--home {
  margin-top: var(--espazo-l);
  max-width: 28ch;
  font-size: 0.95rem;
  line-height: 1.45;
}
.home-rodape { display: flex; flex-direction: column; align-items: center; gap: var(--espazo-s); text-align: center; }
.home-rodape p { margin: 0; }
.home-rodape__menu { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: var(--espazo-s); font-size: 0.88rem; }
.home-rodape__sep { color: var(--cor-texto-suave); opacity: 0.45; user-select: none; }
.home-rodape__version { color: var(--cor-texto-suave); opacity: 0.55; font-variant-numeric: tabular-nums; }
.ligazon-rodape { color: var(--cor-texto-suave); text-decoration: none; font-weight: 500; padding: 2px 0; transition: color var(--transicion); }
.ligazon-rodape:hover, .ligazon-rodape:focus-visible { color: var(--cor-verde-escuro); }
.autoria { font-size: 0.72rem; color: var(--cor-texto-suave); opacity: 0.7; }
.ligazon-autoria { color: inherit; text-decoration: none; border-bottom: 1px dotted currentColor; }
.ligazon-autoria:hover, .ligazon-autoria:focus-visible { color: var(--cor-verde-escuro); border-bottom-color: var(--cor-verde-escuro); }

/* ========== PLAY ========== */
.pantalla--play {
  gap: var(--espazo-m);
  padding-top: var(--espazo-m);
  padding-bottom: var(--espazo-m);
}
.xogo-cabeceira { display: flex; flex-direction: column; gap: var(--espazo-s); }
.xogo-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--espazo-s);
  font-size: 0.9rem;
  color: var(--cor-texto-suave);
  flex-wrap: wrap;
}
.xogo-meta__contador { font-weight: 500; }
.xogo-meta__contador strong { color: var(--cor-verde-escuro); }
.xogo-meta__tempo {
  font-family: var(--fonte-titular);
  font-size: 1.4rem;
  color: var(--cor-texto);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
}
.pantalla--play.modo-aviso .xogo-meta__tempo { color: var(--cor-aviso); animation: pulso-aviso 600ms ease-in-out infinite alternate; }
.pantalla--play.modo-critico .xogo-meta__tempo { color: var(--cor-prohibido); animation: pulso-aviso 400ms ease-in-out infinite alternate; }
@keyframes pulso-aviso { from { transform: scale(1); } to { transform: scale(1.08); } }
@media (prefers-reduced-motion: reduce) {
  .pantalla--play.modo-aviso .xogo-meta__tempo,
  .pantalla--play.modo-critico .xogo-meta__tempo { animation: none; }
}

.xogo-meta__rematar {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--cor-borde);
  border-radius: 50%;
  background: var(--cor-fondo);
  color: var(--cor-texto-suave);
  font-size: 0.85rem;
  cursor: pointer;
  flex-shrink: 0;
  transition: color var(--transicion), border-color var(--transicion);
}
.xogo-meta__rematar:hover, .xogo-meta__rematar:focus-visible { color: var(--cor-prohibido); border-color: var(--cor-prohibido); }

.barra-tempo {
  height: 6px;
  background: var(--cor-borde);
  border-radius: 999px;
  overflow: hidden;
}
.barra-tempo__enchida {
  height: 100%;
  width: 100%;
  background: var(--cor-verde-escuro);
  transition: width 1s linear, background var(--transicion);
}
.pantalla--play.modo-aviso .barra-tempo__enchida { background: var(--cor-aviso); }
.pantalla--play.modo-critico .barra-tempo__enchida { background: var(--cor-prohibido); }

/* ========== ENCRUCILLADO ========== */
.encrucillado {
  --tamano-celda: clamp(24px, calc((100vw - 2 * var(--espazo-m)) / var(--cols, 12) - 2px), 40px);
  display: grid;
  grid-template-columns: repeat(var(--cols, 12), var(--tamano-celda));
  grid-template-rows: repeat(var(--rows, 12), var(--tamano-celda));
  gap: 1px;
  padding: var(--espazo-s);
  background: var(--cor-fondo-suave);
  border-radius: var(--radio-l);
  margin: 0 auto;
  user-select: none;
  -webkit-user-select: none;
}

.cela {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cor-fondo);
  color: var(--cor-texto);
  font-family: var(--fonte-titular);
  font-weight: 700;
  font-size: clamp(0.7rem, 2.2vw, 0.95rem);
  border-radius: 2px;
  cursor: pointer;
  transition: background var(--transicion), color var(--transicion);
}
.cela--bloqueada {
  background: transparent;
  cursor: default;
  pointer-events: none;
}
.cela--seleccionada {
  background: rgba(205, 163, 79, 0.25);
  outline: 2px solid var(--cor-area);
  outline-offset: -2px;
  z-index: 1;
}
.cela--activa {
  background: var(--cor-area);
  color: var(--cor-fondo);
  z-index: 2;
}
.cela--completa {
  background: var(--cor-positivo-fondo);
  color: var(--cor-verde-escuro);
}
.cela--erro {
  animation: cela-erro 350ms ease-out;
}
@keyframes cela-erro {
  0%   { background: var(--cor-prohibido); color: var(--cor-fondo); }
  100% { background: var(--cor-fondo); color: var(--cor-texto); }
}
.cela__num {
  position: absolute;
  top: 1px;
  left: 2px;
  font-family: var(--fonte-corpo);
  font-size: 0.55rem;
  font-weight: 600;
  color: var(--cor-texto-suave);
  pointer-events: none;
  line-height: 1;
}
.cela--activa .cela__num,
.cela--completa .cela__num { color: inherit; opacity: 0.6; }

/* ========== PISTAS ========== */
.pistas {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--espazo-m);
}
@media (min-width: 600px) {
  .pistas { grid-template-columns: 1fr 1fr; }
}
.pistas__bloque {
  display: flex;
  flex-direction: column;
  gap: var(--espazo-xs);
  padding: var(--espazo-s) var(--espazo-m);
  background: var(--cor-fondo);
  border: 1px solid var(--cor-borde);
  border-radius: var(--radio-m);
}
.pistas__titulo {
  font-size: 0.72rem;
  color: var(--cor-texto-suave);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.pistas__lista { display: flex; flex-direction: column; gap: 2px; }
.pistas__item {
  display: flex;
  gap: 6px;
  padding: 4px 6px;
  border-radius: var(--radio-s);
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1.35;
  transition: background var(--transicion), color var(--transicion);
}
.pistas__item:hover { background: var(--cor-fondo-suave); }
.pistas__item--activa { background: rgba(205, 163, 79, 0.18); color: var(--cor-verde-escuro); }
.pistas__item--completa { color: var(--cor-texto-suave); text-decoration: line-through; text-decoration-thickness: 2px; text-decoration-color: var(--cor-verde-escuro); }
.pistas__num {
  font-family: var(--fonte-titular);
  font-weight: 700;
  color: var(--cor-area);
  flex-shrink: 0;
  min-width: 1.6em;
}

/* ========== TECLADO VIRTUAL ========== */
.teclado {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: var(--espazo-s);
}
.teclado__fila {
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(9, 1fr);
}
.teclado__fila--accions { grid-template-columns: 1fr 1fr; }
.tecla {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0;
  border: 1px solid var(--cor-borde);
  border-radius: var(--radio-m);
  background: var(--cor-fondo);
  color: var(--cor-texto);
  font-family: inherit;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  user-select: none;
  transition: background var(--transicion), border-color var(--transicion), transform 100ms ease;
}
.tecla:hover, .tecla:focus-visible { background: var(--cor-fondo-suave); border-color: var(--cor-verde-escuro); }
.tecla:active { transform: translateY(1px); }
.tecla--accion { font-size: 0.82rem; color: var(--cor-texto-suave); }
.tecla--accion:hover, .tecla--accion:focus-visible { color: var(--cor-verde-escuro); }

/* ========== TRANSICIÓN ENTRE NIVEIS ========== */
.transicion { display: flex; flex-direction: column; align-items: center; gap: var(--espazo-s); text-align: center; }
.transicion__titulo { font-family: var(--fonte-titular); font-size: 1.5rem; font-weight: 700; color: var(--cor-verde-escuro); }
.transicion__puntos { font-family: var(--fonte-titular); font-size: 2.5rem; font-weight: 700; color: var(--cor-area); line-height: 1; }
.transicion__seguinte { font-size: 0.9rem; color: var(--cor-texto-suave); }

/* ========== RESULTADOS ========== */
.resumo {
  background: var(--cor-fondo-suave);
  border-radius: var(--radio-l);
  padding: var(--espazo-l);
  display: flex;
  flex-direction: column;
  gap: var(--espazo-m);
  margin-top: var(--espazo-m);
}
.resumo__puntos { text-align: center; display: flex; flex-direction: column; gap: var(--espazo-xs); }
.resumo__puntos-num { font-family: var(--fonte-titular); font-size: 3.5rem; font-weight: 700; color: var(--cor-verde-escuro); line-height: 1; }
.resumo__puntos-etiqueta { font-size: 0.75rem; color: var(--cor-texto-suave); letter-spacing: 0.08em; text-transform: uppercase; }

.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--espazo-s); }
.stats-grid__celda { background: var(--cor-fondo); border-radius: var(--radio-m); padding: var(--espazo-s) var(--espazo-m); display: flex; flex-direction: column; gap: 2px; }
.stats-grid__valor { font-family: var(--fonte-titular); font-weight: 700; font-size: 1.25rem; color: var(--cor-verde-escuro); }
.stats-grid__etiqueta { font-size: 0.72rem; color: var(--cor-texto-suave); letter-spacing: 0.05em; text-transform: uppercase; }

.ranking-consentimento { display: flex; flex-direction: column; gap: var(--espazo-s); padding: var(--espazo-m); background: var(--cor-fondo-suave); border-radius: var(--radio-m); }
.ranking-consentimento p { margin: 0; }
.ranking-consentimento__pregunta {
  font-size: 0.9rem;
  color: var(--cor-texto-suave);
  margin: 0;
}
.ranking-consentimento__estado { font-size: 0.85rem; margin: 0; min-height: 1em; color: var(--cor-texto-suave); }
.ranking-consentimento__estado:empty { display: none; }
.ranking-consentimento__estado[data-tipo="ok"]   { color: var(--cor-verde-escuro); }
.ranking-consentimento__estado[data-tipo="erro"] { color: var(--cor-prohibido); }

/* ========== RANKING ========== */
.ranking-lista { display: flex; flex-direction: column; gap: var(--espazo-xs); }
.ranking-fila { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--espazo-m); padding: var(--espazo-s) var(--espazo-m); border: 1px solid var(--cor-borde); border-radius: var(--radio-m); }
.ranking-fila--top { border-color: var(--cor-area); background: rgba(205, 163, 79, 0.08); }
.ranking-fila__posto { font-family: var(--fonte-titular); font-weight: 700; font-size: 1.15rem; color: var(--cor-texto-suave); min-width: 1.5em; text-align: center; }
.ranking-fila--top .ranking-fila__posto { color: var(--cor-area); }
.ranking-fila__nome { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ranking-fila__detalle { font-size: 0.78rem; color: var(--cor-texto-suave); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ranking-fila__puntos { font-family: var(--fonte-titular); font-weight: 700; color: var(--cor-verde-escuro); }
.ranking-mensaxe { font-size: 0.9rem; color: var(--cor-texto-suave); text-align: center; margin: 0; }

/* ========== COMO SE XOGA / LEGAL ========== */
.pantalla--como-xogar, .pantalla--legal { gap: var(--espazo-l); }
.pantalla--como-xogar .pantalla__cabeceira, .pantalla--legal .pantalla__cabeceira { margin-bottom: var(--espazo-s); }
.como-pasos { display: flex; flex-direction: column; gap: var(--espazo-l); }
.como-paso { display: grid; grid-template-columns: auto 1fr; gap: var(--espazo-m); align-items: start; }
.como-paso__num { font-family: var(--fonte-titular); font-weight: 700; font-size: 1.6rem; color: var(--cor-area); line-height: 1; min-width: 1.2em; text-align: center; }
.como-paso__corpo { display: flex; flex-direction: column; gap: var(--espazo-s); min-width: 0; }
.como-paso h3 { font-family: var(--fonte-titular); font-size: 1.05rem; font-weight: 700; margin: 0 0 4px 0; color: var(--cor-verde-escuro); }
.como-paso p { font-size: 0.92rem; color: var(--cor-texto); line-height: 1.55; margin: 0; }
.como-paso__lista { display: flex; flex-direction: column; gap: 4px; margin: 0; padding: 0; list-style: none; }
.como-paso__lista li { position: relative; padding-left: var(--espazo-m); font-size: 0.92rem; line-height: 1.5; color: var(--cor-texto); }
.como-paso__lista li::before { content: ''; position: absolute; left: 4px; top: 0.7em; width: 4px; height: 4px; border-radius: 50%; background: var(--cor-area); }
.pantalla--como-xogar .boton--primario { margin-top: var(--espazo-m); }

.legal-bloque { display: flex; flex-direction: column; gap: var(--espazo-s); }
.legal-bloque h3 { font-family: var(--fonte-titular); font-size: 1.1rem; font-weight: 700; margin: 0; color: var(--cor-verde-escuro); }
.legal-bloque p { font-size: 0.92rem; line-height: 1.55; margin: 0; color: var(--cor-texto); }
.legal-lista { display: flex; flex-direction: column; gap: var(--espazo-xs); margin: 0; padding: 0; }
.legal-lista li { position: relative; padding-left: var(--espazo-m); font-size: 0.92rem; line-height: 1.5; }
.legal-lista li::before { content: ''; position: absolute; left: 4px; top: 0.7em; width: 4px; height: 4px; border-radius: 50%; background: var(--cor-area); }

/* ========== RESPONSIVE ========== */
@media (max-width: 480px) {
  .titulo-xogo { font-size: clamp(2.3rem, 12vw, 3.2rem); }
  .subtitulo--home { font-size: 0.9rem; max-width: 26ch; margin-top: var(--espazo-m); }
  .pantalla--home .pantalla__cabeceira { margin-top: var(--espazo-l); }

  .xogo-meta { font-size: 0.82rem; gap: var(--espazo-xs); }
  .xogo-meta__tempo { font-size: 1.2rem; }
  .xogo-meta__rematar { width: 28px; height: 28px; }

  .encrucillado { padding: 4px; gap: 1px; }
  .cela { font-size: clamp(0.65rem, 3vw, 0.85rem); }
  .cela__num { font-size: 0.45rem; }

  .pistas__bloque { padding: 6px var(--espazo-s); }
  .pistas__item { font-size: 0.85rem; }

  .teclado__fila { gap: 3px; }
  .tecla { min-height: 34px; font-size: 0.88rem; }

  .resumo { padding: var(--espazo-m); gap: var(--espazo-s); margin-top: var(--espazo-s); }
  .resumo__puntos-num { font-size: 2.5rem; }
  .resumo__puntos-etiqueta { font-size: 0.68rem; }
  .stats-grid__celda { padding: 6px var(--espazo-s); }
  .stats-grid__valor { font-size: 1.05rem; }
  .stats-grid__etiqueta { font-size: 0.65rem; }

  .ranking-consentimento { padding: var(--espazo-s) var(--espazo-m); gap: var(--espazo-xs); }
  .ranking-fila { padding: 6px var(--espazo-s); gap: var(--espazo-s); }
  .ranking-fila__posto { font-size: 1rem; }
  .ranking-fila__detalle { font-size: 0.72rem; }
  .ranking-fila__nome { font-size: 0.92rem; }
  .ranking-fila__puntos { font-size: 1rem; }

  .como-paso__num { font-size: 1.35rem; }
  .como-paso h3 { font-size: 0.98rem; }
  .como-paso p { font-size: 0.88rem; }
  .como-paso__lista li { font-size: 0.86rem; }

  .legal-bloque h3 { font-size: 1rem; }
  .legal-bloque p, .legal-lista li { font-size: 0.88rem; }

  .home-rodape__menu { font-size: 0.82rem; gap: var(--espazo-xs) 6px; }
  .autoria { font-size: 0.7rem; }
}

@media (min-width: 768px) {
  .home-acciones { align-items: center; }
  .home-acciones .boton { width: auto; min-width: 280px; }
}
