/* ============ NetWorth — demo styles ============ */
:root{
  --bg:#0A0A0B;
  --panel:#131316;
  --panel2:#1A1A1F;
  --line:#232329;
  --txt:#F4F4F2;
  --dim:#8E8E96;
  --faint:#55555E;
  --money:#C2F75D;
  --money-dim:#94C636;
  --hot:#4ADE80;
  --warm:#FBBF24;
  --cold:#F87171;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,monospace;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --rad:14px;
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{height:100%}
body{
  font-family:var(--sans);background:#000;color:var(--txt);
  height:100%;min-height:100dvh;
  display:flex;justify-content:center;
  -webkit-font-smoothing:antialiased;
}
#phone{
  width:100%;max-width:440px;min-height:100dvh;
  background:var(--bg);position:relative;
  display:flex;flex-direction:column;
  box-shadow:0 0 80px rgba(0,0,0,.8);
}
@media(min-width:441px){#phone{border-left:1px solid var(--line);border-right:1px solid var(--line)}}

/* ---------- header ---------- */
#hdr{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(14px + env(safe-area-inset-top,0px)) 18px 12px;
  background:rgba(10,10,11,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.wordmark{font-family:var(--mono);font-weight:700;font-size:15px;letter-spacing:.14em}
.wordmark span{color:var(--money)}
.hdr-right{display:flex;align-items:center;gap:10px}
.watch-pill{
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--dim);
  border:1px solid var(--line);border-radius:99px;padding:4px 10px;
  display:inline-flex;align-items:center;gap:6px;
}
.watch-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--money);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.reset-btn{background:none;border:none;color:var(--faint);font-size:16px;cursor:pointer;padding:4px}

/* ---------- views ---------- */
.view{display:none;flex:1;padding:16px 16px 110px;overflow-y:auto}
.view.active{display:block}

/* ---------- today ---------- */
.day-strip{margin:4px 2px 14px}
.day-label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--money);text-transform:uppercase}
.day-sub{font-size:13px;color:var(--dim);margin-top:4px}

