/* QUICK ONBOARDING — styles (theme-aware via kit vars) */
.ob-wrap{ max-width:560px; margin:0 auto; }
.ob-cardbox{ background:var(--card); border:1px solid color-mix(in srgb,var(--line) 70%,transparent); border-radius:var(--r-xl,24px);
  padding:28px; box-shadow:var(--sh-glow,0 24px 70px -34px rgba(34,224,200,.4)); animation:ob-rise .35s cubic-bezier(.2,.7,.2,1) both; }
@keyframes ob-rise{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none} }
.ob-kick{ display:inline-block; font-family:var(--font-display); font-size:11px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; color:var(--neon); margin-bottom:8px; }
.ob-cardbox h3{ margin:2px 0 12px; font-size:24px; }
.ob-sub{ color:var(--mut); margin:-4px 0 16px; }
.ob-progwrap{ margin-bottom:18px; }
.ob-step{ display:block; font-family:var(--font-display); font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--mut); margin-bottom:7px; }
.ob-prog{ height:5px; background:var(--line); border-radius:999px; overflow:hidden; }
.ob-prog span{ display:block; height:100%; background:linear-gradient(90deg,var(--neon),var(--violet)); transition:width .4s cubic-bezier(.2,.7,.2,1); }
.ob-err{ color:#ff5e7e; font-size:13px; margin:10px 0 0; min-height:1px; }
.ob-err:empty{ margin:0; }
.ob-label{ display:block; font-size:12px; font-weight:700; color:var(--mut); margin:14px 0 7px; }
.ob-opt-note{ font-weight:500; opacity:.8; }
.ob-input{ width:100%; background:#0c0c18; color:var(--ink); border:1px solid var(--line); border-radius:10px; padding:12px 14px; font:inherit; font-size:15px; }
.ob-input:focus{ outline:none; border-color:color-mix(in srgb,var(--neon) 55%,var(--line)); box-shadow:0 0 0 3px color-mix(in srgb,var(--neon) 14%,transparent); }
.ob-opts{ display:flex; gap:8px; flex-wrap:wrap; }
.ob-opt{ flex:1; min-width:110px; cursor:pointer; font:inherit; font-weight:700; font-size:14px; color:var(--ink); text-align:center;
  background:#0c0c18; border:1px solid var(--line); border-radius:12px; padding:13px 12px; transition:all .18s; }
.ob-opt:hover{ border-color:color-mix(in srgb,var(--neon) 45%,var(--line)); transform:translateY(-1px); }
.ob-opt.on{ color:#05050a; background:linear-gradient(120deg,var(--neon),var(--violet)); border-color:transparent; }
.ob-cardbox>.btn{ width:100%; text-align:center; margin-top:18px; }
.ob-back{ display:inline-block; margin-top:14px; background:none; border:none; color:var(--mut); cursor:pointer; font:inherit; font-weight:600; }
.ob-back:hover{ color:var(--neon); }
.ob-fine{ font-size:12px; color:var(--mut); margin-top:12px; }

/* goal cards */
.ob-cards{ display:flex; flex-direction:column; gap:10px; }
.ob-card{ position:relative; cursor:pointer; text-align:left; display:flex; flex-direction:column; gap:2px; font:inherit;
  background:#0c0c18; border:1px solid var(--line); border-radius:14px; padding:16px 18px 16px 54px; transition:all .18s; }
.ob-card .ob-ic{ position:absolute; left:16px; top:16px; font-size:24px; }
.ob-card b{ font-size:16px; }
.ob-card .ob-d{ color:var(--mut); font-size:13px; }
.ob-card:hover{ border-color:color-mix(in srgb,var(--neon) 45%,var(--line)); transform:translateY(-1px); }
.ob-card.pop{ border-color:color-mix(in srgb,var(--neon) 45%,var(--line)); }
.ob-badge{ position:absolute; top:-10px; right:14px; font-family:var(--font-display); font-size:10px; font-weight:800; letter-spacing:.6px; text-transform:uppercase; color:#05050a; background:linear-gradient(120deg,var(--neon),var(--violet)); padding:3px 9px; border-radius:999px; }

/* result */
.ob-result{ text-align:center; padding:8px 0; }
.ob-spin{ width:42px; height:42px; margin:18px auto; border-radius:50%; border:4px solid var(--line); border-top-color:var(--neon); animation:ob-spin 0.9s linear infinite; }
@keyframes ob-spin{ to{ transform:rotate(360deg) } }
.ob-result.done{ text-align:left; }
.ob-steps{ margin:14px 0 20px; padding-left:20px; color:var(--ink); }
.ob-steps li{ margin:8px 0; }
.ob-cta{ display:flex; gap:10px; flex-wrap:wrap; }
.ob-cta .btn{ flex:1; text-align:center; min-width:150px; }
