/* Enhanced Chat Messages Styles */

.vg-message {
  margin-bottom: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  max-width: 85%;
  word-break: break-word;
  position: relative;
  animation: message-appear 0.3s ease-out forwards;
}

/* User message styling */
.vg-message.user {
  background-color: var(--primary-color, #6c63ff);
  color: white;
  margin-left: auto;
  border-bottom-right-radius: 2px;
}

/* Bot message styling */
.vg-message.bot {
  background-color: var(--card-bg, #1e293b);
  color: var(--text-primary, #f8fafc);
  margin-right: auto;
  border-bottom-left-radius: 2px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Message animation */
@keyframes message-appear {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Typing indicator */
.vg-typing-indicator {
  display: flex;
  align-items: center;
  padding: 8px 12px;
  margin-bottom: 10px;
  max-width: 60px;
  border-radius: 8px;
  background-color: var(--card-bg, #1e293b);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  animation: typing-appear 0.3s ease-out forwards;
}

.vg-typing-indicator span {
  height: 8px;
  width: 8px;
  margin: 0 2px;
  background-color: var(--secondary-color, #00bfa6);
  border-radius: 50%;
  display: inline-block;
  opacity: 0.6;
}

.vg-typing-indicator span:nth-child(1) {
  animation: typing-dot 1s infinite 0s;
}

.vg-typing-indicator span:nth-child(2) {
  animation: typing-dot 1s infinite 0.2s;
}

.vg-typing-indicator span:nth-child(3) {
  animation: typing-dot 1s infinite 0.4s;
}

@keyframes typing-appear {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes typing-dot {
  0%, 100% {
    transform: translateY(0);
    opacity: 0.6;
  }
  50% {
    transform: translateY(-5px);
    opacity: 1;
  }
}
