/* ============================================================
   Onboarding (chat-style guest flow with James / Jane).
   Two views: #view-pick-companion (the chooser) and
   #view-onboarding (the chat-style step-by-step interview).
============================================================ */

/* ---- Pick companion (James / Jane) ----
   Theme matches the splash: olive gradient + leafy bg overlay + cream
   text. The portrait cards stay white so they feel like they're floating
   above the foliage, like postcards on a moss-covered table.

   Layout note: .view is position:absolute / inset:0, so its ::before
   only covers the viewport — when content scrolled past viewport height,
   the bottom showed plain green with no foliage. We put the leaf
   overlay on the inner .onb-pick (which grows with content) and let
   .onb-pick min-height the full scroll area. justify-content:center then
   pulls the cards to vertical-middle on tall screens (no dead top zone). */
#view-pick-companion{
  background:linear-gradient(170deg,#3e4a2f 0%,#4f5536 55%,#5b6840 100%);
  color:var(--ink-on-olive);
  overflow-y:auto;
  overflow-x:hidden;
}
.onb-pick{
  position:relative;
  min-height:100%;
  max-width:920px;
  margin:0 auto;
  /* Vertical rhythm: clamps with vh so the whole stack — brand, title,
     two cards, foot — fits one fold on shorter laptops, but breathes
     properly on tall desktops. */
  padding:clamp(20px,3vh,40px) 24px clamp(20px,3vh,40px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:clamp(18px,3.2vh,32px);
}
.onb-pick::before{
  /* Full-viewport-width leaf overlay that follows content height — break
     out of .onb-pick's 920px max-width via 100vw + center transform. */
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:100vw;
  background-image:url('/static/images/splash-bg.png');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  opacity:.34;
  mix-blend-mode:soft-light;
  pointer-events:none;
  z-index:0;
}
.onb-pick > *{position:relative;z-index:1}
.onb-pick-head{position:relative;text-align:center;width:100%;display:flex;flex-direction:column;align-items:center;gap:clamp(10px,2vh,18px)}
.onb-pick-head .back{position:absolute;left:0;top:0;width:40px;height:40px;border-radius:50%;border:1px solid rgba(245,238,216,.32);background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;color:var(--ink-on-olive);cursor:pointer;backdrop-filter:blur(6px);transition:background .15s ease}
.onb-pick-head .back:hover{background:rgba(255,255,255,.18)}
.onb-exit{position:absolute;right:0;top:0;width:40px;height:40px;border-radius:50%;border:1px solid rgba(245,238,216,.32);background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;color:var(--ink-on-olive);cursor:pointer;backdrop-filter:blur(6px);transition:background .15s ease}
.onb-exit:hover{background:rgba(255,255,255,.18)}
/* Brand lockup — ring + wordmark + tagline, mirroring the splash.
   Sized in vh-aware clamps so it shrinks on shorter laptops.
   The bottom margin sets the lockup apart from the heading group. */
.onb-pick-brand{position:relative;display:flex;flex-direction:column;align-items:center;gap:clamp(6px,1.2vh,12px);margin-bottom:clamp(4px,1.4vh,16px)}
.onb-pick-brand::before{
  content:"";position:absolute;left:-120px;right:-120px;top:-40px;bottom:-20px;
  background:radial-gradient(ellipse 58% 62% at 50% 50%,rgba(12,18,4,.65) 0%,rgba(12,18,4,.25) 45%,rgba(12,18,4,0) 82%);
  filter:blur(20px);z-index:-1;pointer-events:none;
}
.onb-pick-ring-wrap{position:relative;width:clamp(48px,6.5vh,72px);aspect-ratio:1}
.onb-pick-ring-wrap::before{
  content:"";position:absolute;left:50%;top:50%;width:130%;height:130%;transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(closest-side,rgba(196,108,108,.30) 0%,rgba(196,108,108,0) 68%),radial-gradient(closest-side,rgba(120,140,80,.20) 0%,rgba(120,140,80,0) 72%);
  filter:blur(16px);pointer-events:none;animation:breathe-glow 7s ease-in-out infinite;z-index:0;
}
.onb-pick-ring{position:relative;z-index:1;width:100%;height:100%;object-fit:contain}
.onb-pick-wordmark{font-family:'Cal Sans',serif;font-weight:500;font-size:clamp(20px,2.4vh,26px);letter-spacing:-.005em;margin:0;line-height:1.05}
.onb-pick-wordmark .rose{color:var(--rose)}
.onb-pick-wordmark .cream{color:var(--ink-on-olive)}
.onb-pick-tagline{margin:0;font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:rgba(245,238,216,.7);font-weight:500}
.onb-pick-tagline .dot{margin:0 6px;color:var(--rose)}

.onb-pick-kicker{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:rgba(245,238,216,.72);font-weight:600;margin-top:0}
.onb-pick-title{font-family:'Cal Sans',serif;font-size:clamp(28px,5vh,46px);font-weight:500;color:#f4ecd6;letter-spacing:-.025em;line-height:1.05;margin:0;max-width:680px;text-shadow:0 4px 24px rgba(0,0,0,.22)}
.onb-pick-title i{color:var(--rose);font-style:italic;font-weight:500}
.onb-pick-sub{font-size:clamp(13px,1.7vh,15px);color:rgba(245,238,216,.78);max-width:520px;margin:0;line-height:1.5}

/* Authed-only chunks of the pick-companion view — guest visitors see only
   the two Guides (James + Jane). Logged-in users reaching this screen via
   profile → Re-do introductions get the full 9-preset row revealed.
   Specificity is bumped via the doubled class selector so we win over the
   neighbouring `.onb-pick-grid` rule that also declares display:grid. */
.authed-only{display:none}
.onb-pick-grid.authed-only{display:none}
body.is-authed .onb-pick-section-label.authed-only{display:block}
body.is-authed .onb-pick-grid.authed-only{display:grid}

/* Section label between guide row and "more companions" row */
.onb-pick-section-label{
  font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(245,238,216,.6);font-weight:600;align-self:flex-start;
  width:100%;max-width:980px;margin:0 0 -10px;padding:0 6px;
}

/* Featured guide grid — bigger cards (2 across).
   Cards stay white so they pop above the foliage. Hover ring tints
   warm-cream rather than blush so the contrast against the green stays
   gentle, not jarring. */
.onb-pick-grid{display:grid;width:100%}
.onb-pick-grid--featured{grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(14px,2.4vh,22px);max-width:720px}
.onb-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:clamp(8px,1.4vh,12px);background:#fdf6e9;border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:clamp(16px,2.4vh,22px) 18px clamp(18px,2.4vh,22px);cursor:pointer;text-align:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;box-shadow:0 18px 40px rgba(12,18,4,.32);overflow:hidden}
.onb-card:hover{transform:translateY(-4px);box-shadow:0 22px 50px rgba(12,18,4,.42);border-color:var(--rose)}
.onb-card:focus-visible{outline:2px solid var(--rose);outline-offset:2px}
.onb-card-photo{width:clamp(120px,18vh,180px);aspect-ratio:1;border-radius:50%;overflow:hidden;background:var(--blush);box-shadow:0 12px 28px rgba(40,46,20,.20);position:relative}
.onb-card-photo img{width:100%;height:100%;object-fit:cover;display:block}
.onb-card-name{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(22px,3vh,28px);font-weight:500;color:var(--ink);letter-spacing:-.01em}
.onb-card-tag{font-size:clamp(11.5px,1.5vh,13px);color:var(--ink-soft);max-width:240px;line-height:1.4}
.onb-card-badge{
  position:absolute;top:14px;right:14px;
  font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  color:#fff;background:var(--rose);padding:4px 9px;border-radius:99px;
}
.onb-pick-foot{margin:0;color:rgba(245,238,216,.55);font-size:12px}

/* OAuth row at the bottom — match splash colours so buttons read as
   primary actions on the dark olive backdrop. */

#view-pick-companion .oauth-btn{background:var(--ink-on-olive);color:var(--olive-deep);border:0}
#view-pick-companion .oauth-btn:hover{background:#fff7e2}

/* "More companions" grid — 3 cols on wide, 2 on narrow, 1 on phone */
.onb-pick-grid--more{
  grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;max-width:980px;margin-top:8px;
}
.onb-pick-grid--more .onb-card{padding:18px 16px 22px;gap:10px;border-radius:20px}
.onb-pick-grid--more .onb-card-photo{width:140px;height:140px}
.onb-pick-grid--more .onb-card-name{font-size:24px}
.onb-pick-grid--more .onb-card-tag{font-size:12px;max-width:200px}

@media (max-width:900px){
  .onb-pick-grid--more{grid-template-columns:repeat(2,minmax(0,1fr));max-width:640px}
}
@media (max-width:640px){
  .onb-pick{padding:28px 16px 64px;gap:18px}
  .onb-pick-title{font-size:34px}
  .onb-pick-grid--featured{grid-template-columns:1fr;gap:18px;max-width:340px}
  .onb-pick-grid--more{grid-template-columns:repeat(2,1fr);gap:14px;max-width:340px}
  .onb-pick-grid--more .onb-card-photo{width:110px;height:110px}
  .onb-pick-grid--more .onb-card-name{font-size:20px}
  .onb-pick-grid--featured .onb-card-photo{width:160px;height:160px}
  .onb-pick-grid--featured .onb-card-name{font-size:26px}
}

/* ---- Onboarding chat ---- */
#view-onboarding{background:var(--bg);min-height:100vh;display:flex;flex-direction:column}
.onb-chat{display:flex;flex-direction:column;flex:1;max-width:720px;width:100%;margin:0 auto;height:100vh;max-height:100vh;padding:0}
.onb-chat-head{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 20px;background:rgba(241,234,215,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
/* The exit button is `position:absolute` for the pick-companion header
   (where it sits in the top-right corner). Inside the chat header it
   needs to flow as a normal flex item instead — otherwise it sticks to
   the right edge with no breathing room. */
.onb-chat-head .onb-exit{position:static;transform:none;width:36px;height:36px;border:1px solid var(--line);background:#fff;color:var(--ink);flex-shrink:0;backdrop-filter:none}
.onb-chat-head .onb-exit:hover{background:var(--bg);border-color:var(--blush-strong)}
.onb-chat-head .back,.onb-chat-head .ghost{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;flex-shrink:0}
.onb-chat-head .ghost{background:transparent;border:none;cursor:default}
.onb-chat-id{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.onb-chat-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;background:var(--blush);flex-shrink:0}
.onb-chat-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.onb-chat-name{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;font-size:18px;color:var(--ink);line-height:1}
.onb-chat-progress{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-top:3px}

.onb-chat-stream{flex:1;overflow-y:auto;padding:24px 20px 12px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth}
.onb-chat-stream::-webkit-scrollbar{width:6px}
.onb-chat-stream::-webkit-scrollbar-thumb{background:var(--blush-strong);border-radius:6px}

.onb-bubble{display:flex;gap:10px;align-items:flex-end;animation:onb-fade-in .35s ease both}
.onb-bubble-comp{justify-content:flex-start}
.onb-bubble-me{justify-content:flex-end}
.onb-bubble-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;background:var(--blush);flex-shrink:0}
.onb-bubble-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.onb-bubble-body{max-width:78%;padding:12px 16px;border-radius:20px;font-size:15.5px;line-height:1.55;color:var(--ink);box-shadow:var(--shadow-sm);font-family:'Inter',sans-serif}
.onb-bubble-comp .onb-bubble-body{background:#fff;border-bottom-left-radius:6px;border:1px solid var(--line)}
.onb-bubble-me .onb-bubble-body{background:var(--rose);color:#fff;border-bottom-right-radius:6px}
.onb-bubble-body p{margin:0 0 6px}
.onb-bubble-body p:last-child{margin-bottom:0}
@keyframes onb-fade-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* Reply panel — sticks at the bottom of the chat. */
.onb-chat-reply{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(241,234,215,0) 0%,var(--bg) 30%,var(--bg) 100%);padding:18px 20px 22px;border-top:1px solid transparent;z-index:4}
.onb-reply-panel{display:flex;flex-direction:column;gap:12px}
.onb-row{display:flex;gap:8px;align-items:stretch}
.onb-input{flex:1;font-family:'Inter',sans-serif;font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);outline:none;resize:vertical;line-height:1.5}
.onb-input:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(166,114,75,.15)}
textarea.onb-input{min-height:88px}

.btn.onb-send,.onb-send{display:inline-flex;align-items:center;gap:6px;padding:11px 18px;background:var(--rose);color:#fff;border:none;border-radius:14px;font-size:14.5px;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .2s,opacity .2s,transform .15s}
.onb-send:hover:not(:disabled){background:var(--cocoa);transform:translateY(-1px)}
.onb-send:disabled{opacity:.45;cursor:not-allowed}
.onb-send svg{width:16px;height:16px}

.onb-skip{align-self:flex-start;background:none;border:none;color:var(--ink-mute);font-size:13px;cursor:pointer;padding:4px 8px;text-decoration:underline;text-underline-offset:3px;font-family:'Inter',sans-serif}
.onb-skip:hover{color:var(--ink-soft)}

/* Chips ---------- */
.onb-chips-wrap{display:flex;flex-direction:column;gap:10px}
.onb-chips{display:flex;flex-wrap:wrap;gap:8px}
.onb-chip{padding:9px 16px;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:14px;color:var(--ink);cursor:pointer;font-family:'Inter',sans-serif;transition:all .18s ease}
.onb-chip:hover{border-color:var(--blush-strong);background:var(--blush)}
.onb-chip.on{background:var(--rose);border-color:var(--rose);color:#fff;box-shadow:0 4px 12px rgba(166,114,75,.25)}

/* Contact form ---------- */
.onb-contact{display:flex;flex-direction:column;gap:8px}
.onb-help{font-size:12.5px;color:var(--ink-mute);margin:2px 0;line-height:1.4}
.onb-help.err{color:var(--lip)}
.onb-help-link{color:var(--lip);font-weight:500;text-decoration:underline;margin-left:4px}
.onb-help-link:hover{color:var(--rose)}

/* Yes / No ---------- */
.onb-yesno .btn{flex:1}

/* Values priority picker ---------- */
.onb-values{display:flex;flex-direction:column;gap:12px}
.onb-values-grid{display:flex;flex-wrap:wrap;gap:6px;max-height:340px;overflow-y:auto;padding:4px;border:1px solid var(--line);border-radius:14px;background:#fff}
.onb-value-chip{position:relative;padding:7px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:12.5px;color:var(--ink);cursor:pointer;font-family:'Inter',sans-serif;letter-spacing:.04em;transition:all .15s ease}
.onb-value-chip:hover{border-color:var(--blush-strong)}
.onb-value-chip.on{background:var(--rose);border-color:var(--rose);color:#fff;padding-right:30px}
.onb-value-rank{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:18px;height:18px;background:#fff;color:var(--rose);border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Cal Sans',serif}

/* Avatar pick ---------- */
.onb-avatars{display:flex;flex-direction:column;gap:14px}
.onb-avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px;max-height:380px;overflow-y:auto;padding:4px}
.onb-avatar-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;border:1.5px solid var(--line);background:#fff;border-radius:16px;cursor:pointer;transition:all .18s ease}
.onb-avatar-card:hover{border-color:var(--blush-strong);transform:translateY(-2px)}
.onb-avatar-card.on{border-color:var(--rose);box-shadow:0 0 0 3px rgba(166,114,75,.15)}
.onb-avatar-photo{width:84px;height:84px;border-radius:50%;overflow:hidden;background:var(--blush)}
.onb-avatar-photo img{width:100%;height:100%;object-fit:cover;display:block}
.onb-avatar-label{font-size:12px;color:var(--ink-soft);font-family:'Inter',sans-serif}

/* Finalize state ---------- */
.onb-finalize{padding:20px;text-align:center;font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--ink-soft)}
.onb-finalize.err{color:var(--lip);font-style:normal;font-family:'Inter',sans-serif;font-size:14px}

@media (max-width:640px){
  .onb-chat-head{padding:12px 14px}
  .onb-chat-stream{padding:18px 14px 8px;gap:12px}
  .onb-chat-reply{padding:14px 14px 18px}
  .onb-bubble-body{font-size:14.5px;max-width:82%;padding:11px 14px}
  .onb-values-grid{max-height:280px}
  .onb-avatar-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}
  .onb-avatar-photo{width:68px;height:68px}
}

/* ============================================================
   Daily-goal home card (Phase C)
============================================================ */
.home-goal-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px 20px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.goal-kicker{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);font-weight:600;margin-bottom:8px}
.goal-q{font-family:'Cal Sans',serif;font-size:22px;font-weight:500;color:var(--ink);letter-spacing:-.01em;margin-bottom:10px;line-height:1.2}
.goal-row{display:flex;gap:10px;align-items:stretch}
.goal-input{flex:1;font-family:'Inter',sans-serif;font-size:15px;padding:11px 14px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--ink);outline:none}
.goal-input:focus{border-color:var(--rose);background:#fff;box-shadow:0 0 0 3px rgba(166,114,75,.12)}
.btn.goal-save,.goal-save{padding:11px 18px;background:var(--rose);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:background .2s}
.goal-save:hover:not(:disabled){background:var(--cocoa)}
.goal-pending{display:flex;flex-direction:column;gap:14px}
.goal-pending .goal-text,.goal-done .goal-text{font-family:'Playfair Display',serif;font-size:22px;color:var(--ink);font-style:italic;line-height:1.3}
.goal-actions{display:flex;gap:8px}
.goal-actions .btn{padding:8px 16px;font-size:13px;border-radius:10px}
.goal-tick{background:var(--olive)!important;color:var(--ink-on-olive)!important;border:none}
.goal-tick:hover{background:var(--olive-deep)!important}
.goal-done{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.goal-done-mark{color:var(--olive);font-weight:600;font-size:14px;letter-spacing:.04em}
.goal-undo{padding:6px 12px!important;font-size:12px!important;border-radius:8px!important}
.goal-loading{color:var(--ink-mute);font-size:13px;text-align:center;padding:8px 0}

/* ============================================================
   Love-language picker (onboarding step)
============================================================ */
.onb-love-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px}
.onb-love-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;border:1.5px solid var(--line);background:#fff;border-radius:14px;cursor:pointer;font-family:'Inter',sans-serif;text-align:left;transition:all .18s ease}
.onb-love-card:hover{border-color:var(--blush-strong);transform:translateY(-1px)}
.onb-love-card.on{border-color:var(--rose);background:#fff;box-shadow:0 0 0 3px rgba(166,114,75,.12)}
.onb-love-name{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;font-size:17px;color:var(--ink)}
.onb-love-hint{font-size:13px;color:var(--ink-mute);line-height:1.4}
@media (min-width:640px){.onb-love-grid{grid-template-columns:repeat(2,1fr)}}

/* ============================================================
   OAuth + passkey buttons (splash quick-row, login screen)
============================================================ */

.oauth-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.login-oauth{margin:14px 0 16px;justify-content:center}
/* Generic OAuth button shell — used by both Google + Apple */
.oauth-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:11px 22px;min-height:44px;min-width:200px;
  background:#fff;border:1px solid #dadce0;border-radius:24px;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  font-size:14px;font-weight:500;color:#1f1f1f;letter-spacing:.01em;
  cursor:pointer;transition:box-shadow .18s ease,border-color .18s ease,background .18s ease;
  -webkit-font-smoothing:antialiased;
}
.oauth-btn:hover{box-shadow:0 1px 3px rgba(60,64,67,.12),0 1px 2px rgba(60,64,67,.08);border-color:#d2e3fc;background:#f8fbff}
.oauth-btn:active{background:#f1f3f4}
.oauth-btn:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}
.oauth-btn.full{width:100%}

/* Official Google G mark — DO NOT recolour. 18px per Google brand guidelines */
.g-logo{width:18px;height:18px;flex-shrink:0;display:block}

/* Apple uses a single white-on-black aesthetic per their guidelines */
.apple-btn{background:#000;color:#fff;border-color:#000}
.apple-btn:hover{background:#1a1a1a;border-color:#1a1a1a;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.apple-btn:active{background:#2a2a2a}
.oauth-mark.a{display:inline-flex;width:18px;height:22px;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:18px;line-height:1}
.oauth-mark.a::before{content:"";display:block;width:14px;height:17px;background:currentColor;clip-path:polygon(50% 0,68% 4%,80% 18%,82% 32%,72% 42%,80% 56%,90% 70%,72% 90%,50% 100%,30% 96%,18% 80%,10% 60%,12% 40%,18% 26%,30% 12%);}

/* ============================================================
   Onboarding bubble streaming — typing dots + caret
============================================================ */
.onb-typing{display:inline-flex;gap:5px;align-items:center;padding:4px 0;height:18px}
.onb-typing > span{
  width:7px;height:7px;border-radius:50%;background:var(--ink-mute);display:inline-block;opacity:.4;
  animation:onb-bounce 1.2s infinite ease-in-out;
}
.onb-typing > span:nth-child(2){animation-delay:.15s}
.onb-typing > span:nth-child(3){animation-delay:.30s}
@keyframes onb-bounce{
  0%,100%{transform:translateY(0);opacity:.4}
  40%{transform:translateY(-4px);opacity:1}
}
.onb-stream-text{white-space:pre-wrap;font-size:15.5px;line-height:1.55;color:var(--ink);font-family:'Inter',sans-serif}
.onb-stream-caret{
  display:inline-block;color:var(--rose);margin-left:2px;font-weight:700;
  animation:onb-caret 1s infinite steps(2);
}
@keyframes onb-caret{0%,50%{opacity:1}51%,100%{opacity:0}}
@media (prefers-reduced-motion: reduce){
  .onb-typing > span,.onb-stream-caret{animation:none}
}

/* ============================================================
   Onboarding split layout — left brand+portrait, right chat.
   Replaces the previous single-column .onb-chat layout.
============================================================ */
#view-onboarding{background:var(--bg);min-height:100vh;display:flex;flex-direction:column;padding:0}
.onb-shell{display:flex;flex-direction:column;flex:1;width:100%;min-height:100vh}

.onb-side{display:none}  /* hidden on mobile */

/* Right pane — same as old .onb-chat container */
.onb-chat-pane{display:flex;flex-direction:column;flex:1;max-width:720px;width:100%;margin:0 auto;height:100vh;max-height:100vh;padding:0;background:var(--bg)}

/* Header — desktop hides chat-id (it's redundant with side panel) */
.onb-chat-pane .onb-chat-head{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:14px;padding:14px 20px;background:rgba(241,234,215,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
.onb-chat-pane .onb-chat-head .back{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;flex-shrink:0}
.onb-chat-pane .onb-chat-head .back:hover{border-color:var(--blush-strong)}
.onb-chat-id{display:flex;align-items:center;gap:10px;flex:1;min-width:0}

/* Progress dot bar — replaces "1 OF 15" text on desktop. */
.onb-progress-bar{display:flex;gap:6px;flex:1;align-items:center;justify-content:center;padding:0 16px}
.onb-pip{flex:1;max-width:24px;min-width:8px;height:6px;border-radius:3px;background:var(--line);transition:background .25s ease, transform .2s ease}
.onb-pip.done{background:var(--rose)}
.onb-pip.current{background:var(--rose);transform:scaleY(1.4);box-shadow:0 0 0 2px rgba(166,114,75,.18)}

/* === Desktop ≥1024px: split layout, full-bleed === */
@media (min-width:1024px){
  .onb-shell{flex-direction:row;min-height:100vh;height:100vh}
  /* Left side — olive bg + brand + portrait */
  .onb-side{
    display:flex;flex-direction:column;
    flex:0 0 42%;max-width:560px;
    background:linear-gradient(170deg,#3e4a2f 0%,#4f5536 55%,#5b6840 100%);
    color:var(--ink-on-olive);
    padding:48px max(40px,3.5vw) 56px;
    position:relative;overflow:hidden;
    text-align:center;align-items:center;
  }
  .onb-side::before{
    content:"";position:absolute;inset:0;
    background-image:url('/static/images/splash-bg.png');background-size:cover;background-position:center;
    opacity:.30;mix-blend-mode:soft-light;
  }
  .onb-side > *{position:relative;z-index:2}

  .onb-brand{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:auto}
  .onb-brand-ring{width:72px;height:72px;display:flex;align-items:center;justify-content:center}
  .onb-brand-ring img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}
  .onb-brand-name{font-family:'Cal Sans',serif;font-weight:500;font-size:22px;letter-spacing:-.01em;color:#fdf2dc}
  .onb-brand-tag{font-size:10px;letter-spacing:.32em;color:rgba(245,238,216,.72)}
  .onb-brand-tag .dot{margin:0 2px;color:var(--blush-strong)}

  .onb-side-stage{display:flex;flex-direction:column;align-items:center;gap:14px;margin:24px 0}
  /* Portrait — concentric box-shadow rings give the editorial halo without
     a separate positioned element (which was prone to drift off-centre). */
  .onb-side-portrait{
    width:240px;height:240px;border-radius:50%;overflow:hidden;
    margin:0 auto 6px;padding:0;background:var(--blush);
    box-shadow:
      0 18px 50px rgba(0,0,0,.36),
      inset 0 0 0 4px rgba(245,238,216,.18),
      0 0 0 14px rgba(245,238,216,.06),
      0 0 0 16px rgba(245,238,216,.22);
    animation:onb-portrait-in .6s ease both;
  }
  .onb-side-portrait img{
    width:100%;height:100%;object-fit:cover;object-position:center top;
    display:block;transition:transform 8s ease;
    animation:onb-portrait-pulse 14s infinite ease-in-out;
  }
  @keyframes onb-portrait-in{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
  @keyframes onb-portrait-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}

  .onb-side-name{font-family:'Playfair Display',serif;font-style:italic;font-weight:500;font-size:42px;line-height:1;color:#fdf2dc;margin:8px 0 0;letter-spacing:-.01em}
  .onb-side-role{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,238,216,.78);margin:6px 0 0;font-weight:500}

  .onb-side-quote{
    margin:auto 0 0;padding:28px 12px 0;border-top:1px solid rgba(245,238,216,.18);
    font-family:'Playfair Display',serif;font-style:italic;font-size:18px;line-height:1.5;color:rgba(245,238,216,.92);
    position:relative;
  }
  .onb-side-quote .quote-mark{position:absolute;left:-2px;top:14px;font-size:60px;line-height:1;color:var(--blush-strong);opacity:.55;font-family:'Cal Sans',serif;font-weight:600}
  .onb-side-quote{padding-left:38px;text-align:left}

  .onb-chat-pane{flex:1;max-width:none;height:100vh;border-left:none}
  .onb-chat-pane .onb-chat-stream{padding:32px 48px 12px;max-width:720px;margin:0 auto;width:100%}
  .onb-chat-pane .onb-chat-reply{padding:18px 48px 28px;max-width:720px;margin:0 auto;width:100%}
  .onb-chat-pane .onb-chat-id{display:none} /* redundant with side panel */
  .onb-progress-bar{justify-content:center;max-width:520px}
}

/* === Mobile <1024px: keep chat as primary, hide side === */
@media (max-width:1023px){
  .onb-progress-bar{flex:0 0 auto;max-width:none}
  .onb-pip{max-width:14px;min-width:6px;height:5px}
}
@media (max-width:640px){
  .onb-chat-pane .onb-chat-id{display:flex}
  .onb-progress-bar{display:none}
}

/* ============================================================
   Onboarding portrait picker — dedicated full-screen view that
   replaces the cramped inline avatar grid in the chat reply.
============================================================ */
#view-pick-portrait{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-deep) 100%);min-height:100vh;display:flex;flex-direction:column}
/* In-app portrait picker (reached from profile menu) reuses the onboarding
   shell's layout so 'Change their portrait' visually matches the onboarding
   pick-a-face step. Plain bg (no gradient) since it sits on top of app chrome. */
#view-portrait.view, #view-refine.view{display:flex;flex-direction:column;background:var(--bg)}
#view-portrait .onb-portrait-shell, #view-refine .onb-portrait-shell{padding-top:24px}
/* Refine view layout — portrait on the left, controls on the right at desktop;
   stacks on mobile. Mirrors the picker's two-pane layout for visual consistency. */
.refine-body{display:flex;gap:36px;align-items:flex-start;flex:1;padding:24px 0;flex-wrap:wrap;justify-content:center}
.refine-portrait-frame{width:340px;max-width:90vw;aspect-ratio:1;border-radius:32px;overflow:hidden;background:#fff;box-shadow:0 1px 0 rgba(60,40,30,.05);flex-shrink:0}
.refine-portrait-frame img{width:100%;height:100%;object-fit:cover;display:block}
.refine-controls{flex:1;min-width:300px;max-width:540px;display:flex;flex-direction:column;gap:16px;background:transparent;border-radius:24px;padding:24px 0;box-shadow:none}
.refine-controls .refine-input{width:100%;min-height:80px;border:1px solid rgba(60,40,30,.15);border-radius:14px;padding:12px 14px;font:inherit;resize:vertical;background:var(--bg)}
.refine-controls .refine-input:focus{outline:none;border-color:var(--lip)}
.refine-controls .refine-chips{display:flex;flex-wrap:wrap;gap:8px}
.refine-controls .refine-chips .chip{font-size:13px;padding:6px 12px;border-radius:999px;border:1px solid rgba(60,40,30,.15);background:var(--bg);cursor:pointer}
.refine-controls .refine-chips .chip:hover{border-color:var(--lip)}
.refine-controls .refine-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:4px}
.refine-controls .refine-done-row{margin-top:8px;border-top:1px solid rgba(60,40,30,.08);padding-top:16px}
.onb-portrait-shell{display:flex;flex-direction:column;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 24px 32px}

.onb-portrait-head{display:flex;align-items:flex-start;gap:18px;margin-bottom:24px}
.onb-portrait-head .back,.onb-portrait-head .ghost{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;flex-shrink:0}
.onb-portrait-head .ghost{background:transparent;border:none;cursor:default}
/* Match the back button style + position so the X sits in the same row,
   not absolute-anchored to the viewport corner. */
.onb-portrait-head .onb-exit{position:static;transform:none;width:40px;height:40px;border:1px solid var(--line);background:#fff;color:var(--ink);flex-shrink:0;backdrop-filter:none}
.onb-portrait-head .onb-exit:hover{background:var(--bg);border-color:var(--blush-strong)}
.onb-portrait-head-text{flex:1;text-align:center}
.onb-portrait-head-text .q-kicker{margin-bottom:6px}
.onb-portrait-title{font-family:'Cal Sans',serif;font-size:42px;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1.05;margin:0}
.onb-portrait-title i{color:var(--rose);font-style:italic;font-weight:500}
.onb-portrait-sub{font-size:15px;color:var(--ink-soft);margin:8px 0 0;line-height:1.5;max-width:520px;margin-left:auto;margin-right:auto}

/* Body — preview left, grid right (desktop) */
.onb-portrait-body{display:grid;grid-template-columns:300px 1fr;gap:36px;align-items:flex-start;margin-bottom:28px}

.onb-portrait-preview{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-sm);position:sticky;top:24px}
.onb-portrait-preview-frame{
  width:240px;height:240px;border-radius:50%;overflow:hidden;background:var(--blush);
  box-shadow:0 18px 40px rgba(40,46,20,.18),inset 0 0 0 4px rgba(245,238,216,.6),0 0 0 12px rgba(245,238,216,.5),0 0 0 14px var(--blush-strong);
  margin-bottom:8px;
}
.onb-portrait-preview-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.onb-portrait-preview-name{font-family:'Playfair Display',serif;font-style:italic;font-size:32px;font-weight:500;color:var(--ink);margin:0;letter-spacing:-.01em}
.onb-portrait-preview-tag{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin:0;text-align:center}

/* Right: grid of cards */
.onb-portrait-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;align-content:flex-start}
.onb-portrait-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px 14px;border:1.5px solid var(--line);background:#fff;border-radius:18px;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.onb-portrait-card:hover{border-color:var(--blush-strong);transform:translateY(-2px)}
.onb-portrait-card.on{border-color:var(--rose);box-shadow:0 0 0 3px rgba(166,114,75,.18)}
.onb-portrait-card-photo{width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--blush);box-shadow:0 6px 16px rgba(40,46,20,.10)}
.onb-portrait-card-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.onb-portrait-card-name{font-family:'Inter',sans-serif;font-size:13px;color:var(--ink-soft);font-weight:500}

.onb-portrait-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;align-items:center;padding:18px 0 8px;border-top:1px solid var(--line)}

.onb-portrait-genai{min-width:auto;padding:11px 20px;background:#fff;color:var(--ink);border:1px solid var(--line);font-weight:500;font-size:14px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border-radius:24px;transition:all .18s}
.onb-portrait-genai:hover:not(:disabled){border-color:var(--rose);background:#fff8f1}
.onb-portrait-genai:disabled{opacity:.65;cursor:wait}
.onb-portrait-genai .i{color:var(--rose)}
.onb-portrait-continue{padding:13px 32px;font-size:15px;border-radius:24px}

/* Mobile */
@media (max-width:880px){
  .onb-portrait-body{grid-template-columns:1fr;gap:20px}
  .onb-portrait-preview{position:static;padding:18px}
  .onb-portrait-preview-frame{width:180px;height:180px}
  .onb-portrait-preview-name{font-size:26px}
  .onb-portrait-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
  .onb-portrait-card-photo{width:72px;height:72px}
  .onb-portrait-title{font-size:32px}
}
@media (max-width:520px){
  .onb-portrait-shell{padding:20px 14px 24px}
  .onb-portrait-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .onb-portrait-actions{flex-direction:column;align-items:stretch}
  .onb-portrait-actions .btn,.onb-portrait-genai{width:100%;justify-content:center}
}

/* ============================================================
   In-onboarding customize page (view-onb-customize)
============================================================ */
#view-onb-customize{background:var(--bg);min-height:100vh;display:flex;flex-direction:column}
.onb-cust-shell{display:flex;flex-direction:column;flex:1;width:100%;max-width:780px;margin:0 auto;padding:0}
.onb-cust-head{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:14px;padding:14px 20px;background:rgba(241,234,215,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
.onb-cust-head .back,.onb-cust-head .ghost{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;flex-shrink:0}
.onb-cust-head .ghost{background:transparent;border:none;cursor:default}
.onb-cust-head .onb-exit{position:static;transform:none;width:36px;height:36px;border:1px solid var(--line);background:#fff;color:var(--ink);flex-shrink:0;backdrop-filter:none}
.onb-cust-head .onb-exit:hover{background:var(--bg);border-color:var(--blush-strong)}
.onb-cust-progress{display:flex;gap:6px;flex:1;align-items:center;justify-content:center;padding:0 16px;max-width:520px;margin:0 auto}
.onb-cust-body{padding:32px 24px 56px;display:flex;flex-direction:column;gap:18px}
.onb-cust-title{font-family:'Cal Sans',serif;font-size:38px;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1.05;margin:0 0 8px}
.onb-cust-title i{color:var(--rose);font-style:italic;font-weight:500}
.onb-cust-body .signup-sub{margin:0 0 18px}
.onb-cust-body #onbCustContinue{margin-top:14px;border-radius:24px;padding:14px 24px;font-size:15px}
@media (max-width:640px){
  .onb-cust-body{padding:24px 16px 48px}
  .onb-cust-title{font-size:30px}
  .onb-cust-progress{display:none}
}
/* Generating overlay shown after user clicks Create — covers the entire
   viewport so the form is visually replaced by a focused loader while signup +
   portrait gen runs. position:fixed (not absolute) so it stays centered on the
   viewport regardless of how tall the form behind is — otherwise on a long
   customize form the loader's middle ends up far below the fold and the user
   sees only the bottom of the form. */
.onb-cust-loader{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;background:rgba(244,236,227,.96);backdrop-filter:blur(6px);padding:24px;overflow-y:auto}
.onb-cust-loader[hidden]{display:none}
.onb-cust-shell{position:relative}
.onb-cust-loader-card{max-width:420px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;margin:auto}
.onb-cust-loader-spinner{width:54px;height:54px;border-radius:50%;border:3px solid rgba(168,99,76,.18);border-top-color:var(--lip);animation:onb-cust-spin 1s linear infinite;margin-bottom:8px}
.onb-cust-loader.is-error .onb-cust-loader-spinner{display:none}
@keyframes onb-cust-spin{to{transform:rotate(360deg)}}
/* Mobile: scale down spinner + title so the loader fits on tiny screens. */
@media (max-width:640px){
  .onb-cust-loader{padding:16px}
  .onb-cust-loader-card{gap:10px}
  .onb-cust-loader-spinner{width:44px;height:44px;margin-bottom:4px}
  .onb-cust-loader-title{font-size:24px !important}
  .onb-cust-loader-sub{font-size:14px}
}
.onb-cust-loader-title{font-family:'Cal Sans',serif;font-size:30px;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1.1;margin:0}
.onb-cust-loader-title i{color:var(--rose);font-style:italic;font-weight:500}
.onb-cust-loader-sub{margin:0;color:var(--ink-soft);font-size:15px}
.onb-cust-loader-err{margin:6px 0 0;color:#a83c3c;font-size:14px}
.onb-cust-loader-link{display:inline-block;margin-left:6px;color:var(--lip);font-weight:500;text-decoration:underline}
.onb-cust-loader-link:hover{color:var(--rose)}

/* ============================================================
   Onboarding stock-vs-customize chooser (view-onb-choose)
============================================================ */
#view-onb-choose{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-deep) 100%);min-height:100vh;display:flex;flex-direction:column}

/* === Updated chooser: 11-stock grid + bottom action row ===
   Big editorial 3-col grid — square-rounded cards, photo dominates, no
   name labels (the conversation already revealed the persona).
   Selected card gets a rose ring. */

/* Hide the name label inside chooser cards — the photo IS the choice. */

/* ============================================================
   Onboarding "Exit and start over" button — reused across all
   onboarding views' top bars. Sits opposite the back button.
============================================================ */
.onb-exit{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  background:#fff;color:var(--ink-soft);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;transition:all .18s;
}
.onb-exit:hover{border-color:var(--lip);color:var(--lip);background:#fff5f3}
.onb-exit:focus-visible{outline:2px solid var(--lip);outline-offset:2px}
.onb-exit .i{width:18px;height:18px}
/* Pick-companion has a centered head; absolutely position the exit so the
   centered title doesn't fight for the same row. */
#view-pick-companion .onb-exit{position:absolute;right:16px;top:0}
#view-pick-companion .onb-pick-head{position:relative;padding-top:0}

/* ============================================================
   V3 redesign — cream/sepia + copper accents (matches v2-ref).
   Replaces the older dark-gold global theme + v2 dark onboarding
   scope. Below: theme overrides + new component styles for
   splash, onboarding, chat, dream life.
   ============================================================ */

