:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#102a43;background:#f0f4f8}*{box-sizing:border-box}body{margin:0}.page{min-height:100vh;display:grid;place-items:center;padding:24px}.card{background:#fff;border-radius:16px;box-shadow:0 10px 30px #102a431a;padding:24px;width:min(92vw,420px)}.auth-card h1{margin:0 0 8px}.chat-shell{width:min(92vw,720px);height:min(88vh,780px);background:#fff;border-radius:16px;box-shadow:0 12px 35px #102a4329;display:grid;grid-template-rows:auto 1fr auto auto;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #d9e2ec;padding:16px 20px}.chat-header h1{margin:0;font-size:1.3rem}.chat-header p{margin:4px 0 0;color:#486581;font-size:.9rem}.chat-list{padding:16px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,#f0f4f8,#e6edf4)}.bubble{max-width:80%;border-radius:12px;padding:10px 12px;color:#102a43}.bubble p{margin:0;overflow-wrap:break-word}.bubble .meta{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px;font-size:.75rem;color:#486581}.bubble.mine{align-self:flex-end;background:#d2f8d2}.bubble.theirs{align-self:flex-start;background:#fff}.composer{display:flex;gap:10px;padding:14px 16px;border-top:1px solid #d9e2ec}.composer input{flex:1}input,button{border-radius:10px;border:1px solid #bcccdc;padding:10px 12px;font-size:.95rem}button{cursor:pointer;border:none;background:#0f9d58;color:#fff}button.secondary{background:#627d98}button:disabled{opacity:.65;cursor:not-allowed}.error{margin:0;padding:0 16px 16px;color:#d64545;font-size:.9rem}@media(max-width:640px){.page{padding:8px}.chat-shell{width:100%;height:calc(100vh - 16px);border-radius:12px}}
