/* ============================================================
   WORKFLOW OPS — Design System Tokens
   Inspiração: n8n (canvas/coral) + SendFlow/DevZapp (verde WA, dataviz)
   Tom: dark engineering, denso, operacional, terminal-like
   ============================================================ */

/* ───────────── FONTS ───────────── */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700;800&family=Geist:wght@300;400;500;600;700;800&family=Geist+Mono:wght@400;500;600&display=swap');

:root {
  /* ───────── SURFACES (dark) ─────────
     L0 = void; L1 = canvas; L2 = card; L3 = elevated; L4 = popover */
  --surface-0: #0A0B0F;
  --surface-1: #0F1116;
  --surface-2: #161922;
  --surface-3: #1E222D;
  --surface-4: #262B38;
  --surface-overlay: rgba(10, 11, 15, 0.72);

  /* hairline borders */
  --border-subtle: rgba(255, 255, 255, 0.06);
  --border-default: rgba(255, 255, 255, 0.10);
  --border-strong: rgba(255, 255, 255, 0.18);
  --border-focus: var(--accent);

  /* ───────── INK (text) ───────── */
  --ink-100: #F4F5F7;   /* primary text */
  --ink-80:  #C9CCD4;   /* secondary */
  --ink-60:  #8B909C;   /* tertiary */
  --ink-40:  #5A5F6B;   /* disabled / hint */
  --ink-20:  #363943;   /* placeholder bg */

  /* ───────── ACCENT (n8n coral) ─────────
     Cor de marca / actions primárias / nodes do canvas */
  --accent:        #FF6D5A;
  --accent-hover:  #FF8773;
  --accent-active: #E5523F;
  --accent-soft:   rgba(255, 109, 90, 0.12);
  --accent-glow:   rgba(255, 109, 90, 0.32);
  --accent-on:     #0A0B0F; /* texto sobre accent */

  /* ───────── SECONDARY (WhatsApp green) ─────────
     Estados de conexão WA, badges de entrega, mensagens vivas */
  --wa:            #25D366;
  --wa-hover:      #34E37B;
  --wa-active:     #1FB857;
  --wa-soft:       rgba(37, 211, 102, 0.12);
  --wa-glow:       rgba(37, 211, 102, 0.32);
  --wa-on:         #062313;

  /* ───────── SEMANTIC ───────── */
  --success:       #22C55E;
  --success-soft:  rgba(34, 197, 94, 0.12);
  --warning:       #F5A524;
  --warning-soft:  rgba(245, 165, 36, 0.14);
  --danger:        #EF4444;
  --danger-soft:   rgba(239, 68, 68, 0.14);
  --info:          #5FA8FF;
  --info-soft:     rgba(95, 168, 255, 0.14);

  /* ───────── NODE / FLOW PALETTE
     Cores para nós do canvas (estilo n8n), badges, categorias */
  --node-trigger:   #FF6D5A;  /* gatilho */
  --node-action:    #5FA8FF;  /* ação http/api */
  --node-logic:     #B991FF;  /* if/switch/loop */
  --node-data:      #FFD166;  /* transform/code */
  --node-ai:        #14E4C4;  /* IA / OpenAI */
  --node-wa:        #25D366;  /* WhatsApp/Evolution */
  --node-db:        #F472B6;  /* database/storage */
  --node-mute:      #5A5F6B;  /* desativado */

  /* ───────── TYPOGRAPHY ───────── */
  --font-sans: 'Geist', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Geist Mono', ui-monospace, monospace;

  /* Scale (compacto, denso, orientado a tela operacional) */
  --fs-2xs: 10px;   --lh-2xs: 14px;
  --fs-xs:  11px;   --lh-xs:  16px;
  --fs-sm:  12px;   --lh-sm:  18px;
  --fs-md:  13px;   --lh-md:  20px;  /* base de UI */
  --fs-lg:  15px;   --lh-lg:  22px;
  --fs-xl:  18px;   --lh-xl:  26px;
  --fs-2xl: 22px;   --lh-2xl: 30px;
  --fs-3xl: 28px;   --lh-3xl: 36px;
  --fs-4xl: 40px;   --lh-4xl: 48px;
  --fs-5xl: 56px;   --lh-5xl: 60px;

  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semi:    600;
  --fw-bold:    700;
  --fw-black:   800;

  --tracking-tight:  -0.02em;
  --tracking-normal: 0;
  --tracking-wide:    0.04em;
  --tracking-mono:    0.01em;
  --tracking-caps:    0.12em;

  /* ───────── SPACING (4px base) ───────── */
  --s-0:  0;
  --s-1:  2px;
  --s-2:  4px;
  --s-3:  6px;
  --s-4:  8px;
  --s-5:  12px;
  --s-6:  16px;
  --s-7:  20px;
  --s-8:  24px;
  --s-9:  32px;
  --s-10: 40px;
  --s-11: 48px;
  --s-12: 64px;
  --s-13: 80px;
  --s-14: 96px;

  /* ───────── RADIUS ─────────
     Conservador. Operacional. Nada de "pílulas". */
  --r-0:   0;
  --r-1:   2px;
  --r-2:   4px;   /* botões, inputs */
  --r-3:   6px;
  --r-4:   8px;   /* cards */
  --r-5:   10px;
  --r-6:   12px;  /* containers maiores */
  --r-full: 999px;

  /* ───────── ELEVATION
     Sombras sutis. No dark, glow ≫ shadow. */
  --el-1: 0 1px 0 0 rgba(255,255,255,0.03) inset, 0 1px 2px rgba(0,0,0,0.4);
  --el-2: 0 1px 0 0 rgba(255,255,255,0.04) inset, 0 4px 12px rgba(0,0,0,0.5);
  --el-3: 0 1px 0 0 rgba(255,255,255,0.05) inset, 0 12px 32px rgba(0,0,0,0.6);
  --el-pop: 0 1px 0 0 rgba(255,255,255,0.06) inset, 0 20px 60px rgba(0,0,0,0.7), 0 0 0 1px var(--border-default);

  --glow-accent: 0 0 0 4px var(--accent-soft), 0 0 24px var(--accent-glow);
  --glow-wa:     0 0 0 4px var(--wa-soft), 0 0 24px var(--wa-glow);
  --glow-focus:  0 0 0 3px var(--accent-soft);

  /* ───────── MOTION ───────── */
  --ease-out-quad:    cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-quart:   cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-expo:    cubic-bezier(0.19, 1, 0.22, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);

  --t-instant: 80ms;
  --t-fast:    140ms;
  --t-base:    220ms;
  --t-slow:    420ms;

  /* ───────── Z-INDEX ───────── */
  --z-base: 1;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-overlay: 400;
  --z-modal: 500;
  --z-popover: 600;
  --z-toast: 700;
  --z-tooltip: 800;

  /* ───────── LAYOUT ───────── */
  --sidebar-w: 224px;
  --sidebar-w-collapsed: 56px;
  --topbar-h: 48px;
  --statusbar-h: 28px;
  --container-max: 1440px;

  /* ───────── CANVAS (dots grid background) ───────── */
  --canvas-bg: var(--surface-1);
  --canvas-dot: rgba(255,255,255,0.06);
  --canvas-dot-size: 1.5px;
  --canvas-grid-gap: 24px;
}