.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);
  padding:16px;margin-bottom:12px;position:relative;overflow:hidden;
  animation:rise .35s ease both;
}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.card.acted{opacity:.92}
.tag-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.tag{
  font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.12em;
  padding:3px 8px;border-radius:4px;text-transform:uppercase;
}
.tag.job{background:rgba(194,247,93,.12);color:var(--money)}
.tag.fund{background:rgba(74,222,128,.12);color:var(--hot)}
.tag.meet{background:rgba(96,165,250,.14);color:#60A5FA}
.tag.decay{background:rgba(248,113,113,.12);color:var(--cold)}
.tag.promo{background:rgba(251,191,36,.12);color:var(--warm)}
.tag-time{font-family:var(--mono);font-size:10px;color:var(--faint);margin-left:auto}
.t-head{display:flex;gap:12px;align-items:flex-start}
.avatar{
  width:42px;height:42px;border-radius:12px;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-weight:700;font-size:14px;
  background:var(--panel2);border:1px solid var(--line);color:var(--money);
}
.t-title{font-size:15px;font-weight:700;line-height:1.35}
.t-title em{color:var(--money);font-style:normal}
.t-why{font-size:13px;color:var(--dim);line-height:1.5;margin-top:6px}
.t-why b{color:var(--txt);font-weight:600}
.money-line{
  display:flex;align-items:center;gap:6px;margin-top:10px;
  font-family:var(--mono);font-size:11px;color:var(--money-dim);letter-spacing:.04em;
}
.btn-row{display:flex;gap:8px;margin-top:14px}
.btn-primary{
  flex:1;background:var(--money);color:#0A0A0B;border:none;border-radius:10px;
  font-family:var(--sans);font-size:13.5px;font-weight:700;padding:12px;cursor:pointer;
  transition:transform .08s;
}
.btn-primary:active{transform:scale(.97)}
.btn-ghost{
  flex:1;background:none;color:var(--dim);border:1px solid var(--line);border-radius:10px;
  font-size:13.5px;font-weight:600;padding:12px;cursor:pointer;
}
.btn-ghost:active{background:var(--panel2)}
.btn-mini{
  background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  border-radius:8px;font-size:12px;font-weight:600;padding:8px 12px;cursor:pointer;
}
/* sent / outcome state */
.sent-strip{
  display:flex;align-items:center;gap:8px;margin-top:14px;
  font-family:var(--mono);font-size:11px;color:var(--hot);letter-spacing:.05em;
}
.outcome-row{display:flex;gap:8px;margin-top:10px}
.outcome-row .btn-mini.win{border-color:rgba(194,247,93,.4);color:var(--money)}
.booked-stamp{
  margin-top:14px;border:1px dashed rgba(194,247,93,.45);border-radius:10px;
  padding:10px 12px;font-family:var(--mono);font-size:11px;color:var(--money);
  display:flex;justify-content:space-between;align-items:center;letter-spacing:.04em;gap:12px;
}
.booked-stamp button{background:none;border:none;color:var(--money);font-family:var(--mono);font-size:11px;cursor:pointer;text-decoration:underline}
.dead-stamp{margin-top:14px;font-family:var(--mono);font-size:11px;color:var(--faint)}

/* decay sub-list */
.decay-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.decay-item{
  display:flex;align-items:center;gap:10px;background:var(--panel2);
  border:1px solid var(--line);border-radius:10px;padding:10px 12px;
}
.decay-item .avatar{width:32px;height:32px;font-size:11px;border-radius:9px}
.decay-meta{flex:1;min-width:0}
.decay-meta b{font-size:13px;display:block}
.decay-meta span{font-size:11px;color:var(--cold);font-family:var(--mono)}
.decay-item .btn-mini{flex:none}

.quiet-note{text-align:center;padding:34px 30px 20px;color:var(--faint)}
.quiet-icon{font-size:22px;margin-bottom:10px;color:var(--line)}
.quiet-note p{font-size:12.5px;line-height:1.6}
.quiet-note span{color:#3D3D45}

/* ---------- network ---------- */
.search-wrap input{
  width:100%;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  color:var(--txt);font-size:14px;padding:12px 14px;outline:none;font-family:var(--sans);
}
.search-wrap input::placeholder{color:var(--faint)}
.seg{display:flex;gap:6px;margin:12px 0 14px}
.seg-btn{
  flex:1;background:none;border:1px solid var(--line);color:var(--dim);
  border-radius:99px;font-size:12px;font-weight:600;padding:7px;cursor:pointer;
}
.seg-btn.active{background:var(--txt);color:#0A0A0B;border-color:var(--txt)}
.c-row{
  display:flex;align-items:center;gap:12px;padding:12px 4px;
  border-bottom:1px solid var(--line);cursor:pointer;
}
.c-row:active{background:var(--panel)}
.c-meta{flex:1;min-width:0}
.c-meta b{font-size:14px;display:block}
.c-meta span{font-size:12px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.touch-pill{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:99px;flex:none}
.touch-pill.hot{color:var(--hot);background:rgba(74,222,128,.1)}
.touch-pill.warm{color:var(--warm);background:rgba(251,191,36,.1)}
.touch-pill.cold{color:var(--cold);background:rgba(248,113,113,.1)}
.c-new{font-family:var(--mono);font-size:9px;color:var(--money);border:1px solid rgba(194,247,93,.4);padding:2px 6px;border-radius:4px;margin-left:6px}

/* ---------- capture ---------- */
.cap-stage{display:flex;flex-direction:column;align-items:center;padding-top:8vh;text-align:center}
.mic-btn{
  width:96px;height:96px;border-radius:50%;cursor:pointer;
  background:var(--money);color:#0A0A0B;border:none;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 0 rgba(194,247,93,.35);
  animation:ring 2.6s infinite;transition:transform .1s;
}
.mic-btn:active{transform:scale(.94)}
@keyframes ring{0%{box-shadow:0 0 0 0 rgba(194,247,93,.3)}70%{box-shadow:0 0 0 26px rgba(194,247,93,0)}100%{box-shadow:0 0 0 0 rgba(194,247,93,0)}}
.cap-idle h2{font-size:20px;font-weight:800;margin-top:26px}
.cap-tag{font-size:13px;color:var(--dim);line-height:1.6;margin-top:8px}
.cap-alts{display:flex;flex-direction:column;gap:10px;margin-top:34px;width:100%;max-width:280px}
.alt-btn{
  display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);
  color:var(--txt);border-radius:12px;padding:13px 16px;font-size:13.5px;font-weight:600;cursor:pointer;
}
.alt-btn span{font-family:var(--mono);font-weight:700;color:var(--money);width:20px}
/* live */
.cap-live{width:100%;padding:0 8px}
.wave{display:flex;align-items:center;justify-content:center;gap:4px;height:64px;margin-top:4vh}
.wave i{width:4px;border-radius:3px;background:var(--money);animation:wv 1s ease-in-out infinite}
.wave i:nth-child(odd){animation-duration:.85s}
.wave i:nth-child(3n){animation-duration:1.2s}
@keyframes wv{0%,100%{height:10px}50%{height:52px}}
.cap-timer{font-family:var(--mono);font-size:13px;color:var(--money);margin:14px 0 22px}
.transcript{
  text-align:left;font-size:15px;line-height:1.7;color:var(--txt);
  background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);
  padding:18px;min-height:120px;width:100%;
}
.transcript .cursor{display:inline-block;width:8px;height:16px;background:var(--money);vertical-align:-2px;animation:pulse 1s infinite}
/* done */
.cap-done{width:100%}
.cap-stamp{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--money);margin:2vh 0 14px}
.built-card{
  text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:var(--rad);
  padding:18px;margin-bottom:16px;
}
.bc-head{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.bc-head .avatar{width:46px;height:46px}
.bc-head b{font-size:16px;display:block}
.bc-head span{font-size:12.5px;color:var(--dim)}
.bc-field{display:flex;gap:10px;padding:8px 0;border-top:1px solid var(--line);font-size:13px;align-items:baseline;animation:rise .3s ease both}
.bc-field label{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--faint);width:74px;flex:none;text-transform:uppercase}
.bc-field p{color:var(--txt);line-height:1.45;flex:1}
.bc-field .ok{color:var(--money);font-family:var(--mono);font-size:11px}
.cap-done .btn-primary{width:100%;margin-bottom:10px}
.cap-done .btn-ghost{width:100%}

/* ---------- score ---------- */
.score-hero{text-align:center;padding:26px 0 6px}
.score-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--dim)}
.score-big{
  font-family:var(--mono);font-weight:700;font-size:52px;letter-spacing:-.02em;
  color:var(--money);margin-top:10px;font-variant-numeric:tabular-nums;
}
.score-roi{font-size:12.5px;color:var(--dim);margin-top:8px}
.score-roi b{color:var(--txt)}
.score-row3{display:flex;gap:8px;margin:22px 0 26px}
.s3{
  flex:1;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px 8px;text-align:center;
}
.s3 b{font-family:var(--mono);font-size:18px;display:block;font-variant-numeric:tabular-nums}
.s3 span{font-size:10.5px;color:var(--dim);display:block;margin-top:4px}
.attr-head{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--faint);margin-bottom:10px}
.attr-item{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px;margin-bottom:10px;animation:rise .3s ease both;
}
.attr-top{display:flex;justify-content:space-between;align-items:baseline}
.attr-top b{font-family:var(--mono);font-size:16px;color:var(--money);font-variant-numeric:tabular-nums}
.attr-top span{font-family:var(--mono);font-size:10px;color:var(--faint)}
.attr-what{font-size:13px;font-weight:600;margin-top:6px}
.attr-src{font-size:12px;color:var(--dim);margin-top:4px;line-height:1.5}
.attr-src em{color:var(--money-dim);font-style:normal}
.attr-item.pending .attr-top b{color:var(--warm)}

