/* ============================================================================
   components.css — componentes do Design System usados na LP.
   DERIVADO fielmente de docs/design-system/styles.css. Nenhuma cor/fonte nova:
   tudo consome os tokens. É a fonte da verdade visual que o app Next vai espelhar.
   ============================================================================ */

/* --------------------------------------------------------------------------
   Botões — reto-ish (4px), denso, dev-nativo
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-height: 48px; padding: 0 var(--space-6);
  font-family: var(--font-display); font-weight: 700; font-size: var(--fs-400);
  letter-spacing: 0.01em; border: 1px solid transparent; border-radius: var(--radius-int);
  background: var(--surface-2); color: var(--ink); cursor: pointer; text-align: center;
  transition: transform var(--motion-ui) var(--ease-out),
              background var(--motion-ui) var(--ease-out),
              box-shadow var(--motion-ui) var(--ease-out),
              border-color var(--motion-ui) var(--ease-out);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn:hover { text-decoration: none; }

/* Primário = a ação que avança a verdade. Verde de marca, glow no hover. */
.btn-go { background: var(--go); color: var(--void); border-color: var(--go); }
.btn-go:hover { box-shadow: var(--glow-go); }

/* Secundário — borda viva, fundo do void. */
.btn-ghost {
  background: transparent; border-color: var(--line); color: var(--ink);
  font-family: var(--font-mono); font-weight: 500;
}
.btn-ghost:hover { border-color: var(--ink-dim); background: var(--surface-2); }

/* Perigo — consequência. */
.btn-danger { background: transparent; border-color: var(--danger-dim); color: var(--danger); }
.btn-danger:hover { background: rgba(255, 77, 77, 0.08); border-color: var(--danger); }

.btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none; box-shadow: none; }

/* --------------------------------------------------------------------------
   Chips — opções curadas
   -------------------------------------------------------------------------- */
.chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  min-height: 36px; padding: var(--space-2) var(--space-4);
  font-family: var(--font-mono); font-size: var(--fs-300);
  color: var(--ink); background: var(--surface-2);
  border: var(--border-1); border-radius: var(--radius-int); cursor: pointer;
  transition: border-color var(--motion-ui) var(--ease-out);
}
.chip:hover { border-color: var(--ai); }
.chip[aria-pressed="true"] { border-color: var(--go); color: var(--go); }

/* --------------------------------------------------------------------------
   Panes — o frame de terminal e a barra de janela
   -------------------------------------------------------------------------- */
.pane {
  background: var(--surface); border: var(--border-1); border-radius: var(--radius-0);
  padding: var(--space-5);
}
.pane-head {
  display: flex; align-items: center; gap: var(--space-3);
  margin: calc(var(--space-5) * -1) calc(var(--space-5) * -1) var(--space-5);
  padding: var(--space-3) var(--space-5);
  border-bottom: var(--border-1); background: var(--surface-2);
}
.pane-head .dots { display: flex; gap: 6px; }
.pane-head .dots i { width: 9px; height: 9px; border-radius: var(--radius-pill); display: block; background: var(--line); }
.pane-head .dots i:nth-child(1) { background: var(--danger-dim); }
.pane-head .dots i:nth-child(2) { background: var(--xp-dim); }
.pane-head .dots i:nth-child(3) { background: var(--go-dim); }
.pane-head .title { font-family: var(--font-mono); font-size: var(--fs-300); color: var(--ink-dim); text-transform: lowercase; }

/* --------------------------------------------------------------------------
   Voz da IA — o bloco do mentor falando (ciano)
   -------------------------------------------------------------------------- */
.ai-line { display: flex; gap: var(--space-3); padding: var(--space-3) 0; }
.ai-avatar {
  flex: 0 0 auto; width: 32px; height: 32px;
  display: grid; place-items: center;
  border: 1px solid var(--ai-dim); border-radius: var(--radius-int);
  color: var(--ai); font-family: var(--font-mono); font-size: var(--fs-300);
  box-shadow: var(--glow-ai);
}
.ai-bubble {
  background: var(--surface-2); border-left: 2px solid var(--ai);
  padding: var(--space-3) var(--space-4); font-size: var(--fs-400);
}
.user-line { display: flex; justify-content: flex-end; padding: var(--space-2) 0; }
.user-bubble {
  background: transparent; border: var(--border-1); border-right: 2px solid var(--ink-dim);
  padding: var(--space-3) var(--space-4); font-family: var(--font-mono); font-size: var(--fs-300);
  max-width: 70%;
}

/* --------------------------------------------------------------------------
   Selos / conquistas — sprites pixel (a camada colecionável)
   -------------------------------------------------------------------------- */
.badge {
  display: inline-flex; flex-direction: column; align-items: center; gap: var(--space-3);
  width: 132px; padding: var(--space-4); text-align: center;
  background: var(--surface); border: var(--border-1);
}
.badge-sprite { display: block; width: 64px; height: 64px; object-fit: contain; image-rendering: pixelated; }
.badge-real { border-color: var(--xp-dim); }
/* arte ja tem glow proprio; drop-shadow so reforça o "aceso" sem estourar */
.badge-real .badge-sprite { filter: drop-shadow(0 0 6px rgba(255,182,39,0.35)); }
.badge-locked { opacity: 0.5; }
/* PNG nao tinge via color: dessatura pra simular o selo "a conquistar" */
.badge-locked .badge-sprite { filter: grayscale(1) brightness(0.55); }
.badge-label { font-family: var(--font-pixel); font-size: 8px; line-height: 1.7; color: var(--ink); }
.badge-locked .badge-label { color: var(--ink-dim); }
.badge-meta { font-family: var(--font-mono); font-size: var(--fs-300); color: var(--ink-dim); }

