/* THEME VARIABLES */
:root {
  --color-ink-900: #0b1224;
  --color-ink-800: #0f172a;
  --color-ink-100: #e2e8f0;
  --color-ink-200: #94a3b8;
  --color-ink-50: #f8fafc;
  --color-cloud-0: #ffffff;
  --color-cloud-50: #f1f5f9;
  --color-cloud-100: #f6f8fb;
  --color-cloud-200: #eef2f7;
  --color-cloud-300: #f7fbff;
  --color-emerald-400: #34d399;
  --color-emerald-500: #10b981;
  --color-emerald-600: #059669;
  --color-emerald-700: #047857;
  --color-sky-400: #38bdf8;
  --color-sky-500: #0ea5e9;
  --color-sky-900: #075985;
  --color-indigo-500: #6366f1;
  --color-indigo-600: #4f46e5;
  --color-indigo-900: #312e81;
  --color-amber-400: #fbbf24;
  --color-amber-500: #f59e0b;
  --color-amber-900: #92400e;
  --color-rose-500: #f43f5e;
  --color-rose-600: #ef4444;
  --color-rose-900: #9f1239;
  --color-slate-400: #94a3b8;
  --color-slate-900: #0f172a;

  --gradient-start: var(--color-ink-900);
  --gradient-end: var(--color-ink-800);
  --halo-1: color-mix(in srgb, var(--color-sky-500) 16%, transparent);
  --halo-2: color-mix(in srgb, var(--color-sky-400) 10%, transparent);

  --surface: color-mix(in srgb, var(--color-ink-800) 92%, transparent);
  --panel: color-mix(in srgb, var(--color-ink-800) 85%, transparent);
  --card: color-mix(in srgb, var(--color-cloud-0) 6%, transparent);
  --border: color-mix(in srgb, var(--color-cloud-0) 8%, transparent);
  --shadow: 0 22px 70px color-mix(in srgb, var(--color-ink-800) 45%, transparent);

  --text-main: var(--color-ink-100);
  --text-muted: var(--color-ink-200);
  --text-contrast: var(--color-cloud-0);

  --badge-soft-bg: color-mix(in srgb, var(--text-main) 8%, transparent);
  --badge-soft-border: var(--border);

  --banner-warning-bg: color-mix(in srgb, var(--color-amber-400) 36%, transparent);
  --banner-warning-border: var(--color-amber-500);
  --banner-warning-text: var(--color-amber-900);
  --banner-success-bg: color-mix(in srgb, var(--color-emerald-400) 32%, transparent);
  --banner-success-border: var(--color-emerald-600);
  --banner-success-text: var(--color-emerald-700);
  --banner-error-bg: color-mix(in srgb, var(--color-rose-500) 34%, transparent);
  --banner-error-border: var(--color-rose-600);
  --banner-error-text: var(--color-rose-900);

  --node-ready: var(--color-emerald-400);
  --node-warning: var(--color-amber-400);
  --node-danger: var(--color-rose-500);
  --node-focus: var(--color-sky-500);

  --toast-success-bg: color-mix(in srgb, var(--color-emerald-500) 16%, transparent);
  --toast-success-highlight: color-mix(in srgb, var(--color-emerald-600) 12%, transparent);
  --toast-success-text: color-mix(in srgb, var(--color-emerald-400) 92%, transparent);

  --tone-warning-bg: color-mix(in srgb, var(--color-amber-500) 18%, transparent);
  --tone-warning-border: color-mix(in srgb, var(--color-amber-500) 42%, transparent);
  --tone-warning-hover: color-mix(in srgb, var(--color-amber-500) 26%, transparent);
  --tone-warning-text: color-mix(in srgb, var(--color-cloud-0) 86%, var(--color-amber-400) 14%);
  --tone-success-bg: color-mix(in srgb, var(--color-emerald-500) 18%, transparent);
  --tone-success-border: color-mix(in srgb, var(--color-emerald-500) 42%, transparent);
  --tone-success-hover: color-mix(in srgb, var(--color-emerald-500) 26%, transparent);
  --tone-success-text: color-mix(in srgb, var(--color-cloud-0) 90%, var(--color-emerald-400) 10%);
  --tone-danger-bg: color-mix(in srgb, var(--color-rose-500) 20%, transparent);
  --tone-danger-border: color-mix(in srgb, var(--color-rose-500) 46%, transparent);
  --tone-danger-hover: color-mix(in srgb, var(--color-rose-500) 28%, transparent);
  --tone-danger-text: color-mix(in srgb, var(--color-cloud-0) 90%, var(--color-rose-500) 10%);

  --stat-bg: var(--card);
  --stat-border: var(--border);
  --stat-text: var(--text-main);
  --stat-emerald-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-emerald-500) 20%, transparent), color-mix(in srgb, var(--color-emerald-600) 16%, transparent));
  --stat-emerald-border: color-mix(in srgb, var(--color-emerald-500) 45%, transparent);
  --stat-emerald-text: color-mix(in srgb, var(--color-emerald-400) 96%, transparent);
  --stat-sky-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-sky-500) 20%, transparent), color-mix(in srgb, var(--color-sky-400) 14%, transparent));
  --stat-sky-border: color-mix(in srgb, var(--color-sky-500) 45%, transparent);
  --stat-sky-text: color-mix(in srgb, var(--color-sky-400) 92%, transparent);
  --stat-indigo-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-indigo-500) 20%, transparent), color-mix(in srgb, var(--color-indigo-600) 16%, transparent));
  --stat-indigo-border: color-mix(in srgb, var(--color-indigo-500) 45%, transparent);
  --stat-indigo-text: color-mix(in srgb, var(--color-indigo-500) 92%, transparent);
  --stat-amber-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-amber-400) 20%, transparent), color-mix(in srgb, var(--color-amber-500) 16%, transparent));
  --stat-amber-border: color-mix(in srgb, var(--color-amber-500) 50%, transparent);
  --stat-amber-text: color-mix(in srgb, var(--color-amber-400) 90%, transparent);
  --stat-rose-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-rose-500) 20%, transparent), color-mix(in srgb, var(--color-rose-600) 16%, transparent));
  --stat-rose-border: color-mix(in srgb, var(--color-rose-500) 50%, transparent);
  --stat-rose-text: color-mix(in srgb, var(--color-rose-500) 92%, transparent);
  --stat-slate-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-slate-400) 20%, transparent), color-mix(in srgb, var(--color-slate-900) 14%, transparent));
  --stat-slate-border: color-mix(in srgb, var(--color-slate-400) 45%, transparent);
  --stat-slate-text: var(--text-main);
}