/* ---------- tabbar ---------- */
#tabbar{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:440px;z-index:50;
  display:flex;justify-content:space-around;align-items:flex-end;
  background:rgba(10,10,11,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--line);
  padding:10px 8px calc(10px + var(--safe-b));
}
.tab{
  background:none;border:none;color:var(--faint);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  font-family:var(--sans);font-size:10px;font-weight:600;width:72px;position:relative;
}
.tab.active{color:var(--txt)}
.tab.active svg{color:var(--money)}
.tab-badge{
  position:absolute;top:-3px;right:18px;width:8px;height:8px;border-radius:50%;
  background:var(--money);
}
.cap-circle{
  width:46px;height:46px;border-radius:50%;background:var(--money);color:#0A0A0B;
  display:flex;align-items:center;justify-content:center;margin-top:-26px;
  border:4px solid var(--bg);box-shadow:0 4px 18px rgba(194,247,93,.25);
}
.tab-cap.active .cap-circle{background:var(--txt)}

/* ---------- sheet ---------- */
#scrim{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:60;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
#scrim.on{opacity:1;pointer-events:auto}
#sheet{
  position:fixed;bottom:0;left:50%;transform:translate(-50%,105%);
  width:100%;max-width:440px;z-index:61;
  background:var(--panel);border-radius:20px 20px 0 0;border:1px solid var(--line);border-bottom:none;
  max-height:86dvh;overflow-y:auto;
  transition:transform .3s cubic-bezier(.32,.72,.25,1);
  padding:10px 20px calc(24px + var(--safe-b));
}
#sheet.on{transform:translate(-50%,0)}
.sheet-grab{width:38px;height:4px;border-radius:2px;background:var(--line);margin:4px auto 14px}
.sh-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--money);text-transform:uppercase}
.sh-title{font-size:18px;font-weight:800;margin-top:6px}
.sh-sub{font-size:13px;color:var(--dim);margin-top:4px;line-height:1.5}
.draft-meta{display:flex;gap:8px;margin:16px 0 10px;flex-wrap:wrap}
.chip{
  font-family:var(--mono);font-size:10.5px;border:1px solid var(--line);color:var(--dim);
  border-radius:6px;padding:5px 9px;cursor:pointer;background:none;
}
.chip.sel{border-color:var(--money);color:var(--money)}
.draft-box{
  width:100%;background:var(--bg);border:1px solid var(--line);border-radius:12px;
  color:var(--txt);font-family:var(--sans);font-size:14px;line-height:1.65;
  padding:14px;min-height:170px;resize:vertical;outline:none;
}
.draft-box:focus{border-color:rgba(194,247,93,.4)}
.send-note{
  display:flex;align-items:center;gap:8px;margin:12px 0;
  font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.04em;
}
.send-note i{color:var(--money);font-style:normal}
.sheet-actions{display:flex;gap:10px;margin-top:6px}
/* brief sheet */
.brief-block{border-top:1px solid var(--line);margin-top:16px;padding-top:14px}
.brief-block h4{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--faint);margin-bottom:8px}
.brief-block ul{list-style:none}
.brief-block li{font-size:13.5px;line-height:1.6;color:var(--txt);padding-left:16px;position:relative;margin-bottom:7px}
.brief-block li::before{content:'·';position:absolute;left:2px;color:var(--money);font-weight:700}
.brief-block li b{font-weight:600}
/* value picker */
.val-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}
.val-btn{
  background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:12px;
  padding:18px 10px;cursor:pointer;text-align:center;
}
.val-btn b{font-family:var(--mono);font-size:17px;display:block;color:var(--money)}
.val-btn span{font-size:10.5px;color:var(--dim)}
.val-btn:active{border-color:var(--money)}
/* person sheet */
.p-head{display:flex;gap:14px;align-items:center;margin-bottom:4px}
.p-head .avatar{width:52px;height:52px;font-size:16px}
.p-watch{
  margin-top:16px;border:1px solid var(--line);border-radius:12px;padding:12px 14px;
  font-family:var(--mono);font-size:10.5px;color:var(--dim);line-height:1.8;letter-spacing:.03em;
}
.p-watch i{color:var(--money);font-style:normal}
.p-attr{margin-top:14px;font-size:13px;color:var(--dim)}
.p-attr b{color:var(--money);font-family:var(--mono)}
.timeline{margin-top:16px}
.tl-item{display:flex;gap:12px;margin-bottom:2px}
.tl-rail{display:flex;flex-direction:column;align-items:center}
.tl-dot{width:7px;height:7px;border-radius:50%;background:var(--money);flex:none;margin-top:5px}
.tl-line{width:1px;flex:1;background:var(--line);min-height:18px}
.tl-body{padding-bottom:14px}
.tl-body b{font-size:13px;display:block}
.tl-body span{font-family:var(--mono);font-size:10px;color:var(--faint)}
/* share win */
.win-card{
  background:linear-gradient(160deg,rgba(194,247,93,.14),rgba(194,247,93,.03));
  border:1px solid rgba(194,247,93,.4);border-radius:16px;padding:22px;text-align:center;margin:14px 0 18px;
}
.win-emoji{font-size:30px}
.win-card h3{font-size:17px;font-weight:800;margin-top:10px}
.win-card p{font-size:13px;color:var(--dim);margin-top:6px;line-height:1.5}
.win-card .wm{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;color:var(--money);margin-top:14px}

