*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0a0a0a;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100%}.header{flex-shrink:0;border-bottom:1px solid #171717}.header-inner{max-width:720px;margin:0 auto;padding:20px 24px 16px}.header h1{font-size:17px;font-weight:600;letter-spacing:-.025em;color:#fff}.header p{margin-top:4px;font-size:11px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:#3d3d3d}.chat-area{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#1e1e1e transparent}.chat-area::-webkit-scrollbar{width:4px}.chat-area::-webkit-scrollbar-thumb{background:#1e1e1e;border-radius:2px}.messages{max-width:720px;margin:0 auto;padding:28px 24px 16px;display:flex;flex-direction:column;gap:14px}.message{display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.bubble{max-width:82%;padding:12px 16px;font-size:14px;line-height:1.65;word-break:break-word}.message.user .bubble{background:#1e1e1e;border-radius:14px 14px 2px;color:#d8d8d8}.message.assistant .bubble{background:#141414;border-radius:14px 14px 14px 2px;color:#c8c8c8}.bubble p{margin-bottom:8px}.bubble p:last-child{margin-bottom:0}.bubble h1,.bubble h2,.bubble h3{font-size:14px;font-weight:600;color:#fff;margin:18px 0 6px;letter-spacing:-.01em}.bubble h1:first-child,.bubble h2:first-child,.bubble h3:first-child{margin-top:0}.bubble strong{font-weight:600;color:#e0e0e0}.bubble em{font-style:italic;color:#999}.bubble ul,.bubble ol{padding-left:20px;margin:6px 0}.bubble li{margin:4px 0}.bubble code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;background:#222;padding:2px 6px;border-radius:4px;color:#a0a0a0}.bubble pre{background:#111;border:1px solid #222;border-radius:8px;padding:14px;overflow-x:auto;margin:10px 0}.bubble pre code{background:none;padding:0;font-size:13px}.bubble blockquote{border-left:2px solid #2a2a2a;padding-left:14px;color:#666;margin:8px 0}.bubble hr{border:none;border-top:1px solid #222;margin:14px 0}.bubble table{width:100%;border-collapse:collapse;font-size:13px;margin:10px 0}.bubble th,.bubble td{padding:7px 12px;border:1px solid #222;text-align:left}.bubble th{background:#1a1a1a;color:#ddd;font-weight:500}.typing-indicator{display:flex;align-items:center;gap:5px;padding:14px 18px;background:#141414;border-radius:14px 14px 14px 2px;width:fit-content}.dot{width:5px;height:5px;background:#444;border-radius:50%;animation:pulse 1.4s infinite ease-in-out}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,60%,to{transform:translateY(0);opacity:.3}30%{transform:translateY(-5px);opacity:1}}.input-area{flex-shrink:0;border-top:1px solid #171717}.input-inner{max-width:720px;margin:0 auto;padding:14px 24px 20px;display:flex;gap:10px;align-items:flex-end}.input-inner textarea{flex:1;background:#111;border:1px solid #222;border-radius:10px;color:#e0e0e0;font-family:inherit;font-size:14px;line-height:1.5;padding:10px 14px;resize:none;outline:none;overflow-y:auto;max-height:96px;transition:border-color .15s}.input-inner textarea::placeholder{color:#333}.input-inner textarea:focus{border-color:#2e2e2e}.input-inner textarea:disabled{opacity:.4;cursor:not-allowed}.send-btn{flex-shrink:0;background:#fff;color:#000;border:none;border-radius:10px;padding:0 20px;height:40px;font-family:inherit;font-size:14px;font-weight:500;letter-spacing:-.01em;cursor:pointer;transition:opacity .15s;white-space:nowrap}.send-btn:hover:not(:disabled){opacity:.88}.send-btn:disabled{opacity:.22;cursor:not-allowed}