html[data-theme="light"] {
  --gradient-start: var(--color-cloud-300);
  --gradient-end: var(--color-cloud-200);
  --halo-1: color-mix(in srgb, var(--color-sky-500) 28%, transparent);
  --halo-2: color-mix(in srgb, var(--color-sky-500) 18%, transparent);

  --surface: var(--color-cloud-100);
  --panel: var(--color-cloud-0);
  --card: var(--color-cloud-0);
  --border: #d6deeb;
  --shadow: 0 22px 45px color-mix(in srgb, var(--color-ink-800) 12%, transparent);

  --text-main: var(--color-slate-900);
  --text-muted: #475569;
  --text-contrast: var(--color-ink-900);

  --banner-warning-bg: #fff4d6;
  --banner-warning-border: var(--color-amber-500);
  --banner-warning-text: var(--color-amber-900);
  --banner-success-bg: #e5fbf1;
  --banner-success-border: var(--color-emerald-600);
  --banner-success-text: var(--color-emerald-700);
  --banner-error-bg: #ffe7eb;
  --banner-error-border: var(--color-rose-600);
  --banner-error-text: var(--color-rose-900);

  --toast-success-bg: #e9fff5;
  --toast-success-highlight: color-mix(in srgb, var(--color-emerald-500) 12%, transparent);
  --toast-success-text: var(--color-emerald-700);

  --tone-warning-bg: #fff4d6;
  --tone-warning-border: color-mix(in srgb, var(--color-amber-500) 50%, transparent);
  --tone-warning-hover: color-mix(in srgb, #fff4d6 82%, var(--color-amber-500) 18%);
  --tone-warning-text: var(--color-amber-900);
  --tone-success-bg: #e5fbf1;
  --tone-success-border: color-mix(in srgb, var(--color-emerald-600) 45%, transparent);
  --tone-success-hover: color-mix(in srgb, #e5fbf1 82%, var(--color-emerald-500) 18%);
  --tone-success-text: var(--color-emerald-800);
  --tone-danger-bg: #ffe7eb;
  --tone-danger-border: color-mix(in srgb, var(--color-rose-600) 50%, transparent);
  --tone-danger-hover: color-mix(in srgb, #ffe7eb 82%, var(--color-rose-500) 18%);
  --tone-danger-text: var(--color-rose-900);

  /* Toggle component */
  --toggle-track-bg: color-mix(in srgb, var(--color-cloud-0) 6%, transparent);
  --toggle-track-border: color-mix(in srgb, var(--color-cloud-0) 12%, transparent);
  --toggle-track-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-cloud-0) 6%, transparent);
  --toggle-thumb-bg: var(--color-cloud-0);
  --toggle-thumb-shadow: 0 8px 24px color-mix(in srgb, var(--color-ink-900) 35%, transparent);
  --toggle-label-muted: var(--text-muted);
  --toggle-label-active: color-mix(in srgb, var(--color-emerald-400) 80%, transparent);
  --toggle-on-track-bg: linear-gradient(135deg, var(--color-emerald-500), var(--color-sky-500));
  --toggle-on-track-border: color-mix(in srgb, var(--color-emerald-500) 65%, transparent);
  --toggle-on-track-shadow: 0 12px 32px color-mix(in srgb, var(--color-emerald-500) 35%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--color-cloud-0) 20%, transparent);
  --toggle-on-thumb-bg: var(--color-ink-900);
  --toggle-on-thumb-shadow: 0 10px 28px color-mix(in srgb, var(--color-ink-900) 50%, transparent);
  --toggle-chip-bg: color-mix(in srgb, var(--color-cloud-0) 5%, transparent);
  --toggle-chip-border: color-mix(in srgb, var(--color-cloud-0) 12%, transparent);
  --toggle-chip-text: color-mix(in srgb, var(--text-muted) 92%, transparent);
  --toggle-chip-dot: color-mix(in srgb, var(--text-muted) 92%, transparent);
  --toggle-chip-dot-ring: color-mix(in srgb, var(--text-muted) 16%, transparent);
  --toggle-chip-on-bg: color-mix(in srgb, var(--color-emerald-500) 12%, transparent);
  --toggle-chip-on-border: color-mix(in srgb, var(--color-emerald-500) 50%, transparent);
  --toggle-chip-on-text: color-mix(in srgb, var(--color-emerald-400) 96%, transparent);
  --toggle-chip-on-dot: var(--color-emerald-400);
  --toggle-chip-on-ring: color-mix(in srgb, var(--color-emerald-500) 32%, transparent);
  --toggle-chip-off-bg: color-mix(in srgb, var(--color-cloud-0) 2%, transparent);
  --toggle-chip-off-border: color-mix(in srgb, var(--color-cloud-0) 8%, transparent);
  --toggle-chip-off-dot: var(--text-muted);
  --toggle-chip-off-ring: color-mix(in srgb, var(--text-muted) 18%, transparent);

  --stat-bg: var(--card);
  --stat-border: var(--border);
  --stat-text: var(--text-main);
  --stat-emerald-bg: #e9fff5;
  --stat-emerald-border: color-mix(in srgb, var(--color-emerald-500) 35%, transparent);
  --stat-emerald-text: var(--color-emerald-700);
  --stat-sky-bg: #e6f7ff;
  --stat-sky-border: color-mix(in srgb, var(--color-sky-500) 35%, transparent);
  --stat-sky-text: var(--color-sky-900);
  --stat-indigo-bg: #eef1ff;
  --stat-indigo-border: color-mix(in srgb, var(--color-indigo-500) 35%, transparent);
  --stat-indigo-text: var(--color-indigo-900);
  --stat-amber-bg: #fff4d6;
  --stat-amber-border: color-mix(in srgb, var(--color-amber-500) 40%, transparent);
  --stat-amber-text: var(--color-amber-900);
  --stat-rose-bg: #ffe7eb;
  --stat-rose-border: color-mix(in srgb, var(--color-rose-500) 40%, transparent);
  --stat-rose-text: var(--color-rose-900);
  --stat-slate-bg: #f1f5f9;
  --stat-slate-border: color-mix(in srgb, var(--color-slate-400) 35%, transparent);
  --stat-slate-text: var(--color-slate-900);

  /* Toggle component - light mode */
  --toggle-track-bg: color-mix(in srgb, var(--color-slate-400) 18%, transparent);
  --toggle-track-border: color-mix(in srgb, var(--color-slate-400) 35%, transparent);
  --toggle-track-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-cloud-0) 75%, transparent);
  --toggle-thumb-bg: var(--color-cloud-0);
  --toggle-thumb-shadow: 0 6px 18px color-mix(in srgb, var(--color-ink-800) 18%, transparent);
  --toggle-label-muted: var(--text-muted);
  --toggle-label-active: var(--color-emerald-700);
  --toggle-on-track-bg: linear-gradient(135deg, color-mix(in srgb, var(--color-emerald-500) 85%, var(--color-cloud-0) 15%),
      color-mix(in srgb, var(--color-sky-500) 85%, var(--color-cloud-0) 15%));
  --toggle-on-track-border: color-mix(in srgb, var(--color-emerald-500) 60%, transparent);
  --toggle-on-track-shadow: 0 10px 28px color-mix(in srgb, var(--color-emerald-500) 22%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--color-cloud-0) 70%, transparent);
  --toggle-on-thumb-bg: var(--color-cloud-0);
  --toggle-on-thumb-shadow: 0 8px 20px color-mix(in srgb, var(--color-ink-800) 22%, transparent);
  --toggle-chip-bg: color-mix(in srgb, var(--color-cloud-0) 90%, transparent);
  --toggle-chip-border: color-mix(in srgb, var(--color-slate-400) 35%, transparent);
  --toggle-chip-text: var(--text-muted);
  --toggle-chip-dot: var(--color-slate-400);
  --toggle-chip-dot-ring: color-mix(in srgb, var(--color-slate-400) 28%, transparent);
  --toggle-chip-on-bg: color-mix(in srgb, var(--color-emerald-500) 16%, transparent);
  --toggle-chip-on-border: color-mix(in srgb, var(--color-emerald-500) 55%, transparent);
  --toggle-chip-on-text: var(--color-emerald-700);
  --toggle-chip-on-dot: var(--color-emerald-500);
  --toggle-chip-on-ring: color-mix(in srgb, var(--color-emerald-500) 32%, transparent);
  --toggle-chip-off-bg: color-mix(in srgb, var(--color-cloud-0) 92%, transparent);
  --toggle-chip-off-border: color-mix(in srgb, var(--color-slate-400) 28%, transparent);
  --toggle-chip-off-dot: var(--color-slate-400);
  --toggle-chip-off-ring: color-mix(in srgb, var(--color-slate-400) 26%, transparent);
}