/* ---------- toast ---------- */
#toast{
  position:fixed;top:calc(18px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%,-80px);
  z-index:80;background:var(--txt);color:#0A0A0B;font-size:13px;font-weight:600;
  padding:11px 18px;border-radius:99px;transition:transform .35s cubic-bezier(.32,.72,.25,1);
  box-shadow:0 8px 30px rgba(0,0,0,.5);white-space:nowrap;max-width:92vw;overflow:hidden;text-overflow:ellipsis;
}
#toast.on{transform:translate(-50%,0)}

/* confetti */
.confetti{position:fixed;z-index:90;width:8px;height:8px;pointer-events:none;animation:fall 1.4s ease-in forwards}
@keyframes fall{to{transform:translateY(110vh) rotate(540deg);opacity:.2}}

/* ---------- urgency window ---------- */
.window-strip{margin-top:10px}
.window-strip .w-label{
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--warm);
}
.window-strip .w-label i{color:var(--faint);font-style:normal}
.w-bar{height:3px;border-radius:2px;background:var(--line);margin-top:6px;overflow:hidden}
.w-bar b{display:block;height:100%;background:var(--warm);border-radius:2px}

/* ---------- reply state ---------- */
.reply-bubble{
  margin-top:14px;background:rgba(74,222,128,.07);border:1px solid rgba(74,222,128,.3);
  border-radius:12px 12px 12px 4px;padding:12px 14px;animation:rise .35s ease both;
}
.reply-bubble .rb-meta{font-family:var(--mono);font-size:10px;color:var(--hot);letter-spacing:.08em;margin-bottom:6px}
.reply-bubble p{font-size:13.5px;line-height:1.55;color:var(--txt)}

