:root{color-scheme:dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0b1420;color:#e8f1f8}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;height:100%;background:#0b1420}body{overflow:hidden}button,input{font:inherit}button{cursor:pointer}input::placeholder{color:#7e96ab}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.truncate-block{min-width:0}.app-shell{display:grid;grid-template-columns:380px 1fr;min-height:100vh;height:100vh;background:linear-gradient(120deg,#0c1b2bfa,#07111c)}.sidebar,.chat-window{min-height:0;min-width:0}.sidebar{display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,#17212b,#101922)}.sidebar-header,.chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;min-width:0;border-bottom:1px solid rgba(255,255,255,.06);background:#17212bf0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.chat-header{position:sticky;top:0;z-index:5}.sidebar-actions{padding:14px;display:grid;gap:10px}.profile-chip{display:flex;align-items:center;gap:12px;min-width:0}.profile-name,.chat-item-title{font-weight:700}.small{font-size:12px}.muted{color:#8ea8c1}.avatar,.mini-avatar{position:relative;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;box-shadow:0 8px 18px #00000038}.avatar{width:46px;height:46px;border-radius:50%}.avatar-chat{width:52px;height:52px}.mini-avatar{width:28px;height:28px;border-radius:50%;font-size:11px}.online-dot{position:absolute;right:2px;bottom:2px;width:12px;height:12px;border-radius:50%;background:#4cd964;border:2px solid #17212b}.icon-button,.send-button,.new-chat-button,.primary-button,.tab,.chat-item,.user-item,.ghost-button,.danger-button{border:none}.icon-button{width:38px;height:38px;border-radius:50%;background:#ffffff14;color:#e8f1f8}.new-chat-button,.primary-button{width:100%;border-radius:14px;padding:14px 16px;background:linear-gradient(180deg,#2aabee,#229ed9);color:#fff;font-weight:700;box-shadow:0 10px 24px #269ad83d}.new-chat-button.secondary,.ghost-button{background:#ffffff0f;color:#dbeaf4;box-shadow:none}.ghost-button{padding:8px 12px;border-radius:12px}.danger-button{padding:10px 14px;border-radius:12px;background:#e5393524;color:#ffb6b4;white-space:nowrap}.new-chat-button:disabled,.icon-button:disabled,.send-button:disabled,.primary-button:disabled{opacity:.65;cursor:not-allowed}.search-wrap{display:flex;align-items:center;gap:10px;padding:0 14px;border-radius:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.05)}.search-icon{color:#7e96ab}.search-input{width:100%;background:transparent;color:#fff;border:none;outline:none;padding:13px 0}.chat-list,.user-list{overflow:auto;padding:8px 10px 16px;min-height:0}.chat-item,.user-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:18px;background:transparent;color:#e8f1f8;text-align:left;margin-bottom:6px;transition:background .18s ease,transform .18s ease}.chat-item.active,.chat-item:hover,.user-item:hover,.user-item.checked{background:#2aabee26;transform:translateY(-1px)}.chat-item-content{min-width:0;flex:1}.chat-item-title-row,.chat-item-subtitle-row{display:flex;align-items:center;gap:8px;justify-content:space-between}.chat-item-subtitle-row{margin-top:4px}.chat-item-subtitle{color:#8ea8c1}.chat-time{color:#7fa0b8;font-size:12px;white-space:nowrap}.presence-pill{font-size:11px;padding:3px 8px;border-radius:999px;color:#8ea8c1;background:#ffffff0d;white-space:nowrap}.presence-pill.online{color:#92f3a0;background:#4cd96421}.empty-hint{color:#8ea8c1;padding:20px 12px}.chat-window{display:grid;grid-template-rows:auto minmax(0,1fr) auto auto;background:radial-gradient(circle at top left,rgba(42,171,238,.08),transparent 25%),radial-gradient(circle at bottom right,rgba(135,116,225,.08),transparent 24%),#0e1621}.telegram-wallpaper{background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 0);background-size:22px 22px}.message-area{min-height:0;overflow:auto;padding:22px 20px 8px;display:flex;flex-direction:column;gap:12px}.message-row{display:flex;align-items:flex-end;gap:8px;max-width:min(760px,78%)}.message-row.mine{align-self:flex-end;justify-content:flex-end}.bubble{position:relative;max-width:100%;background:#182533;border:1px solid rgba(255,255,255,.06);padding:10px 44px 8px 12px;border-radius:18px 18px 18px 8px;box-shadow:0 12px 30px #0000002e;display:inline-block}.bubble.mine{background:linear-gradient(180deg,#2aabee,#229ed9);border-radius:18px 18px 8px}.media-bubble{padding:10px}.message-author{font-size:12px;color:#7ecaf6;margin-bottom:6px;font-weight:700}.message-meta{font-size:11px;color:#ffffffb8;text-align:right;margin-top:6px}.message-text,.caption{white-space:pre-wrap;word-break:normal;overflow-wrap:anywhere;line-height:1.35;font-size:15px}.attachment-wrap{display:flex;flex-direction:column;gap:8px}.message-image,.message-video{display:block;width:min(420px,100%);max-width:min(420px,62vw);max-height:420px;border-radius:14px;object-fit:cover;background:#0f1d2b}.typing-indicator{align-self:flex-start;padding:10px 14px;border-radius:14px;background:#ffffff0d;color:#9bb4c8;font-size:13px}.composer-shell{position:sticky;bottom:0;z-index:4;padding:8px 16px max(8px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#0e162100,#0e1621d1 22%,#0e1621fa 52%)}.composer{display:flex;align-items:center;gap:10px;padding:12px;border-radius:22px;background:#17212bf5;border:1px solid rgba(255,255,255,.08);box-shadow:0 14px 28px #00000038;margin:0}.composer-input,.auth-form input,.modal-input{width:100%;min-width:0;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;padding:14px 16px;border-radius:16px;outline:none}.file-picker{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:#ffffff14;flex:0 0 auto}.file-picker input{display:none}.send-button{width:46px;height:46px;border-radius:50%;background:linear-gradient(180deg,#2aabee,#229ed9);color:#fff;font-size:18px;flex:0 0 auto}.file-hint{margin:0 16px 8px;padding:10px 14px;border-radius:14px;background:#ffffff0f;color:#c9d9e6;font-size:12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.auth-page{min-height:100vh;padding:24px;display:grid;place-items:center;background:radial-gradient(circle at top,rgba(42,171,238,.2),transparent 30%),radial-gradient(circle at bottom,rgba(135,116,225,.16),transparent 35%),#0e1621}.auth-card,.modal-card{width:min(100%,420px);border-radius:28px;padding:28px;background:#17212bf5;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px #00000047}.auth-logo{width:72px;height:72px;border-radius:22px;background:linear-gradient(180deg,#2aabee,#2385b7);display:grid;place-items:center;font-size:32px;margin-bottom:14px}.auth-form{display:flex;flex-direction:column;gap:12px;margin-top:18px}.tab-row{display:flex;gap:8px;margin-top:18px}.tab-row.compact{margin:12px 0}.tab{flex:1;background:#ffffff12;color:#dbeaf4;padding:12px 14px;border-radius:14px}.tab.active{background:#2aabee2e;color:#7ed1fd}.error-box{margin-top:10px;padding:12px 14px;border-radius:14px;background:#e539352e;color:#ffb6b4}.info-box{margin-top:10px;padding:12px 14px;border-radius:14px;background:#4cd96426;color:#c8ffd1}.text-link-button{margin-top:14px;background:transparent;color:#7ed1fd;border:none;padding:0;font-weight:600}.auth-hint{margin-top:14px}.admin-actions-wrap{flex-wrap:wrap;justify-content:flex-end}.error-box.bottom{margin:0 16px 16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:grid;place-items:center;padding:20px}.modal-card{width:min(100%,520px);max-height:min(90vh,760px);display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center}.checkmark{width:28px;color:#7ed1fd;font-size:18px}.selected-strip{display:flex;gap:8px;flex-wrap:wrap;padding-top:10px}.selected-pill{padding:8px 10px;border-radius:999px;background:#2aabee29;color:#9dd8fa;font-size:13px}.empty-state,.center-screen{display:grid;place-items:center}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{max-height:45vh}.message-row{max-width:94%}.message-image,.message-video{max-width:100%}.danger-button{font-size:12px;padding:9px 12px}}.chat-header-main{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.back-button{display:inline-flex;align-items:center;justify-content:center}@media(max-width:900px){html,body,#root{height:100%;min-height:100dvh}body{overflow:hidden}.app-shell,.mobile-pane,.sidebar,.chat-window{min-height:100dvh;height:100dvh}.mobile-shell{display:block;position:relative;background:#0e1621}.mobile-pane.hidden{display:none}.mobile-pane.visible{display:block}.sidebar{border-right:none}.sidebar-header,.chat-header{padding:calc(12px + env(safe-area-inset-top)) 14px 12px}.sidebar-actions{padding:12px;gap:8px}.new-chat-button,.primary-button{padding:13px 14px;border-radius:16px}.chat-list,.user-list{padding:6px 10px calc(18px + env(safe-area-inset-bottom))}.chat-item,.user-item{padding:12px 10px;border-radius:16px;align-items:center}.chat-item-title-row,.chat-item-subtitle-row{gap:6px}.chat-item-subtitle-row{align-items:center}.presence-pill{flex:0 0 auto;font-size:10px;padding:4px 7px}.chat-window{grid-template-rows:auto minmax(0,1fr) auto auto}.chat-header{gap:8px;align-items:center;flex-wrap:nowrap}.chat-header-main,.profile-chip,.truncate-block{min-width:0}.delete-chat-button{font-size:11px;padding:8px 10px;border-radius:10px}.message-area{padding:14px 10px 6px;gap:10px}.message-row{max-width:calc(100% - 6px);gap:6px}.mini-avatar{width:24px;height:24px;font-size:10px}.bubble{padding:9px 40px 7px 10px;border-radius:16px 16px 16px 8px}.bubble.mine{border-radius:16px 16px 8px}.message-image,.message-video{width:100%;max-width:min(100%,320px);max-height:min(50vh,360px)}.composer-shell{padding:6px 10px max(4px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#0e162100,#0e1621e0 24%,#0e1621fa 52%)}.composer{padding:10px;gap:8px;border-radius:22px}.composer-input,.auth-form input,.modal-input{padding:12px 14px;border-radius:14px;font-size:16px}.file-picker,.send-button,.icon-button,.record-button{width:42px;height:42px}.file-hint{margin:0 10px 6px;padding:9px 12px;border-radius:12px}.modal-overlay{padding:12px;align-items:end}.modal-card{width:100%;max-height:min(88dvh,760px);padding:20px;border-radius:22px 22px 0 0}}.avatar-image{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.avatar-upload-trigger{position:relative;display:inline-flex;cursor:pointer}.avatar-upload-trigger input{display:none}.avatar-edit-badge{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;background:#2aabee;color:#fff;font-size:11px;display:grid;place-items:center;box-shadow:0 4px 12px #00000040}.message-menu-button{position:absolute;top:6px;right:6px;width:26px;height:26px;border:none;border-radius:999px;background:#ffffff14;color:inherit;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}.deleted-message{opacity:.7;font-style:italic}.chat-select-button{flex:1;min-width:0;display:flex;align-items:center;gap:12px;background:transparent;border:none;color:inherit;text-align:left;padding:0}.chat-delete-inline{width:34px;height:34px;border-radius:50%;background:#e5393524;color:#ffb6b4;border:none;flex:0 0 auto}.admin-panel{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden}.admin-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;background:transparent;color:#e8f1f8;border:none;padding:12px 14px;font-weight:700}.admin-list{padding:8px;display:grid;gap:8px;max-height:240px;overflow:auto}.admin-user-row{display:grid;gap:8px;padding:10px;border-radius:14px;background:#ffffff0a}.admin-user-main{display:flex;align-items:center;gap:10px;min-width:0}.admin-avatar{width:36px;height:36px}.admin-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.admin-badge,.compact-danger{padding:7px 10px}@media(max-width:900px){.chat-delete-inline{width:30px;height:30px;font-size:12px}.chat-select-button{gap:10px}.sidebar-header .profile-chip{align-items:flex-start}.avatar-chat{width:46px;height:46px}.chat-item-title{font-size:15px}.chat-item-subtitle{font-size:14px}.message-area{padding-top:12px}.admin-list{max-height:180px}}.chat-item-meta{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}.unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#2aabee;color:#fff;font-size:11px;font-weight:700;line-height:1}.message-audio{width:min(320px,100%);max-width:min(320px,62vw);display:block}.preview-audio{margin-top:8px}.record-button{width:44px;height:44px;border-radius:50%;border:none;background:#ffffff14;color:#fff;flex:0 0 auto;font-size:18px}.record-button.recording{background:#e5393538;color:#ffb6b4;box-shadow:0 0 0 6px #e5393514}.recording-indicator{margin:0 16px 8px;padding:10px 14px;border-radius:14px;background:#e5393524;color:#ffb6b4;font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:12px}.recording-indicator-main,.recording-indicator-actions{display:inline-flex;align-items:center;gap:8px}.recording-pulse.paused{animation:none;opacity:.65}.voice-file-hint{align-items:flex-start}.chat-item-meta{display:flex;align-items:center;gap:8px}.unread-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#2aabee;color:#fff;font-size:11px;font-weight:700}@media(max-width:900px){.message-audio{max-width:100%}.recording-indicator{margin:0 10px 6px;flex-direction:column;align-items:stretch}.recording-indicator-actions{justify-content:flex-end}}.load-older-button{align-self:center;border:none;border-radius:999px;padding:8px 14px;background:#ffffff14;color:#dbeaf4}.reply-preview-inline,.reply-composer-card{display:flex;flex-direction:column;gap:2px;border:none;width:100%;text-align:left;padding:8px 10px;border-left:3px solid #2AABEE;border-radius:12px;background:#ffffff0f;color:inherit;margin-bottom:8px}.reply-composer-card{margin:0 16px 8px;position:relative}.reply-composer-card .ghost-button{position:absolute;right:8px;top:8px}.reply-preview-author{font-size:12px;font-weight:700;color:#8dd7ff}.reply-preview-text{font-size:13px;color:#cfe3f2}.reaction-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.reaction-pill{border:none;border-radius:999px;padding:4px 8px;background:#ffffff14;color:#fff;display:inline-flex;align-items:center;gap:4px}.reaction-pill.active{background:#2aabee38;color:#9fe1ff}.reaction-add-button{border:none;border-radius:999px;min-width:30px;height:30px;padding:0 10px;background:#ffffff0d;color:#cfe6f7;display:inline-flex;align-items:center;justify-content:center}.quick-reaction-button.active{background:#2aabee38;color:#9fe1ff;box-shadow:inset 0 0 0 1px #2aabee47}.voice-player{display:grid;gap:6px}.voice-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.voice-duration{font-size:12px;color:#ffffffbf}.voice-speed-button{border:none;border-radius:999px;padding:4px 8px;background:#ffffff14;color:#fff}.recording-pulse{width:10px;height:10px;border-radius:50%;background:#ff6b6b;box-shadow:0 0 #ff6b6b73;animation:pulse 1.2s infinite;display:inline-block;margin-right:8px}@keyframes pulse{0%{box-shadow:0 0 #ff6b6b73}70%{box-shadow:0 0 0 10px #ff6b6b00}to{box-shadow:0 0 #ff6b6b00}}.message-jump-highlight .bubble{box-shadow:0 0 0 2px #2aabee99,0 12px 30px #0000002e}.action-sheet{width:min(100%,420px);margin-top:auto;background:#17212bfa;border:1px solid rgba(255,255,255,.08);border-radius:22px 22px 0 0;padding:14px 14px calc(18px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px #00000059}.action-sheet-title{font-size:13px;color:#8ea8c1;padding:4px 8px 10px}.quick-reaction-row{display:flex;justify-content:space-between;gap:8px;margin-bottom:10px}.quick-reaction-button{border:none;border-radius:14px;background:#ffffff14;color:#fff;font-size:24px;padding:10px;flex:1}.action-sheet-item{width:100%;border:none;border-radius:14px;background:transparent;color:#fff;text-align:left;padding:14px 12px}.action-sheet-item:hover{background:#ffffff0d}.action-sheet-item.danger{color:#ffb6b4}.action-sheet-item.cancel{margin-top:8px;background:#ffffff0d;text-align:center}@media(max-width:900px){.reply-composer-card{margin:0 10px 6px}.action-sheet{width:100%}}
