/* ===========================================================
   PESKEL — Onboarding / verificação (app-minimal, Instagram-clean)
   Google → CPF → Pix(estorno) → token + região → pronto. Scoped .ob
   =========================================================== */
.ob{position:relative;height:100%;background:var(--bg);color:var(--ink);font-family:var(--font-ui);display:flex;flex-direction:column;overflow:hidden}

/* top: back + progress (verification steps only) */
.ob-top{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:14px 16px 6px;min-height:48px}
.web .ob-top{padding:16px 26px 6px}
.ob-back{width:34px;height:34px;border-radius:50%;border:0;background:transparent;color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:background .15s}
.ob-back:hover{background:var(--surface-sunken)}
.ob-back svg{width:18px;height:18px}
.ob-back.hide{visibility:hidden}
.ob-prog{flex:1;display:flex;gap:5px;max-width:240px;margin:0 auto;opacity:0;transition:opacity .25s}
.ob-prog.show{opacity:1}
.ob-prog .pg{flex:1;height:4px;border-radius:3px;background:var(--track);overflow:hidden}
.ob-prog .pg i{display:block;height:100%;width:0;background:var(--solid-ink);border-radius:3px;transition:width .4s cubic-bezier(.22,1,.36,1)}
.ob-prog .pg.done i{width:100%}
.ob-prog .pg.cur i{width:100%}
.ob-step{flex:0 0 auto;width:34px;text-align:right;font-family:var(--font-mono);font-size:10px;color:var(--ink-3)}

/* body */
.ob-body{flex:1 1 auto;min-height:0;overflow-y:auto;display:flex;flex-direction:column;padding:8px 22px 0}
.web .ob-body{padding:8px 26px 0;align-items:center}
.ob-body::-webkit-scrollbar{width:0}
.ob-inner{width:100%;max-width:380px;margin:0 auto;flex:1;display:flex;flex-direction:column}

/* generic step header */
.ob-h{font-size:26px;font-weight:800;letter-spacing:-.03em;line-height:1.12;margin-top:14px;text-wrap:balance}
.web .ob-h{font-size:30px}
.ob-sub{font-size:14px;color:var(--ink-2);margin-top:8px;line-height:1.5}

/* discreet privacy line */
.ob-lock{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--font-mono);font-size:10.5px;
  color:var(--ink-3);letter-spacing:.01em}
.ob-lock svg{width:12px;height:12px;flex:0 0 auto}

/* bottom action */
.ob-foot{flex:0 0 auto;padding:14px 22px calc(16px + env(safe-area-inset-bottom,8px))}
.web .ob-foot{padding:16px 26px 22px;display:flex;justify-content:center}
.ob-cta{width:100%;max-width:380px;display:flex;align-items:center;justify-content:center;gap:9px;border:0;border-radius:15px;padding:16px;
  cursor:pointer;background:var(--solid-ink);color:var(--on-solid);font-family:var(--font-ui);font-weight:700;font-size:15px;letter-spacing:-.01em;
  transition:filter .15s,transform .1s,opacity .15s}
.ob-cta:hover{filter:brightness(.93)}
.ob-cta:active{transform:scale(.99)}
.ob-cta[disabled]{opacity:.4;pointer-events:none}
.ob-cta svg{width:17px;height:17px}
.ob-ghost{background:transparent;color:var(--ink-2);font-weight:600;font-size:13px;margin-top:6px;width:100%;text-align:center;border:0;cursor:pointer;padding:10px}
.ob-ghost:hover{color:var(--ink)}

/* ===== WELCOME ===== */
.ob.welcome .ob-top{visibility:hidden}
.wel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:0}
.wel .wmark{color:var(--ink);margin-bottom:22px}
.wel .wtitle{font-size:34px;font-weight:800;letter-spacing:-.035em;line-height:1.05;text-wrap:balance}
.web .wel .wtitle{font-size:40px}
.wel .wsub{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;margin-top:14px;text-transform:uppercase}
.wel .wkind{display:flex;gap:3px;margin-top:30px;padding:3px;background:var(--surface-sunken);border:1px solid var(--hair);border-radius:12px}
.wel .wkind button{border:0;background:transparent;cursor:pointer;border-radius:9px;padding:9px 16px;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--ink-2);transition:background .15s,color .15s}
.wel .wkind button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

/* google button */
.gbtn{width:100%;max-width:380px;display:flex;align-items:center;justify-content:center;gap:11px;border:1px solid var(--hair-2);
  background:var(--surface);color:var(--ink);border-radius:15px;padding:15px;cursor:pointer;font-family:var(--font-ui);font-weight:700;font-size:15px;
  transition:background .15s,transform .1s}
.gbtn:hover{background:var(--surface-sunken)}
.gbtn:active{transform:scale(.99)}
.gbtn .gg{width:20px;height:20px;flex:0 0 auto}

/* ===== GOOGLE account pick ===== */
.gacct{margin-top:20px;border:1px solid var(--hair);border-radius:16px;overflow:hidden;background:var(--surface)}
.gacct .ga{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--hair);transition:background .15s;border-left:0;border-right:0;border-top:0;width:100%;background:var(--surface);text-align:left}
.gacct .ga:last-child{border-bottom:0}
.gacct .ga:hover{background:var(--surface-sunken)}
.gacct .ga .av{width:38px;height:38px;border-radius:50%;background:var(--p-violet);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex:0 0 auto}
.gacct .ga .gi{min-width:0;flex:1}
.gacct .ga .gn{font-size:14px;font-weight:600;color:var(--ink)}
.gacct .ga .ge{font-size:12px;color:var(--ink-3);font-family:var(--font-mono)}
.gacct .ga.add .av{background:var(--surface-sunken);color:var(--ink-3)}
.gacct .ga.add .gn{color:var(--ink-2)}

