/* Automatiza — Dark mode design tokens (v2) */
:root {
  /* ===== Swappable accent tokens (see __applyAccent in Automatiza.html) =====
     All brand-colored surfaces in the app route through these. Changing the
     accent palette in Tweaks only needs to rewrite these — no component edits. */
  --accent-1: #8b5cf6;            /* primary solid (buttons, focus rings) */
  --accent-2: #6366f1;            /* mid stop */
  --accent-3: #3b82f6;            /* secondary solid / gradient tail */
  --accent-text: #c4b5fd;         /* accessible tint on dark bg (WCAG AA) */
  --accent-text-2: #a78bfa;       /* alternate accessible tint */
  --accent-rgb: 139,92,246;       /* used in rgba(var(--accent-rgb), a) */
  --accent-rgb-2: 99,102,241;     /* mid-stop rgb (for glows) */
  --accent-soft-08: rgba(139,92,246,.08);
  --accent-soft-10: rgba(139,92,246,.10);
  --accent-soft-14: rgba(139,92,246,.14);
  --accent-soft-20: rgba(139,92,246,.20);
  --accent-soft-30: rgba(139,92,246,.30);
  --accent-soft-40: rgba(139,92,246,.40);
  --accent-soft-55: rgba(139,92,246,.55);
  --accent-glow: 0 8px 32px -4px rgba(99,102,241,.4);

  /* Brand aliases (legacy names, still theme-swappable) */
  --brand-purple: var(--accent-1);
  --brand-blue: var(--accent-3);
  --brand-violet: var(--accent-1);
  --brand-indigo: var(--accent-2);
  --brand-cyan: var(--accent-3);
  --brand-gradient: linear-gradient(135deg, var(--accent-1) 0%, var(--accent-2) 40%, var(--accent-3) 100%);
  --brand-gradient-soft: linear-gradient(135deg, rgba(var(--accent-rgb),.15) 0%, rgba(var(--accent-rgb-2),.15) 100%);
  --brand-gradient-text: linear-gradient(135deg, var(--accent-text-2) 0%, var(--accent-text) 50%, #93c5fd 100%);

  /* Dark surface scale */
  --bg-base: #07060f;        /* page deep */
  --bg-1: #0c0b1a;           /* primary surface */
  --bg-2: #13132a;           /* cards */
  --bg-3: #1b1b36;           /* raised card / hover */
  --bg-4: #242449;           /* border-ish fills */
  --bg-glass: rgba(26,26,46,.72);
  --bg-glass-strong: rgba(20,20,40,.88);

  /* Lines */
  --line-1: rgba(255,255,255,.06);
  --line-2: rgba(255,255,255,.10);
  --line-3: rgba(255,255,255,.16);
  --line-focus: var(--accent-soft-55);

  /* Text */
  --text-0: #ffffff;
  --text-1: #e7e7f0;
  --text-2: #b6b6cc;
  --text-3: #8787a3;
  --text-4: #5f5f7a;
  --text-5: #3e3e52;

  /* Light surface (used in some overlays/sidebar) */
  --paper: #ffffff;
  --light-1: #f5f5fa;
  --light-2: #ebebf2;
  --light-ink-1: #14141f;
  --light-ink-2: #4a4a66;

  /* Semantic */
  --green: #22c55e;
  --green-soft: rgba(34,197,94,.14);
  --green-glow: rgba(34,197,94,.35);
  --red: #ef4444;
  --red-soft: rgba(239,68,68,.14);
  --red-glow: rgba(239,68,68,.35);
  --amber: #f59e0b;
  --amber-soft: rgba(245,158,11,.14);
  --coral: #fb7185;
  --coral-soft: rgba(251,113,133,.14);

  /* Type */
  --font-sans: 'Inter', 'Söhne', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Cascadia Code', Consolas, monospace;
  --font-display: 'Inter', 'Söhne', -apple-system, sans-serif;

  /* Radii */
  --r-xs: 6px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-2xl: 28px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,.25);
  --shadow-md: 0 8px 24px -6px rgba(0,0,0,.4), 0 2px 6px rgba(0,0,0,.2);
  --shadow-lg: 0 24px 60px -12px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.25);
  --shadow-glow: 0 0 0 1px var(--accent-soft-30), var(--accent-glow);
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  color: var(--text-1);
  background: var(--bg-base);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'ss01','cv11';
  line-height: 1.5;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea, select { font-family: inherit; }