/* GLOBAL SURFACES */
html {
  color: var(--text-main);
}

body { color: inherit; }

.dashboard-shell {
  background: radial-gradient(circle at 20% 18%, var(--halo-1), transparent 32%),
              radial-gradient(circle at 82% 0%, var(--halo-2), transparent 28%),
              linear-gradient(180deg, var(--gradient-start), var(--gradient-end));
  color: var(--text-main);
  transition: background 0.3s ease, color 0.3s ease;
}

.bg-surface-theme { background: var(--surface); color: var(--text-main); }
.bg-card-theme { background: var(--card); color: var(--text-main); }
.bg-panel-theme { background: var(--panel); color: var(--text-main); }
.border-theme { border-color: var(--border); }
.shadow-theme { box-shadow: var(--shadow); }
.surface-blur { backdrop-filter: blur(14px); }

.glass-card,
.dashboard-surface {
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  color: var(--text-main);
}

.dashboard-surface { background: var(--panel); }

.has-dark-surface {
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-main);
  box-shadow: var(--shadow);
}

.alerts-panel {
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  color: var(--text-main);
}

.alert-total { color: var(--text-main); }

.alert-card {
  --alert-accent: var(--color-sky-500);
  --alert-accent-soft: color-mix(in srgb, var(--alert-accent) 12%, transparent);
  --alert-accent-strong: color-mix(in srgb, var(--alert-accent) 22%, transparent);

  background: color-mix(in srgb, var(--card) 92%, transparent);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 12px 32px color-mix(in srgb, var(--color-ink-900) 10%, transparent);
  color: var(--text-main);
  padding: 16px;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.system-update-alert {
  background: color-mix(in srgb, var(--color-amber-200) 50%, var(--card) 50%);
  border-color: color-mix(in srgb, var(--color-amber-500) 55%, var(--border) 45%);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-amber-500) 30%, transparent),
    0 18px 40px color-mix(in srgb, var(--color-ink-900) 18%, transparent);
  animation: system-alert-pulse 1.8s ease-in-out infinite;
}

