:root{--tg-bg: #0e1621;--tg-sidebar: #17212b;--tg-panel: #0e1621;--tg-header: #17212b;--tg-hover: #202b36;--tg-active: #2b5278;--tg-accent: #5288c1;--tg-bubble-own: #2b5278;--tg-bubble-other: #182533;--tg-text: #f5f5f5;--tg-muted: #7f91a4;--tg-border: #0f1419;--tg-input: #242f3d;--tg-radius: 12px;--tg-font: "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--tg-font);background:var(--tg-bg);color:var(--tg-text);line-height:1.45}a{color:var(--tg-accent);text-decoration:none}button{font-family:inherit;cursor:pointer}.loading,.empty-hint{color:var(--tg-muted);text-align:center;padding:1.5rem 1rem;font-size:.9rem}.error{color:#ff6b6b;background:#ff6b6b1a;padding:.6rem 1rem;border-radius:8px;font-size:.85rem}.error.banner{margin:.5rem 1rem}.btn-primary{background:var(--tg-accent);color:#fff;border:none;border-radius:8px;padding:.65rem 1.2rem;font-weight:600}.btn-primary.full{width:100%;margin-top:.75rem}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.icon-btn{background:transparent;border:none;color:var(--tg-muted);font-size:1.1rem;padding:.35rem .5rem;border-radius:8px}.icon-btn:hover{background:var(--tg-hover);color:var(--tg-text)}.avatar{width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0}.avatar.sm{width:48px;height:48px;font-size:1.1rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(160deg,#0e1621,#17212b 50%,#1a3a5c)}.auth-card{background:var(--tg-sidebar);padding:2rem;border-radius:16px;width:100%;max-width:400px;box-shadow:0 8px 32px #0006}.auth-card h1{color:var(--tg-accent);margin-bottom:.25rem}.subtitle{color:var(--tg-muted);margin-bottom:1.25rem;font-size:.9rem}.auth-card form{display:flex;flex-direction:column;gap:.85rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--tg-muted)}.auth-card input{padding:.7rem .9rem;border:1px solid var(--tg-border);border-radius:8px;background:var(--tg-input);color:var(--tg-text)}.auth-link{margin-top:1rem;text-align:center;color:var(--tg-muted);font-size:.9rem}.join-actions{display:flex;gap:.5rem;justify-content:center}.tg-app{height:100vh;overflow:hidden}.tg-layout{display:grid;grid-template-columns:360px 1fr;height:100vh}.tg-sidebar{background:var(--tg-sidebar);border-right:1px solid var(--tg-border);display:flex;flex-direction:column;position:relative;min-width:0}.tg-sidebar-header{padding:.65rem .75rem .5rem;border-bottom:1px solid var(--tg-border)}.tg-user-row{display:flex;align-items:center;gap:.65rem;margin-bottom:.65rem}.tg-user-meta{flex:1;min-width:0}.tg-user-meta strong{display:block;font-size:.95rem}.tg-sub{font-size:.75rem;color:var(--tg-muted)}.tg-search-wrap{padding:0 .15rem}.tg-search{width:100%;padding:.55rem .85rem;border:none;border-radius:20px;background:var(--tg-input);color:var(--tg-text);font-size:.9rem}.tg-search:focus{outline:2px solid var(--tg-accent)}.tg-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:.4rem .5rem;border-bottom:1px solid var(--tg-border)}.tg-tab{background:transparent;border:none;color:var(--tg-muted);font-size:.68rem;padding:.45rem .2rem;border-radius:8px;display:flex;flex-direction:column;align-items:center;gap:.15rem}.tg-tab-icon{font-size:1rem}.tg-tab.active{background:var(--tg-hover);color:var(--tg-accent)}.tg-chat-list{flex:1;overflow-y:auto}.chat-list-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;border:none;background:transparent;color:var(--tg-text);text-align:left;border-bottom:1px solid rgba(255,255,255,.03)}.chat-list-item:hover{background:var(--tg-hover)}.chat-list-item.active{background:var(--tg-active)}.chat-list-body{flex:1;min-width:0}.chat-list-name{display:block;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-preview{display:block;font-size:.8rem;color:var(--tg-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-fab{position:absolute;right:1rem;bottom:1rem;width:48px;height:48px;border-radius:50%;border:none;background:var(--tg-accent);color:#fff;font-size:1.6rem;line-height:1;box-shadow:0 4px 12px #00000059}.tg-chat-panel{display:flex;flex-direction:column;background:var(--tg-panel);min-width:0;height:100vh;background-image:radial-gradient(circle at 20% 20%,rgba(82,136,193,.04),transparent 40%)}.tg-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--tg-muted);gap:.5rem}.tg-empty-icon{font-size:4rem;opacity:.35}.tg-chat-header{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;background:var(--tg-header);border-bottom:1px solid var(--tg-border)}.tg-chat-header-info{flex:1;min-width:0}.tg-chat-header-info strong{display:block;font-size:.95rem}.tg-chat-header-info span{font-size:.78rem;color:var(--tg-muted)}.tg-messages{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.35rem}.tg-bubble-row{display:flex}.tg-bubble-row.own{justify-content:flex-end}.tg-bubble{max-width:min(75%,520px);padding:.45rem .7rem .3rem;border-radius:var(--tg-radius);background:var(--tg-bubble-other);box-shadow:0 1px 2px #00000026}.tg-bubble-row.own .tg-bubble{background:var(--tg-bubble-own);border-bottom-right-radius:4px}.tg-bubble-row.other .tg-bubble{border-bottom-left-radius:4px}.tg-bubble p{word-break:break-word;font-size:.95rem;margin-bottom:.15rem}.tg-bubble time{display:block;text-align:right;font-size:.68rem;color:#ffffff8c}.tg-composer{display:flex;gap:.5rem;padding:.65rem 1rem;background:var(--tg-header);border-top:1px solid var(--tg-border)}.tg-composer input{flex:1;padding:.65rem 1rem;border:none;border-radius:22px;background:var(--tg-input);color:var(--tg-text)}.tg-composer button{width:44px;height:44px;border-radius:50%;border:none;background:var(--tg-accent);color:#fff;font-size:1.1rem}.tg-composer button:disabled{opacity:.4}.tg-composer.readonly{justify-content:center;color:var(--tg-muted);font-size:.85rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-card{background:var(--tg-sidebar);border-radius:14px;width:100%;max-width:400px;overflow:hidden;box-shadow:0 12px 40px #00000073}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem;border-bottom:1px solid var(--tg-border)}.modal-body{padding:1rem 1.1rem 1.25rem}.modal-hint{color:var(--tg-muted);font-size:.85rem;margin-bottom:.65rem}.search-results{max-height:280px;overflow-y:auto;margin-top:.5rem}.mobile-only{display:none}@media(max-width:768px){.tg-layout{grid-template-columns:1fr}.tg-layout .tg-sidebar{display:flex}.tg-layout .tg-chat-panel,.tg-layout.show-chat .tg-sidebar{display:none}.tg-layout.show-chat .tg-chat-panel{display:flex}.mobile-only{display:inline-flex}.tg-tabs{grid-template-columns:repeat(4,1fr)}.tg-tab{font-size:.62rem}}.voice-call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c12eb;display:flex;align-items:center;justify-content:center;z-index:200;padding:1.5rem}.voice-call-card{text-align:center;max-width:320px;width:100%}.voice-call-avatar{width:96px;height:96px;font-size:2rem;margin:0 auto 1.25rem}.voice-call-card h2{font-size:1.35rem;margin-bottom:.35rem}.voice-call-status{color:var(--tg-muted);font-size:.95rem;margin-bottom:.5rem}.voice-call-ice{color:var(--tg-accent);font-size:.78rem;margin-bottom:1rem}.voice-call-error{margin-bottom:1rem}.voice-call-wave{display:flex;justify-content:center;gap:6px;margin-bottom:1.5rem;height:24px;align-items:flex-end}.voice-call-wave span{width:4px;height:8px;background:var(--tg-accent);border-radius:2px;animation:voice-wave .9s ease-in-out infinite}.voice-call-wave span:nth-child(2){animation-delay:.15s}.voice-call-wave span:nth-child(3){animation-delay:.3s}@keyframes voice-wave{0%,to{height:8px}50%{height:22px}}.voice-call-actions{display:flex;justify-content:center;gap:1.5rem}.voice-btn{width:56px;height:56px;border-radius:50%;border:none;font-size:1.35rem;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s}.voice-btn:active{transform:scale(.94)}.voice-btn.accept{background:#3dd68c;color:#0e1621}.voice-btn.reject{background:#ff6b6b;color:#fff}.voice-btn.mute{background:var(--tg-input);color:var(--tg-text)}.voice-btn.mute.active{background:#ff6b6b}.tg-call-log{display:flex;justify-content:center;margin:.45rem 0}.tg-call-log-inner{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:14px;background:#5288c11f;color:var(--tg-muted);font-size:.82rem;max-width:90%;flex-wrap:wrap;justify-content:center}.tg-call-log-inner.missed{background:#ff6b6b1a;color:#ff8a8a}.tg-call-log-icon{font-size:.95rem;line-height:1}.tg-call-log-inner time{font-size:.68rem;opacity:.75}.voice-call-overlay+audio,audio[autoplay]{position:fixed;width:0;height:0;opacity:0;pointer-events:none}
