/* ═══════════════════════════════════════════════════════════════════════════
   iPdelve — Guia assistido (tokens + componentes)
   Porta do design Claude Design (abril/2026).
   Escopado em .onboarding-page para não afetar o restante do app.
   ═══════════════════════════════════════════════════════════════════════════ */

.onboarding-page {
  --ip-accent: #7f5af0;
  --ip-accent-600: #6b46e0;
  --ip-accent-700: #5a3dd8;
  --ip-accent-50:  color-mix(in srgb, #7f5af0, white 90%);
  --ip-accent-100: color-mix(in srgb, #7f5af0, white 82%);
  --ip-accent-200: color-mix(in srgb, #7f5af0, white 68%);

  --ip-bg:        #f4f7fb;
  --ip-bg-2:      #eef3fa;
  --ip-surface:   #ffffff;
  --ip-ink:       #0f1728;
  --ip-ink-2:     #1c2635;
  --ip-muted:     #5f6e83;
  --ip-light:     #8ea0b8;
  --ip-border:    #dde5f1;
  --ip-border-2:  #eef3fa;

  --ip-ai-grad:   linear-gradient(135deg, #7f5af0 0%, #a78bfa 45%, #38bdf8 100%);
  --ip-ai-soft:   linear-gradient(135deg, rgba(127,90,240,.08), rgba(56,189,248,.06));

  --ip-r-sm:  8px;
  --ip-r-md: 12px;
  --ip-r-lg: 16px;
  --ip-r-xl: 20px;

  --ip-shadow-sm: 0 1px 2px rgba(15,23,40,.05);
  --ip-shadow-md: 0 4px 14px -4px rgba(15,23,40,.08), 0 1px 3px rgba(15,23,40,.04);
  --ip-shadow-lg: 0 16px 48px -18px rgba(15,23,40,.2), 0 6px 16px -10px rgba(15,23,40,.1);
  --ip-shadow-accent: 0 10px 28px -12px rgba(127,90,240,.4);

  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  background: var(--ip-bg);
  color: var(--ip-ink);
  min-height: 100vh;
}

.onboarding-page h1,
.onboarding-page h2,
.onboarding-page h3,
.onboarding-page .display {
  font-family: 'Sora', 'Manrope', system-ui, sans-serif;
  letter-spacing: -.4px;
}

/* ─── Top bar ──────────────────────────────────────────────────────────── */

.onb-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 28px;
  border-bottom: 1px solid var(--ip-border);
  background: var(--ip-surface);
}
.onb-topbar img.onb-logo {
  height: 28px;
  width: auto;
  display: block;
}
.onb-topbar .onb-topbar-tag {
  margin-left: auto;
  font-size: 12px;
  color: var(--ip-muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.onb-topbar .onb-topbar-tag i {
  color: var(--ip-accent);
}

/* ─── Container ────────────────────────────────────────────────────────── */

.onb-wrap {
  padding: 40px 48px;
  max-width: 1000px;
  margin: 0 auto;
}

@media (max-width: 640px) {
  .onb-wrap { padding: 28px 16px; }
}

/* ─── Stepper ──────────────────────────────────────────────────────────── */

.onb-stepper {
  display: flex;
  gap: 8px;
  margin-bottom: 36px;
}
.onb-stepper-item { flex: 1; }
.onb-stepper-bar {
  height: 4px;
  border-radius: 2px;
  background: var(--ip-border);
  transition: background .3s ease;
}
.onb-stepper-item.done  .onb-stepper-bar,
.onb-stepper-item.current .onb-stepper-bar {
  background: var(--ip-accent);
}
.onb-stepper-label {
  margin-top: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--ip-light);
}
.onb-stepper-item.current .onb-stepper-label { color: var(--ip-accent); }

/* ─── Hero & headings ──────────────────────────────────────────────────── */

.onb-eyebrow {
  font-size: 11px;
  font-weight: 700;
  color: var(--ip-accent);
  letter-spacing: 1px;
  text-transform: uppercase;
}
.onb-h1 {
  font-size: 40px;
  margin: 6px 0 10px;
  letter-spacing: -1px;
  line-height: 1.1;
}
.onb-subtitle {
  color: var(--ip-muted);
  font-size: 16px;
  max-width: 620px;
  margin: 0;
  line-height: 1.55;
}
@media (max-width: 640px) {
  .onb-h1 { font-size: 28px; }
}

/* ─── AI role suggest ──────────────────────────────────────────────────── */

.ai-role-suggest {
  margin-top: 22px;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--ip-accent-100);
  border-radius: var(--ip-r-lg);
  background: var(--ip-ai-soft);
  box-shadow: var(--ip-shadow-sm);
}
.ai-role-suggest-head {
  padding: 18px 20px 14px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.ai-role-suggest .ai-avatar {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--ip-ai-grad);
  color: #fff;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 20px;
}
.ai-role-suggest .ai-title {
  font-family: 'Sora', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--ip-ink);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ai-role-suggest .ai-sub {
  font-size: 13px;
  color: var(--ip-muted);
  line-height: 1.5;
  margin-top: 2px;
}
.ai-role-suggest .ai-input-box {
  margin: 0 20px 14px;
  padding: 10px;
  display: flex;
  align-items: flex-end;
  gap: 8px;
  border: 1px solid var(--ip-accent-100);
  border-radius: var(--ip-r-md);
  background: var(--ip-surface);
}
.ai-role-suggest textarea {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  padding: 8px 6px;
  font-family: inherit;
  font-size: 14px;
  color: var(--ip-ink);
  resize: none;
  line-height: 1.5;
}
.ai-role-suggest .ai-examples {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 20px 16px;
}
.ai-role-suggest .ai-example {
  padding: 5px 10px;
  font-size: 11.5px;
  border-radius: 999px;
  background: var(--ip-surface);
  border: 1px dashed var(--ip-accent-100);
  color: var(--ip-accent-700);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.ai-role-suggest .ai-example-label {
  font-size: 11px;
  color: var(--ip-muted);
  align-self: center;
  margin-right: 2px;
}

.ai-role-suggest .ai-result {
  margin: 0 20px 16px;
  padding: 14px;
  border-radius: var(--ip-r-md);
  background: var(--ip-surface);
  border: 1.5px solid var(--ip-accent);
  display: flex;
  align-items: center;
  gap: 12px;
}
.ai-role-suggest .ai-result-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--ip-accent-50);
  color: var(--ip-accent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 18px;
}
.ai-role-suggest .ai-result-meta {
  font-size: 11px;
  color: var(--ip-muted);
  font-weight: 600;
  letter-spacing: .3px;
}
.ai-role-suggest .ai-result-title {
  font-family: 'Sora', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--ip-ink);
  margin-top: 2px;
}
.ai-role-suggest .ai-result-reason {
  font-size: 12.5px;
  color: var(--ip-muted);
  margin-top: 3px;
  line-height: 1.45;
}

/* ─── Divider "ou escolha manualmente" ─────────────────────────────────── */

.onb-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 24px 0 18px;
}
.onb-divider-line {
  flex: 1;
  height: 1px;
  background: var(--ip-border);
}
.onb-divider-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--ip-light);
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ─── Role cards (Step 1) ──────────────────────────────────────────────── */

