.npc-dialog-container {
  background: var(--bg-surface);
  border-radius: var(--radius-card);
  padding: 1rem;
  margin: 1rem auto;
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
  color: var(--text-main);
  max-width: 860px;
}

.dialog-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--glass-border);
}

.dialog-header h3 {
  margin: 0;
  color: var(--text-bright);
}

.dialog-message {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1rem;
  animation: fadeIn 0.25s ease-out;
}

.dialog-options {
  display: grid;
  gap: 0.65rem;
  margin-top: 1rem;
}

.dialog-option {
  background: #f8fafc;
  border: 1px solid var(--glass-border);
  color: var(--text-main);
  border-radius: var(--radius-btn);
  padding: 0.78rem 0.9rem;
  cursor: pointer;
  text-align: left;
  transition: transform var(--anim-fast), border-color var(--anim-fast), background var(--anim-fast);
  font-size: 0.95rem;
  line-height: 1.4;
}

.dialog-option:hover {
  background: #eef4f3;
  border-color: rgba(15, 118, 110, 0.35);
  transform: translateX(3px);
}

.dialog-back {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  margin-top: 0.75rem;
  padding: 0.4rem 0;
  font-size: 0.9rem;
}

.dialog-back:hover {
  color: var(--text-bright);
}

.xp-earned {
  animation: xpPop 0.5s ease;
  color: var(--accent);
  display: inline-block;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes xpPop {
  0% { transform: scale(1); }
  50% { transform: scale(1.08); color: var(--accent); }
  100% { transform: scale(1); }
}

@media (max-width: 768px) {
  .npc-dialog-container {
    padding: 0.85rem;
  }
}

.npc-dialog-container {
  background:
    linear-gradient(135deg, rgba(255, 43, 214, 0.16), rgba(0, 229, 255, 0.1), rgba(216, 255, 0, 0.12)),
    rgba(17, 2, 30, 0.92);
  border: 2px solid rgba(216, 255, 0, 0.42);
}

.dialog-header h3 {
  color: var(--text-bright);
}

.dialog-message {
  color: var(--text-main);
}

.dialog-option {
  background: linear-gradient(135deg, rgba(216, 255, 0, 0.16), rgba(255, 43, 214, 0.18));
  border: 2px solid rgba(216, 255, 0, 0.42);
  color: var(--text-bright);
}

.dialog-option:hover {
  background: linear-gradient(135deg, rgba(216, 255, 0, 0.28), rgba(0, 229, 255, 0.22), rgba(255, 43, 214, 0.26));
}