/* ---------- push banner ---------- */
#pushBanner{
  position:fixed;top:calc(10px + env(safe-area-inset-top,0px));left:50%;
  transform:translate(-50%,-130%);width:calc(100% - 24px);max-width:416px;z-index:85;
  display:flex;gap:12px;align-items:center;text-align:left;
  background:#1C1C22;border:1px solid rgba(74,222,128,.35);border-radius:16px;
  padding:13px 15px;cursor:pointer;box-shadow:0 14px 44px rgba(0,0,0,.65);
  transition:transform .45s cubic-bezier(.32,.72,.25,1);
}
#pushBanner.on{transform:translate(-50%,0)}
.pb-avatar{
  width:38px;height:38px;border-radius:11px;flex:none;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-weight:700;font-size:13px;
  background:rgba(74,222,128,.12);color:var(--hot);border:1px solid rgba(74,222,128,.3);
}
.pb-body{min-width:0}
.pb-body b{display:block;font-size:13px;color:var(--txt)}
.pb-body span{display:block;font-size:12px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}

/* ---------- closed-won takeover ---------- */
#takeover{
  position:fixed;inset:0;z-index:100;background:rgba(8,9,7,.97);
  display:flex;align-items:center;justify-content:center;
  animation:toFade .3s ease both;
}
@keyframes toFade{from{opacity:0}to{opacity:1}}
.to-inner{text-align:center;padding:30px;width:100%;max-width:380px}
.to-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.34em;color:var(--money)}
.to-amount{
  font-family:var(--mono);font-weight:700;font-size:64px;color:var(--money);
  margin-top:18px;font-variant-numeric:tabular-nums;letter-spacing:-.02em;
  text-shadow:0 0 60px rgba(194,247,93,.35);
}
.to-sub{font-size:15px;font-weight:700;margin-top:12px}
.to-line{font-size:13px;color:var(--dim);margin-top:8px;line-height:1.6}
.to-line em{color:var(--money-dim);font-style:normal}
#takeover .btn-primary{width:100%;margin-top:30px}
#takeover .btn-ghost{width:100%;margin-top:10px}

