@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0f1117;--bg-secondary:#161b22;--bg-tertiary:#1c2330;--bg-card:#1c2330;--bg-hover:#ffffff0a;--bg-active:#ffffff12;--bg-input:#ffffff0a;--glass-bg:#161b22;--glass-border:#ffffff14;--glass-blur:0px;--accent-primary:#2563eb;--accent-secondary:#3b82f6;--accent-gradient:#2563eb;--accent-gradient-hover:#1d4ed8;--accent-glow:#2563eb26;--text-primary:#e6edf3;--text-secondary:#7d8590;--text-tertiary:#484f58;--text-accent:#58a6ff;--online-color:#3fb950;--offline-color:#484f58;--unread-color:#2563eb;--error-color:#f85149;--success-color:#3fb950;--warning-color:#d29922;--bubble-sent:#2563eb;--bubble-received:#1c2330;--bubble-sent-text:#fff;--bubble-received-text:#e6edf3;--border-color:#ffffff14;--border-subtle:#ffffff0a;--shadow-sm:0 1px 4px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow:0 0 0 #0000;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.7rem;--font-size-sm:.8rem;--font-size-base:.9rem;--font-size-md:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.35s ease;--sidebar-width:360px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow:hidden}#root{min-height:100vh}a{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-secondary)}button{font-family:var(--font-family);cursor:pointer;border:none;outline:none}input,textarea{font-family:var(--font-family);border:none;outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.loading-spinner{border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:all var(--transition-base);font-weight:500;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-gradient-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff04 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.auth-card{width:100%;max-width:420px;padding:var(--space-3xl);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:1;animation:.4s fadeInUp;position:relative}.auth-card:before{content:"";background:var(--accent-primary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.auth-header{text-align:center;margin-bottom:var(--space-2xl)}.auth-logo{background:var(--accent-primary);border-radius:var(--radius-lg);width:52px;height:52px;margin:0 auto var(--space-lg);font-size:var(--font-size-xl);color:#fff;justify-content:center;align-items:center;display:flex}.auth-header h1{font-size:var(--font-size-xl);margin-bottom:var(--space-xs);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.auth-header p{color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-form{gap:var(--space-lg);flex-direction:column;display:flex}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-group label{font-size:var(--font-size-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;font-weight:600}.form-input{padding:var(--space-md) var(--space-lg);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.form-input:focus{border-color:var(--accent-primary);background:#ffffff0d;box-shadow:0 0 0 3px #2563eb26}.form-input::placeholder{color:var(--text-tertiary)}.auth-submit{width:100%;padding:var(--space-md) var(--space-xl);margin-top:var(--space-sm);background:var(--accent-primary);color:#fff;font-size:var(--font-size-base);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base), transform var(--transition-fast);letter-spacing:.01em;border:none;font-weight:600}.auth-submit:hover:not(:disabled){background:var(--accent-gradient-hover);transform:translateY(-1px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.45;cursor:not-allowed}.auth-footer{text-align:center;margin-top:var(--space-xl);font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer a{color:var(--text-accent);margin-left:var(--space-xs);transition:color var(--transition-fast);font-weight:500}.auth-footer a:hover{color:var(--accent-secondary)}.auth-error{border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);color:var(--error-color);font-size:var(--font-size-sm);background:#f8514914;border:1px solid #f8514940;animation:.25s fadeIn}.contact-list{flex-direction:column;display:flex}.contact-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-xl);cursor:pointer;transition:background var(--transition-fast);border-left:3px solid #0000;display:flex;position:relative}.contact-item:hover{background:var(--bg-hover)}.contact-item.active{background:var(--bg-active);border-left-color:var(--accent-primary)}.contact-avatar-wrapper{flex-shrink:0;position:relative}.contact-avatar{background:var(--accent-primary);width:44px;height:44px;font-size:var(--font-size-sm);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.online-dot{background:var(--online-color);border:2px solid var(--bg-secondary);border-radius:50%;width:11px;height:11px;position:absolute;bottom:2px;right:2px}.contact-info{flex:1;min-width:0}.contact-name{font-size:var(--font-size-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;font-weight:600;overflow:hidden}.contact-last-message{font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.contact-meta{align-items:flex-end;gap:var(--space-xs);flex-direction:column;flex-shrink:0;display:flex}.contact-time{font-size:var(--font-size-xs);color:var(--text-tertiary);white-space:nowrap}.unread-badge{background:var(--accent-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:700;display:flex}.search-results{border-bottom:1px solid var(--border-color);position:relative}.search-results-header{padding:var(--space-sm) var(--space-xl);font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.search-result-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-xl);cursor:pointer;transition:background var(--transition-fast);display:flex}.search-result-item:hover{background:var(--bg-hover)}.search-result-item .contact-avatar{width:38px;height:38px;font-size:var(--font-size-xs)}.search-result-name{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500}.search-result-username{font-size:var(--font-size-xs);color:var(--text-tertiary)}.search-no-results{padding:var(--space-xl);text-align:center;color:var(--text-tertiary);font-size:var(--font-size-sm)}.section-label{padding:var(--space-sm) var(--space-xl);font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.chat-container{flex-direction:column;flex:1;height:100vh;animation:.25s fadeIn;display:flex}.chat-header{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-xl);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);min-height:var(--header-height);display:flex}.chat-header-avatar{background:var(--accent-primary);width:40px;height:40px;font-size:var(--font-size-sm);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.chat-header-info{flex:1}.chat-header-name{font-size:var(--font-size-base);color:var(--text-primary);letter-spacing:-.01em;font-weight:600}.chat-header-status{font-size:var(--font-size-xs);color:var(--text-tertiary);align-items:center;gap:var(--space-xs);display:flex}.chat-header-status.online{color:var(--online-color)}.status-dot{background:var(--offline-color);border-radius:50%;width:7px;height:7px}.status-dot.online{background:var(--online-color)}.messages-area{padding:var(--space-xl);gap:var(--space-sm);background:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow-y:auto}.date-separator{align-items:center;gap:var(--space-lg);margin:var(--space-lg) 0;display:flex}.date-separator:before,.date-separator:after{content:"";background:var(--border-color);flex:1;height:1px}.date-separator span{font-size:var(--font-size-xs);color:var(--text-tertiary);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase;font-weight:500}.message-wrapper{flex-direction:column;max-width:65%;animation:.2s fadeInUp;display:flex}.message-wrapper.sent{align-self:flex-end;align-items:flex-end}.message-wrapper.received{align-self:flex-start;align-items:flex-start}.message-bubble{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--font-size-base);word-wrap:break-word;line-height:1.55;position:relative}.message-wrapper.sent .message-bubble{background:var(--bubble-sent);color:var(--bubble-sent-text);border-bottom-right-radius:var(--radius-sm)}.message-wrapper.received .message-bubble{background:var(--bubble-received);color:var(--bubble-received-text);border-bottom-left-radius:var(--radius-sm);border:1px solid var(--border-color)}.message-time{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-xs);padding:0 var(--space-xs)}.message-wrapper.sent .message-time{color:var(--text-secondary)}.typing-indicator{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-xl);animation:.25s fadeIn;display:flex}.typing-indicator-text{font-size:var(--font-size-xs);color:var(--text-tertiary);font-style:italic}.typing-dots{gap:3px;display:flex}.typing-dots span{background:var(--text-tertiary);border-radius:50%;width:5px;height:5px;animation:1.4s ease-in-out infinite bounce}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.message-input-area{padding:var(--space-md) var(--space-xl);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.message-input-container{align-items:center;gap:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xs) var(--space-xs) var(--space-xs) var(--space-lg);transition:border-color var(--transition-base);display:flex}.message-input-container:focus-within{border-color:var(--accent-primary)}.message-input{color:var(--text-primary);font-size:var(--font-size-base);padding:var(--space-sm) 0;resize:none;background:0 0;border:none;flex:1}.message-input::placeholder{color:var(--text-tertiary)}.send-button{border-radius:var(--radius-md);background:var(--accent-primary);color:#fff;cursor:pointer;width:38px;height:38px;transition:background var(--transition-fast), transform var(--transition-fast);font-size:var(--font-size-md);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-button:hover:not(:disabled){background:var(--accent-gradient-hover);transform:scale(1.05)}.send-button:disabled{opacity:.3;cursor:default}.messages-loading{flex:1;justify-content:center;align-items:center;display:flex}.chat-layout{background:var(--bg-primary);height:100vh;display:flex}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;height:100vh;animation:.3s slideInLeft;display:flex}.sidebar-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color);min-height:var(--header-height);justify-content:space-between;align-items:center;display:flex}.sidebar-title{font-size:var(--font-size-lg);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.sidebar-user{align-items:center;gap:var(--space-sm);display:flex}.sidebar-user-name{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.logout-btn{color:var(--text-tertiary);font-size:var(--font-size-md);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none}.logout-btn:hover{color:var(--error-color);background:#f8514914}.sidebar-search{padding:var(--space-md) var(--space-xl)}.search-container{position:relative}.search-input{width:100%;padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);transition:border-color var(--transition-base);padding-left:40px}.search-input:focus{border-color:var(--accent-primary);outline:none}.search-input::placeholder{color:var(--text-tertiary)}.search-icon{color:var(--text-tertiary);font-size:var(--font-size-sm);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.sidebar-content{padding:var(--space-sm) 0;flex:1;overflow-y:auto}.main-area{background:var(--bg-primary);flex-direction:column;flex:1;display:flex}.empty-state{justify-content:center;align-items:center;gap:var(--space-lg);color:var(--text-tertiary);flex-direction:column;flex:1;animation:.4s fadeIn;display:flex}.empty-state-icon{opacity:.2;font-size:3.5rem}.empty-state h2{font-size:var(--font-size-lg);color:var(--text-secondary);letter-spacing:-.01em;font-weight:600}.empty-state p{font-size:var(--font-size-sm);text-align:center;max-width:300px;line-height:1.6}
