/* Autogenic Labs — quiz-funnel component styles.
   Shared across all cell funnels (/c/<id>/q.html); per-cell content lives in
   that cell's funnel.config.js. Brand tokens come from /c/lp.css; this file
   adds funnel-only tokens + the screen/option/chip/thread/summary/identity
   components. Ported from the validated prototype
   (.superpowers/funnel-design/funnel-q2rawt-full.html) minus the review-only
   device frame and analytics debug panel. */

/* Funnel tokens. The funnel renders in the warm/light "candlelit" register
   only (it's its own full-viewport surface and does not theme-toggle), so it
   carries its own concrete values rather than depending on lp.css aliases —
   lp.css names some tokens differently (--muted-foreground vs --muted,
   --primary-foreground vs --primary-fg) and defines a different --shadow-sm. */
:root{
  --background:#F7F3EA; --card:#FDFBF4; --foreground:#1F1C16; --muted:#5E5847;
  --wordmark:#ABA28F; --border:#E8DFCC; --secondary:#EFE9D9;
  --primary:#2F8761; --primary-fg:#FDFBF4; --primary-700:#287153; --green-100:#D2EEDF; --green-800:#215C44;
  --cta:linear-gradient(135deg,#F4DC8E,#E6C461); --cta-hover:linear-gradient(135deg,#F1D578,#DCB94E); --cta-fg:#3A2B0A; --gold:#E6C461;
  --rb:12px; --rc:14px; --ri:10px; --rp:999px;
  --shadow-sm:0 2px 12px -5px rgba(31,28,22,.10),0 1px 3px -1px rgba(31,28,22,.04);
  --shadow-md:0 10px 28px -12px rgba(31,28,22,.14),0 2px 8px -4px rgba(31,28,22,.05);
  --font:'Plus Jakarta Sans',system-ui,sans-serif; --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
/* Full-viewport mobile page. Overrides the brand lp.css body (which centers a
   document column) — the funnel is its own scroll container, no document flow. */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background:var(--background);color:var(--foreground);font-family:var(--font);
  display:flex;flex-direction:column;overflow:hidden;position:relative;
  min-height:100%;max-width:none;padding:0}
/* Content frame: mobile = transparent full-viewport flex column (texture shows
   through behind the screens). Desktop = centered defined card (see @media
   below) while the texture stays full-bleed around it. */
.frame{flex:1 1 auto;min-height:0;width:100%;display:flex;flex-direction:column;position:relative;z-index:1}
.tex{position:absolute;inset:0;z-index:0;color:#1F1C16;opacity:.09;pointer-events:none;
  -webkit-mask-image:linear-gradient(to bottom,transparent 0,transparent 20%,#000 33%);mask-image:linear-gradient(to bottom,transparent 0,transparent 20%,#000 33%)}
.top{height:64px;flex:0 0 auto;position:relative;z-index:2;display:flex;align-items:center;justify-content:center;padding-top:18px}
.logo{position:absolute;top:24px;right:18px;display:flex;align-items:center;color:var(--wordmark);background:none;border:none;cursor:pointer;padding:4px}
.logo svg{height:22px;width:auto;display:block}
.back{position:absolute;left:14px;top:22px;background:none;border:none;color:var(--muted);font-size:1.35rem;line-height:1;cursor:pointer;padding:6px;display:none}
.back.on{display:block}
.progwrap{position:relative;display:flex;align-items:center}
.progwrap.hide{visibility:hidden}
.prog{width:148px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.prog>i{display:block;height:100%;width:0;background:var(--primary);border-radius:2px;transition:width .42s var(--ease)}
.progtxt{position:absolute;left:calc(100% + 9px);top:50%;transform:translateY(-50%);font-size:.6rem;font-weight:700;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
.stage{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1}
.scr{padding:14px 24px 30px;display:none;flex-direction:column;min-height:100%}
.scr.on{display:flex;animation:reveal .42s var(--ease)}
@keyframes reveal{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.spacer{flex:1;min-height:10px}
/* green-line label (replaces eyebrow pills) */
.glabel{font-size:.69rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:.9rem;display:flex;align-items:center;gap:.6rem}
.glabel::before{content:"";width:1.4rem;height:2px;background:var(--primary);border-radius:1px;flex:0 0 auto}
h1{font-size:1.78rem;font-weight:700;line-height:1.16;letter-spacing:-.015em;margin-bottom:.75rem}
h1.dim{font-size:1.5rem}
.lede{color:var(--muted);font-size:1.0625rem;line-height:1.55;margin-bottom:1.25rem;max-width:36ch}
.opts{display:flex;flex-direction:column;gap:.55rem;margin-top:.2rem}
.opt{display:flex;align-items:center;gap:.65rem;width:100%;text-align:left;background:var(--card);border:1px solid var(--border);border-radius:var(--rb);padding:.9rem 1rem;font:inherit;font-size:1.0625rem;color:var(--foreground);cursor:pointer;transition:border-color .12s,background .12s,transform .09s var(--ease);box-shadow:var(--shadow-sm)}
.opt:hover{border-color:var(--primary)}.opt:active{transform:scale(.99)}.opt.sel{border-color:var(--primary);background:var(--green-100)}
.opt .ov{flex:1;min-width:0}
.opt .rt{margin-left:.35rem;color:var(--primary);opacity:0;transition:opacity .12s}.opt.sel .rt{opacity:1}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.2rem}
/* Grouped-opener category label (n3mmxt "which of these have you used"). */
.glbl{font-size:.82rem;font-weight:600;color:var(--muted);margin:.95rem 0 .35rem}
.glbl:first-of-type{margin-top:.3rem}
.chip{display:inline-flex;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:var(--rp);padding:.5rem .85rem;font:inherit;font-size:.94rem;color:var(--foreground);cursor:pointer;transition:border-color .12s,background .12s,transform .09s}
.chip:active{transform:scale(.97)}.chip.sel{border-color:var(--primary);background:var(--green-100);font-weight:600;color:var(--green-800)}
.btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;min-height:54px;border:none;border-radius:var(--rb);font:inherit;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;transition:transform .09s var(--ease),background .12s}
.btn .chev{font-weight:800;font-size:1.2rem;line-height:1;margin-left:.1rem}.btn .ccode{font-family:var(--mono);letter-spacing:.06em}.btn .micon{flex:0 0 auto}
.btn:active{transform:scale(.985)}
.btn.cta{background:var(--cta);color:var(--cta-fg)}.btn.cta:hover{background:var(--cta-hover);transform:translateY(-1px)}
.btn.green{background:var(--primary);color:var(--primary-fg)}
.btn.ghost{background:none;color:var(--muted);min-height:40px;font-weight:500;font-size:.85rem;text-decoration:underline;text-underline-offset:2px}
.btn[disabled],.btn[disabled]:hover{background:var(--secondary);color:var(--wordmark);box-shadow:none;cursor:not-allowed;transform:none}
.btn.ghost[disabled],.btn.ghost[disabled]:hover{background:none;color:#cdbfa9}
.btn[aria-disabled="true"]{background:var(--secondary);color:var(--wordmark);box-shadow:none;cursor:not-allowed;pointer-events:none}
.btn.ghost[aria-disabled="true"]{background:none;color:#cdbfa9}
/* Error slot lives BELOW the stripe badge now; reserve no space when empty so
   "Secured by stripe" hugs the card field (no gap). */
.cardmsg{font-size:.82rem;color:#c0392b;line-height:1.4;min-height:0;margin:0}
.cardmsg:not(:empty){margin:.3rem 0 .1rem}
/* The Stripe card field mounts an iframe here. The mount MUST be a block:
   Stripe's iframe is `width:1px; min-width:100%`, which collapses to 1px inside
   a flex container (you then cannot type). Keep flex:1 for sizing within the
   .cardrow, but display:block so the iframe fills the width. Row height +
   vertical centering live on .cardrow. */
.cardbox .cf{flex:1;display:block;min-height:0;padding:0 .9rem}
.door{display:block;width:100%;text-align:left;border-radius:var(--rc);padding:1.05rem 1.15rem 2.6rem;cursor:pointer;font:inherit;transition:transform .14s var(--ease),border-color .14s,box-shadow .14s;margin-bottom:1.25rem;position:relative}
/* Tap affordance: a small directional chip in the bottom-right corner so the
   big text-heavy doors read as selectable. Per-door accent (B = recommended). */
.door .dgo{position:absolute;right:.95rem;bottom:.9rem;width:1.85rem;height:1.85rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.05rem;font-weight:800;line-height:1;color:var(--muted);background:var(--secondary);border:1px solid var(--border);transition:transform .14s var(--ease),color .14s,background .14s,border-color .14s}
.door.b .dgo{color:var(--primary)}
.door:hover .dgo,.door:active .dgo{transform:translateX(3px)}
.door.b:hover .dgo,.door.b:active .dgo{background:var(--cta);color:var(--cta-fg);border-color:transparent}
.door:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.door.b:hover{border-color:var(--primary-700)}
.door:active{transform:translateY(0) scale(.992);box-shadow:var(--shadow-sm)}
.door.a{background:var(--card);border:1.5px solid var(--border);box-shadow:var(--shadow-sm)}
.door.b{background:var(--card);border:1.5px solid var(--primary);box-shadow:var(--shadow-md);position:relative}
.door .rec{position:absolute;top:-10px;right:14px;background:var(--cta);color:var(--cta-fg);font-size:.6rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.2rem .55rem;border-radius:var(--rp)}
.door .recb{position:absolute;top:-10px;right:14px;background:var(--green-100);color:var(--green-800);border:1px solid #bfe0cd;font-size:.6rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.2rem .55rem;border-radius:var(--rp)}
.door .dt{font-size:.62rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.door.b .dt{color:var(--primary)}
.door h3{font-size:1.12rem;font-weight:700;margin-bottom:.25rem;color:var(--foreground)}.door p{font-size:.92rem;color:var(--muted);line-height:1.45}
.thread{display:flex;flex-direction:column;gap:.55rem;margin:.4rem 0 .2rem}
.bub{max-width:84%;padding:.7rem .9rem;font-size:1.0625rem;line-height:1.45;border-radius:18px;animation:bub .36s var(--ease) both}
@keyframes bub{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}
.bub.you{align-self:flex-end;background:var(--secondary);color:var(--foreground);border-bottom-right-radius:4px}
.bub.ag{align-self:flex-start;background:var(--card);color:var(--foreground);border:1px solid var(--border);border-bottom-left-radius:4px}
.bub.ag .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary);margin-right:.4rem;vertical-align:middle}
.bub.d2{animation-delay:.5s}
/* summary tags (display only) */
.sg{margin-bottom:.1rem}
.sg .sgl{font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}
.tag{display:inline-flex;align-items:center;gap:.35rem;background:var(--secondary);border:1px solid var(--border);border-radius:var(--rp);padding:.32rem .7rem;font-size:.9rem;color:var(--foreground)}
.tag .ck{color:var(--primary);display:flex}.tag .ck svg{width:13px;height:13px}
.setup{display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--muted);margin-top:.3rem}
.setup .ring{width:13px;height:13px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* identity graphic */
.idgfx{margin:.4rem 0 1.2rem}
.idgfx svg{width:100%;height:auto;display:block}
.idgfx .track{stroke:var(--border);stroke-width:2;stroke-dasharray:3 7;stroke-linecap:round}
.idgfx .pack{fill:var(--wordmark)}
.idgfx .youdot{transform:translateX(-86px);animation:slideAhead 1.3s var(--ease) .15s both}
@keyframes slideAhead{to{transform:translateX(0)}}
.idgfx .you{fill:var(--primary)}
.idgfx .ysp{fill:var(--gold);transform-origin:center;animation:spark .3s var(--ease) 1.15s both}
@keyframes spark{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
.idgfx .lbl{font:600 11px var(--font);letter-spacing:.04em}
.idgfx .lbl.g{fill:var(--green-800)}.idgfx .lbl.m{fill:var(--muted)}
.idlines{display:flex;flex-direction:column;gap:.55rem;margin-bottom:.2rem}
.idline{font-size:1.0625rem;line-height:1.45;color:var(--foreground)}
.idline.m{color:var(--muted);font-size:.96rem}
/* google */
.gbtn{display:flex;align-items:center;justify-content:center;gap:.65rem;width:100%;min-height:50px;background:#fff;border:1px solid #dadce0;border-radius:var(--rb);font-family:'Plus Jakarta Sans',Roboto,sans-serif;font-weight:600;font-size:.98rem;color:#3c4043;cursor:pointer;transition:background .12s,box-shadow .12s}
.gbtn:hover{background:#f8faff;box-shadow:0 1px 3px rgba(60,64,67,.15)}
.gsi-wrap{display:flex;justify-content:center;min-height:44px}
.orline{display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.8rem;margin:.9rem 0}
.orline::before,.orline::after{content:"";flex:1;height:1px;background:var(--border)}
.inp{width:100%;min-height:50px;background:var(--card);border:1px solid var(--border);border-radius:var(--ri);padding:0 .9rem;font:inherit;font-size:1.0625rem;color:var(--foreground)}
.inp::placeholder{color:var(--wordmark)}
.inp:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(47,135,97,.15)}
/* card form */
.cardhead{display:flex;align-items:baseline;justify-content:space-between;margin:.15rem 0 .45rem}
.cardhead-l{font-size:.95rem;font-weight:600;color:var(--foreground)}
.cardhead-r{font-size:.8rem;font-weight:600;color:var(--green-800);background:var(--green-100);padding:.15rem .5rem;border-radius:var(--rp)}
.cardbox{border:1px solid var(--border);border-radius:var(--ri);background:var(--card);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:.45rem}
.cardrow{display:flex;align-items:center;min-height:54px;border-bottom:1px solid var(--border)}.cardrow:last-child{border-bottom:none}
.cardrow .ci{display:flex;align-items:center;padding-left:.85rem;color:var(--muted)}
.cf{flex:1;border:none;background:none;min-height:48px;padding:0 .85rem;font:inherit;font-size:1.0625rem;color:var(--foreground);letter-spacing:.02em}
.cf:focus{outline:none}.cf::placeholder{color:var(--wordmark)}
.cardrow.split .cf{border-left:1px solid var(--border)}.cardrow.split .cf:first-child{border-left:none}
.stripebadge{display:flex;align-items:center;justify-content:flex-end;gap:.35rem;font-size:.72rem;color:var(--muted);margin:.3rem 0 .9rem}
.stripebadge b{color:#635bff;font-weight:700}
.rr{display:flex;flex-direction:column;gap:.55rem;background:var(--green-100);border-radius:var(--rc);padding:.9rem 1rem;margin:.2rem 0 1rem}
.rr .r{display:flex;gap:.55rem;align-items:center;font-size:.88rem;color:var(--green-800);font-weight:500}
.rr .r .ck{color:var(--primary);flex:0 0 auto;display:flex}.rr .r .ck svg{width:15px;height:15px}
.rr .r span.t{font-weight:500;color:var(--green-800)}
.agree{display:flex;gap:.6rem;align-items:center;justify-content:center;font-size:.85rem;color:var(--wordmark);line-height:1.45;margin:.3rem 0 1rem;cursor:pointer}
.agree input{margin-top:.05rem;width:22px;height:22px;accent-color:var(--primary);flex:0 0 auto}
.agree a{color:var(--muted);text-decoration:underline}
.plan{border:1px solid var(--border);border-radius:var(--rc);background:var(--card);box-shadow:var(--shadow-sm);padding:.8rem .95rem;margin:.1rem 0 1.1rem}
.plan .prow{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}
.plan .pl{font-size:.94rem;font-weight:600;color:var(--foreground)}
.plan .pp{font-size:1.2rem;font-weight:700;color:var(--foreground)}.plan .pp small{font-size:.78rem;font-weight:600;color:var(--muted)}
.plan .pnote{font-size:.8rem;color:var(--muted);margin-top:.25rem}
.pdtoggle{background:none;border:none;color:var(--wordmark);font:inherit;font-size:.74rem;font-weight:500;cursor:pointer;padding:.4rem 0 0;display:flex;align-items:center;gap:.3rem}
.pchev{display:inline-block;transition:transform .2s}.pchev.open{transform:rotate(180deg)}
.pdetails{margin-top:.55rem;display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--border);padding-top:.6rem}
.pdetails[hidden]{display:none}
.pdrow{font-size:.84rem;color:var(--muted);line-height:1.4}.pdrow b{color:var(--foreground)}
.setup.done{color:var(--green-800)}
.setup .dn{color:var(--primary);display:flex}.setup .dn svg{width:15px;height:15px}
.codecard{background:var(--card);border:1px solid var(--border);border-radius:var(--rc);padding:1.1rem 1.2rem;margin:.3rem 0 1.1rem;box-shadow:var(--shadow-sm);text-align:center}
.codecard .cl{font-size:.64rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.codecard .cv{font-family:var(--mono);font-size:1.55rem;font-weight:600;letter-spacing:.12em;color:var(--foreground);margin-top:.3rem}
.reassure{font-size:.86rem;color:var(--muted);text-align:center;line-height:1.5;margin-top:.7rem}
.fine{font-size:.72rem;color:var(--muted);line-height:1.6;border-top:1px solid var(--border);padding-top:.85rem;margin-top:.5rem}
.fine a{color:var(--primary-700);text-decoration:underline;text-underline-offset:2px}
.fine .kbd{font-family:var(--mono);font-size:.68rem;background:var(--secondary);padding:.05rem .35rem;border-radius:4px}

/* ---- keyboard affordances (Typeform-style). Hidden by default; shown only on
   desktop + fine pointer where a physical keyboard exists. ---- */
.okey,.ckey,.dkey{display:none}

/* ---- Desktop: keep the texture full-bleed; just constrain the content column
   and center it horizontally. The base layout is preserved (content top-aligned,
   spacer pushes the Continue/CTA to the bottom). ---- */
@media (min-width:760px){
  body{align-items:center}
  .frame{max-width:512px}
  .scr{padding:28px 30px 34px}
}
@media (min-width:760px) and (pointer:fine){
  .okey{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
    width:1.5rem;height:1.5rem;border:1px solid var(--border);border-radius:7px;
    background:var(--secondary);color:var(--muted);font-family:var(--mono);font-size:.74rem;
    font-weight:700;transition:border-color .12s,background .12s,color .12s}
  .opt:hover .okey{border-color:var(--primary)}
  .opt.sel .okey{border-color:var(--primary);background:var(--green-100);color:var(--green-800)}
  .ckey{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
    width:1.1rem;height:1.1rem;margin-right:.45rem;border-radius:5px;background:var(--secondary);
    color:var(--muted);font-family:var(--mono);font-size:.64rem;font-weight:700}
  .chip.sel .ckey{background:#bfe0cd;color:var(--green-800)}
  .dkey{display:inline-flex;align-items:center;justify-content:center;position:absolute;
    top:-10px;left:14px;width:1.4rem;height:1.4rem;border:1px solid var(--border);border-radius:7px;
    background:var(--card);color:var(--muted);font-family:var(--mono);font-size:.72rem;font-weight:700;
    box-shadow:var(--shadow-sm)}
}
</content>
</invoke>