.alert-card:hover {
  background: color-mix(in srgb, var(--card) 98%, transparent);
  border-color: color-mix(in srgb, var(--alert-accent) 35%, var(--border) 65%);
  box-shadow: 0 18px 40px color-mix(in srgb, var(--color-ink-900) 14%, transparent);
  transform: translateY(-2px);
}

.alert-label { color: var(--text-muted); }
.alert-description { color: color-mix(in srgb, var(--text-main) 92%, transparent); }

.alert-pill {
  background: var(--alert-accent-soft);
  border: 1px solid color-mix(in srgb, var(--alert-accent) 26%, transparent);
  border-radius: 12px;
  color: var(--text-main);
  padding: 6px 10px;
}

.alert-badge { color: var(--alert-accent); }

.alert-cta {
  background: var(--alert-accent-soft);
  border: 1px solid color-mix(in srgb, var(--alert-accent) 24%, transparent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--alert-accent) 18%, transparent);
  color: var(--text-main);
}

.alert-card.tone-amber {
  --alert-accent: var(--color-amber-500);
  --alert-accent-soft: color-mix(in srgb, var(--color-amber-500) 20%, transparent);
  --alert-accent-strong: color-mix(in srgb, var(--color-amber-500) 30%, transparent);
}

.alert-card.tone-rose {
  --alert-accent: var(--color-rose-500);
  --alert-accent-soft: color-mix(in srgb, var(--color-rose-500) 18%, transparent);
  --alert-accent-strong: color-mix(in srgb, var(--color-rose-500) 28%, transparent);
}

@keyframes system-alert-pulse {
  0% {
    transform: translateY(0);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--color-amber-500) 30%, transparent),
      0 18px 40px color-mix(in srgb, var(--color-ink-900) 18%, transparent);
  }
  50% {
    transform: translateY(-2px);
    box-shadow: 0 0 0 10px color-mix(in srgb, var(--color-amber-400) 14%, transparent),
      0 20px 44px color-mix(in srgb, var(--color-ink-900) 20%, transparent);
  }
  100% {
    transform: translateY(0);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--color-amber-500) 30%, transparent),
      0 18px 40px color-mix(in srgb, var(--color-ink-900) 18%, transparent);
  }
}

.dashboard-border { border-color: var(--border); }

html[data-theme="light"] .glass-card,
html[data-theme="light"] .dashboard-surface,
html[data-theme="light"] .bg-card-theme,
html[data-theme="light"] .bg-panel-theme { box-shadow: 0 14px 36px color-mix(in srgb, var(--color-ink-800) 10%, transparent); }

/* TEXT SYSTEM */
.text-theme { color: var(--text-main); }
.text-muted-theme { color: var(--text-muted); }
.text-contrast-theme { color: var(--text-contrast); }

.form-accent { accent-color: var(--color-sky-500); }
.focus-accent:focus,
.focus-accent:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-sky-500) 45%, transparent);
}
.hover-border-accent:hover { border-color: color-mix(in srgb, var(--color-sky-500) 70%, var(--border) 30%); }

.gradient-text {
  background: linear-gradient(120deg, var(--color-emerald-400), var(--color-sky-500), var(--color-indigo-500));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.pulse-dot { position: relative; }
.pulse-dot::after {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: 9999px;
  background: color-mix(in srgb, var(--color-sky-500) 18%, transparent);
  animation: ping 1.4s infinite;
}

@keyframes ping {
  0% { transform: scale(0.7); opacity: 0.9; }
  80%, 100% { transform: scale(1.5); opacity: 0; }
}

.badge-soft { background: var(--badge-soft-bg); border: 1px solid var(--badge-soft-border); color: var(--text-main); }

.badge-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 9999px;
  border: 1px solid var(--badge-soft-border);
  background: var(--badge-soft-bg);
  color: var(--text-main);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}

.badge-status__label { color: color-mix(in srgb, currentColor 72%, var(--text-muted) 28%); font-weight: 700; }

.badge-status--success { background: var(--tone-success-bg); border-color: var(--tone-success-border); color: var(--tone-success-text); }

.badge-status--warning { background: var(--tone-warning-bg); border-color: var(--tone-warning-border); color: var(--tone-warning-text); }

.badge-status--danger { background: var(--tone-danger-bg); border-color: var(--tone-danger-border); color: var(--tone-danger-text); }

