:root{--carbon:#1e1e1e;--pine:#1f4a42;--pine-700:#163a33;--pine-50:#eaf1ef;--pine-100:#d3e2dd;--sand:#efd2a6;--sand-600:#e3bd84;--ink:#1e1e1e;--muted:#6b6f6c;--line:#e6e3dd;--bg:#f6f4ef;--card:#fff;--shadow:0 1px 2px #1118270f, 0 8px 24px #1118270f;--radius:18px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.app{background:var(--bg);flex-direction:column;max-width:720px;height:100dvh;margin:0 auto;display:flex}.topbar{z-index:10;background:var(--carbon);border-bottom:1px solid #000;padding:14px 16px 12px;position:sticky;top:0}.topbar-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.brand{align-items:center;gap:12px;min-width:0;display:flex}.menu{flex:none;position:relative}.menu-trigger{color:#fff;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff2e;border-radius:10px;place-items:center;width:34px;height:34px;font-size:18px;line-height:1;transition:background .15s;display:grid}.menu-trigger:hover{background:#ffffff21}.menu-pop{z-index:50;border:1px solid var(--line);background:#fff;border-radius:14px;flex-direction:column;gap:2px;min-width:232px;padding:6px;animation:.15s chips-in;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 12px 32px #0003}.menu-item{text-align:left;color:var(--ink);font:inherit;cursor:pointer;background:0 0;border:none;border-radius:10px;padding:11px 12px;font-size:14px;font-weight:600}.menu-item:hover:not(:disabled){background:var(--pine-50)}.menu-item:disabled{opacity:.4;cursor:not-allowed}.brand-mark{background:var(--sand);border-radius:12px;flex:none;place-items:center;width:38px;height:38px;font-size:18px;display:grid}.brand-text h1{letter-spacing:-.01em;color:#fff;margin:0;font-size:18px}.brand-text p{color:#a7aba6;margin:1px 0 0;font-size:12.5px}.progress-track{background:#ffffff24;border-radius:999px;height:6px;overflow:hidden}.progress-fill{background:var(--sand);border-radius:999px;height:100%;transition:width .5s cubic-bezier(.22,1,.36,1)}.progress-nodes{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;display:grid}.pnode{border:1px solid #0000;border-radius:12px;flex-direction:column;gap:2px;padding:6px 8px;display:flex}.pnode-label{color:#8e938f;font-size:12px;font-weight:650}.pnode-sub{color:#71756f;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.pnode.active{background:#efd2a61f;border-color:#efd2a66b}.pnode.active .pnode-label{color:var(--sand)}.pnode.active .pnode-sub{color:#d3bd95}.pnode.done .pnode-label{color:#dfe3e0}.pnode.done .pnode-label:before{content:"✓ ";color:var(--sand)}.thread{scroll-behavior:smooth;flex:1;overflow-y:auto}.thread-inner{flex-direction:column;gap:12px;padding:18px 16px 24px;display:flex}.row{display:flex}.row.user{justify-content:flex-end}.row.assistant{justify-content:flex-start}.bubble{border-radius:var(--radius);max-width:86%;box-shadow:var(--shadow);word-wrap:break-word;overflow-wrap:anywhere;padding:11px 15px;font-size:15.5px;line-height:1.5}.bubble.assistant{background:var(--card);color:var(--ink);border-bottom-left-radius:6px}.bubble.user{background:var(--pine);color:#fff;border-bottom-right-radius:6px}.bubble .line{margin:0}.bubble .line+.line{margin-top:2px}.bubble .gap{height:8px}.bubble .bullet{gap:8px;display:flex}.bullet-dot{color:var(--pine);flex:none}.bubble.user .bullet-dot{color:#9ec3ba}.caret{vertical-align:-2px;background:var(--pine);border-radius:2px;width:7px;height:16px;margin-left:2px;animation:1s steps(2,start) infinite blink;display:inline-block}@keyframes blink{to{opacity:0}}.bubble.typing{gap:5px;padding:14px 16px;display:inline-flex}.dot{background:#cbd5d1;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite bounce}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{opacity:.6;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.error{color:#b91c1c;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;align-self:center;max-width:92%;padding:10px 14px;font-size:13.5px}.dock{padding:10px 16px calc(12px + env(safe-area-inset-bottom));-webkit-backdrop-filter:saturate(180%)blur(12px);backdrop-filter:saturate(180%)blur(12px);border-top:1px solid var(--line);background:#f6f4efe6;position:sticky;bottom:0}.cta{background:var(--sand);color:var(--carbon);font:inherit;cursor:pointer;border:none;border-radius:12px;padding:12px 16px;font-size:14.5px;font-weight:700;transition:background .15s,transform 50ms,opacity .15s}.cta:hover:not(:disabled){background:var(--sand-600)}.cta:active{transform:scale(.99)}.cta:disabled{opacity:.5;cursor:not-allowed}.export-card{background:var(--pine-50);border:1px solid var(--pine-100);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;align-self:stretch;gap:12px;padding:16px;display:flex}.export-card-head{align-items:flex-start;gap:12px;display:flex}.export-card-emoji{flex:none;font-size:22px;line-height:1.2}.export-card-title{color:var(--pine);margin:0;font-size:15px;font-weight:700}.export-card-text{color:var(--muted);margin:2px 0 0;font-size:13.5px}.export-cta{width:100%}.composer{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:16px;align-items:flex-end;gap:8px;padding:6px 6px 6px 14px;display:flex}.composer-input{resize:none;font:inherit;max-height:160px;color:var(--ink);background:0 0;border:none;outline:none;flex:1;padding:8px 0;font-size:15.5px;line-height:1.45}.composer-input::placeholder{color:#aab0b8}.send{background:var(--pine);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:none;width:40px;height:40px;font-size:19px;transition:transform 50ms,background .15s,opacity .15s}.send:hover:not(:disabled){background:var(--pine-700)}.send:active{transform:scale(.95)}.send:disabled{opacity:.4;cursor:not-allowed}.composer-wrap{flex-direction:column;gap:6px;display:flex}.composer-notice{color:#b91c1c;padding:0 4px;font-size:12.5px}.composer.listening{border-color:#f1b6b6}.mic{border:1px solid var(--line);color:#7b817d;cursor:pointer;background:#fff;border-radius:12px;flex:none;place-items:center;width:40px;height:40px;transition:background .15s,color .15s,transform 50ms;display:grid}.mic:hover:not(:disabled){background:var(--pine-50);color:var(--pine)}.mic:active{transform:scale(.95)}.mic:disabled{cursor:not-allowed}.mic-recording{color:#d32f2f;background:#fde8e8;border-color:#f1b6b6;animation:1.3s ease-in-out infinite mic-pulse}.mic-transcribing{color:var(--muted)}@keyframes mic-pulse{0%,to{box-shadow:0 0 #d32f2f52}50%{box-shadow:0 0 0 6px #d32f2f00}}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chips{align-self:flex-start;gap:8px;max-width:96%;animation:.25s chips-in;display:flex}.chips-row{flex-wrap:wrap}.chips-list{flex-direction:column;align-items:stretch;width:100%;max-width:460px}@keyframes chips-in{0%{opacity:0;transform:translateY(4px)}}.chip{border:1.5px solid var(--pine-100);color:var(--pine);font:inherit;cursor:pointer;text-align:center;background:#fff;border-radius:999px;padding:9px 15px;font-size:14px;font-weight:600;transition:transform 50ms,background .15s,border-color .15s}.chips-list .chip{text-align:left;border-radius:14px;padding:13px 16px}.chip:hover{background:var(--pine-50);border-color:var(--pine)}.chip:active{transform:scale(.98)}.chip:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.pnode-label{font-size:11px}.pnode-sub{font-size:10px}.bubble{max-width:90%}}.gate{background:var(--bg);flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.gate-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:100%;max-width:360px;box-shadow:var(--shadow);text-align:center;padding:28px 24px}.gate-emoji{font-size:30px}.gate-title{color:var(--ink);margin:10px 0 4px;font-size:18px;font-weight:700}.gate-text{color:var(--muted);margin:0 0 18px;font-size:14px;line-height:1.5}.gate-input{box-sizing:border-box;border:1px solid var(--line);width:100%;font:inherit;color:var(--ink);background:#fff;border-radius:12px;margin-bottom:12px;padding:12px 14px;font-size:15px}.gate-input:focus{border-color:var(--pine);outline:none}.gate-cta{width:100%}
