/* ============================================================
   Alerts (extracted from main.css)
   Fixed-position toast-style alerts with semantic variants.
   ============================================================ */

.alert {
  position: fixed;
  top: 40px;
  right: 20px;
  z-index: 1050;
  padding: 1rem 2.5rem;
  margin: 0;
  border: 1px solid transparent;
  border-radius: var(--border-radius-sm);
  font-family: var(--font-family);
  color: var(--text);
  box-shadow: var(--shadow);
  min-width: 250px;
  max-width: 400px;
  transition: all 0.3s ease-in-out;
  opacity: 1;
}

.alert:not(:last-child) {
  margin-bottom: 10px;
}

.alert.fade-out {
  opacity: 0;
  transform: translateY(-10px);
}

.alert .btn-close {
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 1.25rem;
  font-weight: bold;
  color: var(--text-color-primary);
  cursor: pointer;
  transition: color 0.2s ease-in-out;
}

.alert .btn-close:hover {
  color: var(--danger);
}

/* Alert Variations */
.alert-primary {
  background-color: var(--alert-primary-bg);
  border-color: var(--alert-primary-border);
}

.alert-secondary {
  background-color: var(--alert-secondary-bg);
  border-color: var(--alert-secondary-border);
}

.alert-success {
  background-color: var(--alert-success-bg);
  border-color: var(--alert-success-border);
  color: var(--success);
}

.alert-info {
  background-color: var(--alert-info-bg);
  border-color: var(--alert-info-border);
  color: var(--info);
}

.alert-warning {
  background-color: var(--alert-warning-bg);
  border-color: var(--alert-warning-border);
  color: var(--warning);
}

.alert-danger {
  background-color: var(--alert-danger-bg);
  border-color: var(--alert-danger-border);
  color: var(--danger);
}

.alert-light {
  background-color: var(--light);
  border-color: var(--neutral-gray);
  color: var(--text-color-secondary);
}

.alert-dark {
  background-color: var(--dark);
  border-color: var(--alert-danger-border);
  color: var(--white);
}

/* Toast (fixed-position alerts triggered by JS success/error) */
.toast {
  position: fixed;
  top: var(--space-5);
  right: var(--space-5);
  z-index: var(--z-toast);
  min-width: 300px;
  padding: var(--space-4);
  border-radius: var(--radius);
  border: 1px solid transparent;
}

.toast--success {
  background: var(--success-bg);
  border-color: #c3e6cb;
  color: #155724;
}

.toast--danger {
  background: var(--danger-bg);
  border-color: #f5c6cb;
  color: #721c24;
}

.toast .btn-close {
  float: right;
  background: none;
  border: none;
  font-size: var(--fs-md);
  cursor: pointer;
}