/* ============================================================
   BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--surface-0);
  color: var(--ink-100);
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  line-height: var(--lh-md);
  font-weight: var(--fw-regular);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
}

::selection {
  background: var(--accent);
  color: var(--accent-on);
}

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.t-display {
  font-family: var(--font-sans);
  font-size: var(--fs-5xl);
  line-height: var(--lh-5xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--tracking-tight);
}
.t-h1 { font-size: var(--fs-4xl); line-height: var(--lh-4xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.t-h2 { font-size: var(--fs-3xl); line-height: var(--lh-3xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.t-h3 { font-size: var(--fs-2xl); line-height: var(--lh-2xl); font-weight: var(--fw-semi); letter-spacing: var(--tracking-tight); }
.t-h4 { font-size: var(--fs-xl); line-height: var(--lh-xl); font-weight: var(--fw-semi); }
.t-body { font-size: var(--fs-md); line-height: var(--lh-md); }
.t-body-lg { font-size: var(--fs-lg); line-height: var(--lh-lg); }
.t-small { font-size: var(--fs-sm); line-height: var(--lh-sm); }
.t-mono { font-family: var(--font-mono); letter-spacing: var(--tracking-mono); }

/* "kicker" / over-line / system caps — assinatura visual */
.t-kicker {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--ink-60);
}