.role-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 900px) {
  .role-grid { grid-template-columns: 1fr; }
}

.role-card {
  all: unset;
  display: block;
  box-sizing: border-box;
  cursor: pointer;
  padding: 20px;
  border: 1.5px solid var(--ip-border);
  border-radius: var(--ip-r-lg);
  background: var(--ip-surface);
  transition: all .18s ease;
  box-shadow: var(--ip-shadow-sm);
  font-family: inherit;
}
.role-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--ip-shadow-md);
}
.role-card.active {
  border-color: var(--role-color, var(--ip-accent));
  background: color-mix(in srgb, var(--role-color, var(--ip-accent)), white 94%);
  box-shadow: 0 14px 30px -16px color-mix(in srgb, var(--role-color, var(--ip-accent)), transparent 60%);
}
.role-card .role-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--role-color, var(--ip-accent));
  display: grid;
  place-items: center;
  color: #fff;
  margin-bottom: 14px;
  font-size: 20px;
}
.role-card .role-title {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 17px;
  color: var(--ip-ink);
}
.role-card .role-sub {
  font-size: 13px;
  color: var(--ip-muted);
  margin-top: 6px;
  line-height: 1.5;
}
.role-card .role-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* ─── Chips ────────────────────────────────────────────────────────────── */

.onb-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--ip-bg-2);
  color: var(--ip-muted);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .2px;
  border: 1px solid var(--ip-border);
}
.onb-chip-accent {
  background: var(--ip-accent-50);
  color: var(--ip-accent-700);
  border-color: var(--ip-accent-100);
}