.tone-warning,
.tone-success,
.tone-danger {
  background: var(--tone-warning-bg);
  border: 1px solid var(--tone-warning-border);
  color: var(--tone-warning-text);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.tone-success {
  background: var(--tone-success-bg);
  border-color: var(--tone-success-border);
  color: var(--tone-success-text);
}

.tone-danger {
  background: var(--tone-danger-bg);
  border-color: var(--tone-danger-border);
  color: var(--tone-danger-text);
}

.tone-warning:hover { background: var(--tone-warning-hover); }
.tone-success:hover { background: var(--tone-success-hover); }
.tone-danger:hover { background: var(--tone-danger-hover); }

/* BUTTONS */
.dashboard-ghost-button {
  background: color-mix(in srgb, var(--text-main) 6%, transparent);
  border: 1px solid var(--border);
  color: var(--text-main);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.dashboard-ghost-button:hover { background: color-mix(in srgb, var(--text-main) 12%, transparent); }

html[data-theme="light"] .dashboard-ghost-button { background: var(--color-cloud-50); border-color: var(--border); color: var(--color-slate-900); }
html[data-theme="light"] .dashboard-ghost-button:hover { background: color-mix(in srgb, var(--color-ink-100) 80%, transparent); border-color: color-mix(in srgb, var(--border) 90%, transparent); }

/* INPUTS */
.dashboard-field,
.auth-input,
.input-theme {
  background: color-mix(in srgb, var(--text-main) 4%, transparent);
  border: 1px solid var(--border);
  color: var(--text-main);
  box-shadow: var(--shadow);
}

html[data-theme="light"] .dashboard-field,
html[data-theme="light"] .auth-input,
html[data-theme="light"] .input-theme { background: var(--color-ink-50); border-color: var(--border); box-shadow: 0 10px 26px color-mix(in srgb, var(--color-ink-800) 8%, transparent); color: var(--color-slate-900); }

.dashboard-field input,
.dashboard-field input::placeholder,
.auth-input input,
.auth-input input::placeholder,
.input-theme::placeholder { color: var(--text-muted); }

.auth-badge,
.auth-pill-group {
  background: color-mix(in srgb, var(--card) 70%, transparent);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.auth-pill-group { padding: 4px; border-radius: 9999px; }

.form-tab {
  color: var(--text-muted);
  border-radius: 9999px;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.form-tab[aria-selected="true"] {
  background: color-mix(in srgb, var(--text-main) 12%, transparent);
  border: 1px solid var(--border);
  color: var(--text-main);
  box-shadow: var(--shadow);
}

.form-tab[aria-selected="false"]:hover { background: color-mix(in srgb, var(--text-main) 8%, transparent); }

.auth-shell {
  background: radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 55%),
    radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--secondary) 16%, transparent), transparent 60%),
    var(--section-default-bg);
  color: var(--section-default-text);
  font-family: var(--font-body);
  --surface: var(--section-default-bg);
  --panel: var(--background-muted);
  --card: var(--background-card);
  --border: var(--border-default);
  --shadow: var(--shadow-default);
  --text-main: var(--section-default-text);
  --text-muted: var(--neutral-300);
  --text-contrast: var(--section-alt-text);
  --auth-shell-bg: color-mix(in srgb, var(--section-default-bg) 85%, var(--background-muted));
  --auth-panel-bg: var(--card);
  --auth-panel-text: var(--text-main);
  --auth-marketing-gradient-start: color-mix(in srgb, var(--primary) 70%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--primary) 35%, var(--section-default-bg));
  --auth-marketing-pattern-opacity: 0.35;
  --auth-marketing-accent: var(--primary);
  --auth-pill-bg: color-mix(in srgb, var(--text-main) 12%, transparent);
}

html[data-theme="light"] .auth-shell {
  --auth-marketing-gradient-start: color-mix(in srgb, var(--primary) 78%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--primary) 20%, var(--section-default-bg));
  --auth-marketing-pattern-opacity: 0.45;
}

.auth-shell .auth-input,
.auth-shell .input-theme {
  background: color-mix(in srgb, var(--section-default-text) 6%, transparent);
  border: 1px solid var(--border);
  color: var(--text-main);
  box-shadow: var(--shadow);
}

html[data-theme="light"] .auth-shell .auth-input,
html[data-theme="light"] .auth-shell .input-theme {
  background: color-mix(in srgb, var(--section-default-text) 6%, transparent);
  border-color: var(--border);
  box-shadow: var(--shadow);
  color: var(--text-main);
}

.auth-shadow { box-shadow: 0 25px 80px color-mix(in srgb, var(--color-ink-900) 8%, transparent); }

.auth-layout {
  width: 100%;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
  align-items: stretch;
  background: var(--auth-shell-bg);
  border-radius: 0;
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  box-shadow: var(--shadow);
  overflow: hidden;
  min-height: 100vh;
}

.auth-layout--split,
.auth-layout--immersive,
.auth-layout--centered,
.auth-layout--solo { grid-template-columns: minmax(0, 1fr); }

.auth-layout--solo .auth-panel { max-width: 540px; margin: 0 auto; }

@media (min-width: 1024px) {
  .auth-layout--split { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
  .auth-layout--immersive { grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr); }
  .auth-layout--centered { grid-template-columns: minmax(0, 440px); justify-content: center; }
}

.auth-marketing {
  background: linear-gradient(140deg, var(--auth-marketing-gradient-start), var(--auth-marketing-gradient-end));
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 3vw, 32px);
  color: var(--text-main);
  position: relative;
  overflow: hidden;
}

.auth-marketing::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 30%, color-mix(in srgb, var(--auth-marketing-accent) 25%, transparent), transparent 45%),
    radial-gradient(circle at 80% 20%, color-mix(in srgb, var(--auth-marketing-accent) 18%, transparent), transparent 55%),
    linear-gradient(90deg, color-mix(in srgb, var(--auth-marketing-accent) 16%, transparent) 1px, transparent 1px),
    linear-gradient(180deg, color-mix(in srgb, var(--auth-marketing-accent) 16%, transparent) 1px, transparent 1px);
  background-size: auto, auto, 36px 36px, 36px 36px;
  opacity: var(--auth-marketing-pattern-opacity);
  pointer-events: none;
}

