*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}:root{--font:"Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;--font-tight:"Inter Tight","Inter",-apple-system,sans-serif;--bg:#e8eaed;--surface:#fff;--surface-hover:#f7f8f9;--bubble-assistant:#f2f3f5;--bubble-assistant-border:rgba(0,0,0,.06);--bubble-user:#2563eb;--bubble-user-hover:#1d4ed8;--text:#1a1a1a;--text-secondary:#5f6368;--text-muted:#9aa0a6;--text-on-blue:#fff;--chip-bg:#fff;--chip-border:rgba(0,0,0,.1);--chip-hover-bg:#f0f4ff;--chip-hover-border:rgba(37,99,235,.25);--chip-text:#3c4043;--chip-hover-text:#2563eb;--border:rgba(0,0,0,.08);--border-light:rgba(0,0,0,.05);--input-bg:#f7f8f9;--input-border:rgba(0,0,0,.08);--input-focus-border:rgba(37,99,235,.4);--input-focus-shadow:rgba(37,99,235,.08);--danger:#dc2626;--danger-bg:#fef2f2;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-full:9999px;--shadow-card:0 1px 3px rgba(0,0,0,.04),0 0 0 1px rgba(0,0,0,.03);--shadow-elevated:0 8px 32px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);--ease:cubic-bezier(0.25,0.1,0.25,1);--t-fast:150ms var(--ease);--t-normal:250ms var(--ease)}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;height:100dvh;align-items:center;justify-content:center}.chat-container,body{overflow:hidden;display:flex}.chat-container{width:100%;max-width:640px;height:92vh;height:92dvh;max-height:820px;background:var(--surface);border-radius:20px;box-shadow:var(--shadow-elevated);flex-direction:column}@media (max-width:680px){.chat-container{max-width:100%;height:100vh;height:100dvh;max-height:none;border-radius:0}}.chat-header{padding:16px 20px;gap:10px;border-bottom:1px solid var(--border-light);flex-shrink:0}.chat-header,.header-brand{display:flex;align-items:center}.header-brand{gap:8px;flex:1 1}.header-icon{color:var(--bubble-user);display:flex;align-items:center}.header-icon svg{width:22px;height:22px}.header-title{font-family:var(--font-tight);font-size:17px;font-weight:600;color:var(--text);letter-spacing:-.3px}.header-status{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px;margin-top:1px}.header-info{flex:1 1}.status-dot{width:6px;height:6px;border-radius:50%;background:#34d399;box-shadow:0 0 6px rgba(52,211,153,.4)}.new-chat-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);padding:7px 16px;border-radius:var(--radius-full);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--t-fast)}.new-chat-btn:hover{background:var(--surface-hover);border-color:rgba(0,0,0,.12);color:var(--text)}.messages{flex:1 1;overflow-y:auto;padding:24px 20px 16px;display:flex;flex-direction:column;gap:6px;scroll-behavior:smooth;overscroll-behavior:contain}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:rgba(0,0,0,.08);border-radius:4px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message{max-width:82%;animation:fadeUp .3s ease both;font-size:15px;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}.message.assistant{align-self:flex-start;background:var(--bubble-assistant);border:1px solid var(--bubble-assistant-border);color:var(--text);padding:12px 16px;border-radius:var(--radius-md)}.message.assistant.first{border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 6px}.message.assistant.mid{border-radius:6px var(--radius-md) var(--radius-md) 6px}.message.assistant.last{border-radius:6px var(--radius-md) var(--radius-md) var(--radius-md)}.message.assistant.only{border-radius:var(--radius-md)}.message.user{align-self:flex-end;background:var(--bubble-user);color:var(--text-on-blue);padding:12px 16px;border-radius:var(--radius-md) var(--radius-md) 6px var(--radius-md)}.copy-block-wrapper{max-width:82%;align-self:flex-start;animation:fadeUp .3s ease both}.copy-block-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:6px;padding-left:4px;display:flex;align-items:center;gap:5px}.copy-block-label svg{width:12px;height:12px}.copy-block{background:var(--surface);border:1px solid var(--chip-border);border-radius:var(--radius-sm);padding:14px 16px;font-size:14px;line-height:1.65;position:relative;cursor:pointer;transition:border-color var(--t-fast),box-shadow var(--t-fast);color:var(--text);white-space:pre-wrap}.copy-block:hover{border-color:var(--bubble-user);box-shadow:0 0 0 3px var(--input-focus-shadow)}.copy-btn{position:absolute;top:10px;right:10px;background:var(--surface);border:1px solid var(--chip-border);border-radius:8px;padding:4px 10px;font-size:11px;font-weight:500;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast);display:flex;align-items:center;gap:4px}.copy-btn:hover{background:var(--chip-hover-bg);border-color:var(--chip-hover-border);color:var(--bubble-user)}.copy-btn svg{width:12px;height:12px}.copy-btn.copied{background:var(--bubble-user);color:#fff;border-color:var(--bubble-user)}.typing-indicator{align-self:flex-start;padding:14px 18px;background:var(--bubble-assistant);border:1px solid var(--bubble-assistant-border);border-radius:6px var(--radius-md) var(--radius-md) 6px;display:flex;gap:5px;align-items:center;animation:fadeUp .2s ease both}.typing-dot{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:pulse 1.4s ease-in-out infinite both}.typing-dot:first-child{animation-delay:-.3s}.typing-dot:nth-child(2){animation-delay:-.15s}@keyframes pulse{0%,80%,to{transform:scale(.5);opacity:.3}40%{transform:scale(1);opacity:.8}}.suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0 8px;align-self:flex-start;max-width:90%;animation:fadeUp .3s ease both}.suggestion-chip{padding:8px 15px;background:var(--chip-bg);border:1px solid var(--chip-border);border-radius:var(--radius-full);font-size:13px;font-weight:500;font-family:var(--font);color:var(--chip-text);cursor:pointer;transition:all var(--t-fast);line-height:1.3}.suggestion-chip:hover{background:var(--chip-hover-bg);border-color:var(--chip-hover-border);color:var(--chip-hover-text)}.suggestion-chip:active{transform:scale(.97)}.quick-starts{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;padding:0 20px 10px;flex-shrink:0}.quick-start-btn{padding:14px 16px;background:var(--surface);border:1px solid var(--chip-border);border-radius:var(--radius-sm);font-size:13px;font-weight:450;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast);text-align:left;line-height:1.45}.quick-start-btn:hover{background:var(--chip-hover-bg);border-color:var(--chip-hover-border);color:var(--chip-hover-text)}.quick-start-btn:active{transform:scale(.98)}.input-area{padding:12px 20px 10px;gap:10px;flex-shrink:0}.input-area,.input-wrapper{display:flex;align-items:flex-end}.input-wrapper{flex:1 1;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-lg);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.input-wrapper:focus-within{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow)}.input-wrapper textarea{flex:1 1;padding:12px 16px;border:none;background:transparent;font-size:15px;font-family:var(--font);resize:none;outline:none;min-height:44px;max-height:120px;line-height:1.4;color:var(--text)}.input-wrapper textarea::placeholder{color:var(--text-muted)}.send-btn{padding:10px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);font-size:14px;font-weight:500;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast);flex-shrink:0;height:44px}.send-btn:hover{background:var(--bubble-user);border-color:var(--bubble-user);color:#fff}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn:disabled:hover{background:var(--surface);border-color:var(--border);color:var(--text-secondary)}.disclaimer{padding:4px 20px 14px;font-size:11px;color:var(--text-muted);text-align:center;flex-shrink:0;line-height:1.5}.welcome-section{text-align:center;padding:32px 20px 24px;animation:fadeUp .4s ease both}.welcome-icon{width:48px;height:48px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;color:var(--bubble-user)}.welcome-icon svg{width:32px;height:32px}.welcome-title{font-family:var(--font-tight);font-size:20px;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:-.3px}.welcome-subtitle{font-size:14px;color:var(--text-secondary);max-width:340px;margin:0 auto;line-height:1.5}.timestamp{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 0;letter-spacing:.3px;font-weight:500}.error-bubble{align-self:flex-start;max-width:82%;padding:12px 16px;font-size:14px;line-height:1.5;background:var(--danger-bg);border:1px solid rgba(220,38,38,.12);color:var(--danger);border-radius:var(--radius-sm);animation:fadeUp .3s ease both;display:flex;align-items:flex-start;gap:8px}.error-bubble svg{width:16px;height:16px;flex-shrink:0;margin-top:2px}.scroll-fab{position:absolute;bottom:0;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);padding:6px 14px;font-size:12px;font-weight:500;font-family:var(--font);color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-elevated);transition:all var(--t-fast);display:flex;align-items:center;gap:4px;z-index:10}.scroll-fab:hover{background:var(--chip-hover-bg);color:var(--bubble-user)}.scroll-fab svg{width:14px;height:14px}@media (max-width:600px){.copy-block-wrapper,.message{max-width:88%}.quick-starts{grid-template-columns:1fr}.messages{padding:16px 16px 12px}.input-area{padding:10px 16px 8px}.chat-header{padding:14px 16px}.quick-starts{padding:0 16px 8px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--bubble-user);outline-offset:2px}