.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-base)}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.auth-orb{position:absolute;border-radius:50%;filter:blur(80px)}.auth-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(108,99,255,.18) 0%,transparent 70%);top:-100px;left:-100px}.auth-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(74,222,128,.08) 0%,transparent 70%);bottom:-80px;right:-80px}.auth-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:40px 40px}.auth-card{width:100%;max-width:420px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;position:relative;z-index:1;box-shadow:var(--shadow-md),0 0 60px #6c63ff14}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.auth-logo-icon{width:40px;height:40px;background:var(--accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 16px var(--accent-glow)}.auth-logo-text{font-size:20px;font-weight:600;letter-spacing:-.3px}.auth-title{font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:6px}.auth-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.auth-error{display:flex;align-items:center;gap:8px;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.2);color:var(--red);padding:12px 14px;border-radius:var(--radius-md);font-size:13px;margin-bottom:20px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:.2px}.auth-field input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:11px 14px;font-size:15px;color:var(--text-primary);transition:var(--transition);width:100%}.auth-field input::placeholder{color:var(--text-muted)}.auth-field input:focus{border-color:var(--accent);background:var(--bg-elevated);box-shadow:0 0 0 3px var(--accent-dim)}.auth-btn{background:var(--accent);color:#fff;padding:13px;border-radius:var(--radius-md);font-size:15px;font-weight:500;margin-top:4px;transition:var(--transition);display:flex;align-items:center;justify-content:center;min-height:46px}.auth-btn:hover:not(:disabled){background:var(--accent-bright);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-1px)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-link{text-align:center;font-size:14px;color:var(--text-secondary);margin-top:20px}.auth-link a{color:var(--accent-bright);font-weight:500}.sidebar{width:380px;min-width:380px;height:100vh;background:#111416;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:18px 18px 12px;display:flex;align-items:center;justify-content:space-between}.sidebar-brand{display:flex;align-items:center;gap:8px}.sidebar-brand-icon{width:32px;height:32px;background:linear-gradient(135deg,#1daa61,#2dd4bf);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.sidebar-brand-name{font-size:16px;font-weight:600;letter-spacing:-.3px}.sidebar-conn{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;font-family:var(--font-mono);padding:3px 8px;border-radius:20px}.sidebar-conn.connected,.sidebar-conn.disconnected{color:var(--green);background:var(--green-dim)}.sidebar-conn-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.sidebar-conn.connected .sidebar-conn-dot{animation:pulse 2s infinite}.sidebar-profile{padding:8px 14px 12px}.profile-summary{align-items:center;background:linear-gradient(135deg,rgba(45,212,191,.12),rgba(29,170,97,.1));border:1px solid rgba(45,212,191,.16);border-radius:14px;color:var(--text-primary);display:flex;gap:12px;padding:12px;text-align:left;transition:var(--transition);width:100%}.profile-summary:hover{background:linear-gradient(135deg,rgba(45,212,191,.16),rgba(29,170,97,.14));border-color:#2dd4bf47}.profile-summary-info{flex:1;min-width:0}.profile-label{color:var(--text-muted);display:block;font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase}.profile-name{display:block;font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email{color:var(--text-secondary);display:block;font-size:12px;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-chevron{color:var(--text-secondary);display:flex;flex-shrink:0;transition:var(--transition)}.profile-chevron.open{transform:rotate(180deg)}.profile-panel{animation:fadeIn .2s ease forwards;background:rgba(255,255,255,.035);border:1px solid var(--border);border-radius:14px;margin-top:8px;padding:10px}.profile-stat-grid{display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.profile-stat{background:rgba(255,255,255,.04);border-radius:10px;padding:9px 8px;text-align:center}.profile-stat span,.profile-name-card strong{color:var(--text-primary);display:block;font-size:15px;font-weight:700}.profile-stat small,.profile-name-card span{color:var(--text-muted);display:block;font-size:11px}.profile-name-card{background:rgba(29,170,97,.08);border-radius:10px;margin-top:8px;padding:10px}.profile-logout{align-items:center;background:transparent;border-radius:10px;color:var(--red);display:flex;gap:8px;justify-content:flex-start;margin-top:8px;padding:9px 10px;transition:var(--transition);width:100%}.profile-logout:hover{background:rgba(248,113,113,.1)}.people-search-block{padding:8px 14px 10px}.people-search-copy{margin-bottom:10px}.people-search-copy span{color:var(--text-primary);display:block;font-size:15px;font-weight:700}.people-search-copy p{color:var(--text-muted);font-size:12px;margin-top:1px}.sidebar-search{background:#1b2023;border:1px solid rgba(255,255,255,.08);border-radius:14px;display:flex;align-items:center;gap:8px;min-height:46px;padding:0 12px;transition:var(--transition)}.sidebar-search:focus-within{border-color:#2dd4bf8c;box-shadow:0 0 0 3px #2dd4bf1f}.sidebar-search-icon{color:var(--text-muted);flex-shrink:0}.sidebar-search input{background:none;border:none;padding:12px 0;font-size:14px;color:var(--text-primary);flex:1;min-width:0}.sidebar-search input::placeholder{color:var(--text-muted)}.sidebar-search-clear{align-items:center;background:rgba(255,255,255,.06);border-radius:999px;color:var(--text-muted);display:flex;height:26px;justify-content:center;padding:0;width:26px}.sidebar-search-clear:hover{color:var(--text-primary)}.sidebar-section-label{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.sidebar-online-badge{background:rgba(45,212,191,.12);color:var(--green);padding:2px 7px;border-radius:20px;font-size:10px;font-weight:500;text-transform:none;letter-spacing:0}.sidebar-users{flex:1;overflow-y:auto;padding:0 10px 12px}.sidebar-empty{align-items:center;background:rgba(255,255,255,.035);border:1px dashed rgba(255,255,255,.12);border-radius:14px;color:var(--text-muted);display:flex;flex-direction:column;gap:6px;margin:12px 4px;padding:28px 18px;text-align:center}.sidebar-empty-icon{align-items:center;background:rgba(45,212,191,.1);border-radius:50%;color:var(--green);display:flex;height:50px;justify-content:center;margin-bottom:4px;width:50px}.sidebar-empty.error{border-color:#f8717133}.sidebar-empty.error .sidebar-empty-icon{background:rgba(248,113,113,.1);color:var(--red)}.sidebar-empty strong{color:var(--text-primary);font-size:14px}.sidebar-empty span{font-size:13px}.user-item{display:flex;align-items:center;gap:12px;padding:11px 10px;border-radius:14px;width:100%;background:none;color:var(--text-primary);cursor:pointer;transition:var(--transition);animation:slideIn .2s ease forwards}.user-item:hover{background:rgba(255,255,255,.045)}.user-item.active{background:rgba(45,212,191,.12);border:1px solid rgba(45,212,191,.2)}.user-item-avatar{position:relative;flex-shrink:0}.user-item-status-dot{position:absolute;bottom:1px;right:1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-surface)}.user-item-status-dot.online{background:var(--green)}.user-item-status-dot.offline{background:var(--text-muted)}.user-item.active .user-item-status-dot{border-color:#152522}.user-item-info{flex:1;min-width:0;text-align:left}.user-item-main,.user-item-meta{display:flex;align-items:center;gap:8px;min-width:0}.user-item-main{justify-content:space-between}.user-item-name{display:inline-block;font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.user-item-time{color:var(--text-muted);flex-shrink:0;font-size:11px;font-family:var(--font-mono)}.user-item-sub{font-size:12px;color:var(--text-muted);display:inline-block;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.user-item-unread{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--green);color:#08120b;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.user-skeleton{display:flex;align-items:center;gap:12px;padding:10px 8px}.skeleton-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-elevated);animation:pulse 1.5s infinite;flex-shrink:0}.skeleton-info{flex:1;display:flex;flex-direction:column;gap:6px}.skeleton-line{border-radius:4px;background:var(--bg-elevated);animation:pulse 1.5s infinite}.skeleton-name{height:13px;width:70%}.skeleton-status{height:11px;width:40%}@media (max-width: 760px){.sidebar{width:100vw;min-width:100vw}.chat-layout.has-selected-chat .sidebar{display:none}}.message-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:2px;animation:fadeIn .18s ease forwards}.message-row.mine{flex-direction:row-reverse}.message-avatar-slot{width:28px;height:28px;flex-shrink:0;display:flex;align-items:flex-end}.message-content{display:flex;flex-direction:column;max-width:65%;gap:3px}.message-row.mine .message-content{align-items:flex-end}.message-row.theirs .message-content{align-items:flex-start}.message-bubble{padding:10px 14px;border-radius:18px;word-wrap:break-word;word-break:break-word;line-height:1.5;min-width:48px}.bubble-mine{background:var(--accent);color:#fff;border-radius:18px 18px 4px}.bubble-theirs{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:18px 18px 18px 4px}.message-text{font-size:14.5px;white-space:pre-wrap}.message-time{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);padding:0 4px}.message-status{display:block;font-size:11px;line-height:1.2;margin-top:4px}.message-status.failed{color:#fecaca}.message-date-divider{display:flex;align-items:center;margin:16px 0 12px}.message-date-divider:before,.message-date-divider:after{content:"";flex:1;height:1px;background:var(--border)}.message-date-divider span{font-size:11px;color:var(--text-muted);padding:0 12px;white-space:nowrap;font-family:var(--font-mono)}@media (max-width: 760px){.message-content{max-width:82%}.message-bubble{padding:9px 12px}}.chat-window{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;background:radial-gradient(circle at top right,rgba(45,212,191,.08),transparent 28rem),linear-gradient(180deg,#0c1112,#0b0f10)}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(45,212,191,.09),transparent 22rem),var(--bg-base);padding:28px}.chat-empty-content{max-width:420px;text-align:center;color:var(--text-muted)}.chat-empty-icon{width:92px;height:92px;border-radius:50%;background:linear-gradient(135deg,rgba(45,212,191,.18),rgba(29,170,97,.08));border:1px solid rgba(45,212,191,.22);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--green)}.chat-empty-content h2{font-size:24px;font-weight:800;color:var(--text-primary);margin-bottom:8px}.chat-empty-content p{color:var(--text-secondary);font-size:15px}.chat-header{padding:14px 20px;border-bottom:1px solid var(--border);background:rgba(21,25,28,.94);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-header-user{display:flex;align-items:center;gap:12px;min-width:0}.chat-back-btn,.chat-refresh-btn{width:36px;height:36px;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);display:none;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}.chat-refresh-btn{display:flex}.chat-back-btn:hover,.chat-refresh-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.chat-header-avatar{position:relative;flex-shrink:0}.chat-header-info{min-width:0}.chat-header-status{position:absolute;bottom:2px;right:2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-surface)}.chat-header-status.online{background:var(--green)}.chat-header-status.offline{background:var(--text-muted)}.chat-header-info h2{font-size:17px;font-weight:800;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-presence{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px;margin-top:1px}.chat-header-presence.online{color:var(--green)}.typing-label{display:flex;align-items:center;gap:5px;color:var(--accent-bright);font-style:italic}.chat-messages{flex:1;overflow-y:auto;padding:20px 20px 10px;display:flex;flex-direction:column;gap:2px}.chat-error-banner{align-self:center;background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.22);border-radius:var(--radius-md);color:#fecaca;font-size:13px;margin:0 0 12px;max-width:520px;padding:9px 12px;text-align:center;width:fit-content}.chat-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);font-size:14px}.chat-loading-spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.chat-no-messages{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px}.chat-no-messages-avatar{margin-bottom:4px}.chat-no-messages-name{font-size:17px;font-weight:600}.chat-no-messages-sub{font-size:14px;color:var(--text-muted)}.typing-indicator{display:flex;align-items:flex-end;gap:8px;margin-top:6px;animation:fadeIn .2s ease}.typing-bubble{background:var(--bg-elevated);border:1px solid var(--border);border-radius:18px 18px 18px 4px;padding:10px 14px}.typing-dots{display:flex;gap:3px;align-items:center}.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-secondary);animation:blink 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.chat-input-area{padding:12px 16px 14px;border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0}.chat-input-wrapper{display:flex;align-items:flex-end;gap:10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px 10px 10px 16px;transition:var(--transition)}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.chat-input{flex:1;background:none;border:none;color:var(--text-primary);font-size:15px;resize:none;max-height:120px;min-height:24px;line-height:1.5;padding:0;overflow-y:auto}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-hover);color:var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}.chat-send-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent-bright));color:#fff;box-shadow:0 0 12px var(--accent-glow)}.chat-send-btn.active:hover{background:var(--accent-bright);transform:scale(1.05)}.chat-send-btn:disabled:not(.active){cursor:default}.chat-input-hint{font-size:11px;color:var(--text-muted);margin-top:6px;padding:0 4px}@media (max-width: 760px){.chat-window{display:none;width:100vw;min-width:100vw}.chat-layout.has-selected-chat .chat-window,.chat-back-btn{display:flex}.chat-header{padding:10px 12px}.chat-header-avatar{display:none}.chat-messages{padding:14px 12px 8px}.chat-input-area{padding:10px 10px 12px}.chat-input-hint{display:none}}.chat-layout{display:flex;height:100vh;width:100vw;background:var(--bg-base);overflow:hidden}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0b0f10;--bg-surface: #15191c;--bg-elevated: #1d2326;--bg-hover: #263034;--accent: #1daa61;--accent-bright: #2dd4bf;--accent-dim: rgba(45, 212, 191, .14);--accent-glow: rgba(45, 212, 191, .22);--green: #2dd4bf;--green-dim: rgba(45, 212, 191, .14);--red: #f87171;--text-primary: #f3f7f5;--text-secondary: #9ba8a5;--text-muted: #687674;--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--font-sans: "DM Sans", system-ui, sans-serif;--font-mono: "Space Mono", monospace;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-glow: 0 0 24px rgba(45, 212, 191, .16);--transition: all .18s ease}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none}input,textarea{font-family:var(--font-sans);outline:none}a{color:var(--accent-bright);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes blink{0%,80%,to{opacity:0}40%{opacity:1}}.fade-in{animation:fadeIn .25s ease forwards}