.auth-marketing > * { position: relative; z-index: 1; }

.auth-marketing--auto {
  --auth-marketing-accent: var(--primary);
  --auth-marketing-gradient-start: color-mix(in srgb, var(--primary) 70%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--primary) 35%, var(--section-default-bg));
}

.auth-marketing--primary {
  --auth-marketing-accent: var(--primary);
  --auth-marketing-gradient-start: color-mix(in srgb, var(--primary) 75%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--primary) 35%, var(--section-default-bg));
}

.auth-marketing--secondary {
  --auth-marketing-accent: var(--secondary);
  --auth-marketing-gradient-start: color-mix(in srgb, var(--secondary) 70%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--secondary) 30%, var(--section-default-bg));
}

.auth-marketing--neutral {
  --auth-marketing-accent: var(--neutral-200);
  --auth-marketing-gradient-start: color-mix(in srgb, var(--neutral-200) 45%, var(--panel));
  --auth-marketing-gradient-end: color-mix(in srgb, var(--neutral-200) 20%, var(--section-default-bg));
}

.auth-marketing__intro { display: flex; flex-direction: column; gap: 12px; }
.auth-marketing__kicker { letter-spacing: 0.3em; }
.auth-marketing__text { max-width: 520px; }

.auth-layout--centered .auth-marketing {
  text-align: center;
  align-items: center;
}

.auth-layout--centered .auth-marketing__text { max-width: 100%; }

.auth-marketing__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.auth-marketing__badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 9999px;
  border: 1px solid color-mix(in srgb, var(--auth-marketing-accent) 35%, var(--border));
  background: color-mix(in srgb, var(--auth-marketing-accent) 16%, transparent);
  color: var(--text-main);
  box-shadow: var(--shadow);
}

.auth-marketing__benefits {
  display: grid;
  gap: 12px;
}

.auth-marketing__benefits--overlay {
  position: absolute;
  inset: auto clamp(16px, 2vw, 24px) clamp(16px, 2vw, 24px);
  z-index: 2;
  max-height: 55%;
  overflow: hidden;
  padding-right: 4px;
  display: grid;
}

.auth-marketing__benefits--overlay .auth-benefit-card {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.35s ease, transform 0.35s ease;
  pointer-events: none;
  position: absolute;
  inset: 0;
  margin: 0;
}

.auth-marketing__benefits--overlay .auth-benefit-card.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  position: relative;
}

.auth-benefit-card {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: color-mix(in srgb, var(--auth-panel-bg) 82%, transparent);
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

.auth-benefit-icon {
  width: 32px;
  height: 32px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--auth-marketing-accent) 18%, transparent);
  color: var(--text-main);
  font-size: 16px;
}

.auth-marketing__visual { margin: 0; position: relative; }

.auth-visual-image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
  box-shadow: var(--shadow);
  object-fit: cover;
}

@media (min-width: 1024px) {
  .auth-marketing { min-height: 100vh; }

  .auth-marketing__visual {
    flex: 1;
    display: flex;
    align-items: center;
    min-height: 0;
  }

  .auth-visual-image {
    max-height: clamp(260px, 52vh, 520px);
    object-fit: contain;
  }
}

.auth-panel {
  background: var(--auth-panel-bg);
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-panel__content {
  width: min(100%, 420px);
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.auth-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.auth-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}

.auth-brand__logo { display: inline-flex; align-items: center; }

.auth-logo__image {
  height: var(--logo-height-desktop);
  width: auto;
  display: block;
}

.auth-logo__image--dark { display: none; }

html[data-theme="dark"] .auth-logo__image--light { display: none; }
html[data-theme="dark"] .auth-logo__image--dark { display: block; }

@media (max-width: 768px) {
  .auth-logo__image { height: var(--logo-height-mobile); }
}

.auth-panel__intro {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auth-panel__tabs {
  display: inline-flex;
  gap: 6px;
  padding: 4px;
  border-radius: 9999px;
  align-self: flex-start;
  background: var(--auth-pill-bg);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
}

.auth-submit {
  background: linear-gradient(120deg, var(--primary), var(--secondary));
  color: var(--text-contrast);
  border: 1px solid color-mix(in srgb, var(--primary) 55%, var(--border));
  box-shadow: 0 16px 36px color-mix(in srgb, var(--primary) 30%, transparent);
}

.auth-submit:hover {
  box-shadow: 0 18px 40px color-mix(in srgb, var(--primary) 36%, transparent);
}

.auth-form-reassurance { margin-top: 8px; }

@media (max-width: 768px) {
  .auth-layout {
    width: min(100%, calc(100% - 2rem));
    margin: 0 auto;
    border-radius: 24px;
    min-height: unset;
  }
  .auth-marketing__benefits--overlay {
    position: static;
  }
  .auth-panel__content { width: min(100%, 380px); }
}

/* BANNERS */
.dashboard-banner {
  --banner-bg: color-mix(in srgb, var(--card) 80%, transparent);
  --banner-border: var(--border);
  --banner-text: var(--text-main);
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--banner-border);
  background: var(--banner-bg);
  color: var(--banner-text);
  box-shadow: var(--shadow);
}

.dashboard-banner__icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  background: color-mix(in srgb, currentColor 18%, transparent);
}

.dashboard-banner__body { flex: 1; color: inherit; }

.dashboard-banner__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  font-weight: 600;
  color: inherit;
  text-decoration: none;
}

.dashboard-banner__link:hover { text-decoration: underline; }

