/* ==========================================================================
 * HAONchat — onboarding.css  [owner: Onboarding]
 * --------------------------------------------------------------------------
 * Estilos do WIZARD de 5 passos (#onboarding) — a porta de entrada da pessoa
 * de 54 anos. SÓ acrescenta por cima do styles.css (Fundação): reusa tokens
 * (--blue/--green/--orange/--ink…), .btn, .field, .card, .toast, .empty-state,
 * .spinner, keyframes (haon-rise/haon-spin/haon-fade) e o responsivo base.
 *
 * NÃO redeclara tokens nem utilities globais. Zero cor hardcoded fora de
 * rgba()/gradientes derivados das vars. Dark-aware via as próprias vars.
 *
 * Ergonomia 54 respeitada:
 *  - 1 tarefa por tela, 1 CTA laranja grande (.btn.orange.lg, >=54px).
 *  - Barra de progresso com 5 segmentos verdes + "Passo X de 5" sempre visível.
 *  - Botões Voltar/Próximo grandes, no MESMO lugar (vira hábito).
 *  - QR grande, instrução numerada, feedback humano, sem loading infinito.
 *  - prefers-reduced-motion herdado do styles.css (desliga animações).
 * ========================================================================== */

/* ==========================================================================
 * 1. CASCA DO WIZARD  (#onboarding ocupa a tela; centraliza o cartão)
 * ========================================================================== */
#onboarding{
  min-height:100vh; min-height:100dvh;
  display:flex; flex-direction:column;
  background:
    radial-gradient(1100px 520px at 80% -8%, color-mix(in srgb,var(--green-500) 12%,transparent), transparent 60%),
    radial-gradient(900px 480px at -5% 110%, color-mix(in srgb,var(--blue-500) 10%,transparent), transparent 60%),
    var(--bg);
}
#onboarding[hidden]{display:none!important}

/* barra superior fina: marca + idioma + tema (controles globais ficam no app) */
.ob-topbar{
  display:flex; align-items:center; gap:14px;
  padding:14px clamp(16px,4vw,34px);
  border-bottom:1px solid var(--line);
  background:color-mix(in srgb,var(--bg) 88%, transparent);
}
.ob-topbar .ob-brand{display:flex; align-items:center; gap:11px; flex-shrink:0}
.ob-topbar .ob-brand .logo{
  width:40px; height:40px; border-radius:12px; display:grid; place-items:center; color:#fff; flex-shrink:0;
  background:linear-gradient(135deg,var(--blue-800),var(--green-600)); box-shadow:var(--shadow-sm);
}
.ob-topbar .ob-brand .logo svg{width:23px;height:23px}
.ob-topbar .ob-brand small{display:block;font-size:10px;letter-spacing:.10em;text-transform:uppercase;color:var(--green-600);font-weight:700}
.ob-topbar .ob-brand strong{display:block;font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink);line-height:1.1}
.ob-topbar .ob-top-right{display:flex; align-items:center; gap:10px; margin-left:auto}

/* área central rolável */
.ob-stage{
  flex:1 1 auto; display:flex; align-items:flex-start; justify-content:center;
  padding:clamp(20px,4vw,44px) clamp(16px,4vw,34px) 40px;
}
.ob-shell{width:100%; max-width:640px; display:flex; flex-direction:column; gap:22px}

/* ==========================================================================
 * 2. PROGRESSO  (.ob-progress — 5 segmentos verdes + "Passo X de 5")
 * ========================================================================== */
