/* ── Onboarding wizard (fullscreen overlay no /inicio) ── */
.ob-overlay {
  position:fixed; inset:0; z-index:6000;
  background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  opacity:1; transition:opacity .35s var(--ease);
}
.ob-overlay.done { opacity:0; pointer-events:none; }
.ob-overlay[hidden] { display:none; }

.ob-box {
  width:100%; max-width:420px; padding:0 22px;
  text-align:center;
}

/* ── Indicador de passos ── */
.ob-steps {
  display:flex; gap:8px; justify-content:center; margin-bottom:32px;
}
.ob-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--line-2); transition:background .3s var(--ease), transform .3s var(--snap);
}
.ob-dot.on { background:var(--c); transform:scale(1.25); }
.ob-dot.past { background:var(--c); opacity:.45; }

/* ── Ícone topo ── */
.ob-icon {
  width:72px; height:72px; border-radius:18px; margin:0 auto 20px;
  background:var(--c-soft); color:var(--c-deep);
  display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--c-line);
}
.ob-icon svg { width:34px; height:34px; }

/* ── Títulos ── */
.ob-title {
  font-family:var(--font-display); font-weight:400;
  font-size:28px; line-height:1.1; color:var(--ink); margin:0 0 6px;
}
.ob-sub {
  font-size:14px; color:var(--ink-3); margin:0 0 28px; line-height:1.4;
}

/* ── Opções (cards seleccionáveis) ── */
.ob-opts { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }

.ob-opt {
  display:flex; align-items:center; gap:14px;
  padding:16px; border-radius:14px;
  border:1.5px solid var(--line-2); background:var(--card);
  text-align:left; width:100%;
  transition:border-color .2s, background .2s, transform .12s;
}
.ob-opt:active { transform:translate(1px,1px); }
.ob-opt.sel { border-color:var(--c); background:var(--c-soft); }

.ob-opt .ic {
  width:44px; height:44px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; flex:0 0 auto;
  background:var(--paper-2); color:var(--ink-2);
  transition:background .2s, color .2s;
}
.ob-opt.sel .ic { background:var(--c); color:var(--c-on); }
.ob-opt .ic svg { width:22px; height:22px; }

.ob-opt .lt { flex:1; min-width:0; }
.ob-opt .lt .nm { display:block; font-weight:600; font-size:15.5px; color:var(--ink); line-height:1.25; }
.ob-opt .lt .d { display:block; font-size:12px; color:var(--ink-3); margin-top:3px; line-height:1.3; }

.ob-opt .chk {
  width:24px; height:24px; border-radius:7px; flex:0 0 auto;
  border:1.5px solid var(--line-2); background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  transition:all .2s var(--snap);
}
.ob-opt.sel .chk { background:var(--c); border-color:var(--c); }
.ob-opt .chk svg { width:14px; height:14px; color:var(--c-on); opacity:0; transition:opacity .15s; }
.ob-opt.sel .chk svg { opacity:1; }

/* ── Força side-by-side (passo 1) ── */
.ob-forces { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:24px; }
.ob-force {
  padding:22px 14px; border-radius:16px;
  border:1.5px solid var(--line-2); background:var(--card);
  text-align:center; transition:border-color .2s, background .2s, transform .12s, box-shadow .2s;
}
.ob-force:active { transform:translate(1px,1px); }
.ob-force.sel { border-color:var(--ink); box-shadow:3px 3px 0 var(--c); }

.ob-force .badge {
  display:inline-block; font-family:var(--font-mono);
  font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  padding:5px 12px; border-radius:8px; margin-bottom:12px;
}
.ob-force.psp .badge { background:var(--psp-soft); color:var(--psp-deep); }
.ob-force.gnr .badge { background:var(--gnr-soft); color:var(--gnr-deep); }
.ob-force .fname { font-family:var(--font-display); font-size:20px; line-height:1.1; margin:0; }
.ob-force .fsub { font-size:11.5px; color:var(--ink-3); margin-top:4px; }

/* ── Botões ── */
.ob-actions { display:flex; gap:10px; margin-top:8px; }
.ob-actions .btn { flex:1; }

/* ── Animação de transição entre passos ── */
.ob-step { animation:ob-in .35s var(--snap); }
@keyframes ob-in { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:none; } }

/* ── Passo final (resumo) ── */
.ob-summary {
  border:1.5px solid var(--line-2); border-radius:16px;
  background:var(--card); padding:18px 16px; text-align:left;
  margin-bottom:24px;
}
.ob-summary .row {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 0; border-bottom:1px solid var(--line);
}
.ob-summary .row:last-child { border-bottom:none; }
.ob-summary .row .lbl {
  font-family:var(--font-mono); font-size:10px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-3);
}
.ob-summary .row .val { font-weight:600; font-size:14.5px; color:var(--ink); }

@media (prefers-reduced-motion:reduce) {
  .ob-step { animation:none; }
  .ob-overlay { transition:none; }
}