.dashboard-banner__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 9999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  background: color-mix(in srgb, currentColor 14%, transparent);
  border: 1px solid color-mix(in srgb, currentColor 32%, transparent);
}

.dashboard-banner--warning { --banner-bg: var(--banner-warning-bg); --banner-border: var(--banner-warning-border); --banner-text: var(--banner-warning-text); }
.dashboard-banner--success { --banner-bg: var(--banner-success-bg); --banner-border: var(--banner-success-border); --banner-text: var(--banner-success-text); }
.dashboard-banner--error { --banner-bg: var(--banner-error-bg); --banner-border: var(--banner-error-border); --banner-text: var(--banner-error-text); }

html[data-theme="light"] .dashboard-banner { background: linear-gradient(145deg, var(--color-cloud-0), var(--gradient-start)); border-color: color-mix(in srgb, var(--color-slate-400) 35%, transparent); color: var(--text-main); box-shadow: 0 12px 36px color-mix(in srgb, var(--color-ink-800) 8%, transparent); }
html[data-theme="light"] .dashboard-banner__icon { background: color-mix(in srgb, var(--text-muted) 14%, transparent); color: var(--text-main); }
html[data-theme="light"] .dashboard-banner__pill { background: color-mix(in srgb, var(--text-main) 10%, transparent); border-color: color-mix(in srgb, var(--text-muted) 24%, transparent); color: var(--text-main); }

html[data-theme="light"] .dashboard-banner--warning { --banner-bg: var(--banner-warning-bg); --banner-border: var(--banner-warning-border); --banner-text: var(--banner-warning-text); }
html[data-theme="light"] .dashboard-banner--warning .dashboard-banner__icon { background: color-mix(in srgb, var(--banner-warning-border) 28%, transparent); color: var(--banner-warning-text); }
html[data-theme="light"] .dashboard-banner--success { --banner-bg: var(--banner-success-bg); --banner-border: var(--banner-success-border); --banner-text: var(--banner-success-text); }
html[data-theme="light"] .dashboard-banner--success .dashboard-banner__icon { background: color-mix(in srgb, var(--banner-success-border) 28%, transparent); color: var(--banner-success-text); }
html[data-theme="light"] .dashboard-banner--error { --banner-bg: var(--banner-error-bg); --banner-border: var(--banner-error-border); --banner-text: var(--banner-error-text); }
html[data-theme="light"] .dashboard-banner--error .dashboard-banner__icon { background: color-mix(in srgb, var(--banner-error-border) 26%, transparent); color: var(--banner-error-text); }

/* TABLES */
.table-card tr:hover td { background-color: color-mix(in srgb, var(--text-main) 8%, transparent); }

.dashboard-nav-link,
.dashboard-nav-sublink {
  color: var(--text-muted);
  border: 1px solid transparent;
}

.dashboard-nav-link:hover,
.dashboard-nav-sublink:hover {
  color: var(--text-main);
  background-color: color-mix(in srgb, var(--text-main) 8%, transparent);
}

.dashboard-nav-link.nav-active,
.dashboard-nav-sublink.nav-active {
  color: var(--text-main);
  background-color: color-mix(in srgb, var(--text-main) 14%, transparent);
  border: 1px solid var(--border);
}

/* NODES */
.node-table { width: 100%; border-collapse: separate; border-spacing: 0 10px; }

.node-table thead th {
  padding: 10px 12px;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.node-row {
  background: color-mix(in srgb, var(--card) 88%, transparent);
  border: 1px solid var(--border);
  box-shadow: 0 12px 32px color-mix(in srgb, var(--color-ink-800) 35%, transparent);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.node-row:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--text-main) 18%, transparent);
  box-shadow: 0 16px 40px color-mix(in srgb, var(--color-sky-500) 25%, transparent);
}

.node-row td:first-child,
.node-row th:first-child { border-top-left-radius: 14px; border-bottom-left-radius: 14px; }

.node-row td:last-child,
.node-row th:last-child { border-top-right-radius: 14px; border-bottom-right-radius: 14px; }

.node-cell { padding: 14px 12px; vertical-align: middle; }

.node-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px dashed color-mix(in srgb, var(--text-main) 35%, transparent);
  background: color-mix(in srgb, var(--text-main) 5%, transparent);
  color: var(--text-muted);
}

.node-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 140px;
  padding: 9px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  font-weight: 600;
  background: color-mix(in srgb, var(--text-main) 6%, transparent);
}

.node-status__dot { width: 12px; height: 12px; border-radius: 9999px; background: currentColor; box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 20%, transparent); }

.node-status--ready { color: var(--node-ready); border-color: color-mix(in srgb, var(--node-ready) 45%, transparent); background: linear-gradient(135deg, color-mix(in srgb, var(--node-ready) 15%, transparent), color-mix(in srgb, var(--color-emerald-500) 12%, transparent)); }
.node-status--warning { color: var(--node-warning); border-color: color-mix(in srgb, var(--node-warning) 40%, transparent); background: linear-gradient(135deg, color-mix(in srgb, var(--node-warning) 18%, transparent), color-mix(in srgb, var(--color-amber-500) 14%, transparent)); }
.node-status--muted { color: var(--text-muted); border-color: var(--border); background: color-mix(in srgb, var(--text-main) 4%, transparent); }

.node-status--danger { color: color-mix(in srgb, var(--color-rose-500) 85%, transparent); border-color: color-mix(in srgb, var(--color-rose-500) 45%, transparent); background: linear-gradient(135deg, color-mix(in srgb, var(--node-danger) 16%, transparent), color-mix(in srgb, var(--color-rose-600) 14%, transparent)); }

