:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;background:#edf1f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,textarea{font:inherit}.app{grid-template-columns:310px minmax(0,1fr);height:100vh;display:grid;overflow:hidden}.sidebar{color:#fff;background:linear-gradient(#111827,#1f2937);flex-direction:column;gap:22px;padding:22px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brandIcon{background:#ffffff1f;border-radius:15px;place-items:center;width:44px;height:44px;display:grid}.brand h1{margin:0;font-size:22px}.brand p{color:#cbd5e1;margin:2px 0 0;font-size:13px}.sessionBox{background:#ffffff14;border:1px solid #ffffff1f;border-radius:18px;gap:8px;padding:16px;display:grid}.sessionBox span{color:#cbd5e1;font-size:12px}.sessionBox strong,.sessionBox code{color:#fff;word-break:break-word}.sessionBox code{font-size:12px}.clearButton{color:#fecaca;cursor:pointer;background:#ef44442e;border:0;border-radius:14px;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:13px 14px;display:flex}.clearButton:hover{background:#ef444447}.chat{grid-template-rows:auto minmax(0,1fr) auto;height:100vh;display:grid}.chatHeader{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;border-bottom:1px solid #d9e0ea;padding:18px 26px}.chatHeader h2{margin:0;font-size:19px}.chatHeader p{color:#64748b;margin:4px 0 0;font-size:14px}.errorBox{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:14px;margin:14px 24px 0;padding:12px 14px}.messages{padding:24px;overflow-y:auto}.emptyState{text-align:center;color:#64748b;place-content:center;height:100%;min-height:420px;display:grid}.emptyState h3{color:#172033;margin:14px 0 4px;font-size:25px}.emptyState p{margin:0}.message{gap:12px;margin-bottom:18px;display:flex}.userMessage{flex-direction:row-reverse}.avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex:0 0 34px;place-items:center;width:34px;height:34px;display:grid}.userMessage .avatar{color:#15803d;background:#dcfce7}.bubble{background:#fff;border:1px solid #dbe3ef;border-radius:18px;max-width:min(850px,82%);padding:14px 16px;line-height:1.55;box-shadow:0 10px 30px #0f172a0f}.userMessage .bubble{color:#fff;background:#2563eb;border-color:#2563eb}.bubble p{margin:0 0 10px}.bubble p:last-child{margin-bottom:0}.bubble ul,.bubble ol{padding-left:22px}.bubble pre{color:#e2e8f0;background:#0f172a;border-radius:12px;padding:12px;overflow-x:auto}.bubble code{font-size:.92em}.attachments{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.attachments a{color:#1d4ed8;background:#eff6ff;border-radius:999px;padding:7px 11px;font-size:13px;text-decoration:none}.composer{background:linear-gradient(#edf1f733,#edf1f7 45%);gap:12px;padding:18px 24px 24px;display:flex}.composer textarea{resize:none;background:#fff;border:1px solid #cbd5e1;border-radius:18px;outline:none;flex:1;min-height:52px;max-height:160px;padding:15px 16px}.composer textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.composer button{color:#fff;cursor:pointer;background:#2563eb;border:0;border-radius:18px;place-items:center;width:54px;height:54px;display:grid}.composer button:disabled{opacity:.45;cursor:not-allowed}.typing{align-items:center;gap:6px;min-width:70px;display:flex}.typing span{background:#94a3b8;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite bounce}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{opacity:.45;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}@media (width<=850px){.app{grid-template-columns:1fr}.sidebar{display:none}.bubble{max-width:92%}}