/* ===== CPF / input ===== */
.ob-field{margin-top:24px}
.ob-input{width:100%;border:1.5px solid var(--hair-2);background:var(--surface);border-radius:14px;padding:16px;
  font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--ink);letter-spacing:.02em;text-align:center;transition:border-color .15s}
.ob-input:focus{outline:0;border-color:var(--ink)}
.ob-input::placeholder{color:var(--ink-3);font-weight:500}
.ob-checking{display:flex;align-items:center;gap:9px;margin-top:16px;font-family:var(--font-mono);font-size:12px;color:var(--ink-2);opacity:0;transition:opacity .2s}
.ob-checking.show{opacity:1}
.ob-checking .spin{width:15px;height:15px;border:2px solid var(--hair-2);border-top-color:var(--ink);border-radius:50%;animation:obspin .7s linear infinite}
@keyframes obspin{to{transform:rotate(360deg)}}
.ob-verified{display:flex;align-items:center;gap:9px;margin-top:16px;font-size:13px;font-weight:600;color:var(--p-green);opacity:0;transition:opacity .25s}
.ob-verified.show{opacity:1}
.ob-verified .vc{width:22px;height:22px;border-radius:50%;background:var(--p-green);color:#fff;display:grid;place-items:center}
.ob-verified .vc svg{width:13px;height:13px}

/* ===== PIX ===== */
.pix-card{margin-top:18px;border:1px solid var(--hair);border-radius:18px;padding:18px;background:var(--surface);text-align:center}
.pix-amt{display:flex;align-items:baseline;justify-content:center;gap:7px;font-family:var(--font-mono);margin-bottom:4px;flex-wrap:wrap}
.pix-amt .v{font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.02em;white-space:nowrap}
.pix-amt .tag{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--p-green);border:1px solid currentColor;border-radius:6px;padding:2px 7px}
.pix-est{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-3);margin-bottom:16px}
.qr{width:188px;height:188px;margin:0 auto;background:#fff;border-radius:14px;padding:12px;box-shadow:inset 0 0 0 1px var(--hair)}
.qr svg{width:100%;height:100%;display:block}
.pix-copy{display:flex;align-items:center;gap:9px;margin-top:16px;border:1px solid var(--hair-2);border-radius:12px;padding:11px 13px;cursor:pointer;background:var(--surface-2);transition:background .15s}
.pix-copy:hover{background:var(--surface-sunken)}
.pix-copy .pk{flex:1;min-width:0;font-family:var(--font-mono);font-size:11px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}
.pix-copy .cic{width:30px;height:30px;border-radius:8px;background:var(--solid-ink);color:var(--on-solid);display:grid;place-items:center;flex:0 0 auto}
.pix-copy .cic svg{width:14px;height:14px}
.pix-why{display:flex;align-items:flex-start;gap:8px;margin-top:14px;font-size:11.5px;line-height:1.45;color:var(--ink-3)}
.pix-why svg{width:14px;height:14px;flex:0 0 auto;margin-top:1px;color:var(--ink-2)}
.pix-logo{display:inline-grid;place-items:center;color:#32BCAD}
.pix-logo svg{width:15px;height:15px}

/* ===== DONE / token ===== */
.done-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.done-ck{width:64px;height:64px;border-radius:20px;background:var(--p-green);color:#fff;display:grid;place-items:center;margin-bottom:18px;
  animation:pop .5s cubic-bezier(.22,1.4,.4,1)}
@keyframes pop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.done-ck svg{width:32px;height:32px}
.done-h{font-size:26px;font-weight:800;letter-spacing:-.03em}
.done-sub{font-size:13.5px;color:var(--ink-2);margin-top:7px;line-height:1.5}
.done-rows{width:100%;margin-top:22px;border:1px solid var(--hair);border-radius:14px;overflow:hidden;background:var(--surface);text-align:left}
.done-rows .dr{display:flex;align-items:center;gap:11px;padding:13px 15px;border-bottom:1px solid var(--hair)}
.done-rows .dr:last-child{border-bottom:0}
.done-rows .dr .di{width:30px;height:30px;border-radius:9px;background:var(--surface-sunken);display:grid;place-items:center;color:var(--ink-2);flex:0 0 auto}
.done-rows .dr .di svg{width:15px;height:15px}
.done-rows .dr .dt{min-width:0;flex:1}
.done-rows .dr .dk{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.done-rows .dr .dv{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--ink);margin-top:2px}
.done-rows .dr .seal{margin-left:auto;flex:0 0 auto;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:9.5px;font-weight:700;
  color:var(--p-green);letter-spacing:.04em;text-transform:uppercase}
.done-rows .dr .seal svg{width:13px;height:13px}

/* org badge in welcome flow tint */
.ob .vbadge{display:inline-grid;place-items:center;color:var(--ink)}
.ob .vbadge svg{width:16px;height:16px}