.ob-progress{display:flex; flex-direction:column; gap:10px}
.ob-progress-head{
  display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.ob-progress-step{
  font-family:var(--font-display); font-size:14px; font-weight:700; color:var(--ink);
}
.ob-progress-label{font-size:13px; font-weight:600; color:var(--soft)}
.ob-segments{display:grid; grid-template-columns:repeat(5,1fr); gap:8px}
.ob-seg{
  height:9px; border-radius:var(--radius-pill);
  background:color-mix(in srgb,var(--line) 60%, var(--card));
  border:1px solid var(--line);
  transition:background .25s ease, border-color .25s ease;
}
.ob-seg.is-done{
  background:linear-gradient(90deg,var(--green-700),var(--green-500));
  border-color:transparent;
}
.ob-seg.is-current{
  background:linear-gradient(90deg,var(--green-600),var(--green-500));
  border-color:transparent;
  box-shadow:0 0 0 3px color-mix(in srgb,var(--green-500) 22%,transparent);
}

/* ==========================================================================
 * 3. CARTÃO DO PASSO  (.ob-card — slide-in; 1 tarefa por tela)
 * ========================================================================== */
.ob-card{
  background:var(--card); border:1px solid var(--line); border-radius:22px;
  box-shadow:var(--shadow-md); padding:clamp(22px,4vw,34px);
  animation:haon-rise .28s ease both;
}
.ob-card .ob-step-ico{
  width:58px; height:58px; flex:0 0 auto; border-radius:17px; display:grid; place-items:center;
  margin-bottom:16px; color:#fff;
  background:linear-gradient(135deg,var(--blue-800),var(--green-600)); box-shadow:var(--shadow-sm);
}
.ob-card .ob-step-ico svg{width:30px;height:30px}
.ob-card.tone-green .ob-step-ico{background:linear-gradient(135deg,var(--green-700),var(--green-500))}
.ob-card.tone-orange .ob-step-ico{background:linear-gradient(135deg,var(--orange-600),var(--orange-500))}
.ob-card.tone-blue .ob-step-ico{background:linear-gradient(135deg,var(--blue-800),var(--blue-600))}

.ob-card h2{font-family:var(--font-display); font-size:clamp(22px,3.4vw,28px); line-height:1.18; margin-bottom:8px}
.ob-card .ob-lead{font-size:clamp(15px,1.9vw,17px); color:var(--soft); line-height:1.55; max-width:48ch}
.ob-card .ob-body{margin-top:20px}

/* ==========================================================================
 * 4. PASSO 1 — BOAS-VINDAS  (lista de "o que vamos fazer")
 * ========================================================================== */
.ob-welcome-list{display:grid; gap:12px; margin-top:6px}
.ob-welcome-item{
  display:flex; align-items:flex-start; gap:13px;
  padding:14px 16px; border:1px solid var(--line); border-radius:14px; background:var(--bg);
}
.ob-welcome-item .wi-num{
  width:30px; height:30px; flex:0 0 auto; border-radius:9px; display:grid; place-items:center;
  font-family:var(--font-display); font-size:14px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--green-700),var(--green-500));
}
.ob-welcome-item .wi-text strong{display:block; font-size:15.5px; font-weight:700; margin-bottom:1px}
.ob-welcome-item .wi-text span{font-size:14px; color:var(--soft)}

/* ==========================================================================
 * 5. PASSO 2 — CONECTAR WHATSAPP (QR grande + instrução + status)
 * ========================================================================== */