/* ─── Buttons ──────────────────────────────────────────────────────────── */

.onb-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 10px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .12s ease;
  font-family: inherit;
  white-space: nowrap;
  text-decoration: none;
}
.onb-btn-primary { background: var(--ip-ink); color: #fff; }
.onb-btn-primary:hover { background: #000; color: #fff; }
.onb-btn-outline { background: var(--ip-surface); color: var(--ip-ink-2); border-color: var(--ip-border); }
.onb-btn-outline:hover { background: var(--ip-bg-2); color: var(--ip-ink-2); }
.onb-btn-ghost { background: transparent; color: var(--ip-ink-2); }
.onb-btn-ghost:hover { background: var(--ip-bg-2); color: var(--ip-ink-2); }
.onb-btn-ai {
  background: var(--ip-ai-grad);
  color: #fff;
  box-shadow: var(--ip-shadow-accent);
}
.onb-btn-ai:hover { filter: brightness(1.06); color: #fff; }
.onb-btn-sm { padding: 6px 10px; font-size: 12px; border-radius: 8px; }
.onb-btn[disabled] { opacity: .55; cursor: not-allowed; }

.onb-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 28px;
  gap: 12px;
  flex-wrap: wrap;
}

/* ─── Step 2 — conversa ────────────────────────────────────────────────── */

.onb-card {
  background: var(--ip-surface);
  border: 1px solid var(--ip-border);
  border-radius: var(--ip-r-lg);
  box-shadow: var(--ip-shadow-sm);
  overflow: hidden;
  margin-top: 22px;
}
.onb-question {
  padding: 22px 24px;
  border-bottom: 1px solid var(--ip-border);
}
.onb-question:last-child { border-bottom: none; }
.onb-question-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.onb-question-avatar {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: var(--ip-ai-grad);
  display: grid;
  place-items: center;
  color: #fff;
  flex-shrink: 0;
  font-size: 14px;
}
.onb-question-text {
  font-family: 'Sora', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--ip-ink);
}
.onb-question-hint {
  font-size: 12px;
  color: var(--ip-muted);
  margin-top: 3px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.onb-question-options {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding-left: 40px;
}
.onb-option {
  all: unset;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--ip-border);
  background: var(--ip-surface);
  color: var(--ip-ink-2);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all .12s ease;
}
.onb-option:hover { border-color: var(--ip-accent-100); }
.onb-option.multi { border-radius: 10px; }
.onb-option.active {
  border-color: var(--ip-accent);
  background: var(--ip-accent-50);
  color: var(--ip-accent-700);
}
.onb-option .onb-option-check { font-size: 13px; color: var(--ip-light); }
.onb-option.active .onb-option-check { color: var(--ip-accent); }

.onb-other-wrap {
  padding-left: 40px;
  margin-top: 10px;
}
.onb-other {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px;
  border: 1px dashed var(--ip-border);
  border-radius: 10px;
  background: var(--ip-bg-2);
}
.onb-other input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  padding: 8px 0;
  font-family: inherit;
  font-size: 13px;
  color: var(--ip-ink);
}
.onb-other i { color: var(--ip-accent); font-size: 14px; }

