:root{--bg:#f7f7f8;--surface:#fff;--border:#e7e7ea;--text:#0f1115;--muted:#5f6368;--primary:#2563eb;--primary-ink:#fff;--user:#0ea5e9;--assistant:#e5e7eb;--code-bg:#f6f8fa;--code-border:#d1d9e0;--code-text:#24292f;--radius:14px;--shadow:0 1px 2px #0f11150f, 0 8px 24px #0f11150f}*{box-sizing:border-box}html,body,#root{height:100%}body{background:radial-gradient(1200px 800px at 80% -10%, #eef2ff 0%, #eef2ff00 60%), var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji}.app{grid-template-rows:auto 1fr;gap:16px;max-width:880px;height:100%;margin:0 auto;padding:24px 16px 16px;display:grid;overflow:hidden}.header,.header-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.brand{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:10px;padding:10px 14px;display:inline-flex}.brand .title{letter-spacing:.1px;font-weight:600}.picker{align-items:center;gap:8px;display:inline-flex}.picker-with-info{gap:10px}.picker-select{appearance:none;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;box-shadow:var(--shadow);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235f6368' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:999px;outline:none;padding:10px 32px 10px 14px;font-family:inherit;font-size:14px;font-weight:500;transition:border-color .16s,box-shadow .16s}.picker-select:hover{border-color:#93c5fd}.picker-select:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1f}.picker-select:disabled{opacity:.72;cursor:not-allowed}.info-tooltip{position:relative}.info-button{border:1px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--muted);cursor:help;box-shadow:var(--shadow);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.info-tooltip-content{border:1px solid var(--border);background:var(--surface);width:240px;color:var(--text);box-shadow:var(--shadow);opacity:0;pointer-events:none;z-index:2;border-radius:12px;padding:10px 12px;font-size:13px;line-height:1.4;transition:opacity .16s,transform .16s;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(-4px)}.info-tooltip:hover .info-tooltip-content,.info-tooltip:focus-within .info-tooltip-content{opacity:1;transform:translateY(0)}.chat{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);box-shadow:var(--shadow);grid-template-rows:1fr auto;gap:0;min-height:0;display:grid;overflow:hidden}.messages{scroll-behavior:smooth;padding:16px;overflow-y:auto}.msg{grid-template-columns:36px 1fr 36px;align-items:flex-end;gap:10px;margin:8px 0;display:grid}.msg.system .bubble{color:var(--muted);background:0 0;border:none;padding-left:0;font-style:italic}.msg .avatar{border:1px solid var(--border);background:#f0f2f5;border-radius:50%;place-items:center;width:36px;height:36px;font-size:16px;display:grid}.msg .bubble{background:var(--assistant);color:var(--text);border:1px solid var(--border);white-space:pre-wrap;border-radius:12px;padding:10px 12px;line-height:1.45}.msg.user{grid-template-columns:1fr 36px;justify-content:end}.msg.user .bubble{color:var(--primary-ink);background:linear-gradient(#38bdf8,#0ea5e9);border:none;justify-self:end}.msg.user .avatar{background:#e0f2fe;border-color:#bae6fd;order:2}.msg.assistant{grid-template-columns:36px 1fr}.msg.assistant .bubble{background:#f7f7f8}.bubble.thinking{color:var(--muted);font-style:italic}.bubble code{background-color:var(--code-bg);border:1px solid var(--code-border);border-radius:3px;padding:.2em .4em;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:85%;color:var(--code-text)!important}.bubble pre{background-color:var(--code-bg);border:1px solid var(--code-border);white-space:pre;word-wrap:break-word;border-radius:6px;margin:.75em 0;padding:16px;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;font-size:14px;line-height:1.45;overflow:auto}.bubble pre code{color:var(--code-text);font-size:inherit;background:0 0;border:none;padding:0;font-family:inherit}.bubble p{margin:.5em 0}.bubble p:first-child{margin-top:0}.bubble p:last-child{margin-bottom:0}.bubble ul,.bubble ol{margin:.5em 0;padding-left:1.5em}.bubble blockquote{border-left:3px solid var(--border);color:var(--muted);margin:.5em 0;padding-left:12px}.bubble table{border-collapse:collapse;margin:.5em 0}.bubble th,.bubble td{border:1px solid var(--border);text-align:left;padding:6px 10px}.bubble th{background:var(--code-bg);font-weight:600}.composer{border-top:1px solid var(--border);-webkit-backdrop-filter:saturate(180%)blur(8px);backdrop-filter:saturate(180%)blur(8px);background:linear-gradient(#fff9,#fff 60%);grid-template-columns:1fr auto;gap:10px;padding:12px;display:grid;position:sticky;bottom:0}.input{appearance:none;border:1px solid var(--border);border-radius:var(--radius);resize:none;-webkit-border-radius:var(--radius);box-sizing:border-box;touch-action:manipulation;background:#fff;outline:none;width:100%;min-height:44px;padding:12px 16px;font-family:inherit;font-size:16px;line-height:1.2;transition:box-shadow .16s,border-color .16s}.input:focus,.input:focus-visible{border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1f}.send{appearance:none;color:#fff;cursor:pointer;touch-action:manipulation;background:linear-gradient(#3b82f6,#2563eb);border:1px solid #1d4ed8;border-radius:999px;min-height:44px;padding:12px 18px;font-size:14px;font-weight:600;transition:transform 80ms,box-shadow .16s,opacity .16s;box-shadow:0 6px 16px #2563eb40}.send:hover:not(:disabled){transform:translateY(-1px)}.send:active:not(:disabled){transform:translateY(0)}.send:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.spinner{border:2px solid #ffffff73;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:-webkit-any(input:-webkit-autofill,textarea:-webkit-autofill){-webkit-text-fill-color:var(--text)!important;-webkit-box-shadow:inset 0 0 0 30px #fff!important}:is(input:autofill,textarea:autofill){-webkit-text-fill-color:var(--text)!important;-webkit-box-shadow:inset 0 0 0 30px #fff!important}@media (width<=640px){.app{height:100vh;min-height:100vh;height:-webkit-fill-available;min-height:-webkit-fill-available;padding:16px 8px}.messages{min-height:0;padding:12px}.chat{height:100%;min-height:0;margin-bottom:0}.composer{border-radius:0;flex-shrink:0;gap:8px;margin:0;padding:12px;position:sticky;bottom:0;left:auto;right:auto}.input{border-radius:8px;font-size:16px}.send{border-radius:8px;padding:10px 16px}.app{height:100dvh}.chat{height:100%;overflow:hidden}.messages{overscroll-behavior:contain;overflow-y:auto}}@supports (-webkit-touch-callout:none){@media (width<=640px){.app{height:100vh;height:-webkit-fill-available}.composer{padding-bottom:calc(12px + env(safe-area-inset-bottom))}.input{font-size:16px;transform:translateZ(0)}}}@media screen and (-webkit-device-pixel-ratio>=0){@media (width<=640px){.input{-webkit-text-size-adjust:100%}.app{height:100vh}}}
