:root{font-family:Inter,SF Pro Text,system-ui,Arial,sans-serif;color:#111827}*{box-sizing:border-box}body{margin:0;background:radial-gradient(800px 450px at 0% -20%,#dbeafe 0%,transparent 55%),radial-gradient(700px 400px at 100% -20%,#fde68a66 0%,transparent 55%),#f6f8ff}.chat-app{max-width:980px;margin:0 auto;padding:18px 14px 28px}.chat-hero h1{margin:0;font-size:2rem}.chat-hero p{margin:8px 0 14px;color:#4b5563}.card{background:#ffffffd6;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 12px 34px #4f46e514;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-stage{padding:14px}.stage-top{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center}.stage-top.compact{margin-bottom:8px}.sub{margin:0;color:#6b7280;font-size:13px}.mini-stats{display:flex;gap:12px;font-size:13px;color:#374151;align-items:center}.fill{height:100%;background:linear-gradient(90deg,#60a5fa,#22c55e);transition:width .25s ease}.error-banner{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;border-radius:10px;padding:8px 10px;margin-bottom:10px;font-size:13px}.chatbox{height:64vh;max-height:64vh;overflow:auto;padding:12px;border-radius:14px;background:#f8fafc;border:1px solid #e5e7eb;margin:10px 0}.empty-state{display:grid;gap:10px;padding:14px;border:1px dashed #c7d2fe;border-radius:12px;background:#eef2ff70}.empty-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.empty-title{font-weight:700;color:#4338ca}.suggestions{display:flex;gap:8px;flex-wrap:wrap}.msg-row{display:flex;gap:8px;margin-bottom:10px;align-items:flex-start}.msg-row.user{flex-direction:row-reverse}.avatar{width:28px;height:28px;border-radius:50%;background:#eef2ff;display:grid;place-items:center;font-size:15px;border:1px solid #e5e7eb;flex-shrink:0}.msg-bubble{max-width:80%;border-radius:14px;padding:10px 12px;line-height:1.45;white-space:pre-wrap}.msg-bubble.user{background:#4f46e5;color:#fff;border-bottom-right-radius:6px}.msg-bubble.assistant{background:#fff;border:1px solid #e5e7eb;color:#1f2937;border-bottom-left-radius:6px}.msg-name{font-size:12px;font-weight:700;opacity:.8;margin-bottom:4px}.msg-bubble p{margin:0 0 8px}.msg-bubble p:last-child{margin-bottom:0}.msg-bubble strong{font-weight:700}.msg-bubble ul,.msg-bubble ol{margin:0 0 8px 18px;padding:0}img.twemoji{height:1.1em;width:1.1em;margin:0 .05em 0 .1em;vertical-align:-.15em}.thinking{color:#6b7280;font-style:italic;padding:4px 2px}.composer.sticky{position:sticky;bottom:0;background:linear-gradient(180deg,#fff3,#ffffffde 30%);padding-top:10px}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}select,button,textarea,input{padding:10px 12px;border-radius:12px;border:1px solid #d1d5db;font:inherit}button{border:none;color:#fff;font-weight:600;background:linear-gradient(135deg,#4f46e5,#7c3aed);cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}textarea{width:100%;min-height:44px;max-height:220px;resize:none;overflow-y:auto;background:#fff;line-height:1.35}.ghost{background:#fff;color:#374151;border:1px solid #d1d5db}.ghost.danger{color:#b91c1c;border-color:#fecaca;background:#fff1f2}.reset-btn{height:36px;padding:0 14px;border-radius:10px;font-size:14px;font-weight:600}.kbd-tip{margin-left:auto;font-size:12px;color:#6b7280}.auth-strip{max-width:980px;margin:8px auto 0;padding:0 14px;display:flex;justify-content:flex-end;gap:10px;align-items:center;color:#4b5563;font-size:12px}@media (max-width: 760px){.chat-hero h1{font-size:1.6rem}.msg-bubble{max-width:90%}.kbd-tip{width:100%;margin-left:0}.chatbox{height:56vh;max-height:56vh}.stage-top{grid-template-columns:1fr;align-items:start}.reset-btn{justify-self:start}}
