.chat-typing {
  position: relative;
}

.chat-typing::before {
  content: attr(data-character);
  position: absolute;
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--card);
  color: var(--accent);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.85rem;
  border: 1px solid var(--border);
  opacity: 0.9;
  white-space: nowrap;
  max-width: 90%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-typing:not([data-character])::before {
  display: none;
}

/* Typing text styles */
.typing-text {
  position: absolute;
  top: -24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--card);
  color: var(--accent);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.85rem;
  border: 1px solid var(--border);
  opacity: 0.9;
  white-space: nowrap;
  max-width: 90%;
  overflow: hidden;
  text-overflow: ellipsis;
}