.onb-free-text-block {
  padding: 22px 24px;
  background: var(--ip-ai-soft);
}
.onb-free-text-block textarea {
  width: calc(100% - 40px);
  margin-left: 40px;
  padding: 14px;
  border: 1px solid var(--ip-border);
  border-radius: var(--ip-r-md);
  background: var(--ip-surface);
  font-family: inherit;
  font-size: 13.5px;
  color: var(--ip-ink);
  resize: vertical;
  outline: none;
  line-height: 1.5;
}

/* ─── Step 3 — feature cards ───────────────────────────────────────────── */

.onb-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 26px;
  margin-bottom: 12px;
}
.onb-section-icon {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 14px;
}
.onb-section-icon.ai { background: var(--ip-ai-grad); }
.onb-section-icon.optional {
  background: var(--ip-bg-2);
  color: var(--ip-muted);
  border: 1px solid var(--ip-border);
}
.onb-section-title {
  font-family: 'Sora', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--ip-ink);
}
.onb-section-meta {
  font-size: 12px;
  color: var(--ip-muted);
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.feature-card {
  position: relative;
  cursor: pointer;
  user-select: none;
  padding: 18px 14px 16px;
  border-radius: 14px;
  border: 1.5px solid var(--ip-border);
  background: var(--ip-surface);
  transition: all .15s ease;
  box-shadow: var(--ip-shadow-sm);
  text-align: center;
}
.feature-card.active {
  border-color: var(--ip-accent);
  background: color-mix(in srgb, var(--ip-accent), white 88%);
  box-shadow: 0 10px 24px -18px rgba(127,90,240,.45);
}
.feature-card .feature-help {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid var(--ip-border);
  background: var(--ip-surface);
  color: var(--ip-light);
  cursor: pointer;
  font-size: 10px;
  display: grid;
  place-items: center;
  padding: 0;
}
.feature-card .feature-check {
  position: absolute;
  top: 8px;
  left: 8px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ip-accent);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 12px;
  opacity: 0;
  transform: scale(.6);
  transition: all .14s ease;
}
.feature-card.active .feature-check {
  opacity: 1;
  transform: scale(1);
}
.feature-card .feature-icon {
  width: 44px;
  height: 44px;
  margin: 2px auto 12px;
  border-radius: 12px;
  background: var(--ip-accent-50);
  color: var(--ip-accent-700);
  display: grid;
  place-items: center;
  font-size: 22px;
  transition: all .15s ease;
}
.feature-card.active .feature-icon {
  background: var(--ip-accent);
  color: #fff;
}
.feature-card .feature-label {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--ip-ink);
  line-height: 1.25;
}
.feature-card .feature-sub {
  font-size: 11.5px;
  color: var(--ip-muted);
  margin-top: 2px;
}
.feature-card .feature-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  border-radius: 6px;
  background: var(--ip-ai-grad);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .4px;
  vertical-align: middle;
}

.onb-hidden-block {
  margin-top: 22px;
  padding: 14px 16px;
  border-radius: var(--ip-r-md);
  background: var(--ip-bg-2);
  border: 1px dashed var(--ip-border);
}
.onb-hidden-label {
  font-size: 12px;
  color: var(--ip-muted);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.onb-hidden-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.onb-hidden-chips .onb-chip { opacity: .7; }

/* ─── Tela final / done ────────────────────────────────────────────────── */

.onb-done {
  min-height: 70vh;
  display: grid;
  place-items: center;
  text-align: center;
}
.onb-done-icon {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  background: var(--ip-ai-grad);
  color: #fff;
  display: grid;
  place-items: center;
  margin: 0 auto 20px;
  font-size: 32px;
}

/* ─── Spinner (substitui circle-notch do Phosphor) ─────────────────────── */
@keyframes onb-spin { to { transform: rotate(360deg); } }
.onb-spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: onb-spin 1s linear infinite;
  vertical-align: -2px;
}
