/* ============================================================================
   TOAST NOTIFICATIONS - Blog V2
   Extracted from blog-v2.css
   ============================================================================ */

.toast {
  position: fixed;
  bottom: var(--sp-4, 24px);
  right: var(--sp-4, 24px);
  padding: 12px 20px;
  background: var(--c-text, #000);
  color: var(--c-bg, #fff);
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.3s;
  z-index: 10000;
}

.toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reading-progress-toast {
  position: fixed;
  bottom: var(--sp-4, 24px);
  right: var(--sp-4, 24px);
  padding: var(--sp-3, 16px);
  background: var(--c-bg);
  border: 2px solid var(--c-border);
  border-radius: var(--radius-cartoon, 12px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
  max-width: 320px;
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.3s;
  z-index: 10000;
}

.reading-progress-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reading-progress-toast p {
  margin: 0 0 var(--sp-2, 12px);
  font-size: 0.875rem;
  color: var(--c-text);
}

.reading-progress-toast .btn {
  margin-right: var(--sp-1, 8px);
}

/* Mobile responsive */
@media (max-width: 768px) {
  .toast,
  .reading-progress-toast {
    left: var(--sp-3, 16px);
    right: var(--sp-3, 16px);
    bottom: var(--sp-3, 16px);
  }
}