.ob-qr-grid{display:grid; grid-template-columns:248px 1fr; gap:clamp(18px,3vw,30px); align-items:start}
.ob-qr-frame{
  width:248px; height:248px; flex:0 0 auto; margin:0 auto;
  border:1px solid var(--line); border-radius:18px; background:var(--card);
  display:grid; place-items:center; position:relative; overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.ob-qr-frame img{width:212px; height:212px; image-rendering:pixelated; border-radius:6px}
/* cantos tipo "mira" pra parecer leitura de código */
.ob-qr-frame::before,.ob-qr-frame::after{
  content:""; position:absolute; width:34px; height:34px; pointer-events:none;
  border:3px solid color-mix(in srgb,var(--green-500) 65%,transparent);
}
.ob-qr-frame::before{top:12px; left:12px; border-right:0; border-bottom:0; border-radius:8px 0 0 0}
.ob-qr-frame::after{bottom:12px; right:12px; border-left:0; border-top:0; border-radius:0 0 8px 0}

/* estado de carregamento / expirado / erro DENTRO do quadro do QR */
.ob-qr-state{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px;
  text-align:center; padding:20px; color:var(--soft);
}
.ob-qr-state p{font-size:13.5px; max-width:24ch; line-height:1.45}
.ob-qr-state .qs-ico{
  width:48px; height:48px; border-radius:14px; display:grid; place-items:center;
  background:var(--blue-100); color:var(--blue-700);
}
.ob-qr-state.warn .qs-ico{background:var(--yellow-100); color:var(--yellow-600)}
.ob-qr-state.err .qs-ico{background:var(--red-100); color:var(--red-600)}
.ob-qr-state.ok .qs-ico{background:var(--green-100); color:var(--green-700)}
.ob-qr-state .qs-ico svg{width:26px;height:26px}

/* instrução numerada ao lado do QR */
.ob-qr-howto{display:flex; flex-direction:column; gap:14px}
.ob-qr-howto > h3{font-family:var(--font-display); font-size:17px; font-weight:700}
.ob-howto-steps{display:grid; gap:11px}
.ob-howto-steps li{display:flex; align-items:flex-start; gap:11px; font-size:14.5px; color:var(--ink); line-height:1.45}
.ob-howto-steps li .hs-num{
  width:26px; height:26px; flex:0 0 auto; border-radius:8px; display:grid; place-items:center;
  font-size:13px; font-weight:700; color:var(--blue-700);
  background:var(--blue-100); border:1px solid color-mix(in srgb,var(--blue-500) 30%,transparent);
}
.ob-howto-steps li b{font-weight:700}

/* pílula de status da conexão (aguardando / conectado) */
.ob-conn-pill{
  display:inline-flex; align-items:center; gap:9px; align-self:flex-start;
  padding:9px 15px; border-radius:var(--radius-pill); font-size:13.5px; font-weight:700;
  border:1px solid var(--line); background:var(--card); color:var(--soft);
}
.ob-conn-pill .cp-dot{width:9px; height:9px; border-radius:50%; flex:0 0 auto; background:var(--muted)}
.ob-conn-pill.waiting{color:var(--blue-700); background:var(--blue-100); border-color:color-mix(in srgb,var(--blue-500) 35%,transparent)}
.ob-conn-pill.waiting .cp-dot{background:var(--blue-500); animation:haon-pulse-dot 1.7s ease-out infinite}
.ob-conn-pill.connected{color:var(--green-700); background:var(--green-100); border-color:color-mix(in srgb,var(--green-500) 45%,transparent)}
.ob-conn-pill.connected .cp-dot{background:var(--green-500)}
.ob-conn-pill.err{color:var(--red-600); background:var(--red-100); border-color:color-mix(in srgb,var(--red-500) 40%,transparent)}
.ob-conn-pill.err .cp-dot{background:var(--red-500)}

/* faixa verde grande de "Conectado!" que aparece ao concluir o passo 2 */
.ob-connected-banner{
  display:flex; align-items:center; gap:14px;
  padding:18px 20px; border-radius:16px;
  background:var(--green-100); border:1px solid color-mix(in srgb,var(--green-500) 50%,transparent);
  color:var(--green-700); animation:haon-rise .3s ease both;
}
.ob-connected-banner .cb-ico{
  width:46px; height:46px; flex:0 0 auto; border-radius:13px; display:grid; place-items:center; color:#fff;
  background:linear-gradient(135deg,var(--green-700),var(--green-500)); box-shadow:var(--shadow-sm);
}
.ob-connected-banner .cb-ico svg{width:26px;height:26px}
.ob-connected-banner strong{display:block; font-family:var(--font-display); font-size:18px; font-weight:700; line-height:1.2}
.ob-connected-banner span{display:block; font-size:14px; color:color-mix(in srgb,var(--green-700) 82%, var(--ink)); margin-top:2px}

/* ==========================================================================
 * 6. PASSO 3 — NOMEAR O BOT  (1 input grande + dica)
 * ========================================================================== */
.ob-name-wrap{max-width:460px}
.ob-name-wrap .field input{min-height:var(--touch); font-size:16px}
.ob-name-suggest{display:flex; flex-wrap:wrap; gap:9px; margin-top:14px}
.ob-name-chip{
  min-height:38px; padding:0 14px; border-radius:var(--radius-pill);
  border:1px solid var(--line-strong); background:var(--card); color:var(--ink);
  font-size:13.5px; font-weight:600; cursor:pointer;
  transition:background .14s, border-color .14s, color .14s;
}
.ob-name-chip:hover{background:var(--blue-100); border-color:var(--blue-500); color:var(--blue-700)}

/* ==========================================================================
 * 7. PASSO 4 — ESCOLHER MODELO  (grid 2x2 de cartões com ícone + exemplo)
 * ========================================================================== */
.ob-templates{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:4px}
.ob-tpl{
  position:relative; text-align:left; cursor:pointer;
  background:var(--card); border:1.5px solid var(--line); border-radius:16px;
  padding:18px 18px 16px; display:flex; flex-direction:column; gap:6px;
  transition:transform .16s ease, box-shadow .18s ease, border-color .16s ease;
}
.ob-tpl:hover{transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--blue-500)}
.ob-tpl.is-selected{
  border-color:var(--blue-600);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--blue-500) 22%,transparent), var(--shadow-md);
}
.ob-tpl .tpl-ico{
  width:46px; height:46px; flex:0 0 auto; border-radius:13px; display:grid; place-items:center;
  color:#fff; background:linear-gradient(135deg,var(--blue-800),var(--blue-600)); margin-bottom:4px;
}
.ob-tpl.t-food .tpl-ico{background:linear-gradient(135deg,var(--orange-600),var(--orange-500))}
.ob-tpl.t-shop .tpl-ico{background:linear-gradient(135deg,var(--blue-800),var(--blue-600))}
.ob-tpl.t-clinic .tpl-ico{background:linear-gradient(135deg,var(--green-700),var(--green-500))}
.ob-tpl.t-services .tpl-ico{background:linear-gradient(135deg,var(--blue-700),var(--green-600))}
.ob-tpl .tpl-ico svg{width:25px;height:25px}
.ob-tpl strong{font-family:var(--font-display); font-size:16.5px; font-weight:700; color:var(--ink)}
.ob-tpl p{font-size:13.5px; color:var(--soft); line-height:1.45; margin:0}
/* check no canto quando selecionado */
.ob-tpl .tpl-check{
  position:absolute; top:14px; right:14px; width:26px; height:26px; border-radius:50%;
  display:grid; place-items:center; color:#fff; opacity:0; transform:scale(.6);
  background:var(--blue-600); transition:opacity .16s ease, transform .16s ease;
}
.ob-tpl .tpl-check svg{width:15px;height:15px}
.ob-tpl.is-selected .tpl-check{opacity:1; transform:none}