a { color: inherit; text-decoration: none; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--line-3); border-radius: 8px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.28); background-clip: padding-box; border: 2px solid transparent; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 18px; border-radius: 10px; font-weight: 500; font-size: 14px;
  transition: all .15s ease; white-space: nowrap;
  border: 1px solid transparent;
}
.btn-primary {
  background: var(--brand-gradient); color: white;
  box-shadow: 0 8px 24px -8px rgba(var(--accent-rgb-2),.6), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 12px 28px -8px rgba(var(--accent-rgb-2),.7), inset 0 1px 0 rgba(255,255,255,.15); }
.btn-ghost { color: var(--text-1); }
.btn-ghost:hover { background: var(--bg-3); }
.btn-outline {
  border-color: var(--line-3); color: var(--text-1); background: transparent;
}
.btn-outline:hover { border-color: var(--text-3); background: var(--bg-2); }
.btn-light {
  background: var(--paper); color: var(--light-ink-1);
}
.btn-light:hover { background: var(--light-1); }

/* Chips */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 500;
  background: var(--bg-3); color: var(--text-2); border: 1px solid var(--line-2);
}
.chip-brand { background: var(--brand-gradient-soft); color: var(--accent-text); border-color: var(--accent-soft-30); }
.chip-green { background: var(--green-soft); color: #86efac; border-color: rgba(34,197,94,.25); }
.chip-red { background: var(--red-soft); color: #fca5a5; border-color: rgba(239,68,68,.25); }
.chip-amber { background: var(--amber-soft); color: #fcd34d; border-color: rgba(245,158,11,.25); }
.chip-coral { background: var(--coral-soft); color: #fda4af; border-color: rgba(251,113,133,.25); }

/* Cards */
.card {
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}

/* Wordmark (brand) */
.wordmark {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 18px; letter-spacing: -0.02em;
}
.wordmark-mark {
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--brand-gradient);
  display: grid; place-items: center; color: white; font-weight: 700;
  box-shadow: 0 4px 12px -2px rgba(var(--accent-rgb-2),.55), inset 0 1px 0 rgba(255,255,255,.25);
  position: relative;
  flex-shrink: 0;
}
.wordmark-mark svg {
  stroke: white; stroke-width: 2.2; fill: none;
}
.wordmark-text {
  background: var(--brand-gradient-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}

/* Gradient text utility */
.grad-text {
  background: var(--brand-gradient-text);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  /* white-space: nowrap; */
}

/* Focus */
.focus-ring:focus-visible { outline: 2px solid var(--brand-violet); outline-offset: 2px; }
input:focus-visible, select:focus-visible, textarea:focus-visible, button:focus-visible {
  outline: none; box-shadow: 0 0 0 3px var(--line-focus);
}

/* Page transitions */
.fade-in { animation: fadeIn .4s ease both; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* Glow background */
.glow-bg {
  position: relative; overflow: hidden;
}
.glow-bg::before {
  content: ''; position: absolute; pointer-events: none;
  top: -20%; right: -10%; width: 720px; height: 720px; border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--accent-rgb),.18), transparent 60%);
  filter: blur(20px);
}
.glow-bg::after {
  content: ''; position: absolute; pointer-events: none;
  bottom: -30%; left: -10%; width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--accent-rgb-2),.16), transparent 60%);
  filter: blur(20px);
}

/* Utility */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Responsive visibility helpers */
@media (max-width: 900px) {
  .hide-mobile { display: none !important; }
}
@media (min-width: 901px) {
  .show-mobile { display: none !important; }
}

/* Common responsive container */
.container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
@media (max-width: 640px) { .container { padding: 0 16px; } }