.t-kicker-accent {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--accent);
}

.t-muted { color: var(--ink-60); }
.t-dim   { color: var(--ink-40); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-3);
  height: 32px;
  padding: 0 var(--s-5);
  border-radius: var(--r-2);
  border: 1px solid transparent;
  background: transparent;
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--ink-100);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition: background var(--t-fast) var(--ease-out-quad),
              border-color var(--t-fast) var(--ease-out-quad),
              color var(--t-fast) var(--ease-out-quad),
              box-shadow var(--t-fast) var(--ease-out-quad),
              transform var(--t-instant) var(--ease-out-quad);
}
.btn:focus-visible { outline: none; box-shadow: var(--glow-focus); }
.btn:active        { transform: translateY(1px); }

.btn-primary {
  background: var(--accent);
  color: var(--accent-on);
  border-color: var(--accent);
}
.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.btn-primary:active { background: var(--accent-active); }

.btn-wa {
  background: var(--wa);
  color: var(--wa-on);
  border-color: var(--wa);
}
.btn-wa:hover { background: var(--wa-hover); border-color: var(--wa-hover); }

.btn-secondary {
  background: var(--surface-3);
  border-color: var(--border-default);
  color: var(--ink-100);
}
.btn-secondary:hover { background: var(--surface-4); border-color: var(--border-strong); }

.btn-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--ink-80);
}
.btn-ghost:hover { background: var(--surface-3); color: var(--ink-100); }

.btn-outline {
  background: transparent;
  border-color: var(--border-default);
  color: var(--ink-100);
}
.btn-outline:hover { background: var(--surface-3); border-color: var(--border-strong); }

.btn-danger {
  background: var(--danger);
  color: white;
  border-color: var(--danger);
}
.btn-danger:hover { filter: brightness(1.1); }

.btn-sm { height: 26px; padding: 0 var(--s-4); font-size: var(--fs-sm); border-radius: var(--r-1); }
.btn-lg { height: 40px; padding: 0 var(--s-6); font-size: var(--fs-lg); }
.btn-icon { width: 32px; padding: 0; }
.btn-icon.btn-sm { width: 26px; }

/* ============================================================
   INPUTS
   ============================================================ */
.input,
.textarea,
.select {
  width: 100%;
  height: 32px;
  padding: 0 var(--s-4);
  background: var(--surface-2);
  border: 1px solid var(--border-default);
  border-radius: var(--r-2);
  color: var(--ink-100);
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  line-height: 1;
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.input::placeholder, .textarea::placeholder { color: var(--ink-40); }
.input:hover, .textarea:hover, .select:hover { border-color: var(--border-strong); }
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: var(--glow-focus);
  background: var(--surface-1);
}
.textarea { height: auto; padding: var(--s-4); line-height: var(--lh-md); min-height: 96px; resize: vertical; }

.input-mono { font-family: var(--font-mono); font-size: var(--fs-sm); }

.label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--ink-60);
  margin-bottom: var(--s-3);
}

.helper {
  margin-top: var(--s-2);
  font-size: var(--fs-xs);
  color: var(--ink-60);
}
.helper.is-error { color: var(--danger); }

/* Field group */
.field { display: flex; flex-direction: column; }

/* ============================================================
   CARDS / SURFACES
   ============================================================ */