/* ---------- closed? nudge on booked card ---------- */
.close-nudge{
  width:100%;margin-top:10px;background:none;cursor:pointer;
  border:1px solid rgba(194,247,93,.4);border-radius:10px;color:var(--money);
  font-family:var(--sans);font-size:13px;font-weight:700;padding:11px;
}
.close-nudge:active{background:rgba(194,247,93,.08)}

/* ---------- capture prompt card ---------- */
.tag.cap{background:rgba(194,247,93,.12);color:var(--money)}

/* ---------- intro paths ---------- */
.path-btn{
  width:100%;display:flex;align-items:center;gap:10px;margin-top:12px;
  background:linear-gradient(160deg,rgba(194,247,93,.1),rgba(194,247,93,.02));
  border:1px solid rgba(194,247,93,.35);border-radius:12px;color:var(--txt);
  font-family:var(--sans);font-size:13.5px;font-weight:700;padding:13px 16px;cursor:pointer;
}
.path-btn span{color:var(--money)}
.path-target{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:var(--panel2);border:1px solid var(--line);border-radius:12px;
  color:var(--txt);padding:14px;cursor:pointer;margin-bottom:10px;text-align:left;
}
.path-target b{font-size:14px;display:block}
.path-target span{font-size:11.5px;color:var(--dim);display:block;margin-top:2px}
.path-target i{font-family:var(--mono);font-style:normal;font-size:10px;color:var(--money);flex:none}
.path-viz{display:flex;align-items:center;gap:8px;margin:20px 0 6px;justify-content:center}
.path-node{text-align:center;flex:1;min-width:0}
.path-node .avatar{margin:0 auto 8px}
.path-node b{font-size:12px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.path-node span{font-size:10px;color:var(--dim);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.path-link{flex:none;display:flex;flex-direction:column;align-items:center;gap:3px;padding-bottom:26px}
.path-link i{font-family:var(--mono);font-style:normal;font-size:8.5px;letter-spacing:.1em;color:var(--money)}
.path-link .pl-line{width:34px;height:2px;background:var(--money);border-radius:2px;box-shadow:0 0 8px rgba(194,247,93,.5)}
.path-why{
  background:var(--panel2);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;font-size:13px;color:var(--dim);line-height:1.6;margin-top:14px;
}
.path-why b{color:var(--txt)}

/* ---------- first run ---------- */
#firstRun{
  position:fixed;inset:0;z-index:110;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
.fr-inner{width:100%;max-width:360px;padding:30px;text-align:center}
.fr-tag{font-size:14px;color:var(--dim);line-height:1.6;margin:14px 0 30px}
.fr-steps{text-align:left;min-height:120px}
.fr-step{
  display:flex;align-items:center;gap:10px;padding:9px 0;
  font-family:var(--mono);font-size:12px;color:var(--dim);
  animation:rise .3s ease both;
}
.fr-step i{font-style:normal;color:var(--money);width:14px}
.fr-step span{color:var(--faint);margin-left:auto;font-size:10.5px}
.fr-count{margin:18px 0 26px;animation:rise .4s ease both}
.fr-count b{font-family:var(--mono);font-size:56px;font-weight:700;color:var(--money);display:block;font-variant-numeric:tabular-nums}
.fr-count span{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--dim);display:block;margin-top:8px}
#frGo{width:100%}

/* hidden attr must beat display:flex on overlays */
#firstRun[hidden],#takeover[hidden],#pushBanner[hidden]{display:none}

/* score pulse when money lands */
@keyframes moneyPulse{0%{transform:scale(1)}40%{transform:scale(1.06);text-shadow:0 0 40px rgba(194,247,93,.6)}100%{transform:scale(1)}}
.score-big.pulse{animation:moneyPulse .7s ease}