/* --------------------------------------------------------------------------
   XP / Nível — o ÚNICO lugar onde a pílula aparece
   -------------------------------------------------------------------------- */
.xp-token {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-mono); font-size: var(--fs-300); font-variant-numeric: tabular-nums;
  color: var(--xp); background: rgba(255, 182, 39, 0.10);
  border: 1px solid var(--xp-dim); border-radius: var(--radius-game);
}
.level-badge {
  display: inline-grid; place-items: center; width: 56px; height: 56px;
  border-radius: var(--radius-game); border: 2px solid var(--xp); color: var(--xp);
  font-family: var(--font-pixel); font-size: 14px; background: rgba(255, 182, 39, 0.06);
}
.xp-bar { height: 10px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--radius-game); overflow: hidden; }
.xp-bar > i { display: block; height: 100%; background: var(--xp); box-shadow: var(--glow-xp); }

/* --------------------------------------------------------------------------
   Progresso por FASES nomeadas
   -------------------------------------------------------------------------- */
.phases { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.phase {
  display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3);
  border-left: 2px solid var(--line); font-family: var(--font-mono); font-size: var(--fs-300);
}
.phase .tick { width: 18px; text-align: center; color: var(--ink-dim); }
.phase-done { border-left-color: var(--go); color: var(--ink); }
.phase-done .tick { color: var(--go); }
.phase-current { border-left-color: var(--ai); color: var(--ink); background: var(--surface-2); }
.phase-current .tick { color: var(--ai); }

/* --------------------------------------------------------------------------
   O RELÓGIO-DETONADOR 14/30 — o elemento-assinatura
   -------------------------------------------------------------------------- */
.clock { border: var(--border-1); background: var(--surface); padding: var(--space-5); position: relative; overflow: hidden; }
.clock-label { font-family: var(--font-mono); font-size: var(--fs-300); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--ink-dim); }
.clock-num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: var(--fs-900); font-weight: 700; line-height: var(--lh-tight); letter-spacing: -0.02em; }
.clock-num small { font-size: var(--fs-500); color: var(--ink-dim); font-weight: 400; }
.clock-date { font-family: var(--font-mono); font-size: var(--fs-300); color: var(--ink-dim); }
.clock.is-calm .clock-num { color: var(--ink); }
.clock.is-warm .clock-num { color: var(--warn); }
.clock.is-hot  .clock-num { color: var(--danger); text-shadow: var(--glow-danger); }
.clock.is-hot  { border-color: var(--danger-dim); }
.clock.is-hot::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 100% at 50% 100%, rgba(255,77,77,0.10), transparent 70%);
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   Cards de tarefa / foco do dia
   -------------------------------------------------------------------------- */
.task {
  display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-4);
  border: var(--border-1); background: var(--surface);
  transition: border-color var(--motion-ui) var(--ease-out);
}
.task:hover { border-color: var(--ai-dim); }
.task .box {
  flex: 0 0 auto; width: 22px; height: 22px; border: 1.5px solid var(--line);
  display: grid; place-items: center; font-family: var(--font-mono); color: transparent;
}
.task-done .box { border-color: var(--go); color: var(--go); }
.task-done .task-title { color: var(--ink-dim); text-decoration: line-through; }
.task-why { font-size: var(--fs-300); color: var(--ink-dim); margin-top: 2px; }
.task-title { font-weight: 600; }

/* Marca de "lastro real" vs "interno". */
.tag {
  font-family: var(--font-mono); font-size: 0.68rem; text-transform: uppercase;
  letter-spacing: 0.06em; padding: 2px 6px; border: 1px solid currentColor; border-radius: var(--radius-int);
}
.tag-verified { color: var(--go); }
.tag-internal { color: var(--ink-dim); }

/* --------------------------------------------------------------------------
   Estados — toast / alert / empty / celebração
   -------------------------------------------------------------------------- */
.toast {
  display: inline-flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4); border: 1px solid var(--go-dim);
  background: var(--surface); font-family: var(--font-mono); font-size: var(--fs-300);
}
.toast .glyph { color: var(--go); text-shadow: var(--glow-go); }

.alert {
  display: flex; gap: var(--space-3); align-items: flex-start; padding: var(--space-4);
  border: 1px solid var(--danger-dim); border-left-width: 3px; background: rgba(255, 77, 77, 0.06);
}
.alert .glyph { color: var(--danger); font-family: var(--font-mono); font-size: var(--fs-500); line-height: 1; }
.alert.alert-info { border-color: var(--ai-dim); background: rgba(56, 189, 248, 0.06); }
.alert.alert-info .glyph { color: var(--ai); }

.state-empty {
  text-align: center; padding: var(--space-7) var(--space-5);
  border: 1px dashed var(--line); background-image: var(--dither); background-size: var(--dither-size);
}
.state-empty .glyph { font-family: var(--font-mono); font-size: var(--fs-700); color: var(--go-dim); }