.card {
  background: var(--surface-2);
  border: 1px solid var(--border-default);
  border-radius: var(--r-4);
  padding: var(--s-7);
  box-shadow: var(--el-1);
}
.card-flush { padding: 0; }
.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
  padding: var(--s-5) var(--s-6);
  border-bottom: 1px solid var(--border-subtle);
}
.card-body { padding: var(--s-6); }

.panel {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--r-4);
}

/* ============================================================
   BADGES / CHIPS / STATUS PILLS
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  height: 20px;
  padding: 0 var(--s-3);
  border-radius: var(--r-2);
  background: var(--surface-3);
  color: var(--ink-80);
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  border: 1px solid var(--border-subtle);
}
.badge-success { background: var(--success-soft); color: var(--success); border-color: rgba(34,197,94,0.24); }
.badge-warning { background: var(--warning-soft); color: var(--warning); border-color: rgba(245,165,36,0.24); }
.badge-danger  { background: var(--danger-soft);  color: var(--danger);  border-color: rgba(239,68,68,0.24); }
.badge-info    { background: var(--info-soft);    color: var(--info);    border-color: rgba(95,168,255,0.24); }
.badge-accent  { background: var(--accent-soft);  color: var(--accent);  border-color: rgba(255,109,90,0.24); }
.badge-wa      { background: var(--wa-soft);      color: var(--wa);      border-color: rgba(37,211,102,0.24); }

/* Status dot (connection indicator) */
.dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ink-40);
  flex-shrink: 0;
}
.dot-live {
  background: var(--wa);
  box-shadow: 0 0 0 0 var(--wa-glow);
  animation: pulse 2s var(--ease-out-quad) infinite;
}
.dot-warning { background: var(--warning); }
.dot-danger  { background: var(--danger); }
.dot-offline { background: var(--ink-40); }

@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 var(--wa-glow); }
  70%  { box-shadow: 0 0 0 8px rgba(37,211,102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37,211,102, 0); }
}

/* ============================================================
   TABLES (densas, operacionais)
   ============================================================ */
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--fs-sm);
}
.table th {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--ink-60);
  text-align: left;
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border-default);
  background: var(--surface-1);
  position: sticky;
  top: 0;
}
.table td {
  padding: var(--s-5);
  border-bottom: 1px solid var(--border-subtle);
  color: var(--ink-100);
  vertical-align: middle;
}
.table tr:hover td { background: var(--surface-3); }
.table .num { font-family: var(--font-mono); text-align: right; font-variant-numeric: tabular-nums; }

/* ============================================================
   CANVAS (n8n-style dots grid)
   ============================================================ */
.canvas {
  position: relative;
  background-color: var(--canvas-bg);
  background-image: radial-gradient(var(--canvas-dot) var(--canvas-dot-size), transparent var(--canvas-dot-size));
  background-size: var(--canvas-grid-gap) var(--canvas-grid-gap);
  background-position: 0 0;
}

/* Node card (workflow node) */
.node {
  display: inline-flex;
  flex-direction: column;
  min-width: 200px;
  background: var(--surface-2);
  border: 1px solid var(--border-default);
  border-radius: var(--r-4);
  overflow: hidden;
  box-shadow: var(--el-2);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}
.node:hover {
  border-color: var(--border-strong);
  transform: translateY(-1px);
  box-shadow: var(--el-3);
}
.node-head {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border-subtle);
}
.node-icon {
  width: 24px; height: 24px;
  border-radius: var(--r-1);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: var(--fw-bold);
  color: var(--surface-0);
  flex-shrink: 0;
}
.node-title { font-weight: var(--fw-semi); font-size: var(--fs-md); }
.node-body { padding: var(--s-5); }
.node-foot {
  padding: var(--s-3) var(--s-5);
  border-top: 1px solid var(--border-subtle);
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--ink-60);
  display: flex; justify-content: space-between;
}

