/* screens.css — específico da sopa: home, play (grade), 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 (sopa) ========== */
.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); }

/* ========== GRADE (sopa) ========== */
.sopa {
  --tamano-celda: clamp(28px, calc((100vw - 2 * var(--espazo-m)) / 10 - 4px), 48px);
  display: grid;
  grid-template-columns: repeat(10, var(--tamano-celda));
  grid-template-rows: repeat(10, var(--tamano-celda));
  gap: 2px;
  padding: var(--espazo-s);
  background: var(--cor-fondo-suave);
  border-radius: var(--radio-l);
  margin: 0 auto;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
}

.celda {
  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.8rem, 2.5vw, 1.05rem);
  border-radius: var(--radio-s);
  cursor: pointer;
  transition: background var(--transicion), color var(--transicion), transform 100ms ease;
}
.celda--seleccionada {
  background: var(--cor-area);
  color: var(--cor-fondo);
  transform: scale(1.05);
}
.celda--atopada {
  background: var(--cor-verde-escuro);
  color: var(--cor-fondo);
}
.celda--erro {
  animation: celda-erro 350ms ease-out;
}
@keyframes celda-erro {
  0%   { background: var(--cor-prohibido); color: var(--cor-fondo); }
  100% { background: var(--cor-fondo); color: var(--cor-texto); }
}

/* ========== LISTA DE PALABRAS A BUSCAR ========== */
.palabras-buscar {
  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);
}
.palabras-buscar__titulo {
  font-size: 0.72rem;
  color: var(--cor-texto-suave);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.palabras-buscar__lista {
  display: flex;
  flex-wrap: wrap;
  gap: 6px var(--espazo-s);
}
.palabras-buscar__palabra {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--cor-texto);
  transition: color var(--transicion), text-decoration-color var(--transicion);
}
.palabras-buscar__palabra--atopada {
  color: var(--cor-texto-suave);
  text-decoration: line-through;
  text-decoration-color: var(--cor-verde-escuro);
  text-decoration-thickness: 2px;
}

.palabras-buscar__progreso {
  font-size: 0.78rem;
  color: var(--cor-texto-suave);
  margin-top: var(--espazo-xs);
}

/* ========== TRANSICIÓN ENTRE SOPAS ========== */
.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 ========== */
.pantalla--como-xogar { gap: var(--espazo-l); }
.pantalla--como-xogar .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 ========== */
.pantalla--legal { gap: var(--espazo-l); }
.pantalla--legal .pantalla__cabeceira { margin-bottom: var(--espazo-s); }
.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; }

  .sopa {
    --tamano-celda: calc((100vw - 2 * var(--espazo-m) - 16px - 18px) / 10);
    padding: 4px;
    gap: 1px;
  }
  .celda { font-size: clamp(0.7rem, 3.6vw, 0.95rem); border-radius: 3px; }

  .palabras-buscar { padding: 6px var(--espazo-s); }
  .palabras-buscar__palabra { 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; }
  .sopa { --tamano-celda: 48px; }
}