/* ==========================================================================
   Legacy token compat layer — remaps old coral/ink/blue/amber/green/red tokens
   onto dark surface + violet/blue brand. Any component that still uses
   var(--ink-*), var(--coral-*), etc. will now render correctly on dark.
   ========================================================================== */
:root {
  /* Ink (was light-mode gray scale) → dark surface + dim text */
  --ink-50: var(--bg-2);
  --ink-100: var(--bg-3);
  --ink-200: var(--line-2);
  --ink-300: var(--line-3);
  --ink-400: var(--text-4);
  --ink-500: var(--text-3);
  --ink-600: var(--text-2);
  --ink-700: var(--text-1);
  --ink-800: var(--text-1);
  --ink-900: var(--text-0);

  /* Coral (was brand) → swappable accent brand */
  --coral-50: var(--accent-soft-10);
  --coral-100: var(--accent-soft-14);
  --coral-200: rgba(var(--accent-rgb),.22);
  --coral-300: rgba(var(--accent-rgb),.35);
  --coral-400: var(--accent-soft-55);
  --coral-500: var(--accent-1);
  --coral-600: var(--accent-text-2);
  --coral-700: var(--accent-text);
  --coral-800: #ddd6fe;

  /* Semantic scales */
  --blue-50: rgba(59,130,246,.10);
  --blue-100: rgba(59,130,246,.16);
  --blue-400: #60a5fa;
  --blue-500: #3b82f6;
  --blue-600: #93c5fd;
  --blue-700: #bfdbfe;

  --green-50: rgba(34,197,94,.10);
  --green-100: rgba(34,197,94,.16);
  --green-400: #4ade80;
  --green-500: #22c55e;
  --green-600: #86efac;
  --green-700: #bbf7d0;

  --red-50: rgba(239,68,68,.10);
  --red-100: rgba(239,68,68,.16);
  --red-400: #f87171;
  --red-500: #ef4444;
  --red-600: #fca5a5;
  --red-700: #fecaca;

  --amber-50: rgba(245,158,11,.10);
  --amber-100: rgba(245,158,11,.16);
  --amber-400: #fbbf24;
  --amber-500: #f59e0b;
  --amber-600: #fcd34d;
  --amber-700: #fde68a;
}

/* Legacy components used `background: white` or `background: #fff` literally.
   Override hardcoded whites inside scoped containers so they pick up dark surface. */
.crm-detail, .crm-metric, .kanban-col-count, .lead-card,
.onboarding-card, .step-preview, .step-form-card {
  color: var(--text-1);
}
.lead-card { background: var(--bg-2) !important; border-color: var(--line-1) !important; }
.lead-card:hover { border-color: var(--brand-violet) !important; box-shadow: 0 0 0 1px var(--accent-soft-40) !important; }
.lead-card.selected { border-color: var(--brand-violet) !important; box-shadow: 0 0 0 2px var(--accent-soft-40) !important; }
.crm-metric { background: var(--bg-2) !important; border-color: var(--line-1) !important; color: var(--text-2); }
.crm-metric b { color: var(--text-0) !important; }
.kanban-col-count { background: var(--bg-1) !important; color: var(--text-2) !important; border: 1px solid var(--line-2); }
.kanban-col { background: var(--bg-2) !important; border: 1px solid var(--line-1); }
.crm-detail { background: var(--bg-1) !important; border-left-color: var(--line-1) !important; }
.crm-filter { background: var(--bg-2) !important; border-color: var(--line-2) !important; color: var(--text-1) !important; }
.crm-filter:hover { border-color: var(--line-3) !important; }
.crm-filter.active { background: var(--accent-soft-14) !important; border-color: var(--brand-violet) !important; color: var(--accent-text) !important; }
.detail-tab.active { color: var(--accent-text) !important; border-color: var(--brand-violet) !important; }
.lead-value { color: var(--text-0) !important; }
.lead-name { color: var(--text-1); }
.detail-name { color: var(--text-0); }
.detail-meta-item b { color: var(--text-0) !important; }
.timeline-text { color: var(--text-1) !important; }
.timeline-text b { color: var(--text-0); }