.node-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--text-main) 6%, transparent);
  color: var(--text-main);
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

.node-action:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--text-main) 22%, transparent);
  background: color-mix(in srgb, var(--text-main) 12%, transparent);
}

.node-action--solid {
  color: var(--color-ink-900);
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-cloud-0) 95%, transparent), color-mix(in srgb, var(--color-sky-400) 90%, transparent));
  border: 1px solid color-mix(in srgb, var(--color-sky-400) 80%, transparent);
}

.node-action--danger {
  color: color-mix(in srgb, var(--color-rose-500) 85%, transparent);
  border-color: color-mix(in srgb, var(--node-danger) 45%, transparent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--node-danger) 16%, transparent), color-mix(in srgb, var(--color-rose-600) 14%, transparent));
}

html[data-theme="light"] .node-row { background: var(--color-cloud-0); border-color: var(--border); box-shadow: 0 12px 30px color-mix(in srgb, var(--color-ink-800) 8%, transparent); }

html[data-theme="light"] .node-action--danger { color: var(--color-rose-900); border-color: color-mix(in srgb, var(--color-rose-500) 65%, transparent); background: linear-gradient(135deg, var(--stat-rose-bg), color-mix(in srgb, var(--color-rose-500) 30%, transparent)); }

/* STAT CARDS */
.stat-card {
  position: relative;
  border: 1px solid var(--stat-border);
  background: var(--stat-bg);
  color: var(--stat-text);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}

.stat-card .badge-soft { background: color-mix(in srgb, var(--text-main) 10%, transparent); border: 1px solid var(--border); color: inherit; }

.stat-card[class*="emerald"] { --stat-bg: var(--stat-emerald-bg); --stat-border: var(--stat-emerald-border); --stat-text: var(--stat-emerald-text); }
.stat-card[class*="cyan"],
.stat-card[class*="sky"] { --stat-bg: var(--stat-sky-bg); --stat-border: var(--stat-sky-border); --stat-text: var(--stat-sky-text); }
.stat-card[class*="indigo"],
.stat-card[class*="violet"] { --stat-bg: var(--stat-indigo-bg); --stat-border: var(--stat-indigo-border); --stat-text: var(--stat-indigo-text); }
.stat-card[class*="amber"],
.stat-card[class*="orange"] { --stat-bg: var(--stat-amber-bg); --stat-border: var(--stat-amber-border); --stat-text: var(--stat-amber-text); }
.stat-card[class*="rose"],
.stat-card[class*="red"] { --stat-bg: var(--stat-rose-bg); --stat-border: var(--stat-rose-border); --stat-text: var(--stat-rose-text); }
.stat-card[class*="slate"] { --stat-bg: var(--stat-slate-bg); --stat-border: var(--stat-slate-border); --stat-text: var(--stat-slate-text); }

/* OVERRIDES TAILWIND */
/* Tailwind utility remaps are declared in app/public/css/tailwind-overrides.css to avoid collisions. */

/* UTILITIES */
.step-card { position: relative; transition: transform 0.15s ease, opacity 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background-color 0.15s ease; }
.step-card.dragging { opacity: 0.92; transform: scale(1.01); box-shadow: 0 18px 38px color-mix(in srgb, var(--node-focus) 28%, transparent); border-color: color-mix(in srgb, var(--node-focus) 55%, transparent); background: linear-gradient(135deg, color-mix(in srgb, var(--node-focus) 16%, transparent), color-mix(in srgb, var(--color-indigo-600) 12%, transparent)); }
.step-card.drop-target { background: color-mix(in srgb, var(--color-cloud-0) 50%, transparent); border-color: color-mix(in srgb, var(--color-rose-500) 40%, transparent); box-shadow: 0 14px 30px color-mix(in srgb, var(--color-rose-500) 22%, transparent); }
.step-card.drop-target::before { content: ''; position: absolute; left: 16px; right: 16px; top: -4px; height: 4px; border-radius: 9999px; background: linear-gradient(90deg, var(--color-rose-500), var(--color-indigo-500)); box-shadow: 0 12px 25px color-mix(in srgb, var(--color-rose-500) 28%, transparent); pointer-events: none; }

.step-handle { border: 1px dashed color-mix(in srgb, var(--text-main) 30%, transparent); background: linear-gradient(135deg, color-mix(in srgb, var(--color-cloud-0) 10%, transparent), color-mix(in srgb, var(--color-indigo-500) 12%, transparent)); box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-cloud-0) 15%, transparent); transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease; }
.step-handle:hover,
.step-handle:focus-visible { transform: scale(1.05); background: linear-gradient(135deg, color-mix(in srgb, var(--color-indigo-500) 22%, transparent), color-mix(in srgb, var(--node-focus) 18%, transparent)); box-shadow: 0 10px 24px color-mix(in srgb, var(--node-focus) 28%, transparent); }
.step-handle:focus-visible { outline: 2px solid color-mix(in srgb, var(--color-indigo-500) 60%, transparent); outline-offset: 2px; }
.step-card.dragging .step-handle { cursor: grabbing; }

.steps-toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--color-emerald-500) 40%, transparent);
  background: linear-gradient(135deg, var(--toast-success-bg), var(--toast-success-highlight));
  color: var(--toast-success-text);
  box-shadow: 0 18px 40px color-mix(in srgb, var(--color-emerald-600) 28%, transparent);
  backdrop-filter: blur(10px);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease;
  z-index: 30;
}

.steps-toast.is-visible { opacity: 1; transform: translateY(0); }

.theme-text { color: var(--text-main); }
.theme-muted { color: var(--text-muted); }