/* Node accent variants */
.node-trigger .node-icon { background: var(--node-trigger); }
.node-action  .node-icon { background: var(--node-action); color: white; }
.node-logic   .node-icon { background: var(--node-logic); color: white; }
.node-data    .node-icon { background: var(--node-data); }
.node-ai      .node-icon { background: var(--node-ai); }
.node-wa      .node-icon { background: var(--node-wa); color: white; }
.node-db      .node-icon { background: var(--node-db); color: white; }

.node-trigger { border-left: 3px solid var(--node-trigger); }
.node-action  { border-left: 3px solid var(--node-action); }
.node-logic   { border-left: 3px solid var(--node-logic); }
.node-data    { border-left: 3px solid var(--node-data); }
.node-ai      { border-left: 3px solid var(--node-ai); }
.node-wa      { border-left: 3px solid var(--node-wa); }
.node-db      { border-left: 3px solid var(--node-db); }

/* ============================================================
   METRIC TILE (KPI)
   ============================================================ */
.metric {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-6);
  background: var(--surface-2);
  border: 1px solid var(--border-default);
  border-radius: var(--r-4);
  position: relative;
  overflow: hidden;
}
.metric-label {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--ink-60);
  display: flex; align-items: center; gap: var(--s-2);
}
.metric-value {
  font-family: var(--font-sans);
  font-size: var(--fs-3xl);
  line-height: 1;
  font-weight: var(--fw-bold);
  color: var(--ink-100);
  letter-spacing: var(--tracking-tight);
  font-variant-numeric: tabular-nums;
}
.metric-delta {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
}
.metric-delta.is-up   { color: var(--success); }
.metric-delta.is-down { color: var(--danger); }

/* ============================================================
   TOAST / NOTIFICATION
   ============================================================ */
.toast {
  display: flex;
  align-items: flex-start;
  gap: var(--s-4);
  padding: var(--s-5);
  background: var(--surface-3);
  border: 1px solid var(--border-default);
  border-left-width: 3px;
  border-radius: var(--r-4);
  box-shadow: var(--el-pop);
  max-width: 360px;
}
.toast-success { border-left-color: var(--success); }
.toast-warning { border-left-color: var(--warning); }
.toast-danger  { border-left-color: var(--danger); }
.toast-info    { border-left-color: var(--info); }

/* ============================================================
   CODE BLOCK
   ============================================================ */
.code {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.65;
  background: var(--surface-1);
  color: var(--ink-100);
  border: 1px solid var(--border-default);
  border-radius: var(--r-4);
  padding: var(--s-5);
  overflow: auto;
  white-space: pre;
}
.code .k { color: var(--accent); }                  /* keyword */
.code .s { color: var(--wa); }                       /* string */
.code .n { color: var(--info); }                     /* number */
.code .c { color: var(--ink-40); font-style: italic; } /* comment */
.code .p { color: var(--ink-60); }                   /* punctuation */

/* inline code */
.kbd {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--surface-3);
  border: 1px solid var(--border-default);
  border-bottom-width: 2px;
  padding: 1px 6px;
  border-radius: var(--r-1);
  color: var(--ink-100);
}

/* ============================================================
   SCROLLBAR (custom, sutil)
   ============================================================ */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
  background: var(--surface-4);
  border-radius: var(--r-full);
  border: 2px solid var(--surface-0);
}
*::-webkit-scrollbar-thumb:hover { background: var(--ink-40); }

/* ============================================================
   HELPER UTILITIES
   ============================================================ */
.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.gap-1 { gap: var(--s-2); }
.gap-2 { gap: var(--s-4); }
.gap-3 { gap: var(--s-5); }
.gap-4 { gap: var(--s-6); }
.gap-5 { gap: var(--s-7); }
.gap-6 { gap: var(--s-8); }
.gap-8 { gap: var(--s-10); }

.grow { flex: 1 1 auto; }
.shrink-0 { flex-shrink: 0; }

.divider {
  height: 1px;
  background: var(--border-subtle);
  width: 100%;
}
.divider-v {
  width: 1px;
  background: var(--border-subtle);
  align-self: stretch;
}
