:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:#111827;background-color:#f3f4f6}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{cursor:pointer}.auth-layout{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(440px,100%);background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 10px 30px #00000014}.auth-card h1{margin-top:0;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:.9rem}.auth-form label{display:flex;flex-direction:column;gap:.35rem}.auth-form input{border:1px solid #d1d5db;border-radius:8px;padding:.65rem .75rem}.auth-form button{border:none;border-radius:8px;padding:.65rem .9rem;background:#111827;color:#fff}.auth-help{margin-top:.85rem;margin-bottom:0}.error-text{margin:0;color:#b91c1c}.app-layout{min-height:100vh;display:flex;background:#e5e7eb}.chat-sidebar{width:320px;background:#fff;border-right:1px solid #d1d5db;display:flex;flex-direction:column}.sidebar-header{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:.75rem}.sidebar-label{margin:0;font-size:.75rem;color:#6b7280}.sidebar-meta{margin:.2rem 0 0;font-size:.75rem;color:#6b7280;word-break:break-all}.secondary-button{border:1px solid #d1d5db;border-radius:8px;padding:.45rem .65rem;background:#fff}.new-chat-form{padding:.75rem;border-bottom:1px solid #e5e7eb;display:flex;gap:.5rem}.new-chat-form input{flex:1;border:1px solid #d1d5db;border-radius:8px;padding:.5rem .65rem;min-width:0}.new-chat-form button{border:none;border-radius:8px;padding:.5rem .7rem;background:#111827;color:#fff}.chat-list{padding:.75rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.chat-item{border:1px solid #e5e7eb;border-radius:10px;background:#fff;text-align:left;padding:.7rem;display:flex;flex-direction:column;gap:.2rem}.chat-item.active{border-color:#111827;background:#f3f4f6}.chat-item span{color:#6b7280;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-panel{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}.chat-header{background:#fff;border-bottom:1px solid #d1d5db;padding:1rem}.chat-header h2{margin:0;font-size:1rem}.messages{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.65rem;overflow-y:auto}.message-item{max-width:min(560px,85%);border-radius:10px;padding:.6rem .75rem;background:#fff;border:1px solid #d1d5db}.message-item p{margin:0}.message-item time{display:block;margin-top:.2rem;font-size:.75rem;color:#6b7280}.message-item.mine{align-self:flex-end;background:#dbeafe;border-color:#93c5fd}.message-form{display:flex;gap:.6rem;padding:1rem;border-top:1px solid #d1d5db;background:#fff}.message-form input{flex:1;border:1px solid #d1d5db;border-radius:8px;padding:.65rem .75rem}.message-form button{border:none;border-radius:8px;padding:.65rem 1rem;background:#111827;color:#fff}.empty-chat-state{flex:1;display:grid;place-items:center;color:#6b7280}.muted-text{color:#6b7280;margin:0}.panel-error{position:absolute;left:1rem;bottom:5rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:.45rem .65rem}@media(max-width:900px){.app-layout{flex-direction:column}.chat-sidebar{width:100%;max-height:42vh}.chat-panel{min-height:58vh}.panel-error{bottom:4.8rem}}