/* ==========================================================================
 * 8. PASSO 5 — LIGAR  (resumo do que foi configurado + 1 CTA laranja)
 * ========================================================================== */
.ob-summary{display:grid; gap:11px; margin-top:6px}
.ob-summary-row{
  display:flex; align-items:center; gap:13px;
  padding:13px 16px; border:1px solid var(--line); border-radius:13px; background:var(--bg);
}
.ob-summary-row .sr-ico{
  width:38px; height:38px; flex:0 0 auto; border-radius:11px; display:grid; place-items:center;
  background:var(--green-100); color:var(--green-700);
}
.ob-summary-row .sr-ico svg{width:20px;height:20px}
.ob-summary-row .sr-text{display:flex; flex-direction:column; min-width:0}
.ob-summary-row .sr-label{font-size:12.5px; font-weight:600; color:var(--soft)}
.ob-summary-row .sr-value{font-size:15.5px; font-weight:700; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}

/* ==========================================================================
 * 9. RODAPÉ DE NAVEGAÇÃO  (.ob-nav — Voltar à esquerda, Próximo/CTA à direita)
 *    Botão principal SEMPRE no mesmo lugar (direita) pra virar hábito.
 * ========================================================================== */
.ob-nav{
  display:flex; align-items:center; gap:12px; margin-top:24px;
  padding-top:20px; border-top:1px solid var(--line);
}
.ob-nav .ob-back{flex:0 0 auto}
.ob-nav .ob-spacer{flex:1 1 auto}
.ob-nav .ob-next{flex:0 0 auto; min-width:180px}
/* link discreto "sair do passo a passo / faço depois" */
.ob-skip-link{
  display:inline-block; margin-top:14px; font-size:13.5px; font-weight:600;
  color:var(--soft); text-align:center; width:100%; background:none; border:none; cursor:pointer;
}
.ob-skip-link:hover{color:var(--ink); text-decoration:underline}

/* ==========================================================================
 * 10. RESPONSIVO  (empilha tudo no mobile; QR centralizado; botões 100%)
 *     Breakpoints coerentes com o CONTRATO: 880px (tablet) e 520px (celular).
 *     O cartão do wizard é estreito (max 640px), então a 640px o QR/templates
 *     já colapsam por conteúdo; em 880 garantimos folga; em 520 vira 1 tela.
 * ========================================================================== */
/* tablet (880px): o cartão já é estreito; só garante que o stage respira */
@media (max-width:880px){
  .ob-stage{padding:clamp(18px,4vw,32px) clamp(14px,4vw,28px) 36px}
}
/* ponto natural de colapso do QR (2 col -> 1) e dos templates (2 col -> 1) */
@media (max-width:640px){
  .ob-qr-grid{grid-template-columns:1fr}
  .ob-qr-frame{width:min(248px,100%); height:auto; aspect-ratio:1/1}
  .ob-templates{grid-template-columns:1fr}
  .ob-progress-label{display:none}
}
/* ===== BREAKPOINT DO SISTEMA (520px): wizard em 1 tela cheia, botões 100% ===== */
@media (max-width:520px){
  /* navegação: o CTA principal (Próximo) sempre em cima e 100%, Voltar embaixo */
  .ob-nav{flex-wrap:wrap}
  .ob-nav .ob-spacer{display:none}
  .ob-nav .ob-back{order:2; width:100%}
  .ob-nav .ob-next{order:1; width:100%; min-width:0}
  .ob-topbar .ob-brand strong{font-size:15px}
  /* o cartão ocupa a tela com folga mínima; sem cantos exagerados no estreito */
  .ob-stage{padding:16px 14px 28px}
  .ob-card{padding:20px 18px; border-radius:18px}
  /* chips de sugestão de nome com toque cheio */
  .ob-name-chip{min-height:44px}
  /* topbar enxuta: marca + controles cabem sem quebrar feio */
  .ob-topbar{gap:10px; padding:12px 16px}
}
