:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}body{margin:0}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0b1020;--panel:#12182b;--muted:#94a3b8;--text:#e5e7eb;--accent:#5b9dff;--accent-2:#a78bfa;--border:#94a3b826;--user-bg:#1f2937;--bot-bg:#0f172a;--radius:16px;--shadow:0 10px 30px #00000059}html,body,#root{height:100%}body{background:radial-gradient(90rem 90rem at 80% -15%,#5b9dff40,transparent 40%),radial-gradient(80rem 80rem at -10% 10%,#a78bfa40,transparent 40%),var(--bg);color:var(--text);margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}.app-shell{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative}.hero{text-transform:lowercase;letter-spacing:.25rem;text-align:center;place-items:center;gap:1.25rem;display:grid}.hero img{filter:drop-shadow(0 18px 38px #3b82f666);width:clamp(160px,20vw,260px);height:auto}.hero h2{color:#61dafb;text-shadow:0 8px 30px #61dafb73;margin:0;font-size:clamp(3rem,8vw,6rem)}.version-badge{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);letter-spacing:.08em;background:#0f172aa6;border:1px solid #94a3b840;border-radius:999px;padding:.45rem .85rem;font-size:.95rem;position:fixed;bottom:1.5rem;left:1.5rem;box-shadow:0 12px 30px #00000059}.chat-widget{z-index:40;flex-direction:column;align-items:flex-end;gap:.75rem;max-width:calc(100vw - 3rem);display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.chat-window{border-radius:var(--radius);border:1px solid var(--border);width:min(420px,100vw - 3rem);height:min(620px,100vh - 6rem);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);opacity:0;pointer-events:none;visibility:hidden;background:#0c1123eb;transition:opacity .22s,transform .22s;overflow:hidden;transform:translateY(16px)scale(.96)}.chat-window.open{opacity:1;pointer-events:auto;visibility:visible;transform:translateY(0)scale(1)}.chat-launcher{cursor:pointer;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;width:60px;height:60px;box-shadow:var(--shadow);border:none;border-radius:50%;place-items:center;transition:transform .18s,box-shadow .18s,background .18s;display:grid}.chat-launcher:hover{transform:translateY(-2px);box-shadow:0 14px 30px #00000073}.chat-launcher.open{border:1px solid var(--border);color:var(--text);background:#0f172af2}.chat-launcher svg{width:26px;height:26px}.chat-launcher span{font-size:2rem;line-height:1}.chat-launcher:focus-visible,.icon-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app{background:linear-gradient(#090d19f2,#090d19cc);grid-template-rows:auto 1fr auto;height:100%;min-height:0;display:grid}header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}header .dot{background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px;width:10px;height:10px;box-shadow:0 0 12px #5b9dffcc}header h1{letter-spacing:.02em;margin:0;font-size:1rem}.title-group{flex-direction:column;flex:1;gap:.15rem;display:flex}header .sub{color:var(--muted);font-size:.85rem}.icon-button{cursor:pointer;color:var(--muted);background:#94a3b81f;border:none;border-radius:999px;place-items:center;width:32px;height:32px;margin-left:auto;padding:.35rem .5rem;transition:background .18s,color .18s;display:grid}.icon-button:hover{color:var(--text);background:#94a3b83d}.chat{flex-direction:column;gap:.75rem;height:100%;padding:1.25rem;display:flex;overflow-y:auto}.empty{text-align:center;color:var(--muted);max-width:42rem;margin:auto;padding:2rem;line-height:1.5}.msg{grid-template-columns:40px 1fr;align-items:flex-start;gap:.75rem;width:100%;max-width:1000px;margin-inline:auto;display:grid}.avatar{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-radius:12px;place-items:center;width:40px;height:40px;font-weight:700;display:grid}.avatar.user{background:linear-gradient(135deg,#22c55e,#16a34a)}.bubble{border:1px solid var(--border);background:var(--bot-bg);border-radius:calc(var(--radius) + 4px);box-shadow:var(--shadow);overflow-wrap:anywhere;padding:.9rem 1rem;line-height:1.55}.msg.user .bubble{background:var(--user-bg)}.meta{color:var(--muted);gap:.5rem;margin-top:.35rem;font-size:.78rem;display:flex}.typing{align-items:center;gap:.25rem;margin-left:.25rem;display:inline-flex}.dotty{background:var(--muted);opacity:.6;border-radius:999px;width:6px;height:6px;animation:1.2s ease-in-out infinite bounce}.dotty:nth-child(2){animation-delay:.15s}.dotty:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.composer-wrap{border-top:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1;background:linear-gradient(#ffffff05,#0000);padding:.85rem;position:sticky;bottom:0}.composer{align-items:flex-start;gap:.75rem;max-width:1000px;margin:auto;display:flex}textarea{box-sizing:border-box;resize:none;border-radius:var(--radius);border:1px solid var(--border);background:var(--panel);width:100%;min-height:56px;max-height:220px;color:var(--text);box-shadow:var(--shadow);outline:none;flex:auto;padding:.85rem .95rem;font-family:inherit;font-size:1rem;line-height:1.45;display:block}textarea::placeholder{color:var(--muted)}.btn{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;cursor:pointer;box-shadow:var(--shadow);justify-content:center;align-self:flex-start;align-items:center;min-width:96px;padding:.85rem 1rem;font-family:inherit;font-size:1rem;font-weight:600;display:flex}.btn[disabled]{opacity:.6;cursor:not-allowed}.toolbar{color:var(--muted);justify-content:space-between;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.8rem;display:flex}.toolbar .left{align-items:center;gap:1rem;display:flex}.linky{color:var(--muted);cursor:pointer;font:inherit;background:0 0;border:none;padding:0;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.hidden{display:none!important}pre,code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace}pre{white-space:pre-wrap;border:1px solid var(--border);background:#94a3b814;border-radius:12px;padding:.75rem;overflow:auto}
