*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px}.auth-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.auth-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:100%;max-width:380px;padding:40px 36px}.auth-logo{align-items:center;gap:10px;margin-bottom:28px;display:flex}.auth-logo-icon{background:var(--color-primary);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.auth-logo-text{color:var(--color-text);font-size:1.2rem;font-weight:700}.auth-card h1{color:var(--color-text);margin-bottom:4px;font-size:1.4rem;font-weight:700}.auth-card p{color:var(--color-text-muted);margin-bottom:24px;font-size:.9rem}.auth-form{flex-direction:column;gap:14px;display:flex}.form-field{flex-direction:column;gap:5px;display:flex}.form-field label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;font-weight:600}.form-field input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition);outline:none;padding:10px 14px;font-size:.95rem}.form-field input:focus{border-color:var(--color-primary)}.auth-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);border:none;margin-top:6px;padding:11px;font-size:.95rem;font-weight:600}.auth-btn:hover:not(:disabled){background:var(--color-primary-dark)}.auth-btn:disabled{background:var(--color-primary-muted);cursor:not-allowed}.auth-error{color:var(--color-error);border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;padding:10px 14px;font-size:.875rem}.auth-footer{text-align:center;color:var(--color-text-muted);margin-top:20px;font-size:.875rem}.auth-footer a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}@media (width<=639px){.auth-card{padding:28px 20px}.form-field input{padding:12px 14px;font-size:1rem}.auth-btn{padding:14px;font-size:1rem}}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;height:100%;display:flex}.sidebar-header{height:var(--header-height);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;display:flex}.sidebar-title{color:var(--color-text);font-size:1rem;font-weight:700}.sidebar-user{color:var(--color-text-muted);font-size:.8rem;font-weight:500}.logout-btn{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition), color var(--transition);background:0 0;border:none;padding:4px 8px;font-size:.8rem}.logout-btn:hover{background:var(--color-bg);color:var(--color-error)}.sidebar-search{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:12px}.sidebar-search input{border:1.5px solid var(--color-border);border-radius:var(--radius-full);width:100%;color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition);box-sizing:border-box;outline:none;padding:8px 12px;font-size:.875rem}.sidebar-search input:focus{border-color:var(--color-primary);background:var(--color-surface)}.sidebar-section-label{color:var(--color-text-light);text-transform:uppercase;letter-spacing:.08em;padding:8px 16px 4px;font-size:.72rem;font-weight:700}.sidebar-list{flex:1;padding:4px 0;overflow-y:auto}.conversation-item{cursor:pointer;transition:background var(--transition);border-radius:0;align-items:center;gap:12px;padding:10px 16px;display:flex}.conversation-item:hover{background:var(--color-bg)}.conversation-item.active{background:var(--color-primary-light)}.avatar{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9rem;font-weight:700;display:flex;position:relative}.online-badge{border-radius:var(--radius-full);border:2px solid var(--color-surface);background:var(--color-offline);width:10px;height:10px;position:absolute;bottom:1px;right:1px}.online-badge.online{background:var(--color-online)}.conversation-info{flex:1;min-width:0}.conversation-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.empty-state{text-align:center;color:var(--color-text-muted);padding:24px 16px;font-size:.875rem}.unread-badge{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:.72rem;font-weight:700;display:flex}@media (width<=639px){.conversation-item{padding:13px 16px}.sidebar-search input{padding:11px 16px;font-size:1rem}.logout-btn{min-height:44px;padding:4px 12px}}:root{--color-primary:#4f46e5;--color-primary-dark:#4338ca;--color-primary-light:#ede9fe;--color-primary-muted:#a5b4fc;--color-bg:#f0f2f5;--color-surface:#fff;--color-surface-2:#f8fafc;--color-border:#e2e8f0;--color-text:#1e293b;--color-text-muted:#64748b;--color-text-light:#94a3b8;--color-online:#22c55e;--color-offline:#cbd5e1;--color-error:#ef4444;--color-warning:#f59e0b;--bubble-own-bg:var(--color-primary);--bubble-own-text:#fff;--bubble-other-bg:#f1f5f9;--bubble-other-text:var(--color-text);--sidebar-width:280px;--header-height:56px;--radius-sm:6px;--radius-md:10px;--radius-lg:18px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #0000001f;--transition:.15s ease;--transition-slide:.25s ease}.chat-page{background:var(--color-bg);height:100vh;display:flex;overflow:hidden}.chat-panel{flex-direction:column;flex:1;min-width:0;height:100%;display:flex}.chat-panel-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:12px;padding:0 20px;display:flex}.chat-panel-header .avatar{width:34px;height:34px;font-size:.8rem}.chat-panel-name{color:var(--color-text);font-size:.95rem;font-weight:700}.chat-panel-status{color:var(--color-text-muted);font-size:.78rem}.chat-panel-status.online{color:var(--color-online)}.no-conversation{color:var(--color-text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.no-conversation-icon{opacity:.3;font-size:3rem}.no-conversation p{font-size:.95rem}.message-list{flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex;overflow-y:auto}.message-group{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.message-bubble-wrapper{align-items:flex-end;gap:8px;display:flex}.message-bubble-wrapper.own{flex-direction:row-reverse}.bubble-avatar{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-bottom:2px;font-size:.65rem;font-weight:700;display:flex}.message-bubble-wrapper.own .bubble-avatar{display:none}.message-bubble-inner{max-width:68%}.message-bubble-wrapper.own .message-bubble-inner{flex-direction:column;align-items:flex-end;display:flex}.message-bubble{border-radius:var(--radius-lg);word-break:break-word;width:fit-content;padding:9px 14px;font-size:.9rem;line-height:1.45}.message-bubble.own{background:var(--bubble-own-bg);color:var(--bubble-own-text);border-bottom-right-radius:4px}.message-bubble.other{background:var(--bubble-other-bg);color:var(--bubble-other-text);border-bottom-left-radius:4px}.message-time{color:var(--color-text-light);margin-top:2px;padding:0 2px;font-size:.7rem}.message-bubble-wrapper.own .message-time{text-align:right}.typing-indicator{color:var(--color-text-muted);min-height:22px;padding:4px 20px 8px;font-size:.8rem;font-style:italic}.message-input-area{background:var(--color-surface);border-top:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex}.message-input-area input{border:1.5px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition);outline:none;flex:1;padding:10px 16px;font-size:.9rem}.message-input-area input:focus{border-color:var(--color-primary);background:var(--color-surface)}.send-btn{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;cursor:pointer;width:40px;height:40px;transition:background var(--transition);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-btn:hover:not(:disabled){background:var(--color-primary-dark)}.send-btn:disabled{background:var(--color-primary-muted);cursor:not-allowed}.back-btn{color:var(--color-text);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;margin-right:4px;padding:8px;display:none}.back-btn:hover{background:var(--color-bg)}@media (width<=639px){.back-btn{display:flex}.chat-page{position:relative;overflow:hidden}.chat-page .sidebar{width:100%;transition:transform var(--transition-slide);z-index:2;position:absolute;inset:0;transform:translate(0)}.chat-page .chat-panel{transition:transform var(--transition-slide);z-index:1;position:absolute;inset:0;transform:translate(100%)}.chat-page.show-chat .sidebar{transform:translate(-100%)}.chat-page.show-chat .chat-panel{transform:translate(0)}.message-bubble-inner{max-width:85%}.message-input-area{padding:10px 12px;padding-bottom:max(10px, env(safe-area-inset-bottom))}.message-input-area input{padding:12px 16px;font-size:1rem}.send-btn{width:44px;height:44px}}
