/* 
 * Component Styles
 * Reusable UI components
 */

/* ===== Chat Messages ===== */
.chat-message {
  background: var(--surface);
  backdrop-filter: var(--glass-blur);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  word-break: break-word;
  max-width: 80%;
  margin-right: auto;
  position: relative;
  font-size: var(--font-size-xs);
  animation: slideUp 0.3s ease-out;
}

.chat-message.self {
  background: linear-gradient(135deg, var(--primary-600), var(--primary-500));
  border-color: var(--primary-400);
  margin-left: auto;
  margin-right: 0;
  text-align: right;
}

.chat-message.system {
  background: var(--surface-elevated);
  color: var(--text-muted);
  border: 1px dashed var(--border);
  text-align: center;
  font-style: italic;
  margin: var(--space-1) auto;
  max-width: 90%;
  font-size: var(--font-size-xs);
}

.chat-message .sender {
  font-weight: bold;
  color: var(--accent-yellow);
  margin-right: var(--space-1);
  font-size: var(--font-size-xs);
}

.chat-message.self .sender {
  color: var(--accent-green);
}

.chat-message .timestamp {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-left: var(--space-1);
  opacity: 0.7;
}

/* ===== Status Toasts ===== */
.status-toast-container {
  position: absolute;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: center;
  pointer-events: none;
}

.status-toast {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 2px solid transparent;
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-5);
  font-size: var(--font-size-sm);
  text-align: center;
  box-shadow: var(--glass-shadow);
  opacity: 0;
  animation: toastFade 2.5s forwards;
  max-width: 300px;
}

.status-toast.info {
  border-color: var(--primary-400);
  color: var(--primary-300);
  box-shadow: 
    var(--glass-shadow),
    0 0 20px rgba(14, 165, 233, 0.3);
}

.status-toast.success {
  border-color: var(--accent-green);
  color: var(--accent-green);
  box-shadow: 
    var(--glass-shadow),
    0 0 20px rgba(80, 250, 123, 0.3);
}

.status-toast.error {
  border-color: var(--accent-red);
  color: var(--accent-red);
  box-shadow: 
    var(--glass-shadow),
    0 0 20px rgba(255, 85, 85, 0.3);
}

/* ===== Turn Indicator ===== */
.turn-indicator {
  position: absolute;
  top: var(--space-3);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-2) var(--space-5);
  border: 2px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  font-size: var(--font-size-lg);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  z-index: var(--z-fixed);
  box-shadow: var(--glass-shadow);
  animation: pulse 2.4s ease-in-out infinite;
}

.turn-indicator.player-turn {
  border-color: var(--accent-green);
  color: var(--accent-green);
  box-shadow: 
    var(--glass-shadow),
    var(--turn-timer-glow);
}

.turn-indicator.enemy-turn {
  border-color: var(--accent-red);
  color: var(--accent-red);
  box-shadow: 
    var(--glass-shadow),
    var(--turn-timer-glow);
}

.turn-text {
  pointer-events: none;
  white-space: nowrap;
  text-shadow: 1px 1px 0 rgba(0, 0, 0, 0.8);
}

/* ===== Discord Invite Box ===== */
.discord-invite-box {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface-elevated);
  backdrop-filter: var(--glass-blur);
  border: 2px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--glass-shadow);
  overflow: hidden;
}

/* ===== Utility Components ===== */
.glass-panel {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 2px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--glass-shadow);
}

.surface-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.elevated-panel {
  background: var(--surface-elevated);
  border: 2px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--glass-shadow);
}

/* ===== Animations ===== */
@keyframes spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to { transform: translate(-50%, -50%) rotate(360deg); }
}

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

@keyframes toastFade {
  0% { 
    opacity: 0; 
    transform: translateY(-10px) scale(0.95); 
  }
  10% { 
    opacity: 1; 
    transform: translateY(0) scale(1); 
  }
  90% { 
    opacity: 1; 
    transform: translateY(0) scale(1); 
  }
  100% { 
    opacity: 0; 
    transform: translateY(-10px) scale(0.95); 
  }
}

@keyframes pulse {
  0%, 100% { 
    box-shadow: 
      var(--glass-shadow),
      0 0 10px currentColor; 
  }
  50% { 
    box-shadow: 
      var(--glass-shadow),
      0 0 20px currentColor,
      0 0 30px currentColor; 
  }
}
