/* eCardForever — unified notifications (theme-token compatible) */
#ecard-notify-host {
  position: fixed;
  z-index: 10050;
  left: 50%;
  bottom: max(16px, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: min(420px, calc(100vw - 24px));
  pointer-events: none;
}

.ecard-notify {
  pointer-events: auto;
  width: 100%;
  padding: 13px 20px;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.45;
  box-shadow: var(--portal-shadow-float, 0 16px 48px rgba(15, 23, 42, 0.12));
  border: 1px solid var(--border-subtle, var(--portal-border, rgba(15, 23, 42, 0.08)));
  background: var(--surface, var(--portal-surface, #fff));
  color: var(--text-primary, var(--portal-text, #0f172a));
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--portal-duration, 0.22s) ease, transform var(--portal-duration, 0.22s) ease;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 10px;
}

.ecard-notify__icon {
  flex: 0 0 auto;
  display: inline-flex;
  line-height: 0;
  margin-top: 1px;
  color: var(--text-secondary, var(--portal-text-secondary, #64748b));
}

.ecard-notify--success .ecard-notify__icon { color: #16a34a; }
.ecard-notify--error .ecard-notify__icon { color: #dc2626; }
.ecard-notify--warning .ecard-notify__icon { color: #d97706; }
.ecard-notify--info .ecard-notify__icon { color: var(--accent, var(--portal-accent, #2563eb)); }

.ecard-notify__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ecard-notify__text {
  color: var(--text-primary, var(--portal-text, #0f172a));
}

.ecard-notify__detail {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary, var(--portal-text-secondary, #64748b));
}

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

.ecard-notify--success {
  border-color: color-mix(in srgb, #16a34a 35%, var(--border-subtle, #e2e8f0));
  background: color-mix(in srgb, #16a34a 8%, var(--surface, #fff));
}

.ecard-notify--error {
  border-color: color-mix(in srgb, #dc2626 35%, var(--border-subtle, #e2e8f0));
  background: color-mix(in srgb, #dc2626 8%, var(--surface, #fff));
  color: var(--text-primary, var(--portal-text, #0f172a));
}

.ecard-notify--warning {
  border-color: color-mix(in srgb, #d97706 35%, var(--border-subtle, #e2e8f0));
  background: color-mix(in srgb, #d97706 10%, var(--surface, #fff));
}

.ecard-notify__actions {
  margin-top: 10px;
  flex-basis: 100%;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.ecard-notify__btn {
  appearance: none;
  border: 1px solid var(--border-subtle, #e2e8f0);
  background: var(--surface, #fff);
  color: var(--text-primary, var(--portal-text, #0f172a));
  border-radius: 8px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.ecard-notify__btn--primary {
  background: var(--accent, var(--portal-accent, #2563eb));
  border-color: transparent;
  color: var(--on-accent, var(--portal-on-accent, #fff));
}

/* Critical (modal) notifications */
.ecard-critical {
  position: fixed;
  inset: 0;
  z-index: 10070;
  display: none;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--page-bg, #f8fafc) 85%, transparent);
  backdrop-filter: blur(6px);
}

.ecard-critical.is-visible {
  display: flex;
}

.ecard-critical__panel {
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  padding: 22px 20px;
  border-radius: 16px;
  border: 1px solid var(--border-subtle, #e2e8f0);
  background: var(--surface, #fff);
  color: var(--text-primary, var(--portal-text, #0f172a));
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.14);
}

@media (max-width: 480px) {
  .ecard-critical__actions {
    justify-content: stretch;
  }
  .ecard-critical__btn {
    flex: 1 1 auto;
  }
}

.ecard-critical__panel h2 {
  margin: 0 0 8px;
  font-size: 18px;
}

.ecard-critical__panel p {
  margin: 0 0 16px;
  font-size: 14px;
  color: var(--text-secondary, var(--portal-text-secondary, #64748b));
}

.ecard-critical__actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.ecard-critical__btn {
  appearance: none;
  border: 1px solid var(--border-subtle, #e2e8f0);
  background: var(--surface, #fff);
  color: var(--text-primary, var(--portal-text, #0f172a));
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.ecard-critical__btn--primary {
  background: var(--accent, var(--portal-accent, #2563eb));
  border-color: transparent;
  color: var(--on-accent, var(--portal-on-accent, #fff));
}

#ecard-notify-host {
  /* keep toasts out of thumb bar on mobile */
  bottom: max(16px, calc(env(safe-area-inset-bottom) + 8px));
}

@media (max-width: 480px) {
  #ecard-notify-host {
    width: min(420px, calc(100vw - 20px));
  }
  .ecard-notify {
    padding: 11px 14px;
    font-size: 13px;
  }
}

#ecard-crash-fallback {
  position: fixed;
  inset: 0;
  z-index: 10060;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: color-mix(in srgb, var(--page-bg, #f8fafc) 92%, transparent);
  backdrop-filter: blur(6px);
}

#ecard-crash-fallback.is-visible {
  display: flex;
}

.ecard-crash-fallback__panel {
  max-width: 420px;
  width: 100%;
  padding: 24px;
  border-radius: 16px;
  border: 1px solid var(--border-subtle, #e2e8f0);
  background: var(--surface, #fff);
  color: var(--text-primary, var(--portal-text, #0f172a));
  text-align: center;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12);
}

.ecard-crash-fallback__panel h2 {
  font-size: 18px;
  margin: 0 0 8px;
}

.ecard-crash-fallback__panel p {
  font-size: 14px;
  color: var(--text-secondary, var(--portal-text-secondary, #64748b));
  margin: 0 0 16px;
}

.ecard-crash-fallback__panel button {
  appearance: none;
  border: none;
  border-radius: 999px;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  background: var(--accent, #2563eb);
  color: var(--on-accent, #fff);
}
