@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@400;500;700&display=swap');

* { 
  box-sizing: border-box; 
  margin: 0; 
  padding: 0; 
}

:root {
  --dk-bg:      #0f1117;
  --dk-surface: #1a1d27;
  --dk-card:    #21253a;
  --dk-border:  rgba(255,255,255,0.06);
  --dk-border2: rgba(255,255,255,0.12);
  --dk-text:    #e8eaf0;
  --dk-muted:   #9ca3af; /* Un gris un poco más claro para mejorar el contraste */
  --dk-blue:    #4da3ff;
  --dk-red:     #ff5c5c;
  --dk-green:   #4caf7d;
}

.arena-wrap {
    display: flex;
    justify-content: center;
  font-family: 'DM Sans', sans-serif;
  background: var(--dk-bg);
  min-height: 100vh; /* Se adapta mejor a pantallas completas */
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.inner {
  width: 100%;
  max-width: 720px; /* Un poco más ancho para dar espacio */
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* MARCADOR */
.scoreboard {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.team-score {
  flex: 1;
  padding: 14px 18px;
  border: 1px solid var(--dk-border);
  background: var(--dk-surface);
  border-radius: 12px; /* Ahora es consistente con el resto del diseño */
}
.team-score.blue { border-left: 4px solid var(--dk-blue); }
.team-score.red  { border-left: 4px solid var(--dk-red); }

.team-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 16px;
  letter-spacing: 1.5px;
}
.team-score.blue .team-label { color: var(--dk-blue); }
.team-score.red  .team-label { color: var(--dk-red); }

.score-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px; /* Más imponente */
  line-height: 1;
  color: var(--dk-text);
  margin-top: 2px;
}

.round-badge {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 15px;
  letter-spacing: 1px;
  color: var(--dk-muted);
  text-align: center;
  min-width: 70px;
  line-height: 1.4;
}

/* ÁREA DE JUEGO / COLUMNAS */
.fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 600px) {
  .fields {
    grid-template-columns: 1fr; /* Responsivo para móviles si la pantalla es muy chica */
  }
}

.field {
  background: var(--dk-surface);
  border-radius: 16px;
  border: 1px solid var(--dk-border);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.field.blue { border-top: 3px solid var(--dk-blue); }
.field.red  { border-top: 3px solid var(--dk-red); }

.field-header {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  letter-spacing: 2px;
  text-align: center;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--dk-border);
}
.field.blue .field-header { color: var(--dk-blue); }
.field.red  .field-header { color: var(--dk-red); }

.sentence-display {
  font-size: 14px; /* Mucho más legible */
  color: var(--dk-text); /* Cambiado a color de texto principal para que se lea bien */
  text-align: center;
  min-height: 36px;
  line-height: 1.5;
  padding: 6px 4px;
}

/* CASILLAS DE RESPUESTA */
.answer-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 46px;
  padding: 8px;
  border-radius: 10px;
  border: 1px dashed var(--dk-border2);
  background: var(--dk-bg);
  align-content: flex-start;
}
.answer-slots.correct { border-color: var(--dk-green); background: rgba(76,175,125,0.08); }
.answer-slots.wrong   { border-color: var(--dk-red);   background: rgba(255,92,92,0.08); animation: shake 0.3s ease; }

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25%      { transform: translateX(-4px); }
  75%      { transform: translateX(4px); }
}

/* REPOSITORIO DE PALABRAS */
.word-pool {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 42px;
  align-content: flex-start;
}

.word-tile {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px; /* Subido de 11px a 13px */
  font-weight: 500;
  padding: 6px 12px; /* Más cómodo para hacer click/touch */
  border-radius: 8px;
  border: 1px solid var(--dk-border2);
  background: var(--dk-card);
  color: var(--dk-text);
  cursor: pointer;
  user-select: none;
  transition: transform 0.1s, background 0.1s, border-color 0.1s;
  -webkit-tap-highlight-color: transparent;
}
.word-tile:hover {
  background: rgba(255,255,255,0.04);
}
.word-tile:active { transform: scale(0.95); }
.word-tile.in-answer {
  background: rgba(77,163,255,0.15);
  color: var(--dk-blue);
  border-color: rgba(77,163,255,0.5);
}

/* BARRAS DE PROGRESO */
.progress-bar-wrap {
  height: 5px; /* Un poco más gruesa */
  background: var(--dk-card);
  border-radius: 3px;
  overflow: hidden;
}
.progress-bar {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s ease;
}
.field.blue .progress-bar { background: var(--dk-blue); }
.field.red  .progress-bar { background: var(--dk-red); }

.field-status {
  font-size: 12px; /* Subido de 10px */
  text-align: center;
  min-height: 16px;
  color: var(--dk-muted);
  font-weight: 500;
}
.field-status.ok  { color: var(--dk-green); }
.field-status.err { color: var(--dk-red); }

.outer-wrap { position: relative; width: 100%; }

/* PANTALLA DE VICTORIA */
.victory-overlay {
  display: none;
  position: absolute;
  inset: 0;
  background: rgba(26, 29, 39, 0.96); /* Un toque de transparencia sutil */
  border-radius: 16px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  z-index: 10;
  padding: 32px;
  text-align: center;
  border: 1px solid var(--dk-border2);
  backdrop-filter: blur(4px); /* Efecto moderno de desenfoque detrás */
}
.victory-overlay.show { display: flex; }

.victory-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 48px;
  letter-spacing: 3px;
  line-height: 1;
  color: var(--dk-text);
}

.victory-sub {
  font-size: 15px;
  color: var(--dk-muted);
}

.btn-restart {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  letter-spacing: 2px;
  padding: 12px 36px;
  border-radius: 10px;
  border: 1px solid var(--dk-border2);
  background: var(--dk-card);
  color: var(--dk-text);
  cursor: pointer;
  margin-top: 8px;
  transition: background 0.15s, transform 0.1s;
}
.btn-restart:hover  { background: rgba(255,255,255,0.08); }
.btn-restart:active { transform: scale(0.97); }