:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:24px;box-sizing:border-box}.login-page__container{width:100%;max-width:420px;background:#fff;padding:28px;border-radius:8px;box-shadow:0 6px 18px #141e2814}.login-page__title{margin:0 0 18px;font-size:1.5rem;color:#1f2937}.login-form{display:block}.login-form__field{margin-bottom:14px}.login-form__label{display:block;margin-bottom:6px;color:#374151;font-size:.95rem}.login-form__input{width:100%;padding:10px 12px;font-size:1rem;border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box}.login-form__input:focus{outline:none;box-shadow:0 0 0 3px #3b82f62e;border-color:#3b82f6}.login-form__actions{margin-top:8px;display:flex;justify-content:flex-end}.login-form__button{padding:10px 16px;font-size:1rem;border-radius:6px;border:none;cursor:pointer}.login-form__button--primary{background-color:#2563eb;color:#fff}.login-form__button[disabled]{opacity:.6;cursor:not-allowed}.login-form__error{margin-top:12px;color:#b91c1c;background:#fff7f7;padding:8px 10px;border-radius:6px}.login-form__label:focus-within{outline:none}.site-footer{padding:22px 16px;background:transparent;color:#374151}.site-footer__container{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:center}.site-footer__copyright{font-size:.95rem;color:#374151}.site-footer__copyright--small{opacity:.95}@media(max-width:480px){.site-footer{padding:16px 12px}.site-footer__copyright{font-size:.9rem}}.app-header{width:100%;max-width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;box-sizing:border-box;background:transparent}.app-header__brand{display:flex;align-items:center}.app-header__title{margin:0;font-size:2.25rem;color:#0f172a}.app-header__right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.app-header__actions{display:flex;gap:8px}.app-header__button{padding:8px 12px;font-size:.95rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;cursor:pointer}.app-header__button--logout{background:#f3f4f6;color:#0f172a}.app-header__button:focus{outline:none;box-shadow:0 0 0 3px #3b82f61f}.app-header__user{font-size:.95rem;color:#374151}.app-header__user-email{font-weight:500}.app-header__user-anon{opacity:.7}@media(max-width:640px){.app-header{flex-direction:column;align-items:stretch;gap:8px;padding:12px 14px}.app-header__right{align-items:flex-start;flex-direction:column}}.chat-page__container{max-width:960px;margin:20px auto;padding:16px;box-sizing:border-box;display:flex;flex-direction:column;gap:12px}.chat-page__title{margin:0 0 8px;font-size:1.25rem;color:#0f172a}.chat-page__messages{background:#fff;border-radius:8px;box-shadow:0 6px 18px #141e280a;display:flex;flex-direction:column;min-height:48vh;overflow:hidden}.chat-page__message-list{flex:1 1 auto;overflow-y:auto;padding:12px}.chat-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.chat-list__empty{color:#6b7280;padding:12px}.message-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left;background:#f8fafc;border-radius:10px;padding:10px 12px;max-width:78%;box-shadow:0 1px #0f172a05}.message-item__meta-text{color:#6b7280;font-size:.8rem}.message-item__content{margin-top:6px;font-size:1rem;color:#0f172a;white-space:pre-wrap}.message-composer{display:flex;gap:12px;align-items:flex-end;margin-top:12px}.message-composer__input-wrapper{flex:1 1 auto}.message-composer__input{width:100%;padding:10px 12px;font-size:1rem;border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;resize:vertical}.message-composer__actions{flex:0 0 auto;display:flex;align-items:center}.message-composer__button{padding:10px 14px;font-size:1rem;border-radius:8px;border:none;cursor:pointer}.message-composer__button--primary{background-color:#2563eb;color:#fff}.chat-page__realtime-badge--connected{background:#0b6623}.chat-page__realtime-badge--disconnected{background:#8b0000}.chat-page__error-banner{background:#b22222}.chat-page__inline-error{color:#b91c1c;background:#fff7f7;padding:8px 10px;border-radius:6px}@media(max-width:640px){.message-item{max-width:100%}.chat-page__container{padding:12px}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