/* Onboarding dark — target actual classnames used in onboarding.jsx */
.onb-header { background: var(--bg-1) !important; border-bottom-color: var(--line-1) !important; }
.onb-stepper { background: var(--bg-2) !important; border-color: var(--line-1) !important; color: var(--text-1); }
.onb-card { background: var(--bg-2) !important; border-color: var(--line-1) !important; color: var(--text-1); }
.onb-card h2 { color: var(--text-0); }
.onb-card em { color: var(--accent-text); font-style: normal; }
.onb-card-sub { color: var(--text-2) !important; }
.onb-progress-bar { background: var(--bg-3) !important; }
.onb-progress-fill { background: var(--brand-gradient) !important; }
.onb-step:hover { background: var(--bg-3) !important; }
.onb-step.active { background: var(--accent-soft-14) !important; }
.onb-step-num { background: var(--bg-3) !important; color: var(--text-3) !important; }
.onb-step.active .onb-step-num { background: var(--brand-violet) !important; box-shadow: 0 0 0 4px var(--accent-soft-20) !important; }
.onb-step.done .onb-step-num { background: var(--green) !important; }
.onb-step-title { color: var(--text-0) !important; }
.onb-step.active .onb-step-title { color: var(--accent-text) !important; }
.onb-step-sub { color: var(--text-3) !important; font-size: 12px; }
.onb-badge { background: var(--accent-soft-14) !important; color: var(--accent-text) !important; }
.field label { color: var(--text-2); font-size: 13px; font-weight: 500; display: block; margin-bottom: 6px; }
.field input, .field select, .field-row input {
  background: var(--bg-1) !important;
  border-color: var(--line-2) !important;
  color: var(--text-1) !important;
}
.field input::placeholder, .field select::placeholder { color: var(--text-4) !important; }
.field input:focus, .field select:focus { border-color: var(--brand-violet) !important; box-shadow: 0 0 0 3px var(--accent-soft-20) !important; }
.field-hint { color: var(--text-3) !important; font-size: 12px; margin-top: 6px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.import-option, .integ-option {
  background: var(--bg-1) !important;
  border-color: var(--line-2) !important;
  color: var(--text-1);
}
.import-option:hover, .integ-option:hover { border-color: var(--line-3) !important; }
.import-option.selected, .integ-option.selected {
  background: var(--accent-soft-10) !important;
  border-color: var(--brand-violet) !important;
}
.import-radio, .integ-check { border-color: var(--line-3) !important; }
.import-option.selected .import-radio, .integ-option.selected .integ-check {
  background: var(--brand-violet) !important; border-color: var(--brand-violet) !important;
}
.import-option-desc { color: var(--text-2) !important; }
.dropzone { background: var(--bg-1) !important; border-color: var(--line-3) !important; color: var(--text-2); }
.wordmark-dot {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--brand-gradient); color: white;
  display: grid; place-items: center; font-weight: 700;
  box-shadow: 0 4px 12px -2px rgba(var(--accent-rgb-2),.55);
}
.success-icon { background: var(--brand-gradient) !important; box-shadow: 0 12px 32px -4px rgba(var(--accent-rgb-2),.4) !important; }

/* Onboarding page background */
[data-screen-label="05 Onboarding"] { background: var(--bg-base) !important; }

/* ===== Smooth accent palette transitions =====
   Any themed surface animates when __applyAccent updates the tokens. */
:root {
  transition: --accent-1 220ms ease, --accent-2 220ms ease, --accent-3 220ms ease;
}
body,
.btn, .btn-primary, .btn-outline, .btn-ghost,
.chip, .chip-brand,
.avatar, .wordmark-dot, .success-icon,
.tile, .lead-card, .crm-filter, .crm-metric,
.onb-card, .onb-step, .onb-step-num, .onb-badge,
.import-option, .integ-option,
input, select, textarea,
[class*="sidebar"] [class*="active"],
[class*="nav"] [class*="active"] {
  transition: background-color 220ms ease,
              background 220ms ease,
              border-color 220ms ease,
              color 220ms ease,
              box-shadow 220ms ease,
              fill 220ms ease,
              stroke 220ms ease;
}

