.typing-widget {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  max-width: 960px; margin: 0 auto;
  box-shadow: var(--shadow);
}

.typing-controls {
  display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center;
  margin-bottom: var(--space-4); justify-content: center;
}
.typing-controls .control-group {
  display: inline-flex; gap: 0; align-items: center;
  background: var(--color-surface-2); border-radius: var(--radius-sm);
  padding: 4px;
}
.typing-controls .control-btn {
  background: transparent; border: none; color: var(--color-text-muted);
  padding: 8px 14px; border-radius: 4px; font-family: inherit; font-size: 0.85rem;
  cursor: pointer; min-height: 36px; font-weight: 500;
  transition: background 0.15s, color 0.15s;
}
.typing-controls .control-btn.active { background: var(--color-primary); color: #fff; }
.typing-controls .control-btn:hover:not(.active) { color: var(--color-text); }

.typing-display {
  font-family: var(--font-mono);
  font-size: 1.25rem;
  line-height: 2.2;
  padding: var(--space-4);
  background: var(--color-bg);
  border-radius: var(--radius);
  position: relative;
  user-select: none;
  height: calc(2.2em * 3 + var(--space-4) * 2);
  overflow: hidden;
  margin-bottom: var(--space-4);
  word-wrap: break-word;
}
.typing-display-inner {
  position: relative;
  transition: transform 0.15s ease;
  will-change: transform;
}
.typing-display .word {
  display: inline-block;
  margin-right: 0.5em;
  white-space: nowrap;
}
.typing-display .char {
  color: var(--color-text-muted);
  position: relative;
  transition: color 0.05s;
  display: inline-block;
}
.typing-display .char.correct { color: var(--color-text); }
.typing-display .char.incorrect { color: var(--color-danger); background: rgba(248,81,73,0.15); border-radius: 2px; }
.typing-display .char.current { border-bottom: 2px solid var(--color-primary); animation: caret-blink 1s infinite; }
.typing-display .char.current.incorrect { background: rgba(248,81,73,0.25); }
.typing-display .word.current .char.current { /* placeholder */ }

@keyframes caret-blink {
  0%, 100% { border-bottom-color: var(--color-primary); }
  50% { border-bottom-color: transparent; }
}

.typing-input {
  position: absolute; opacity: 0; pointer-events: none; left: -9999px;
}

.typing-stats-bar {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  justify-content: center; align-items: center;
  background: var(--color-surface-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
}
.typing-stat {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  min-width: 80px;
}
.typing-stat-value { font-size: 1.5rem; font-weight: 700; color: var(--color-primary); }
.typing-stat-label { font-size: 0.75rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.typing-stat.timer .typing-stat-value { color: var(--color-warning); }
.typing-stat.accuracy .typing-stat-value { color: var(--color-success); }

.typing-actions {
  display: flex; gap: var(--space-3); justify-content: center; align-items: stretch; flex-wrap: wrap;
}
.typing-actions .btn { min-width: 140px; }

.typing-hint {
  text-align: center; font-size: 0.85rem; color: var(--color-text-muted); margin-top: var(--space-3);
}

/* Result card */
.result-overlay {
  position: fixed; inset: 0; background: rgba(13,17,23,0.85);
  display: flex; align-items: center; justify-content: center; padding: var(--space-4);
  z-index: 80;
  opacity: 0; pointer-events: none; transition: opacity 0.25s;
}
.result-overlay.show { opacity: 1; pointer-events: auto; }
.result-card {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-8);
  max-width: 560px; width: 100%; text-align: center;
  transform: translateY(40px); transition: transform 0.25s;
}
.result-overlay.show .result-card { transform: translateY(0); }
.result-headline {
  font-size: 1rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: var(--space-2);
}
.result-wpm {
  font-size: 4rem; font-weight: 800; color: var(--color-primary); line-height: 1;
  margin-bottom: var(--space-2);
}
.result-wpm-label { color: var(--color-text-muted); font-size: 1rem; margin-bottom: var(--space-6); }
.result-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3); margin-bottom: var(--space-6); }
.result-stat {
  background: var(--color-surface-2); border-radius: var(--radius-sm); padding: var(--space-3);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.result-stat-value { font-size: 1.4rem; font-weight: 700; }
.result-stat-label { font-size: 0.8rem; color: var(--color-text-muted); text-transform: uppercase; }
.result-xp { color: var(--color-xp); font-weight: 600; margin-bottom: var(--space-3); }
.result-badges { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; margin-bottom: var(--space-6); }
.result-badge {
  background: var(--color-surface-2); border: 1px solid var(--color-warning);
  border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3);
  display: inline-flex; align-items: center; gap: 6px;
  animation: pop-in 0.4s ease;
}
.result-badge i { color: var(--color-warning); }
@keyframes pop-in {
  0% { transform: scale(0.4); opacity: 0; }
  70% { transform: scale(1.1); }
  100% { transform: scale(1); opacity: 1; }
}
.result-actions { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

@media (max-width: 540px) {
  .typing-display { font-size: 1rem; line-height: 2; }
  .result-wpm { font-size: 3rem; }
  .typing-stat-value { font-size: 1.2rem; }
}

/* WPM benchmark table */
.wpm-table-wrap { max-width: 720px; margin: 0 auto; }
.wpm-bars {
  display: flex; flex-direction: column; gap: var(--space-3);
  max-width: 720px; margin: var(--space-6) auto 0;
}
.wpm-bar-row { display: grid; grid-template-columns: 140px 1fr 60px; align-items: center; gap: var(--space-3); }
.wpm-bar-label { color: var(--color-text); font-weight: 500; }
.wpm-bar-track { height: 24px; background: var(--color-surface-2); border-radius: 999px; overflow: hidden; }
.wpm-bar-fill { height: 100%; background: linear-gradient(90deg, var(--color-primary), var(--color-xp)); border-radius: 999px; }
.wpm-bar-value { color: var(--color-text-muted); font-family: var(--font-mono); font-size: 0.9rem; text-align: right; }
@media (max-width: 540px) {
  .wpm-bar-row { grid-template-columns: 110px 1fr 50px; gap: var(--space-2); }
  .wpm-bar-label { font-size: 0.85rem; }
}
