/* ===== Speech Analysis Game Styles ===== */

.transcript-box {
  background: var(--bg-card);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-4);
  min-height: 100px;
}

.gems-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
}

.analysis-card {
  margin-bottom: var(--space-4);
}

.analysis-card h3 {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin-bottom: var(--space-3);
}

.repeats-container {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  align-items: center;
  min-height: 100px;
}

#posOutput {
  text-align: left;
  font-size: var(--font-size-sm);
  background: var(--bg-tertiary);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  overflow-x: auto;
}

/* CEFR Level gems */
.gem {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-full);
  display: inline-block;
  margin: 3px;
  position: relative;
  cursor: pointer;
  transition: transform var(--transition-fast);
}

.gem:hover {
  transform: scale(1.2);
}

.gem:hover::after {
  content: attr(data-word);
  position: absolute;
  bottom: 120%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--text-inverse);
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-xs);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  z-index: 10;
}

.A1 { background-color: #34d399; }
.A2 { background-color: #60a5fa; }
.B1 { background-color: #facc15; }
.B2 { background-color: #f472b6; }
.C1 { background-color: #a78bfa; }
.C2 { background-color: #f87171; }
.UNK { background-color: var(--border-color); }

#repeatsDiv div {
  position: relative;
}

#repeatsDiv div:hover::after {
  content: attr(data-word);
  position: absolute;
  bottom: 120%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-primary);
  color: var(--text-inverse);
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-xs);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  z-index: 10;
}
