:root{--emerald: #2f855a;--emerald-dark: #22543d;--emerald-strong: #276749;--emerald-soft: rgba(47, 133, 90, .1);--emerald-line: rgba(47, 133, 90, .32);--gold: #d69e2e;--gold-soft: rgba(214, 158, 46, .14);--ground: #f6f7f5;--surface: #ffffff;--surface-2: #eef1ee;--surface-3: #e7ebe7;--line: #e1e7e2;--line-soft: #edf1ed;--text: #15201b;--text-dim: #586a62;--text-faint: #8a988f;--danger: #c0392b;--on-emerald: #ffffff;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "Noto Sans Thai", "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, "SF Mono", "JetBrains Mono", "Menlo", "Consolas", monospace;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-15: .9375rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-22: 1.375rem;--fs-28: 1.75rem;--lh-body: 1.65;--lh-tight: 1.25;--tracking-tight: -.011em;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-8: 48px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-full: 999px;--shadow-1: 0 1px 2px rgba(16, 32, 27, .06), 0 1px 1px rgba(16, 32, 27, .04);--shadow-2: 0 12px 32px -12px rgba(16, 32, 27, .22);--ease: cubic-bezier(.22, .61, .36, 1);--fast: .14s;--med: .24s;--sidebar-w: 264px;--reading-w: 760px}[data-theme=dark]{--emerald-soft: rgba(47, 133, 90, .18);--emerald-line: rgba(47, 133, 90, .4);--gold-soft: rgba(214, 158, 46, .16);--ground: #0f1512;--surface: #151c19;--surface-2: #1b2420;--surface-3: #232e29;--line: #283531;--line-soft: #1f2925;--text: #e7ece9;--text-dim: #9db0a8;--text-faint: #6e7e78;--danger: #f1736a;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 16px 40px -16px rgba(0, 0, 0, .6)}@media (prefers-reduced-motion: reduce){:root{--fast: 0ms;--med: 0ms}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:var(--font-sans);font-size:var(--fs-15);line-height:var(--lh-body);color:var(--text);background:var(--ground);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#app{display:flex;flex-direction:column}button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}input,textarea{font:inherit;color:inherit}a{color:var(--emerald);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--emerald);outline-offset:2px;border-radius:var(--r-sm)}::selection{background:var(--emerald-soft)}*{scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:var(--r-full);border:3px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:var(--text-faint);background-clip:content-box}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100%;min-height:0}.sidebar{display:flex;flex-direction:column;min-height:0;background:var(--surface);border-right:1px solid var(--line)}.sidebar-header{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-4) var(--sp-3)}.brand{display:flex;align-items:center;gap:var(--sp-2);font-weight:650;letter-spacing:var(--tracking-tight);font-size:var(--fs-15)}.brand-mark{display:grid;place-items:center;width:26px;height:26px;color:var(--on-emerald);background:linear-gradient(150deg,var(--emerald),var(--emerald-dark));border-radius:7px;transform:rotate(45deg);box-shadow:var(--shadow-1)}.brand-mark>*{transform:rotate(-45deg)}.new-chat-btn{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);margin:0 var(--sp-3) var(--sp-3);padding:10px var(--sp-3);font-size:var(--fs-14);font-weight:600;color:var(--on-emerald);background:var(--emerald);border-radius:var(--r-md);transition:background var(--fast) var(--ease),transform var(--fast) var(--ease)}.new-chat-btn:hover{background:var(--emerald-strong)}.new-chat-btn:active{transform:translateY(1px)}.session-list{flex:1;min-height:0;overflow-y:auto;padding:0 var(--sp-2) var(--sp-2);display:flex;flex-direction:column;gap:2px}.session-list-label{padding:var(--sp-2) var(--sp-3) var(--sp-1);font-size:var(--fs-12);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint)}.session-item{position:relative;display:flex;align-items:center;gap:var(--sp-2);padding:9px var(--sp-3);border-radius:var(--r-md);cursor:pointer;color:var(--text-dim);transition:background var(--fast) var(--ease),color var(--fast) var(--ease)}.session-item:hover{background:var(--surface-2);color:var(--text)}.session-item.active{background:var(--emerald-soft);color:var(--text);box-shadow:inset 2px 0 0 var(--emerald)}.session-item-body{flex:1;min-width:0}.session-title{font-size:var(--fs-14);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-meta{font-size:var(--fs-12);color:var(--text-faint)}.session-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--fast) var(--ease)}.session-item:hover .session-actions,.session-item.active .session-actions{opacity:1}.session-rename-input{flex:1;min-width:0;background:var(--surface);border:1px solid var(--emerald-line);border-radius:var(--r-sm);padding:4px 8px;font-size:var(--fs-14)}.icon-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:var(--r-sm);color:var(--text-dim);transition:background var(--fast) var(--ease),color var(--fast) var(--ease)}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.icon-btn.danger:hover{color:var(--danger)}.sidebar-footer{border-top:1px solid var(--line);padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-2)}.usage-badge{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);background:var(--surface-2)}.usage-ring{flex-shrink:0}.usage-text{min-width:0}.usage-label{font-size:var(--fs-12);color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.usage-value{font-size:var(--fs-14);font-weight:600;font-variant-numeric:tabular-nums}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);transition:background var(--fast) var(--ease)}.user-menu-trigger:hover{background:var(--surface-2)}.avatar{display:grid;place-items:center;width:30px;height:30px;border-radius:var(--r-full);background:var(--emerald-dark);color:var(--on-emerald);font-size:var(--fs-12);font-weight:700;flex-shrink:0}.user-name{flex:1;text-align:left;font-size:var(--fs-14);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-pop{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-2);padding:var(--sp-1);z-index:20;animation:pop var(--fast) var(--ease)}.menu-item{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:9px var(--sp-3);border-radius:var(--r-sm);font-size:var(--fs-14);text-align:left;color:var(--text-dim)}.menu-item:hover{background:var(--surface-2);color:var(--text)}@keyframes pop{0%{opacity:0;transform:translateY(4px)}}.main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--ground)}.topbar{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--ground) 80%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar-title{flex:1;font-size:var(--fs-15);font-weight:600;letter-spacing:var(--tracking-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-status{font-size:var(--fs-12);color:var(--text-faint);font-weight:500}.menu-toggle{display:none}.login-wrap{flex:1;display:grid;place-items:center;padding:var(--sp-5);background:radial-gradient(1200px 600px at 50% -10%,var(--emerald-soft),transparent 60%),var(--ground)}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-2);padding:var(--sp-6)}.login-brand{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-5);text-align:center}.login-brand .brand-mark{width:40px;height:40px}.login-title{font-size:var(--fs-22);font-weight:700;letter-spacing:var(--tracking-tight)}.login-sub{font-size:var(--fs-13);color:var(--text-dim)}.field{margin-bottom:var(--sp-4)}.field label{display:block;font-size:var(--fs-13);font-weight:600;color:var(--text-dim);margin-bottom:var(--sp-2)}.field input{width:100%;padding:11px var(--sp-3);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease)}.field input:focus{outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-soft)}.btn-primary{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);width:100%;padding:12px;font-weight:600;color:var(--on-emerald);background:var(--emerald);border-radius:var(--r-md);transition:background var(--fast) var(--ease),transform var(--fast) var(--ease)}.btn-primary:hover:not(:disabled){background:var(--emerald-strong)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:default}.login-error{margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);font-size:var(--fs-13);color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,transparent);border-radius:var(--r-sm)}.toast-wrap{position:fixed;bottom:var(--sp-5);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--sp-2);z-index:50;pointer-events:none}.toast{padding:10px var(--sp-4);background:var(--text);color:var(--ground);border-radius:var(--r-full);font-size:var(--fs-13);font-weight:500;box-shadow:var(--shadow-2);animation:toast-in var(--med) var(--ease)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}.backdrop{display:none}@media (max-width: 860px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(86vw,var(--sidebar-w));z-index:40;transform:translate(-100%);transition:transform var(--med) var(--ease);box-shadow:var(--shadow-2)}.sidebar.open{transform:none}.backdrop.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;z-index:30;animation:fade var(--fast) var(--ease)}.menu-toggle{display:grid}}@keyframes fade{0%{opacity:0}}.chat-scroll{flex:1;min-height:0;overflow-y:auto;scroll-behavior:smooth}.chat-column{max-width:var(--reading-w);margin:0 auto;padding:var(--sp-6) var(--sp-5) var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-5)}.turn{display:flex;flex-direction:column;gap:var(--sp-3);animation:rise var(--med) var(--ease)}@keyframes rise{0%{opacity:0;transform:translateY(6px)}}.bubble-user{align-self:flex-end;max-width:85%;padding:11px var(--sp-4);background:var(--emerald-soft);border:1px solid var(--emerald-line);border-radius:var(--r-lg) var(--r-lg) var(--sp-1) var(--r-lg);white-space:pre-wrap;word-break:break-word}.assistant{display:flex;gap:var(--sp-3);align-items:flex-start}.assistant-avatar{flex-shrink:0;display:grid;place-items:center;width:28px;height:28px;margin-top:2px;color:var(--on-emerald);background:linear-gradient(150deg,var(--emerald),var(--emerald-dark));border-radius:7px;transform:rotate(45deg)}.assistant-avatar>*{transform:rotate(-45deg)}.assistant-body{flex:1;min-width:0;padding-top:2px}.tool-summary{margin-top:var(--sp-2);display:inline-flex;align-items:center;gap:6px;padding:3px 10px;font-size:var(--fs-12);color:var(--text-dim);background:var(--gold-soft);border-radius:var(--r-full)}.msg-actions{display:flex;gap:var(--sp-1);margin-top:var(--sp-2);opacity:0;transition:opacity var(--fast) var(--ease)}.turn:hover .msg-actions{opacity:1}.msg-action{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;font-size:var(--fs-12);color:var(--text-faint);border-radius:var(--r-sm)}.msg-action:hover{background:var(--surface-2);color:var(--text)}.caret{display:inline-block;width:8px;height:1.05em;margin-left:1px;vertical-align:text-bottom;background:var(--emerald);border-radius:1px;animation:blink 1s steps(2,start) infinite}@keyframes blink{50%{opacity:0}}@media (prefers-reduced-motion: reduce){.caret{animation:none}}.indicator{display:inline-flex;align-items:center;gap:var(--sp-2);color:var(--text-dim);font-size:var(--fs-14)}.dots{display:inline-flex;gap:4px}.dots i{width:6px;height:6px;border-radius:var(--r-full);background:var(--emerald);animation:pulse 1.2s var(--ease) infinite}.dots i:nth-child(2){animation-delay:.15s}.dots i:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.shimmer{position:relative;font-weight:500;background:linear-gradient(90deg,var(--text-faint) 30%,var(--gold) 50%,var(--text-faint) 70%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:sweep 1.8s linear infinite}@keyframes sweep{to{background-position:-200% 0}}@media (prefers-reduced-motion: reduce){.dots i,.shimmer{animation:none}.shimmer{color:var(--text-dim);-webkit-text-fill-color:var(--text-dim)}}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);text-align:center;color:var(--text-dim);padding:var(--sp-8) var(--sp-5)}.empty-state .stamp{display:grid;place-items:center;width:56px;height:56px;color:var(--gold);border:2px dashed var(--gold);border-radius:var(--r-full);opacity:.8}.empty-state h2{font-size:var(--fs-22);font-weight:700;letter-spacing:var(--tracking-tight);color:var(--text)}.jump-btn{position:absolute;left:50%;bottom:96px;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:6px var(--sp-3);font-size:var(--fs-13);color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-full);box-shadow:var(--shadow-2);animation:rise var(--fast) var(--ease)}.composer-wrap{position:relative;padding:var(--sp-3) var(--sp-4) var(--sp-5)}.composer-wrap:before{content:"";position:absolute;left:0;right:0;top:-28px;height:28px;background:linear-gradient(to top,var(--ground),transparent);pointer-events:none}.composer{max-width:var(--reading-w);margin:0 auto;display:flex;align-items:flex-end;gap:var(--sp-2);padding:var(--sp-2) var(--sp-2) var(--sp-2) var(--sp-4);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-1);transition:border-color var(--fast) var(--ease),box-shadow var(--fast) var(--ease)}.composer:focus-within{border-color:var(--emerald);box-shadow:0 0 0 3px var(--emerald-soft),var(--shadow-2)}.composer textarea{flex:1;resize:none;border:none;background:none;outline:none;padding:8px 0;max-height:200px;line-height:1.5}.send-btn{display:grid;place-items:center;width:40px;height:40px;flex-shrink:0;color:var(--on-emerald);background:var(--emerald);border-radius:var(--r-full);transition:background var(--fast) var(--ease),transform var(--fast) var(--ease),opacity var(--fast) var(--ease)}.send-btn:hover:not(:disabled){background:var(--emerald-strong)}.send-btn:active:not(:disabled){transform:scale(.94)}.send-btn:disabled{opacity:.45;cursor:default}.composer-hint{max-width:var(--reading-w);margin:var(--sp-2) auto 0;text-align:center;font-size:var(--fs-12);color:var(--text-faint)}.spinner{width:16px;height:16px;border:2px solid currentColor;border-right-color:transparent;border-radius:var(--r-full);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.md{font-size:var(--fs-15);line-height:var(--lh-body);word-break:break-word}.md>*:first-child{margin-top:0}.md>*:last-child{margin-bottom:0}.md p{margin:var(--sp-3) 0}.md h1,.md h2,.md h3,.md h4{margin:var(--sp-5) 0 var(--sp-2);line-height:var(--lh-tight);letter-spacing:var(--tracking-tight);font-weight:650}.md h1{font-size:var(--fs-22)}.md h2{font-size:var(--fs-18)}.md h3{font-size:var(--fs-16)}.md ul,.md ol{margin:var(--sp-3) 0;padding-left:var(--sp-5)}.md li{margin:var(--sp-1) 0}.md li::marker{color:var(--text-faint)}.md a{color:var(--emerald);text-decoration:underline;text-underline-offset:2px}.md blockquote{margin:var(--sp-3) 0;padding:var(--sp-1) var(--sp-4);border-left:3px solid var(--emerald);background:var(--emerald-soft);border-radius:0 var(--r-sm) var(--r-sm) 0;color:var(--text-dim)}.md hr{border:none;border-top:1px solid var(--line);margin:var(--sp-5) 0}.md code{font-family:var(--font-mono);font-size:.86em;background:var(--surface-2);padding:.15em .4em;border-radius:var(--r-sm)}.md pre{margin:var(--sp-3) 0;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);overflow-x:auto}.md pre code{background:none;padding:0;font-size:var(--fs-13);line-height:1.55}.md table{width:100%;margin:var(--sp-3) 0;border-collapse:collapse;font-size:var(--fs-14);display:block;overflow-x:auto}.md th,.md td{border:1px solid var(--line);padding:var(--sp-2) var(--sp-3);text-align:left}.md th{background:var(--surface-2);font-weight:600}.md tr:nth-child(2n) td{background:var(--surface-2)}.md img{max-width:100%;border-radius:var(--r-md)}.md.streaming>p:last-child{display:inline}.md.streaming .caret{vertical-align:baseline;height:1em}
