:root{--bg: #0c0d10;--bg-2: #15171d;--bg-3: #1b1e26;--ink: #f3f5f9;--ink-soft: #d7dce6;--muted: #99a1b2;--accent: #aaccf2;--accent-strong: #7fb0ec;--accent-ink:#0b0d12;--line: #262a33;--line-soft: #1f232b;--danger: #ff9d9d;--radius: 16px;--radius-lg: 22px;--shadow: 0 10px 40px rgba(0,0,0,.45);--shadow-soft: 0 6px 24px rgba(0,0,0,.35);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg)}.sky{min-height:100%;background:radial-gradient(1100px 560px at 82% -12%,rgba(127,176,236,.12) 0,transparent 60%),radial-gradient(820px 480px at 6% 112%,rgba(127,176,236,.07) 0,transparent 55%),var(--bg);color:var(--ink);display:flex;justify-content:center;padding:clamp(28px,6vw,84px) 18px}.hook{width:100%;max-width:660px}.frankie-line{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:clamp(22px,5vw,40px)}.logo-badge{width:clamp(124px,30vw,152px);height:clamp(124px,30vw,152px);border-radius:var(--radius-lg);background:#fff;display:grid;place-items:center;padding:12px;box-shadow:var(--shadow),0 0 0 1px #aaccf240,0 0 36px #7fb0ec2e;margin-bottom:22px}.logo-badge img{width:100%;height:100%;object-fit:contain;display:block}.opener{font-size:clamp(1.18rem,3.4vw,1.62rem);line-height:1.5;letter-spacing:-.01em;margin:0;color:var(--ink);max-width:30ch}.ask{display:flex;flex-direction:column;gap:24px;margin-top:clamp(20px,4vw,32px)}.field{display:flex;flex-direction:column;gap:11px}.field>span{color:var(--ink-soft);font-size:.96rem;font-weight:500}input[type=number]{background:var(--bg-2);border:1px solid var(--line);color:var(--ink);border-radius:14px;padding:14px 16px;font-size:1.1rem;width:168px;outline:none;transition:border-color .15s,box-shadow .15s}input[type=number]::placeholder{color:#6b7384}input[type=number]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #aaccf22e}.bands{display:flex;flex-wrap:wrap;gap:10px}.band{background:var(--bg-2);border:1px solid var(--line);color:var(--ink-soft);padding:11px 17px;border-radius:999px;cursor:pointer;font-size:.97rem;transition:border-color .15s,background .15s,color .15s,transform .05s}.band:hover{border-color:var(--accent);color:var(--ink)}.band:active{transform:translateY(1px)}.band.selected{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.go{align-self:flex-start;background:var(--accent);color:var(--accent-ink);border:none;border-radius:14px;padding:14px 24px;font-size:1.02rem;font-weight:700;letter-spacing:.01em;cursor:pointer;box-shadow:var(--shadow-soft);transition:background .15s,transform .05s,box-shadow .15s}.go:hover:not(:disabled){background:var(--accent-strong)}.go:active:not(:disabled){transform:translateY(1px)}.go:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.error{color:var(--danger);margin:0;font-size:.98rem}.result{display:flex;flex-direction:column;gap:28px}.frankie-says{font-size:clamp(1.18rem,3.4vw,1.58rem);line-height:1.58;letter-spacing:-.01em;margin:0;color:var(--ink)}.stars{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:560px){.stars{grid-template-columns:repeat(3,1fr)}}.stat{background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:17px;display:flex;flex-direction:column;gap:7px;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),transparent);opacity:.7}.stat-label{color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.28rem;font-weight:700;color:var(--ink)}.stat-sub{color:var(--muted);font-size:.8rem}.transition{border-top:1px solid var(--line);padding-top:24px;display:flex;flex-direction:column;gap:16px;align-items:flex-start}.transition p{margin:0;color:var(--ink-soft);font-size:1.06rem;line-height:1.55}.transition em{color:var(--accent);font-style:normal;font-weight:600}.link{background:none;border:none;color:var(--muted);cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:0;font-size:.95rem}.link:hover{color:var(--ink-soft)}.sources{color:var(--muted);font-size:.76rem;line-height:1.6}.sources a{color:var(--accent);text-decoration:none}.sources a:hover{text-decoration:underline}@media(prefers-reduced-motion:reduce){*{transition:none!important}.spark.lit,.sky-image.is-complete{animation:none!important}}.brandmark{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:22px}.brandmark .tag{display:block;filter:drop-shadow(0 0 22px rgba(127,176,236,.22))}.wordmark{font-size:clamp(2.1rem,7vw,2.7rem);font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1}.onboarding-context{color:var(--muted);font-size:.95rem;margin:-8px 0 0}.chat-sky{padding:0;align-items:stretch}.chat{width:100%;max-width:720px;height:100dvh;display:flex;flex-direction:column}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line-soft)}.logo-badge-sm{width:44px;height:44px;border-radius:11px;padding:5px;margin-bottom:0;box-shadow:0 0 0 1px #aaccf240}.chat-log{flex:1;overflow-y:auto;padding:22px 16px;display:flex;flex-direction:column;gap:14px}.msg{display:flex}.msg.user{justify-content:flex-end}.msg.frankie{justify-content:flex-start}.bubble{max-width:82%;padding:12px 15px;border-radius:16px;line-height:1.5;font-size:1.02rem;white-space:pre-wrap;word-wrap:break-word}.msg.frankie .bubble{background:var(--bg-2);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:6px}.msg.user .bubble{background:var(--accent);color:var(--accent-ink);font-weight:500;border-bottom-right-radius:6px}.bubble.typing{color:var(--muted)}.chat-input-row{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line-soft)}.chat-input{flex:1;background:var(--bg-2);border:1px solid var(--line);color:var(--ink);border-radius:14px;padding:13px 15px;font-size:1.02rem;outline:none;transition:border-color .15s,box-shadow .15s}.chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #aaccf22e}.chat-input:disabled{opacity:.6}.chat-send{align-self:auto}.chat-meta{color:var(--muted);font-size:.85rem;text-align:center;margin:4px 0}.chat-error{text-align:center}.chat-header{position:relative;flex-direction:column;gap:8px;padding:18px 16px 12px}.chat-signout{position:absolute;top:14px;right:16px}.chat-constellation{width:clamp(96px,22vw,124px);height:clamp(96px,22vw,124px);transition:opacity .6s ease}.chat-constellation img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 0 16px rgba(127,176,236,.25))}.constellation-caption{margin:0;color:var(--muted);font-size:.9rem;letter-spacing:.01em}.chat-shell{display:flex;flex-direction:row;width:100%;max-width:1120px;height:100dvh;margin:0 auto}.constellation-pane{flex:0 0 40%;max-width:440px;order:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:28px;border-left:1px solid var(--line-soft);cursor:pointer;text-align:center}.constellation-art{width:min(100%,340px);aspect-ratio:1 / 1;transition:opacity .6s ease}.constellation-art img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 0 28px rgba(127,176,236,.3))}.chat-topbar{display:flex;justify-content:flex-end;padding:12px 16px;border-bottom:1px solid var(--line-soft)}.constellation-overlay{position:fixed;inset:0;background:#0a0b0ff5;display:flex;align-items:center;justify-content:center;z-index:50;cursor:pointer}.constellation-overlay img{width:min(82vw,82vh);height:auto;filter:drop-shadow(0 0 40px rgba(127,176,236,.35))}@media(max-width:760px){.chat-shell{flex-direction:column;height:100dvh}.constellation-pane{flex:0 0 36vh;max-width:none;width:100%;order:-1;border-left:none;border-bottom:1px solid var(--line-soft);padding:14px 14px 10px;gap:8px}.constellation-art{width:min(64vw,240px)}}.constellation-pane{flex:0 0 44%;max-width:560px;order:2;position:relative;overflow:hidden;padding:0;cursor:pointer;border-left:1px solid var(--line-soft);border-right:none}.constellation-pane .sky-layer,.constellation-pane .face-layer,.overlay-sky .sky-layer,.overlay-sky .face-layer{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.constellation-pane .face-layer,.overlay-sky .face-layer{transition:opacity .6s ease}.constellation-caption{position:absolute;left:0;right:0;bottom:20px;margin:0;z-index:2;text-align:center;color:#d7e2f7;font-size:.95rem;letter-spacing:.01em;text-shadow:0 1px 12px rgba(0,0,0,.9)}.constellation-overlay{position:fixed;inset:0;background:#05070f;z-index:50;cursor:pointer;display:flex;align-items:center;justify-content:center}.overlay-sky{position:relative;width:min(94vw,94vh);height:min(94vw,94vh)}@media(max-width:760px){.constellation-pane{flex:0 0 36vh;max-width:none;width:100%;order:-1;border-left:none;border-bottom:1px solid var(--line-soft)}}.chat-sky{position:fixed;top:0;left:0;right:0;padding:0;height:100vh;height:100dvh;display:flex;justify-content:flex-start;align-items:stretch;background-color:#06070f}.sky-image{position:absolute;inset:0;z-index:0;pointer-events:none;background-image:url(/frankie-constellation.png);background-size:cover;background-position:64% center;background-repeat:no-repeat;filter:brightness(calc(.4 + .6 * var(--emerge, 0))) saturate(calc(.55 + .45 * var(--emerge, 0)));transition:filter 1.1s ease}.sky-image.is-complete{animation:sky-bloom 1.7s ease-out}@keyframes sky-bloom{0%{filter:brightness(1) saturate(1)}35%{filter:brightness(1.35) saturate(1.28)}to{filter:brightness(1) saturate(1)}}.mobile-hero{display:none;filter:brightness(calc(.45 + .55 * var(--emerge, 0))) saturate(calc(.6 + .4 * var(--emerge, 0)));transition:filter 1.1s ease}.sky-sparks{position:absolute;inset:0;z-index:1;pointer-events:none}.spark{position:absolute;width:19px;height:19px;margin:-9.5px 0 0 -9.5px;border-radius:50%;background:radial-gradient(circle,#fff,#dcebff 32%,#96c8ff00 70%);opacity:0;transform:scale(.25);transition:opacity .5s ease}.spark.lit{opacity:1;transform:scale(1);box-shadow:0 0 10px 3px #bedcffd9,0 0 26px 10px #82b4ff73;animation:spark-pop .85s ease-out,spark-halo 3.2s ease-in-out .85s infinite}@keyframes spark-pop{0%{opacity:0;transform:scale(.2)}45%{opacity:1;transform:scale(2.1)}to{opacity:1;transform:scale(1)}}@keyframes spark-halo{0%,to{box-shadow:0 0 9px 3px #bedcff99,0 0 20px 7px #82b4ff4d}50%{box-shadow:0 0 16px 6px #d2e6fff2,0 0 36px 14px #96beff8c}}.cluster-label{position:absolute;transform:translate(-50%,-50%) translateY(7px);padding:3px 11px;border-radius:999px;white-space:nowrap;font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#eaf2ff;background:#080c188c;border:1px solid rgba(150,190,255,.28);text-shadow:0 0 10px rgba(120,170,255,.7);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .9s ease,transform .9s ease}.cluster-label.lit{opacity:1;transform:translate(-50%,-50%) translateY(0)}.chat-pane{position:relative;z-index:2;order:0;flex:0 0 auto;width:min(40%,600px);height:100%;display:flex;flex-direction:column;background:#0a0c14;border-right:1px solid rgba(255,255,255,.07)}.stage{position:relative;z-index:1;order:1;flex:1 1 auto;min-width:0;height:100%;display:flex;flex-direction:column}.stage-sky{position:relative;flex:1 1 auto;min-height:0;overflow:hidden}.stage-data{position:relative;flex:0 0 64px;min-height:0;overflow:hidden;border-top:1px solid rgba(255,255,255,.08);background:#060810b8;transition:flex-basis .9s cubic-bezier(.22,.61,.36,1);display:flex;flex-direction:column;justify-content:center}.chat-sky.established .stage-data{flex-basis:42%}.stage-data-teaser{margin:0;padding:0 24px;text-align:center;color:#99a1b2;font-size:.9rem;letter-spacing:.01em}.cashflow{padding:18px 26px;display:flex;flex-direction:column;gap:14px;height:100%;box-sizing:border-box;justify-content:center}.cashflow.empty{align-items:center;justify-content:center}.cashflow-empty-text{color:#99a1b2;font-size:.95rem;text-align:center;max-width:420px}.cashflow-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.cashflow-title{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:#99a1b2}.cashflow-surplus{font-size:1.15rem;font-weight:700;font-variant-numeric:tabular-nums}.cashflow-surplus.pos{color:#7fe0b0}.cashflow-surplus.neg{color:#f0a0a0}.cashflow-bar{display:flex;width:100%;height:18px;border-radius:9px;overflow:hidden;background:#ffffff0f}.cashflow-bar .seg{height:100%;transition:width .8s ease}.cashflow-bar .seg.fixed{background:#5b6b8c}.cashflow-bar .seg.debt{background:#c9974a}.cashflow-bar .seg.surplus{background:#4f9d7e}.cashflow-legend{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:7px 22px}.cashflow-legend li{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#f3f5f9}.cashflow-legend li b{margin-left:auto;font-variant-numeric:tabular-nums}.cashflow-legend li.total{font-weight:700}.cashflow-legend .dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.cashflow-legend .dot.income{background:#cfe6ff}.cashflow-legend .dot.fixed{background:#5b6b8c}.cashflow-legend .dot.debt{background:#c9974a}.cashflow-legend .dot.surplus{background:#4f9d7e}@media(max-width:760px){.chat-sky{flex-direction:column;justify-content:flex-start}.stage{order:0;flex:0 0 42dvh;height:42dvh}.stage-sky{flex:1 1 auto;height:42dvh}.sky-image,.sky-sparks,.stage-data{display:none}.mobile-hero{display:block;width:100%;height:42dvh;object-fit:cover;object-position:center 42%;z-index:0}.chat-pane{order:1;width:100%;flex:1 1 auto;min-height:0;border-right:none;border-top:1px solid rgba(255,255,255,.08);background:#0a0c14}}.chat-menu-wrap{position:relative}.chat-menu-btn{background:var(--bg-3);border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;width:40px;height:40px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);transition:background .15s,color .15s,border-color .15s,transform .05s}.chat-menu-btn:hover{color:var(--ink);background:var(--bg-2);border-color:var(--accent)}.chat-menu-btn:active{transform:translateY(1px)}.chat-menu-btn[aria-expanded=true]{color:var(--ink);border-color:var(--accent);background:var(--bg-2)}.chat-menu-scrim{position:fixed;inset:0;z-index:40}.chat-menu{position:absolute;top:40px;right:0;z-index:41;min-width:184px;padding:6px;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);display:flex;flex-direction:column}.chat-menu-item{background:none;border:none;color:var(--ink-soft);text-align:left;padding:10px 12px;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .12s,color .12s}.chat-menu-item:hover{background:var(--bg-3);color:var(--ink)}.chat-menu-item.danger{color:var(--danger)}.chat-menu-item.danger:hover{background:#ff9d9d1a}.chat-menu-sep{height:1px;background:var(--line);margin:6px 4px}.modal-scrim{position:fixed;inset:0;z-index:60;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px}.modal{width:min(440px,100%);background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:24px}.modal-title{margin:0 0 10px;font-size:1.2rem;color:var(--ink)}.modal-body{margin:0 0 22px;color:var(--ink-soft);font-size:.98rem;line-height:1.55}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.btn-ghost{background:none;border:1px solid var(--line);color:var(--ink-soft);border-radius:12px;padding:11px 18px;font-size:.96rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn-ghost:hover:not(:disabled){border-color:var(--muted);color:var(--ink)}.btn-danger{background:var(--danger);color:#2a0d0d;border:none;border-radius:12px;padding:11px 18px;font-size:.96rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-soft);transition:filter .15s,transform .05s}.btn-danger:hover:not(:disabled){filter:brightness(1.08)}.btn-danger:active:not(:disabled){transform:translateY(1px)}.modal .go{align-self:auto}.btn-ghost:disabled,.btn-danger:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.fb-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.fb-cat{background:var(--bg-3);border:1px solid var(--line);color:var(--ink-soft);border-radius:999px;padding:7px 14px;font-size:.88rem;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.fb-cat:hover{border-color:var(--muted);color:var(--ink)}.fb-cat.selected{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.fb-textarea{width:100%;box-sizing:border-box;min-height:110px;resize:vertical;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:12px;padding:12px 14px;font:inherit;font-size:.98rem;line-height:1.5}.fb-textarea:focus{outline:none;border-color:var(--accent)}.fb-textarea::placeholder{color:var(--muted)}.dataviz{display:flex;flex-direction:column;gap:12px;height:100%}.dataviz-chips{display:flex;flex-wrap:wrap;gap:7px}.dataviz-chip{background:var(--bg-3);border:1px solid var(--line);color:var(--ink-soft);border-radius:999px;padding:6px 13px;font-size:.84rem;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:border-color .15s,background .15s,color .15s}.dataviz-chip:hover{border-color:var(--muted);color:var(--ink)}.dataviz-chip.active{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:600}.dataviz-chip.locked{color:var(--muted);opacity:.8}.dataviz-chip.locked.active{background:var(--bg-2);border-color:var(--line);color:var(--ink-soft)}.dataviz-lock{font-size:.72rem;opacity:.8}.dataviz-body{flex:1;min-height:0;display:flex;flex-direction:column}.dataviz-locked{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:18px}.dataviz-locked-icon{font-size:1.5rem;opacity:.6}.dataviz-locked-hint{color:var(--muted);font-size:.95rem;line-height:1.5;margin:0;max-width:320px}.payoff{display:flex;flex-direction:column;gap:14px}.payoff-head{display:flex;align-items:baseline;justify-content:space-between}.payoff-title{font-size:.95rem;font-weight:600;color:var(--ink)}.payoff-pay{font-size:.82rem;color:var(--muted)}.payoff-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.payoff-stat{background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:4px}.payoff-stat-value{font-size:1.16rem;font-weight:700;color:var(--ink)}.payoff-stat-label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.payoff-spark{display:flex;align-items:flex-end;gap:2px;height:88px;padding:8px;background:var(--bg);border:1px solid var(--line);border-radius:12px}.payoff-col{flex:1;background:linear-gradient(180deg,var(--accent),var(--accent-strong));border-radius:2px 2px 0 0;min-height:2px}.payoff-foot,.payoff-stall{font-size:.82rem;color:var(--muted);line-height:1.5;margin:0}.suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0 10px}.suggestion-chip{background:var(--bg-3);border:1px solid var(--line);color:var(--ink-soft);border-radius:999px;padding:9px 15px;font-size:.9rem;cursor:pointer;text-align:left;line-height:1.3;transition:border-color .15s,background .15s,color .15s,transform .05s}.suggestion-chip:hover{border-color:var(--accent);color:var(--ink);background:var(--bg-2)}.suggestion-chip:active{transform:translateY(1px)}
