* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --bg: #202020;
  --panel: #242424;
  --panel2: #161616;
  --text: #e4e2d5;
  --muted: #8e98a3;
  --border: #202020;
  --accent: #5cd372;
  --accent-hover: #4fb85f;
  --accent-text: #161616;
  --input-bg: #242424;
  --input-bg-focus: #2b3542;
  --hint: #6c757d;
  --danger: #e53935;
  --radius-lg: 20px;
  --radius-md: 12px;
  --radius-sm: 8px;
  --radius-avatar: 15px;
  --avatar-bg: #d9d9d9;
  --avatar-text: #202020;
  --bubble-in: #161616;
  --bubble-out: #5cd372;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  height: 100vh;
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-color: var(--chat-bg, var(--bg));
  background-image: var(--chat-bg-image, none);
  background-size: cover;
  background-position: center;
  opacity: 0.16;
  pointer-events: none;
  z-index: -1;
}

.hidden {
  display: none !important;
}

.auth-container {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.auth-box {
  width: 100%;
  max-width: 420px;
  background: var(--panel);
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}

.auth-header {
  text-align: center;
  margin-bottom: 30px;
}

.logo {
  width: 48px;
  height: 48px;
  background: var(--avatar-bg);
  border-radius: var(--radius-avatar);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
  color: var(--avatar-text);
}

.auth-header .logo {
  width: 80px;
  height: 80px;
  margin: 0 auto 16px;
  border-radius: 20px;
  font-size: 48px;
}

.auth-header h1 {
  font-size: 28px;
  font-weight: 600;
  color: var(--text);
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-form h2 {
  font-size: 24px;
  font-weight: 600;
  color: var(--text);
}

.auth-status,
.auth-hint {
  text-align: center;
  font-size: 14px;
  min-height: 20px;
}

.auth-status {
  color: var(--muted);
}

.auth-status.error {
  color: var(--danger);
}

.auth-status.success {
  color: var(--accent);
}

.auth-hint {
  color: var(--muted);
}

.auth-btn,
.auth-switch-btn,
.btn-primary,
.btn-secondary,
.create-chat-btn,
.send-btn,
.action-btn,
.list-tab,
.chatItem {
  transition: all 0.2s;
}

.auth-btn,
.btn-primary {
  padding: 12px 24px;
  background: var(--accent);
  border: none;
  border-radius: 12px;
  color: var(--accent-text);
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
}

.auth-btn:hover,
.btn-primary:hover {
  background: var(--accent-hover);
}

.auth-switch-btn,
.btn-secondary {
  padding: 10px 20px;
  background: var(--panel);
  border: 1px solid var(--input-bg-focus);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
}

.auth-switch-btn:hover,
.btn-secondary:hover {
  background: var(--input-bg-focus);
}

.form-group {
  display: flex;
  flex-direction: column;
}

.form-group label {
  display: block;
  margin-bottom: 8px;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
}

.form-group input,
.form-group select,
.list-search input,
#textInput {
  width: 100%;
  padding: 12px 16px;
  background: var(--panel2);
  border: 1px solid var(--input-bg-focus);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 14px;
  outline: none;
}

.form-group input:focus,
.form-group select:focus,
.list-search input:focus,
#textInput:focus {
  border-color: var(--accent);
  background: #1a1a1a;
}

.form-group input::placeholder,
.list-search input::placeholder,
#textInput::placeholder {
  color: var(--hint);
}

#layout {
  display: grid;
  grid-template-columns: 70px 420px 1fr;
  height: 100vh;
  min-height: 0;
}

#sidebar {
  background: color-mix(in srgb, var(--panel) 86%, transparent);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 0;
}

.sidebar-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.app-name {
  font-size: 12px;
  color: var(--text);
  font-weight: 500;
}

.sidebar-footer {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.action-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: transparent;
  border: none;
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.action-btn:hover {
  background: var(--panel);
}

.action-btn img,
.send-btn img {
  display: block;
  filter: invert(92%) sepia(7%) saturate(309%) hue-rotate(358deg) brightness(95%) contrast(90%);
}

#chatList {
  background: color-mix(in srgb, var(--panel) 86%, transparent);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.chat-list-header {
  padding: 20px;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  height: 77px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.chat-list-header h2 {
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
}

.chat-list-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.create-chat-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent);
  border: none;
  color: var(--accent-text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}

.create-chat-btn:hover {
  background: var(--accent-hover);
  transform: scale(1.08);
}

.list-tabs {
  display: flex;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}

.list-tab {
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 12px;
  background: var(--panel2);
  color: var(--muted);
  cursor: pointer;
}

.list-tab.active {
  color: var(--accent-text);
  background: var(--accent);
  border-color: transparent;
}

.list-search {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
}

#chatListContent {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
}

.chatItem {
  width: 100%;
  padding: 15px 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  text-align: left;
}

.chatItem:hover {
  background: color-mix(in srgb, var(--panel) 70%, white 8%);
}

.chatItem.active {
  background: var(--panel2);
}

.chatItem .avatar {
  width: 50px;
  height: 50px;
  border-radius: var(--radius-avatar);
  background: var(--avatar-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--avatar-text);
  font-weight: 600;
  flex-shrink: 0;
  font-size: 18px;
}

.chatItem .info {
  flex: 1;
  min-width: 0;
}

.chatItem .name {
  font-weight: 500;
  color: var(--text);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 15px;
}

.chatItem .last-message {
  font-size: 14px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-unread-badge {
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: var(--accent);
  color: var(--accent-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.chat-presence-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #8f96a6;
  flex-shrink: 0;
}

.chat-presence-dot.online {
  background: #39d363;
}

#chat {
  display: flex;
  flex-direction: column;
  background: var(--bg);
  min-height: 0;
}

#chatHeader {
  height: 77px;
  background: color-mix(in srgb, var(--panel) 86%, transparent);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
}

.pinned-bar {
  min-height: 58px;
  padding: 8px 20px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 82%, transparent);
  flex-shrink: 0;
}

.pinned-bar-main {
  flex: 1;
  min-width: 0;
  text-align: left;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 84%, transparent);
  border-radius: 16px;
  padding: 10px 12px;
  cursor: pointer;
}

.pinned-bar-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
}

.pinned-bar-text {
  font-size: 13px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pinned-bar-clear {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--panel2);
  color: var(--text);
  cursor: pointer;
}

.chat-search-bar {
  min-height: 58px;
  padding: 8px 20px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel) 82%, transparent);
  flex-shrink: 0;
}

.chat-search-input {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  border-radius: 16px;
  padding: 11px 14px;
  font-size: 14px;
  outline: none;
}

.chat-folders-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px 12px 6px;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
  scrollbar-width: thin;
}

.chat-folders-bar button {
  flex: 0 0 auto;
  min-height: 32px;
  border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--border) 84%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--muted);
  padding: 0 12px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease;
}

.chat-folders-bar button:hover,
.chat-folders-bar button.active {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--accent) 24%, var(--panel2) 76%);
  color: var(--text);
}

.tg-settings-nav [data-settings-locked="1"]:not([data-settings-panel="privacy"]) {
  opacity: 0.45;
  cursor: not-allowed;
}

.tg-settings-nav [data-settings-panel="privacy"],
.tg-settings-nav [data-settings-panel="privacy"][disabled],
.tg-settings-nav [data-settings-panel="privacy"][aria-disabled="true"],
.tg-settings-nav [data-settings-panel="privacy"][data-settings-locked="1"] {
  opacity: 1 !important;
  filter: none !important;
  pointer-events: auto !important;
  cursor: pointer !important;
  color: color-mix(in srgb, var(--text) 92%, transparent) !important;
}

.tg-settings-nav [data-settings-panel="privacy"] span,
.tg-settings-nav [data-settings-panel="privacy"] .tg-settings-nav-icon {
  opacity: 1 !important;
  color: inherit !important;
}

.chat-folders-bar .folder-create {
  width: 32px;
  padding: 0;
}

.chat-folders-settings {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.folder-settings-create {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.folder-settings-create input {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  padding: 10px 12px;
  outline: none;
}

.folder-settings-create button,
.folder-settings-title button {
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border) 72%);
  border-radius: 14px;
  background: var(--accent);
  color: var(--accent-text);
  padding: 0 14px;
  font-weight: 950;
  cursor: pointer;
}

.folder-settings-empty {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.folder-settings-card {
  display: grid;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
  border-radius: 18px;
  padding: 12px;
  background: color-mix(in srgb, var(--panel2) 72%, transparent);
}

.folder-settings-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.folder-settings-title button {
  background: color-mix(in srgb, #ff6961 24%, var(--panel2) 76%);
  color: var(--text);
}

.folder-settings-chat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 8px;
}

.folder-settings-chat {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
  border-radius: 14px;
  padding: 9px 10px;
  background: color-mix(in srgb, var(--panel) 62%, transparent);
  color: var(--text);
  font-weight: 800;
}

.folder-settings-chat span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.notification-settings-panel {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 72%, transparent);
  padding: 12px;
}

.notification-settings-panel > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text);
}

.notification-settings-head {
  align-items: center;
}

.notification-settings-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.notification-settings-panel span,
.notification-settings-panel small {
  color: var(--muted);
  line-height: 1.4;
}

.notification-push-status {
  border: 1px solid color-mix(in srgb, var(--accent) 32%, transparent);
  border-radius: 14px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  padding: 9px 11px;
}

.notification-settings-panel button {
  justify-self: start;
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: var(--accent-text);
  padding: 9px 14px;
  font-weight: 950;
  cursor: pointer;
}

.notification-settings-panel label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-weight: 850;
}

.push-optin-prompt {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 1500;
  width: min(430px, calc(100vw - 28px));
  animation: pushOptIn 0.28s ease both;
}

.push-optin-card {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 32%, var(--border) 68%);
  border-radius: 24px;
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--accent) 24%, transparent), transparent 35%),
    color-mix(in srgb, var(--panel2) 92%, #000 8%);
  box-shadow: 0 24px 70px color-mix(in srgb, #000 52%, transparent);
  padding: 14px;
  backdrop-filter: blur(18px);
}

.push-optin-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 17px;
  background: linear-gradient(145deg, var(--accent), color-mix(in srgb, var(--accent) 54%, #fff 46%));
  color: var(--accent-text);
  font-weight: 1000;
  box-shadow: 0 12px 30px color-mix(in srgb, var(--accent) 28%, transparent);
}

.push-optin-body {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.push-optin-body strong {
  color: var(--text);
  font-size: 16px;
}

.push-optin-body span {
  color: var(--muted);
  line-height: 1.35;
  font-size: 13px;
}

.push-optin-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.push-optin-actions button {
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border) 70%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  color: var(--text);
  padding: 9px 14px;
  font-weight: 950;
  cursor: pointer;
}

.push-optin-actions [data-push-optin-allow] {
  background: var(--accent);
  color: var(--accent-text);
}

@keyframes pushOptIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.chat-list-soft-update .chatItem {
  animation-duration: 0.12s;
}

.user-decorations {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 6px;
  vertical-align: middle;
}

.emoji-status {
  display: inline-grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 16%, var(--panel2) 84%);
  font-size: 13px;
}

.system-badge {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, transparent);
  border-radius: 50%;
  background: radial-gradient(circle at 30% 20%, color-mix(in srgb, var(--accent) 38%, #fff 18%), color-mix(in srgb, var(--panel2) 80%, #000 20%));
  color: var(--text);
  font-size: 11px;
  font-weight: 950;
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 18%, transparent);
}

.system-badge-confirmed {
  border-radius: 6px;
}

.system-badge-supporter {
  color: #ffd16d;
}

.chat-search-count {
  min-width: 52px;
  text-align: center;
  font-size: 12px;
  color: var(--muted);
}

.back-btn {
  display: none;
}

.profile-mobile-btn {
  display: none;
}

.chat-user {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.chat-user .avatar {
  width: 50px;
  height: 50px;
  border-radius: var(--radius-avatar);
  background: var(--avatar-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--avatar-text);
  font-weight: 600;
  flex-shrink: 0;
  font-size: 18px;
}

.chat-user .info {
  min-width: 0;
}

.chat-user .name {
  font-weight: 500;
  color: var(--text);
  font-size: 16px;
  margin-bottom: 2px;
}

.chat-user .status {
  font-size: 13px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.secure-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  background: var(--panel2);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 12px;
  color: var(--text);
}

.secure-badge img {
  filter: invert(65%) sepia(37%) saturate(620%) hue-rotate(74deg) brightness(94%) contrast(89%);
}

#messages {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  background:
    linear-gradient(var(--chat-wallpaper-dim, rgba(0, 0, 0, 0.68)), var(--chat-wallpaper-dim, rgba(0, 0, 0, 0.68))),
    var(--chat-bg-image, none),
    var(--chat-bg, var(--bg));
  background-size: auto, cover, auto;
  background-position: center, center, center;
  background-repeat: no-repeat, no-repeat, repeat;
  background-attachment: local, local, scroll;
  isolation: isolate;
}

#messages::before {
  display: none;
}

#messages > * {
  position: relative;
  z-index: 1;
}

.empty-chat {
  margin: auto;
  max-width: 420px;
  border: 1px solid var(--border);
  background: var(--panel2);
  border-radius: var(--radius-lg);
  padding: 18px;
  text-align: center;
  color: var(--muted);
  line-height: 1.45;
}

.message {
  max-width: 65%;
  padding: 10px 14px;
  border-radius: var(--radius-lg);
  word-wrap: break-word;
  animation: messageSlide 0.2s ease-out;
  position: relative;
}

#messages.messages-stable-render .message {
  animation: none !important;
}

.message.active {
  outline: 1px solid color-mix(in srgb, var(--accent) 38%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 10%, transparent);
}

.message.search-hit {
  box-shadow: 0 0 0 3px color-mix(in srgb, #f3b24e 14%, transparent);
}

.message-search-mark {
  background: color-mix(in srgb, #f3b24e 64%, transparent);
  color: #1a1a1a;
  border-radius: 4px;
  padding: 0 2px;
}

.message.system {
  align-self: center;
  max-width: min(520px, 100%);
  background: transparent;
  padding: 0;
}

.message.system .system-content {
  padding: 8px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  text-align: center;
}

@keyframes messageSlide {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.message.in {
  background: color-mix(in srgb, var(--bubble-in) 70%, transparent);
  align-self: flex-start;
  border-bottom-left-radius: 4px;
}

.message.out {
  background: color-mix(in srgb, var(--bubble-out) 72%, transparent);
  align-self: flex-end;
  border-bottom-right-radius: 4px;
  color: var(--accent-text);
}

.message .sender {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 6px;
}

.message .content {
  font-size: 14px;
  line-height: 1.45;
  white-space: pre-wrap;
}

.message .reply-preview {
  margin-bottom: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel2) 74%, transparent);
  border-left: 3px solid var(--accent);
}

.message .reply-preview-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
}

.message .reply-preview-text {
  font-size: 12px;
  line-height: 1.35;
  color: var(--muted);
}

.message .forward-preview {
  margin-bottom: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel2) 74%, transparent);
  border-left: 3px solid color-mix(in srgb, var(--accent) 60%, #6fa8ff 40%);
}

.message .forward-preview-label {
  font-size: 11px;
  font-weight: 700;
  color: color-mix(in srgb, var(--accent) 60%, #6fa8ff 40%);
  margin-bottom: 4px;
}

.message .forward-preview-text {
  font-size: 12px;
  line-height: 1.35;
  color: var(--muted);
}

.message-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.message-reactions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.message-reaction-chip {
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
  color: var(--text);
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
}

.message-reaction-chip.active {
  border-color: color-mix(in srgb, var(--accent) 68%, var(--border) 32%);
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
}

.reaction-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.message-action-btn {
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 80%, transparent);
  color: var(--text);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  cursor: pointer;
}

.message-action-btn:hover {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border) 50%);
}

.message-comment-btn {
  align-self: flex-start;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border) 70%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 82%, transparent);
  color: var(--muted);
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 950;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

.message.out .message-comment-btn {
  align-self: flex-end;
}

.message-comment-btn:hover,
.message-comment-btn:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 56%, var(--border) 44%);
  background: color-mix(in srgb, var(--accent) 22%, var(--panel2) 78%);
  color: var(--text);
}

.comment-modal-card {
  max-width: min(560px, 94vw);
  max-height: min(780px, 92vh);
  display: grid;
  grid-template-rows: auto auto minmax(120px, 1fr) auto auto;
  gap: 12px;
}

.comment-post-preview {
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border) 78%);
  border-radius: 18px;
  background: color-mix(in srgb, var(--accent) 10%, var(--panel2) 90%);
  color: var(--text);
  padding: 12px 14px;
  font-weight: 900;
  line-height: 1.35;
}

.comment-thread-list {
  display: grid;
  gap: 10px;
  overflow-y: auto;
  padding-right: 4px;
  align-content: start;
}

.comment-empty {
  border: 1px dashed var(--border);
  border-radius: 18px;
  color: var(--muted);
  padding: 18px;
  text-align: center;
}

.comment-thread-item {
  display: grid;
  gap: 5px;
  width: min(82%, 360px);
  border: 1px solid color-mix(in srgb, var(--border) 82%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
  padding: 11px 12px;
}

.comment-thread-item.is-peer {
  justify-self: start;
  border-bottom-left-radius: 7px;
}

.comment-thread-item.is-own {
  justify-self: end;
  border-bottom-right-radius: 7px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 28%, var(--panel2) 72%), color-mix(in srgb, var(--accent) 14%, var(--panel2) 86%));
  border-color: color-mix(in srgb, var(--accent) 46%, var(--border) 54%);
}

.comment-thread-item.is-peer.is-reply {
  margin-left: 22px;
  border-left: 3px solid var(--accent);
}

.comment-thread-item.is-own.is-reply {
  margin-right: 22px;
  border-right: 3px solid var(--accent);
}

.comment-thread-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.comment-thread-author {
  color: var(--accent);
  font-size: 12px;
  font-weight: 950;
}

.comment-thread-item.is-own .comment-thread-author {
  color: color-mix(in srgb, var(--text) 88%, var(--accent) 12%);
}

.comment-thread-badge {
  justify-self: end;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--border) 66%);
  color: var(--muted);
  padding: 3px 7px;
  font-size: 10px;
  font-weight: 950;
  white-space: nowrap;
}

.comment-thread-text {
  color: var(--text);
  line-height: 1.38;
  white-space: pre-wrap;
}

.comment-thread-item button,
.comment-compose button,
.comment-reply-bar button {
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--border) 66%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
  color: var(--text);
  padding: 7px 12px;
  font-weight: 950;
  cursor: pointer;
}

.comment-thread-item button {
  justify-self: start;
  font-size: 12px;
}

.comment-thread-item.is-own button {
  justify-self: end;
}

.comment-reply-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--accent) 14%, var(--panel2) 86%);
  color: var(--muted);
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 900;
}

.comment-compose {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.comment-compose textarea {
  width: 100%;
  resize: vertical;
  min-height: 72px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
}

.message .meta {
  margin-top: 6px;
  font-size: 11px;
  color: var(--muted);
  text-align: right;
}

.message.out .meta {
  color: rgba(0, 0, 0, 0.52);
}

#messageInput {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  position: relative;
}

.typing-bar {
  min-height: 24px;
  padding: 6px 20px 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.3;
  flex-shrink: 0;
  opacity: 0;
  visibility: hidden;
  transition: color 0.16s ease, opacity 0.16s ease;
}

.typing-bar.active {
  color: color-mix(in srgb, var(--accent) 72%, var(--text) 28%);
  opacity: 1;
  visibility: visible;
}

#typingBar.hidden {
  display: block !important;
}

.reply-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 20px 0;
  flex-shrink: 0;
}

.reply-bar-body {
  flex: 1;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel2) 84%, transparent);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
}

.edit-bar-body {
  border-left-color: color-mix(in srgb, #f3b24e 72%, var(--accent) 28%);
}

.reply-bar-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 4px;
}

.reply-bar-text {
  font-size: 13px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.reply-bar-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--panel2);
  color: var(--text);
  cursor: pointer;
}

.forward-preview-card {
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 84%, transparent);
  border-radius: 16px;
  padding: 12px;
  margin-bottom: 14px;
}

.forward-preview-text {
  font-size: 14px;
  line-height: 1.4;
  color: var(--text);
}

.forward-targets {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 340px;
  overflow-y: auto;
}

.forward-target {
  width: 100%;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
  border-radius: 18px;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
}

.forward-target-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
}

.forward-target-subtitle {
  font-size: 12px;
  color: var(--muted);
}

.input-wrapper {
  flex: 1;
}

.send-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--accent);
  border: none;
  color: var(--accent-text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.send-btn:hover:not(:disabled) {
  background: var(--accent-hover);
  transform: scale(1.05);
}

.send-btn:disabled,
.auth-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.app-status-bar {
  display: none !important;
}

.app-status-bar.error {
  color: var(--danger);
}

.app-status-bar.success {
  color: var(--accent);
}

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal-content {
  background: var(--panel);
  border-radius: var(--radius-lg);
  width: min(560px, calc(100vw - 24px));
  max-height: calc(100vh - 24px);
  overflow: auto;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}

.modal-header {
  padding: 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-header h2 {
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
}

.modal-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 24px;
  cursor: pointer;
}

.modal-footer {
  padding: 20px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 12px;
  justify-content: flex-end;
}

.compact-footer {
  padding: 0;
  border: 0;
  justify-content: flex-start;
  margin-bottom: 16px;
}

.member-picker {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 240px;
  overflow-y: auto;
  padding-right: 4px;
}

.member-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--panel2);
}

.member-option input {
  width: auto;
  accent-color: var(--accent);
}

.member-option-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.member-option-title {
  font-size: 14px;
  font-weight: 600;
}

.member-option-meta {
  font-size: 12px;
  color: var(--muted);
}

.call-modal {
  max-width: 760px;
  overflow: hidden;
}

.call-body {
  padding: 16px;
}

.call-stage {
  position: relative;
  height: 420px;
  background: var(--panel2);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.call-stage:fullscreen,
.call-stage:-webkit-full-screen {
  width: 100vw;
  height: 100vh;
  border-radius: 0;
  background: #000;
}

.call-stage:fullscreen .call-local,
.call-stage:-webkit-full-screen .call-local {
  right: 20px;
  bottom: 20px;
  width: min(28vw, 340px);
  height: min(21vw, 220px);
}

.call-remote {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #000;
  display: block;
}

.call-remote-grid {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  grid-auto-rows: minmax(180px, 1fr);
  gap: 12px;
  padding: 12px;
  pointer-events: none;
}

.call-local {
  position: absolute;
  right: 12px;
  bottom: 12px;
  width: 180px;
  height: 136px;
  border-radius: calc(var(--radius-md) + 2px);
  object-fit: cover;
  background: #000;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
  z-index: 2;
}

.call-peer-tile,
.call-peer-empty {
  position: relative;
  min-height: 180px;
  border-radius: calc(var(--radius-md) + 2px);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.24);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.call-peer-tile.speaking {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 58%, white 8%);
  box-shadow:
    0 14px 34px rgba(0, 0, 0, 0.32),
    0 0 0 1px color-mix(in srgb, var(--accent) 32%, transparent);
}

.call-peer-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
  text-align: center;
  padding: 18px;
}

.call-peer-video,
.call-peer-placeholder {
  width: 100%;
  height: 100%;
  min-height: 180px;
  object-fit: cover;
  display: block;
}

.call-peer-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.92);
  background:
    radial-gradient(circle at top, rgba(92, 211, 114, 0.28), transparent 58%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(0, 0, 0, 0.36));
}

.call-peer-footer {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(10px);
}

.call-peer-badges {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
  z-index: 2;
}

.call-peer-badge {
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 11px;
  line-height: 1;
  backdrop-filter: blur(10px);
}

.call-peer-label {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
}

.call-peer-state {
  color: rgba(255, 255, 255, 0.78);
  font-size: 12px;
  white-space: nowrap;
}

#remoteAudio {
  display: none;
}

.call-status {
  position: absolute;
  left: 12px;
  top: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.48);
  color: #fff;
  font-size: 13px;
  line-height: 1.2;
  z-index: 3;
}

.call-footer {
  justify-content: center;
}

.call-controls {
  margin-top: 14px;
  display: flex;
  gap: 10px;
  justify-content: center;
}

.call-controls .action-btn,
.chat-actions .action-btn {
  background: var(--panel2);
  border: 1px solid var(--border);
}

.call-controls .action-btn:hover,
.chat-actions .action-btn:hover {
  background: color-mix(in srgb, var(--panel2) 84%, var(--accent) 16%);
}

.call-controls .action-btn.off {
  background: rgba(229, 57, 53, 0.14);
  border-color: rgba(229, 57, 53, 0.45);
}

.call-controls .action-btn.active {
  background: color-mix(in srgb, var(--panel2) 72%, var(--accent) 28%);
  border-color: color-mix(in srgb, var(--accent) 50%, transparent);
}

#joinCallBtn {
  background: color-mix(in srgb, var(--accent) 22%, var(--panel2) 78%);
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
}

#joinCallBtn:hover {
  background: color-mix(in srgb, var(--accent) 34%, var(--panel2) 66%);
}

.call-modal.audio .call-remote,
.call-modal.audio .call-local {
  display: none;
}

.call-modal.audio #remoteAudio {
  display: block;
}

.call-modal.audio .call-stage {
  height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-body {
  padding: 20px;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

#profileHome {
  flex: 1;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
}

.profile-home-card {
  width: min(420px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 22px;
  border-radius: calc(var(--radius-lg) + 6px);
  border: 1px solid var(--border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel2) 90%, #fff 6%), var(--panel));
  box-shadow: 0 14px 42px rgba(0, 0, 0, 0.35);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.profile-home-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 330px;
  z-index: -1;
  background-image:
    linear-gradient(180deg, rgba(0, 0, 0, 0.18), color-mix(in srgb, var(--panel) 82%, transparent)),
    var(--profile-home-wallpaper, none);
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.24s ease;
}

.profile-home-card.has-wallpaper::before {
  opacity: 1;
}

.profile-home-top {
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.profile-home-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.profile-home-avatar {
  width: 220px;
  height: 220px;
  border-radius: calc(var(--radius-lg) + 4px);
  background: #d9d9d9;
  color: #202020;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  font-weight: 700;
}

.profile-home-name {
  font-size: 30px;
  line-height: 1;
  font-weight: 700;
  color: var(--text);
  text-align: center;
}

.profile-home-tag {
  font-size: 15px;
  color: var(--muted);
  min-height: 20px;
  text-align: center;
}

.profile-home-actions {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.profile-home-actions .btn-primary,
.profile-home-actions .btn-secondary {
  width: 100%;
}

.news-panel {
  flex: 1;
  padding: 16px;
  display: none;
  flex-direction: column;
  gap: 12px;
}

.news-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.news-title {
  font-size: 18px;
  font-weight: 700;
}

.news-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 140px;
}

.news-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--panel2);
  padding: 12px;
}

.news-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.news-card-title {
  font-size: 14px;
  font-weight: 700;
}

.news-card-meta {
  font-size: 12px;
  color: var(--muted);
}

.news-card-body {
  white-space: pre-wrap;
  line-height: 1.5;
  color: var(--text);
}

.call-log-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--panel2);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.call-log-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.call-log-title {
  font-size: 15px;
  font-weight: 700;
}

.call-log-meta,
.call-log-direction {
  font-size: 12px;
  color: var(--muted);
}

.call-log-status {
  font-size: 14px;
  color: var(--text);
}

.news-actions {
  margin-top: 10px;
  display: flex;
  gap: 8px;
}

#newsEditor {
  min-height: 140px;
  border: 1px solid var(--input-bg-focus);
  border-radius: var(--radius-md);
  background: var(--panel2);
  color: var(--text);
  padding: 12px;
  resize: vertical;
  outline: none;
}

#newsEditor:focus {
  border-color: var(--accent);
}

.news-editor-actions {
  display: flex;
  gap: 8px;
}

body.profile-home-mode #chatHeader,
body.profile-home-mode #messages,
body.profile-home-mode #messageInput,
body.profile-home-mode #appStatusBar {
  display: none;
}

body.profile-home-mode #profileHome {
  display: flex !important;
}

body.news-home-mode #chatHeader,
body.news-home-mode #messages,
body.news-home-mode #messageInput,
body.news-home-mode #appStatusBar,
body.news-home-mode #profileHome,
body.news-home-mode #callsHome {
  display: none !important;
}

body.news-home-mode #newsHome {
  display: flex !important;
}

body.calls-home-mode #chatHeader,
body.calls-home-mode #messages,
body.calls-home-mode #messageInput,
body.calls-home-mode #appStatusBar,
body.calls-home-mode #profileHome,
body.calls-home-mode #newsHome {
  display: none !important;
}

body.calls-home-mode #callsHome {
  display: flex !important;
}

body.profile-home-mode #layout,
body.news-home-mode #layout,
body.calls-home-mode #layout {
  grid-template-columns: 70px minmax(0, 1fr);
}

body.profile-home-mode #chatList,
body.news-home-mode #chatList,
body.calls-home-mode #chatList {
  display: none !important;
}

body.profile-home-mode #chat,
body.news-home-mode #chat,
body.calls-home-mode #chat {
  grid-column: 2 / -1;
  display: flex !important;
  min-width: 0;
}

body.profile-home-mode #chat::before,
body.news-home-mode #chat::before,
body.calls-home-mode #chat::before {
  display: none !important;
}

body.profile-home-mode #pinnedBar,
body.profile-home-mode #chatSearchBar,
body.profile-home-mode #typingBar,
body.profile-home-mode #replyBar,
body.profile-home-mode #editBar,
body.news-home-mode #pinnedBar,
body.news-home-mode #chatSearchBar,
body.news-home-mode #typingBar,
body.news-home-mode #replyBar,
body.news-home-mode #editBar,
body.calls-home-mode #pinnedBar,
body.calls-home-mode #chatSearchBar,
body.calls-home-mode #typingBar,
body.calls-home-mode #replyBar,
body.calls-home-mode #editBar {
  display: none !important;
}

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-thumb {
  background: var(--panel);
  border-radius: 4px;
}

@media (max-width: 768px) {
  body {
    height: 100dvh;
  }

  #layout {
    grid-template-columns: 1fr;
    height: 100dvh;
  }

  #sidebar {
    display: none;
  }

  #chat {
    display: none;
  }

  body.mobile-chat-open #chat {
    display: flex;
  }

  body.mobile-chat-open #chatList {
    display: none;
  }

  .back-btn,
  .profile-mobile-btn {
    display: inline-flex;
  }

  .chat-list-header,
  #chatHeader {
    padding: 0 16px;
  }

  #messages {
    padding: 16px;
  }

  #messageInput {
    padding: 12px;
  }

  .message {
    max-width: 84%;
  }

  .auth-box {
    padding: 28px 22px;
  }

  .form-grid {
    grid-template-columns: 1fr;
  }

  .chat-actions {
    gap: 6px;
  }

  .secure-badge span {
    display: none;
  }

  .call-stage {
    height: 320px;
  }

  .call-local {
    width: 120px;
    height: 90px;
  }

  #callScreenBtn {
    display: none !important;
  }
}

/* Quality polish layer */
:root {
  --focus-ring: 0 0 0 3px color-mix(in srgb, var(--accent) 28%, transparent);
  --surface-soft: color-mix(in srgb, var(--panel) 88%, transparent);
  --surface-strong: color-mix(in srgb, var(--panel2) 88%, transparent);
  --hairline: color-mix(in srgb, var(--border) 72%, white 8%);
  --shadow-soft: 0 16px 36px rgba(0, 0, 0, 0.24);
  --shadow-popover: 0 24px 70px rgba(0, 0, 0, 0.42);
}

button,
input,
select,
textarea {
  font: inherit;
}

button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.chatItem:focus-visible,
.forward-target:focus-visible,
.pinned-bar-main:focus-visible,
.message-reaction-chip:focus-visible,
.message-action-btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.auth-box,
.modal-content,
.empty-chat,
.call-panel,
.call-log-card,
.news-card {
  border: 1px solid var(--hairline);
}

#sidebar,
#chatList,
#chatHeader,
#messageInput,
.pinned-bar,
.chat-search-bar,
.reply-bar {
  backdrop-filter: blur(18px);
}

.action-btn,
.send-btn,
.modal-close,
.reply-bar-close,
.pinned-bar-clear,
.message-action-btn,
.message-reaction-chip,
.forward-target,
.list-tab,
.btn-primary,
.btn-secondary,
.auth-btn,
.auth-switch-btn {
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease,
    opacity 0.18s ease;
}

.action-btn,
.send-btn,
.modal-close,
.reply-bar-close,
.pinned-bar-clear {
  min-width: 40px;
  min-height: 40px;
}

.chatItem {
  position: relative;
  min-height: 76px;
  padding: 13px 18px;
  padding-right: 74px;
  border-bottom-color: color-mix(in srgb, var(--border) 72%, transparent);
}

.chatItem::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 0 999px 999px 0;
  background: transparent;
  transition: background 0.18s ease, opacity 0.18s ease;
}

.chatItem:hover {
  background: color-mix(in srgb, var(--panel) 74%, white 7%);
}

.chatItem.active {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 12%, transparent), transparent 42%),
    var(--surface-strong);
}

.chatItem.active::before {
  background: var(--accent);
}

.chatItem .avatar,
.chat-user .avatar,
.logo {
  box-shadow: inset 0 -10px 16px rgba(0, 0, 0, 0.08);
}

.chatItem .name,
.chat-user .name {
  letter-spacing: 0.01em;
}

.chatItem.utility {
  padding-right: 18px;
  background: color-mix(in srgb, var(--panel2) 72%, var(--accent) 8%);
}

.chatItem .name {
  display: flex;
  align-items: center;
  gap: 8px;
}

.chatItem .name > span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-item-badges {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.chat-item-badges span {
  padding: 2px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 78%, var(--accent) 8%);
  border: 1px solid var(--hairline);
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
}

.chat-item-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.18s ease, max-height 0.18s ease;
}

.chatItem:hover .chat-item-actions,
.chatItem:focus-within .chat-item-actions,
.chatItem.active .chat-item-actions {
  opacity: 1;
  max-height: 40px;
}

.chat-item-actions button {
  min-height: 28px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  padding: 4px 9px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}

.chat-item-actions button:hover,
.chat-item-actions button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 58%, var(--border) 42%);
  background: color-mix(in srgb, var(--panel2) 72%, var(--accent) 12%);
}

.chatItem .last-message {
  line-height: 1.36;
}

.chat-unread-badge {
  box-shadow: 0 8px 18px color-mix(in srgb, var(--accent) 24%, transparent);
  position: absolute;
  right: 52px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.chat-presence-dot {
  border: 2px solid var(--panel);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--panel2) 76%, transparent);
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

.chat-presence-dot.online {
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--panel2) 76%, transparent),
    0 0 14px color-mix(in srgb, #39d363 45%, transparent);
}

.pinned-bar,
.chat-search-bar {
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.pinned-bar-main,
.chat-search-input,
.reply-bar-body,
.forward-preview-card,
.message .reply-preview,
.message .forward-preview {
  border-color: var(--hairline);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.025);
}

.pinned-bar-main:hover,
.forward-target:hover,
.member-option:hover {
  border-color: color-mix(in srgb, var(--accent) 46%, var(--border) 54%);
  background: color-mix(in srgb, var(--panel2) 74%, var(--accent) 8%);
}

.chat-search-input:focus,
#textInput:focus {
  box-shadow: var(--focus-ring);
}

#messages {
  gap: 9px;
}

.message {
  position: relative;
  line-height: 1.45;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
}

.message.in {
  border: 1px solid color-mix(in srgb, var(--border) 70%, white 5%);
}

.message.out {
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 16%, rgba(0, 0, 0, 0.2));
}

.message.active {
  outline: 1px solid color-mix(in srgb, var(--accent) 56%, transparent);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent) 13%, transparent),
    0 14px 32px rgba(0, 0, 0, 0.18);
}

.message.system .system-content {
  background: color-mix(in srgb, var(--panel2) 80%, var(--accent) 5%);
  border-color: color-mix(in srgb, var(--border) 70%, var(--accent) 12%);
}

.message-actions {
  align-items: center;
  padding: 6px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 38%, transparent);
}

.message-action-btn,
.message-reaction-chip {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.message-action-btn:hover,
.message-reaction-chip:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 58%, var(--border) 42%);
}

.reaction-picker {
  width: 100%;
  padding-top: 2px;
}

#messageInput {
  box-shadow: 0 -18px 40px rgba(0, 0, 0, 0.12);
}

#textInput {
  min-height: 44px;
  line-height: 1.35;
}

.send-btn:hover:not(:disabled),
.action-btn:hover,
.modal-close:hover,
.reply-bar-close:hover,
.pinned-bar-clear:hover {
  transform: translateY(-1px);
}

.modal {
  background: rgba(0, 0, 0, 0.62);
  backdrop-filter: blur(10px);
}

.modal-content {
  overflow: hidden;
  box-shadow: var(--shadow-popover);
}

.modal-body {
  overflow: auto;
}

.modal-header,
.modal-footer {
  background: color-mix(in srgb, var(--panel) 90%, transparent);
}

.modal-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
}

.modal-close:hover {
  border-color: var(--hairline);
  background: var(--surface-strong);
}

.forward-target {
  min-height: 58px;
}

.member-option,
.forward-target,
.call-log-card,
.news-card {
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.08);
}

@media (max-width: 768px) {
  .chatItem {
    min-height: 72px;
    padding: 12px 16px;
  }

  .pinned-bar,
  .chat-search-bar,
  .reply-bar {
    padding-left: 14px;
    padding-right: 14px;
  }

  .chat-search-bar {
    flex-wrap: wrap;
  }

  .chat-search-input {
    flex-basis: 100%;
  }

  .message {
    max-width: 88%;
  }

  .message-actions,
  .reaction-picker,
  .message-reactions {
    gap: 5px;
  }

  .message-action-btn,
  .message-reaction-chip {
    min-height: 34px;
  }

  .modal-content {
    width: calc(100vw - 20px);
    max-height: calc(100dvh - 20px);
  }
}

/* Expressive messenger skin */
:root {
  --ink-glow: rgba(92, 211, 114, 0.2);
  --blue-glow: rgba(80, 151, 255, 0.12);
  --shell-line: rgba(255, 255, 255, 0.055);
}

body {
  background:
    radial-gradient(circle at 12% 12%, color-mix(in srgb, var(--accent) 18%, transparent) 0 18%, transparent 34%),
    radial-gradient(circle at 88% 18%, var(--blue-glow) 0 15%, transparent 32%),
    radial-gradient(circle at 56% 100%, rgba(255, 255, 255, 0.035) 0 18%, transparent 42%),
    linear-gradient(135deg, #151816 0%, var(--bg) 48%, #121614 100%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.016) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(circle at center, black 0 45%, transparent 76%);
}

#layout {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0)),
    transparent;
}

#sidebar {
  position: relative;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.018)),
    color-mix(in srgb, var(--panel) 80%, transparent);
}

#sidebar::before {
  content: "";
  position: absolute;
  inset: 12px 8px;
  border: 1px solid var(--shell-line);
  border-radius: 24px;
  pointer-events: none;
}

#sidebar .logo,
.profile-home-avatar {
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.72), transparent 16%),
    linear-gradient(145deg, var(--accent), color-mix(in srgb, var(--accent) 48%, #153820 52%));
  color: #07110a;
}

.sidebar-footer .action-btn,
.chat-list-actions .action-btn,
.create-chat-btn {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 22px rgba(0, 0, 0, 0.18);
}

.app-name {
  color: color-mix(in srgb, var(--text) 86%, var(--accent) 14%);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#chatList {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0)),
    color-mix(in srgb, var(--panel) 82%, transparent);
}

.chat-list-header {
  position: relative;
  overflow: hidden;
}

.chat-list-header::after {
  content: "";
  position: absolute;
  inset: auto 18px 10px 18px;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 55%, transparent), transparent);
}

.chat-list-header h2 {
  font-size: 22px;
  letter-spacing: -0.035em;
}

.list-tabs {
  position: relative;
  background: color-mix(in srgb, var(--panel2) 56%, transparent);
}

.list-tab {
  min-height: 34px;
  font-weight: 700;
}

.list-tab.active {
  box-shadow:
    0 8px 18px color-mix(in srgb, var(--accent) 22%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.list-search {
  background: color-mix(in srgb, var(--panel) 72%, transparent);
}

.list-search input,
.form-group input,
.form-group select,
#textInput,
.chat-search-input,
#newsEditor {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.028),
    0 10px 26px rgba(0, 0, 0, 0.08);
}

.chatItem {
  isolation: isolate;
}

.chatItem::after {
  content: "";
  position: absolute;
  inset: 8px 10px;
  z-index: -1;
  border-radius: 20px;
  background: transparent;
  transition: background 0.18s ease, box-shadow 0.18s ease;
}

.chatItem:hover::after,
.chatItem.active::after {
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--accent) 12%, transparent), transparent 36%),
    rgba(255, 255, 255, 0.018);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.032);
}

.chatItem .avatar {
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.82), transparent 18%),
    linear-gradient(145deg, #e7ece8, #b8c2bd);
}

#chat {
  position: relative;
  overflow: hidden;
}

#chat::before {
  content: "";
  position: absolute;
  inset: 77px 0 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 26% 18%, color-mix(in srgb, var(--accent) 11%, transparent), transparent 32%),
    radial-gradient(circle at 80% 82%, rgba(255, 255, 255, 0.032), transparent 34%);
}

#chatHeader {
  position: relative;
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.042), rgba(255, 255, 255, 0.012)),
    color-mix(in srgb, var(--panel) 84%, transparent);
}

#chatHeader::after {
  content: "";
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 48%, transparent), transparent);
}

.chat-user .avatar {
  background:
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.82), transparent 18%),
    linear-gradient(145deg, color-mix(in srgb, var(--accent) 38%, #e4e8e2 62%), #b7c2bb);
}

.chat-user .name {
  font-size: 17px;
  letter-spacing: -0.02em;
}

.chat-user .status {
  color: color-mix(in srgb, var(--muted) 88%, var(--accent) 12%);
}

.secure-badge {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, var(--panel2) 84%), var(--panel2));
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border) 70%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

#messages {
  position: relative;
  z-index: 1;
  background-image:
    radial-gradient(circle at 18px 18px, rgba(255, 255, 255, 0.022) 1px, transparent 1.5px),
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0));
  background-size: 28px 28px, auto;
}

.message {
  animation: messageSlide 0.22s cubic-bezier(0.2, 0.7, 0.2, 1);
}

.message.in,
.message.out {
  backdrop-filter: blur(14px);
}

.message.in::before,
.message.out::before {
  content: "";
  position: absolute;
  bottom: -1px;
  width: 14px;
  height: 14px;
  background: inherit;
}

.message.in::before {
  left: -5px;
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

.message.out::before {
  right: -5px;
  clip-path: polygon(0 0, 100% 100%, 0 100%);
}

.message.out .reply-preview,
.message.out .forward-preview {
  background: rgba(0, 0, 0, 0.08);
  border-left-color: rgba(0, 0, 0, 0.35);
}

.message.out .reply-preview-label,
.message.out .forward-preview-label {
  color: rgba(0, 0, 0, 0.64);
}

.message.out .reply-preview-text,
.message.out .forward-preview-text {
  color: rgba(0, 0, 0, 0.58);
}

.message.system .system-content {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 10px 24px rgba(0, 0, 0, 0.12);
}

.message-search-mark {
  box-shadow: 0 0 0 2px rgba(243, 178, 78, 0.18);
}

.pinned-bar,
.chat-search-bar,
.reply-bar,
.typing-bar {
  position: relative;
  z-index: 2;
}

.pinned-bar-main,
.reply-bar-body,
.edit-bar-body,
.forward-preview-card {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 58%),
    color-mix(in srgb, var(--panel2) 84%, transparent);
}

#messageInput {
  position: relative;
  z-index: 3;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel2) 74%, transparent), color-mix(in srgb, var(--panel2) 92%, transparent));
}

#messageInput::before {
  content: "";
  position: absolute;
  left: 20px;
  right: 20px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 36%, transparent), transparent);
}

.input-wrapper {
  position: relative;
}

.input-wrapper::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(120deg, color-mix(in srgb, var(--accent) 22%, transparent), transparent 34%, rgba(255, 255, 255, 0.045));
  opacity: 0;
  transition: opacity 0.18s ease;
}

.input-wrapper:focus-within::before {
  opacity: 1;
}

#textInput {
  position: relative;
  z-index: 1;
}

.send-btn {
  box-shadow:
    0 12px 26px color-mix(in srgb, var(--accent) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.send-btn:hover:not(:disabled) {
  box-shadow:
    0 16px 34px color-mix(in srgb, var(--accent) 34%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

.modal-content {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 10%, transparent), transparent 34%),
    var(--panel);
}

.auth-container {
  background:
    radial-gradient(circle at 50% 20%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%),
    transparent;
}

.auth-box,
.profile-home-card,
.news-card,
.call-panel {
  box-shadow:
    var(--shadow-popover),
    inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.auth-header h1,
.profile-home-name,
.news-title {
  letter-spacing: -0.045em;
}

.btn-primary,
.auth-btn,
.create-chat-btn {
  box-shadow:
    0 12px 28px color-mix(in srgb, var(--accent) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.26);
}

.btn-primary:hover,
.auth-btn:hover,
.create-chat-btn:hover {
  box-shadow:
    0 16px 36px color-mix(in srgb, var(--accent) 32%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.call-stage {
  background:
    radial-gradient(circle at 25% 20%, rgba(92, 211, 114, 0.18), transparent 34%),
    radial-gradient(circle at 78% 72%, rgba(80, 151, 255, 0.16), transparent 36%),
    #050706;
}

@keyframes shellReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#sidebar,
#chatList,
#chat {
  animation: shellReveal 0.28s ease both;
}

#chatList {
  animation-delay: 0.04s;
}

#chat {
  animation-delay: 0.08s;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* Avatar upload, chat menu and recording visibility */
.profile-home-back.hidden {
  display: inline-flex !important;
}

.profile-open-trigger {
  cursor: pointer;
}

.profile-open-trigger:hover {
  color: var(--accent);
}

.tg-profile-modal {
  width: min(430px, 96vw);
  max-height: min(860px, 92vh);
  overflow: hidden;
  padding: 0;
  border-radius: 30px;
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 34%),
    color-mix(in srgb, var(--panel) 92%, #000 8%);
}

.profile-editor-modal {
  width: min(460px, 96vw);
  display: flex;
  flex-direction: column;
}

.profile-editor-modal .modal-header,
.profile-editor-modal .modal-footer {
  flex: 0 0 auto;
  padding: 14px 18px;
  background: color-mix(in srgb, var(--panel) 92%, #000 8%);
  border-color: color-mix(in srgb, var(--accent) 16%, var(--hairline) 84%);
}

.profile-editor-modal .modal-body {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  gap: 12px;
  padding: 0 14px 14px;
  overflow: auto;
}

.profile-editor-preview {
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--hairline) 82%);
  border-radius: 28px;
  background:
    radial-gradient(circle at 48% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%),
    color-mix(in srgb, var(--panel2) 86%, #000 14%);
  box-shadow: 0 22px 58px rgba(0, 0, 0, 0.28);
}

.profile-editor-cover {
  min-height: 218px;
}

.profile-editor-preview-body {
  padding: 14px;
  overflow: visible;
}

.profile-editor-share {
  margin-top: 2px;
}

.profile-editor-empty-music {
  width: 100%;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.profile-editor-empty-music:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border) 60%);
  background: color-mix(in srgb, var(--accent) 12%, rgba(255, 255, 255, 0.04));
}

.profile-editor-preview-focused {
  box-shadow:
    0 18px 46px rgba(0, 0, 0, 0.24),
    0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.profile-editor-modal .form-group {
  margin: 0;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--hairline) 86%);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.035);
}

.tg-profile-cover {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 8px;
  min-height: 218px;
  padding: 42px 18px 30px;
  overflow: hidden;
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 14%, var(--hairline) 86%);
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--accent) 20%, transparent), transparent 46%),
    radial-gradient(circle at 28% 14%, rgba(255, 255, 255, 0.08), transparent 26%);
}

.tg-profile-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.46)),
    var(--profile-wallpaper, none);
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.03);
  transition: opacity 0.24s ease, transform 0.24s ease;
}

.tg-profile-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 32%, rgba(0, 0, 0, 0.08), transparent 32%),
    linear-gradient(180deg, transparent 34%, rgba(0, 0, 0, 0.36));
  opacity: 0;
}

.tg-profile-cover.has-wallpaper::before {
  opacity: 1;
  transform: scale(1);
}

.tg-profile-cover.has-wallpaper::after {
  opacity: 1;
}

.tg-profile-cover > * {
  position: relative;
  z-index: 1;
}

.tg-profile-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
}

.tg-profile-avatar {
  width: 96px;
  height: 96px;
  font-size: 28px;
  box-shadow:
    0 22px 48px rgba(0, 0, 0, 0.32),
    0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.tg-profile-name {
  color: var(--text);
  font-size: 19px;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.tg-profile-username {
  color: color-mix(in srgb, var(--accent) 80%, #fff 20%);
  font-size: 13px;
  font-weight: 800;
}

.tg-profile-cover.has-wallpaper .tg-profile-name,
.tg-profile-cover.has-wallpaper .tg-profile-username {
  color: #fff;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.72);
}

.tg-profile-cover.has-wallpaper .tg-profile-username {
  color: color-mix(in srgb, var(--accent) 34%, #fff 66%);
}

.tg-profile-cover.has-wallpaper .tg-profile-avatar {
  box-shadow:
    0 20px 46px rgba(0, 0, 0, 0.48),
    0 0 0 1px rgba(255, 255, 255, 0.18);
}

.tg-profile-body {
  display: grid;
  gap: 12px;
  padding: 14px;
  overflow: auto;
}

.tg-profile-music-card,
.tg-profile-channel,
.tg-profile-share,
.tg-profile-info-item,
.tg-profile-home-details {
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--hairline) 86%);
  background: rgba(255, 255, 255, 0.04);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.tg-profile-music-card {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border-radius: 20px;
}

.tg-profile-music-card.playing {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 0 calc(var(--glow-strength, 22px) * 0.7) color-mix(in srgb, var(--accent) 22%, transparent);
}

.tg-profile-music-card .player-progress {
  height: 10px;
  border-radius: 999px;
  background:
    linear-gradient(90deg,
      color-mix(in srgb, var(--accent) 92%, #fff 8%) 0 var(--player-progress, 0%),
      color-mix(in srgb, var(--text) 14%, transparent) var(--player-progress, 0%) 100%);
  -webkit-appearance: none;
  appearance: none;
}

.tg-profile-music-card .player-progress::-webkit-slider-thumb {
  width: 14px;
  height: 14px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: var(--accent);
  -webkit-appearance: none;
  appearance: none;
}

.tg-profile-music-card .player-progress::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: var(--accent);
}

.tg-profile-channel {
  padding: 12px 14px;
  border-radius: 18px;
}

.tg-profile-channel a,
.tg-profile-link-box a {
  color: color-mix(in srgb, var(--accent) 88%, #fff 12%);
  font-weight: 900;
  text-decoration: none;
  overflow-wrap: anywhere;
}

.tg-profile-info-grid {
  display: grid;
  gap: 8px;
}

.tg-profile-info-item {
  display: grid;
  gap: 3px;
  padding: 12px 14px;
  border-radius: 18px;
}

.tg-profile-info-item.privacy-note {
  min-height: 96px;
  align-content: center;
  border-color: color-mix(in srgb, var(--accent) 28%, var(--hairline) 72%);
  background:
    radial-gradient(circle at 12% 16%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%),
    rgba(255, 255, 255, 0.045);
}

.profile-hidden-view .tg-profile-cover {
  min-height: 246px;
}

.profile-hidden-view .tg-profile-avatar {
  filter: saturate(0.78);
}

.tg-profile-info-item.accent .tg-profile-info-value {
  color: color-mix(in srgb, var(--accent) 82%, #fff 18%);
}

.tg-profile-info-value {
  color: var(--text);
  font-size: 14px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.tg-profile-label,
.tg-profile-info-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.tg-profile-share {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border-radius: 22px;
}

.tg-profile-share.hidden,
.tg-profile-channel.hidden,
.tg-profile-music.hidden {
  display: none !important;
}

.tg-profile-qr {
  display: grid;
  grid-template-columns: repeat(11, 1fr);
  gap: 2px;
  width: 118px;
  height: 118px;
  padding: 9px;
  border-radius: 18px;
  background: #f7f5ef;
}

.tg-profile-qr span {
  border-radius: 2px;
}

.tg-profile-qr img {
  grid-column: 1 / -1;
  grid-row: 1 / -1;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  object-fit: contain;
}

.tg-profile-qr span.filled {
  background: #151515;
}

.tg-profile-link-box {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.tg-profile-home-details {
  width: min(560px, 100%);
  display: grid;
  gap: 8px;
  margin: 18px auto 0;
  padding: 12px;
  border-radius: 24px;
}

.tg-profile-home-music {
  width: min(560px, 100%);
  margin: 18px auto 0;
}

.tg-profile-home-music.hidden {
  display: none !important;
}

.tg-profile-home-music .tg-profile-music-card {
  width: 100%;
}

.tg-profile-home-row {
  display: grid;
  grid-template-columns: 128px 1fr;
  gap: 12px;
  align-items: start;
  padding: 9px 10px;
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.028);
}

.tg-profile-home-row[data-profile-field] {
  cursor: context-menu;
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
  border: 1px solid transparent;
}

.tg-profile-home-row[data-profile-field]:hover {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--accent) 10%, rgba(255, 255, 255, 0.035));
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}

.tg-profile-info-item[data-profile-field] {
  cursor: pointer;
}

.tg-profile-info-item[data-profile-field]:hover {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border) 66%);
  background: color-mix(in srgb, var(--accent) 10%, var(--panel2) 90%);
}

.profile-single-field-editor .form-group.hidden,
#profileHomeApplyThemeBtn.hidden {
  display: none !important;
}

.own-profile-card {
  max-width: 520px;
}

.tg-profile-home-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.tg-profile-home-row strong {
  min-width: 0;
  color: var(--text);
  font-size: 13px;
  overflow-wrap: anywhere;
}

.tg-profile-preview-btn {
  justify-self: center;
  margin-top: 4px;
}

.avatar.has-avatar,
.logo.has-avatar,
.profile-home-avatar.has-avatar {
  background-size: cover !important;
  background-position: center !important;
  color: transparent !important;
  text-shadow: none !important;
}

.profile-home-card.own-profile-card {
  width: min(460px, calc(100vw - 24px));
  padding: 0 0 16px;
  gap: 0;
}

.profile-home-card.own-profile-card::before {
  height: 258px;
  opacity: 1;
  background-image:
    radial-gradient(circle at 50% 18%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel2) 76%, transparent), color-mix(in srgb, var(--panel) 92%, transparent)),
    var(--profile-home-wallpaper, none);
  background-size: auto, auto, cover;
  background-position: center;
}

.profile-home-card.own-profile-card:not(.has-wallpaper)::before {
  background-image:
    radial-gradient(circle at 50% 18%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel2) 88%, transparent), color-mix(in srgb, var(--panel) 96%, transparent));
}

.profile-home-card.own-profile-card .profile-home-top {
  align-self: stretch;
  padding: 12px 12px 0;
}

.profile-home-card.own-profile-card .profile-home-avatar {
  width: clamp(104px, 22vw, 136px);
  height: clamp(104px, 22vw, 136px);
  aspect-ratio: 1 / 1;
  flex: 0 0 auto;
  margin-top: 14px;
  border-radius: 31%;
  background-size: cover !important;
  background-position: center !important;
  box-shadow:
    0 22px 50px rgba(0, 0, 0, 0.38),
    0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent);
}

.profile-home-card.own-profile-card .profile-home-name {
  max-width: calc(100% - 32px);
  margin-top: 14px;
  overflow-wrap: anywhere;
}

.profile-home-card.own-profile-card .profile-home-tag {
  max-width: calc(100% - 32px);
  overflow-wrap: anywhere;
}

.profile-home-card.own-profile-card .tg-profile-home-music,
.profile-home-card.own-profile-card .tg-profile-home-details,
.profile-home-card.own-profile-card .profile-home-actions {
  width: calc(100% - 28px);
}

.avatar-drop-target {
  cursor: pointer;
  position: relative;
}

.avatar-drop-target::after {
  content: "Drop";
  position: absolute;
  inset: auto 4px 4px 4px;
  padding: 3px 5px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.58);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  text-align: center;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  pointer-events: none;
}

.avatar-drop-target:hover::after,
.avatar-drop-target.drag-over::after {
  opacity: 1;
  transform: translateY(0);
}

.avatar-drop-target.drag-over {
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent) 32%, transparent),
    0 0 var(--glow-strength, 22px) color-mix(in srgb, var(--accent) 34%, transparent) !important;
}

.avatar-crop-modal {
  width: min(460px, calc(100vw - 24px));
}

.avatar-crop-frame {
  display: grid;
  place-items: center;
  padding: 14px;
  border: 1px solid var(--hairline);
  border-radius: 24px;
  background:
    linear-gradient(45deg, rgba(255, 255, 255, 0.035) 25%, transparent 25% 50%, rgba(255, 255, 255, 0.035) 50% 75%, transparent 75%),
    var(--panel2);
  background-size: 24px 24px;
}

#avatarCropCanvas {
  width: min(320px, 74vw);
  aspect-ratio: 1 / 1;
  border-radius: 32px;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.32);
}

.avatar-crop-actions {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  justify-content: flex-end;
}

.chat-context-menu {
  min-width: 210px;
}

.chat-item-actions {
  display: none !important;
}

.chat-archive-quick {
  position: absolute;
  right: 14px;
  top: 50%;
  min-width: 62px;
  min-height: 32px;
  flex-shrink: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--hairline) 78%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 88%, transparent);
  color: color-mix(in srgb, var(--text) 88%, var(--accent) 12%);
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  z-index: 4;
  transform: translate(12px, -50%) scale(0.96);
  transition: opacity 0.18s ease, transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.chatItem:hover .chat-archive-quick,
.chatItem:focus-within .chat-archive-quick,
.chatItem.archived .chat-archive-quick {
  opacity: 1;
  pointer-events: auto;
  transform: translate(0, -50%) scale(1);
}

.chatItem:hover .chat-unread-badge,
.chatItem:focus-within .chat-unread-badge {
  opacity: 0;
  transform: translate(-12px, -50%) scale(0.9);
}

.chat-archive-quick:hover,
.chat-archive-quick:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 62%, var(--border) 38%);
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
  box-shadow: var(--focus-ring);
}

.chatItem.archived {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 55%),
    transparent;
}

.chatItem.archived .chat-archive-quick {
  color: var(--accent);
}

.recording-indicator {
  position: fixed;
  right: 18px;
  bottom: 82px;
  z-index: 2800;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 14px;
  border: 1px solid color-mix(in srgb, var(--danger) 52%, var(--hairline) 48%);
  border-radius: 999px;
  background:
    radial-gradient(circle at left, rgba(229, 57, 53, 0.18), transparent 60%),
    color-mix(in srgb, var(--panel2) 88%, transparent);
  color: var(--text);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.32);
  backdrop-filter: blur(var(--glass-blur, 18px));
  animation: menuIslandIn var(--motion-fast, 0.22s) ease both;
}

.recording-indicator span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--danger);
  animation: recordingDot 0.9s ease-in-out infinite;
}

.recording-indicator strong {
  font-size: 13px;
}

@keyframes recordingDot {
  0%,
  100% {
    transform: scale(0.82);
    opacity: 0.55;
  }
  50% {
    transform: scale(1.22);
    opacity: 1;
  }
}

@media (max-width: 768px) {
  .recording-indicator {
    left: 14px;
    right: 14px;
    bottom: 74px;
    justify-content: center;
  }
}

@media (max-width: 768px) {
  body::after,
  #sidebar::before,
  .message.in::before,
  .message.out::before {
    display: none;
  }

  #chatHeader::after,
  #messageInput::before {
    left: 14px;
    right: 14px;
  }

  .chat-list-header h2 {
    font-size: 20px;
  }

  .chat-item-badges {
    display: none;
  }

  .chat-item-actions {
    opacity: 1;
    max-height: 48px;
  }

  #messages {
    background-size: 34px 34px, auto;
  }
}

/* Customization controls and theme variants */
body {
  font-size: calc(16px * var(--font-scale, 1));
}

.theme-presets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.theme-presets button {
  min-height: 74px;
  border: 1px solid var(--hairline);
  border-radius: 18px;
  color: #fff;
  font-weight: 800;
  letter-spacing: -0.02em;
  cursor: pointer;
  text-align: left;
  padding: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 12px 26px rgba(0, 0, 0, 0.14);
}

.theme-presets button[data-theme-preset="forest"] {
  background:
    radial-gradient(circle at 22% 14%, rgba(255, 255, 255, 0.35), transparent 16%),
    linear-gradient(145deg, #5cd372, #142317);
}

.theme-presets button[data-theme-preset="neon"] {
  background:
    radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.38), transparent 16%),
    linear-gradient(145deg, #4df0ff, #15142a 58%, #0b0d18);
}

.theme-presets button[data-theme-preset="ocean"] {
  background:
    radial-gradient(circle at 22% 16%, rgba(255, 255, 255, 0.36), transparent 18%),
    linear-gradient(145deg, #6fb6ff, #102638 64%, #071018);
}

.theme-presets button[data-theme-preset="sand"] {
  background:
    radial-gradient(circle at 24% 16%, rgba(255, 255, 255, 0.32), transparent 18%),
    linear-gradient(145deg, #f0b35f, #312111 62%, #120d08);
}

.theme-presets button[data-theme-preset="negative"] {
  color: #fff;
  background:
    radial-gradient(circle at 22% 15%, rgba(255, 255, 255, 0.75), transparent 16%),
    radial-gradient(circle at 78% 72%, rgba(255, 47, 69, 0.58), transparent 22%),
    linear-gradient(145deg, #ff2f45 0%, #0a0a0a 42%, #000 72%, #f7f7f7 160%);
}

.theme-presets button:hover,
.theme-presets button:focus-visible {
  transform: translateY(-2px);
  box-shadow:
    var(--focus-ring),
    0 18px 40px rgba(0, 0, 0, 0.22);
}

.theme-preview-card {
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 12px;
  min-height: 190px;
  margin-bottom: 18px;
  padding: 12px;
  border: 1px solid var(--hairline);
  border-radius: 24px;
  background:
    radial-gradient(circle at 18% 12%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 36%),
    color-mix(in srgb, var(--panel2) 82%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 44px rgba(0, 0, 0, 0.18);
  overflow: hidden;
}

.theme-preview-sidebar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 10px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel) 78%, transparent);
}

.theme-preview-sidebar span {
  display: block;
  height: 34px;
  border-radius: 14px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 25%, transparent), transparent),
    color-mix(in srgb, var(--panel2) 84%, transparent);
}

.theme-preview-chat {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  border-radius: 20px;
  background: var(--chat-bg);
  overflow: hidden;
}

.theme-preview-chat::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 18px 18px, rgba(255, 255, 255, 0.035) 1px, transparent 1.5px);
  background-size: 28px 28px;
  pointer-events: none;
}

.theme-preview-top,
.theme-preview-input,
.theme-preview-bubble {
  position: relative;
  z-index: 1;
}

.theme-preview-top {
  height: 28px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel) 72%, transparent);
}

.theme-preview-bubble {
  width: fit-content;
  max-width: 78%;
  padding: 8px 12px;
  border-radius: var(--radius-lg);
  font-size: 12px;
  font-weight: 700;
}

.theme-preview-bubble.in {
  background: var(--bubble-in);
  color: var(--text);
}

.theme-preview-bubble.out {
  align-self: flex-end;
  background: var(--bubble-out);
  color: var(--accent-text);
}

.theme-preview-input {
  margin-top: auto;
  height: 32px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel2) 88%, transparent);
  border: 1px solid var(--hairline);
}

.form-group input[type="color"] {
  min-height: 44px;
  padding: 4px;
  cursor: pointer;
}

.form-group input[type="range"] {
  accent-color: var(--accent);
  cursor: pointer;
}

.form-group select {
  min-height: 44px;
  cursor: pointer;
}

body[data-density="compact"] #layout {
  grid-template-columns: 64px 360px 1fr;
}

body[data-density="compact"] .chatItem {
  min-height: 62px;
  padding-top: 9px;
  padding-bottom: 9px;
}

body[data-density="compact"] #messages {
  gap: 5px;
  padding: 14px 18px;
}

body[data-density="compact"] .message {
  padding: 8px 12px;
}

body[data-density="compact"] #messageInput {
  padding-top: 9px;
  padding-bottom: 9px;
}

body[data-density="spacious"] #layout {
  grid-template-columns: 78px 460px 1fr;
}

body[data-density="spacious"] .chatItem {
  min-height: 88px;
  padding-top: 17px;
  padding-bottom: 17px;
}

body[data-density="spacious"] #messages {
  gap: 13px;
  padding: 26px;
}

body[data-density="spacious"] .message {
  padding: 13px 17px;
}

body[data-bubbles="soft"] .message {
  border-radius: 26px;
}

body[data-bubbles="soft"] .message.in,
body[data-bubbles="soft"] .message.out {
  border-bottom-left-radius: 26px;
  border-bottom-right-radius: 26px;
}

body[data-bubbles="soft"] .message.in::before,
body[data-bubbles="soft"] .message.out::before {
  display: none;
}

body[data-bubbles="block"] .message {
  border-radius: 12px;
}

body[data-bubbles="block"] .message.in,
body[data-bubbles="block"] .message.out {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}

body[data-bubbles="block"] .message.in::before,
body[data-bubbles="block"] .message.out::before {
  display: none;
}

body[data-pattern="grid"] #messages {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.022) 1px, transparent 1px);
  background-size: 36px 36px;
}

body[data-pattern="waves"] #messages {
  background-image:
    radial-gradient(ellipse at 20% 12%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 28%),
    repeating-radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.026) 0 1px, transparent 1px 18px);
  background-size: auto, 68px 68px;
}

body[data-pattern="none"] #messages {
  background-image: none;
}

#sidebar,
#chatList,
#chatHeader,
#messageInput,
.pinned-bar,
.chat-search-bar,
.reply-bar,
.modal-content,
.call-peer-footer,
.call-peer-badge {
  backdrop-filter: blur(var(--glass-blur, 18px));
}

@media (max-width: 768px) {
  .voice-transcript-popout {
    position: static;
    width: 100%;
    margin-top: 8px;
  }

  .chat-archive-quick {
    opacity: 1;
    transform: none;
    min-width: 56px;
    padding-inline: 8px;
  }

  .tg-profile-modal {
    width: 100vw;
    max-height: 100vh;
    border-radius: 0;
  }

  .tg-profile-share,
  .tg-profile-home-row {
    grid-template-columns: 1fr;
  }

  .privacy-choice-row {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .privacy-choice-row .tg-settings-row-value {
    grid-column: 2;
    justify-self: start;
  }

  .tg-profile-qr {
    justify-self: center;
  }

  .theme-presets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-density="compact"] #layout,
  body[data-density="spacious"] #layout {
    grid-template-columns: 1fr;
  }

  body.profile-home-mode #layout,
  body.news-home-mode #layout,
  body.calls-home-mode #layout {
    grid-template-columns: 1fr !important;
  }

  body.profile-home-mode #chat,
  body.news-home-mode #chat,
  body.calls-home-mode #chat {
    grid-column: 1 / -1;
    display: flex !important;
    width: 100%;
  }

  body.profile-home-mode #chatList,
  body.news-home-mode #chatList,
  body.calls-home-mode #chatList {
    display: none !important;
  }

  body[data-density="spacious"] #messages {
    padding: 18px;
  }

  .news-panel {
    padding: 14px;
    min-width: 0;
  }

  .news-title-row {
    grid-template-columns: auto 1fr auto;
    gap: 10px;
  }

  .news-title {
    min-width: 0;
    text-align: center;
  }

  .news-content {
    min-width: 0;
  }

  .news-card,
  .call-log-card {
    width: 100%;
    min-width: 0;
  }
}

/* Deeper customization, scrolling settings and effects */
#settingsModal .modal-content {
  width: min(760px, calc(100vw - 24px));
  max-height: min(860px, calc(100dvh - 24px));
}

#settingsModal .modal-body {
  max-height: calc(100dvh - 164px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scroll-behavior: smooth;
  scroll-padding-top: 76px;
  padding-bottom: 26px;
}

.settings-scroll-nav {
  position: sticky;
  top: -1px;
  z-index: 10;
  display: flex;
  gap: 8px;
  margin: -2px -2px 16px;
  padding: 10px 2px 12px;
  overflow-x: auto;
  scrollbar-width: none;
  background:
    linear-gradient(180deg, var(--panel) 0%, color-mix(in srgb, var(--panel) 84%, transparent) 78%, transparent);
  backdrop-filter: blur(var(--glass-blur, 18px));
  scroll-snap-type: x proximity;
}

.settings-scroll-nav::-webkit-scrollbar {
  display: none;
}

.settings-scroll-nav button {
  flex: 0 0 auto;
  min-height: 36px;
  padding: 8px 13px;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 84%, transparent);
  color: var(--text);
  font-weight: 800;
  cursor: pointer;
  scroll-snap-align: start;
}

.settings-scroll-nav button:hover,
.settings-scroll-nav button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 56%, var(--border) 44%);
  background: color-mix(in srgb, var(--accent) 16%, var(--panel2) 84%);
  box-shadow: var(--focus-ring);
}

.tg-settings-modal .modal-content {
  width: min(980px, calc(100vw - 24px));
}

.tg-settings-modal .modal-header {
  padding: 18px 20px;
}

.tg-settings-modal .modal-header h2 {
  font-size: 21px;
  letter-spacing: -0.03em;
}

.tg-settings-shell {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  gap: 18px;
  min-height: min(660px, calc(100dvh - 190px));
}

.tg-settings-nav.settings-scroll-nav {
  position: sticky;
  top: 0;
  display: grid;
  align-self: start;
  gap: 4px;
  margin: 0;
  padding: 8px;
  overflow: visible;
  border: 1px solid color-mix(in srgb, var(--accent) 10%, var(--hairline) 90%);
  border-radius: 24px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel2) 92%, transparent), color-mix(in srgb, var(--panel) 88%, transparent)),
    rgba(255, 255, 255, 0.025);
  backdrop-filter: blur(var(--glass-blur, 18px));
  scroll-snap-type: none;
}

.tg-settings-nav button {
  width: 100%;
  min-height: 48px;
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 0;
  border-radius: 15px;
  background: transparent;
  color: color-mix(in srgb, var(--text) 92%, transparent);
  font-size: 14px;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.tg-settings-nav button:hover,
.tg-settings-nav button:focus-visible,
.tg-settings-nav button.active {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 20%, transparent), color-mix(in srgb, var(--accent) 7%, transparent));
  color: var(--text);
  box-shadow: none;
}

.tg-settings-nav button.active {
  color: color-mix(in srgb, var(--accent) 76%, #fff 24%);
}

.tg-settings-nav button em {
  color: color-mix(in srgb, var(--accent) 80%, #fff 20%);
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.tg-settings-nav-icon {
  width: 24px;
  height: 24px;
  position: relative;
  display: inline-grid;
  place-items: center;
  color: currentColor;
  opacity: 0.92;
}

.tg-settings-nav-icon::before,
.tg-settings-nav-icon::after {
  content: "";
  position: absolute;
  box-sizing: border-box;
  border-color: currentColor;
}

.tg-settings-nav-icon.bell::before {
  width: 15px;
  height: 17px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 10px 10px 5px 5px;
  top: 3px;
}

.tg-settings-nav-icon.bell::after {
  width: 10px;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
  bottom: 3px;
}

.tg-settings-nav-icon.lock::before {
  width: 17px;
  height: 13px;
  border: 2px solid currentColor;
  border-radius: 4px;
  bottom: 3px;
}

.tg-settings-nav-icon.lock::after {
  width: 11px;
  height: 10px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  top: 2px;
}

.tg-settings-nav-icon.chat::before {
  width: 18px;
  height: 15px;
  border: 2px solid currentColor;
  border-radius: 9px;
}

.tg-settings-nav-icon.chat::after {
  width: 7px;
  height: 7px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-18deg);
  left: 5px;
  bottom: 3px;
}

.tg-settings-nav-icon.folder::before {
  width: 19px;
  height: 14px;
  border: 2px solid currentColor;
  border-radius: 3px;
  bottom: 4px;
}

.tg-settings-nav-icon.folder::after {
  width: 9px;
  height: 4px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  border-radius: 3px 0 0 0;
  top: 5px;
  left: 3px;
}

.tg-settings-nav-icon.sliders::before {
  width: 20px;
  height: 15px;
  background:
    linear-gradient(currentColor 0 0) 0 2px / 20px 2px no-repeat,
    linear-gradient(currentColor 0 0) 0 7px / 20px 2px no-repeat,
    linear-gradient(currentColor 0 0) 0 12px / 20px 2px no-repeat;
}

.tg-settings-nav-icon.sliders::after {
  width: 4px;
  height: 17px;
  background:
    radial-gradient(circle at 50% 2px, currentColor 0 2px, transparent 2.5px),
    radial-gradient(circle at 50% 8px, currentColor 0 2px, transparent 2.5px),
    radial-gradient(circle at 50% 14px, currentColor 0 2px, transparent 2.5px);
}

.tg-settings-nav-icon.speaker::before {
  width: 16px;
  height: 16px;
  border-left: 7px solid currentColor;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  left: 2px;
}

.tg-settings-nav-icon.speaker::after {
  width: 9px;
  height: 14px;
  border: 2px solid currentColor;
  border-left: 0;
  border-radius: 0 12px 12px 0;
  right: 1px;
}

.tg-settings-nav-icon.battery::before {
  width: 19px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 4px;
}

.tg-settings-nav-icon.battery::after {
  width: 4px;
  height: 7px;
  right: 0;
  border-radius: 0 2px 2px 0;
  background: currentColor;
}

.tg-settings-nav-icon.language::before {
  width: 18px;
  height: 18px;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.tg-settings-nav-icon.language::after {
  width: 20px;
  height: 2px;
  background: currentColor;
  transform: rotate(-28deg);
}

.tg-settings-panels {
  min-width: 0;
}

.tg-settings-panel {
  display: none;
  animation: settingsPanelIn var(--motion-fast, 0.24s) ease both;
}

.tg-settings-panel.active {
  display: grid;
  gap: 14px;
}

.tg-settings-panel-head {
  display: grid;
  gap: 5px;
  padding: 2px 2px 6px;
}

.tg-settings-kicker {
  color: color-mix(in srgb, var(--accent) 80%, #fff 20%);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tg-settings-panel-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 26px;
  line-height: 1.12;
  letter-spacing: -0.045em;
}

.tg-settings-panel-head p {
  max-width: 62ch;
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.tg-settings-group {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent) 11%, var(--hairline) 89%);
  border-radius: 22px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.tg-settings-group-title {
  display: grid;
  gap: 3px;
  padding: 14px 16px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--hairline) 72%, transparent);
}

.tg-settings-group-title strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 950;
}

.tg-settings-group-title span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.tg-settings-group .theme-presets {
  padding: 12px;
}

.tg-settings-group .theme-preview-card {
  margin: 12px;
}

.tg-setting-control.form-group {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 260px);
  gap: 8px 16px;
  align-items: center;
  margin: 0;
  padding: 13px 16px;
  border-bottom: 1px solid color-mix(in srgb, var(--hairline) 64%, transparent);
}

.tg-setting-control.form-group:last-child,
.tg-settings-row:last-child {
  border-bottom: 0;
}

.tg-setting-control label {
  margin: 0;
  color: var(--text);
  font-size: 14px;
  font-weight: 900;
}

.tg-setting-hint {
  grid-column: 1 / 2;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.42;
}

.tg-setting-control input,
.tg-setting-control select {
  grid-column: 2 / 3;
  grid-row: 1 / span 2;
  width: 100%;
  min-height: 40px;
}

.tg-settings-row {
  width: 100%;
  min-height: 58px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--hairline) 64%, transparent);
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.tg-settings-row:hover,
.tg-settings-row:focus-visible {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.privacy-choice-row {
  grid-template-columns: 34px minmax(0, 1fr) minmax(74px, auto);
  min-height: 70px;
  transition: background 0.18s ease, transform 0.18s ease;
}

.privacy-choice-row:hover,
.privacy-choice-row:focus-visible {
  transform: translateY(-1px);
}

.privacy-choice-row .tg-settings-row-icon {
  border-radius: 50%;
  position: relative;
}

.privacy-choice-row .tg-settings-row-icon::after {
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: inherit;
  background: color-mix(in srgb, var(--accent) 72%, transparent);
  transform: scale(0.6);
  opacity: 0.78;
}

.privacy-choice-row .tg-settings-row-value {
  min-width: 74px;
  padding: 7px 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--hairline) 80%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 70%, transparent);
  text-align: center;
}

.tg-settings-row-icon {
  width: 22px;
  height: 22px;
  border: 2px solid color-mix(in srgb, var(--accent) 58%, var(--text) 42%);
  border-radius: 8px;
  opacity: 0.82;
}

.tg-settings-row.enabled .tg-settings-row-icon {
  background: color-mix(in srgb, var(--accent) 80%, transparent);
  box-shadow: inset 0 0 0 4px color-mix(in srgb, var(--panel2) 90%, transparent);
}

.tg-settings-row.touched {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
}

.theme-wallpaper-tools {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
  margin-top: 4px;
}

.theme-wallpaper-preview {
  min-height: 120px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--hairline) 82%);
  border-radius: 18px;
  background:
    radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 34%),
    color-mix(in srgb, var(--panel) 88%, #000 12%);
  background-size: cover;
  background-position: center;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.theme-wallpaper-tools.has-wallpaper .theme-wallpaper-preview {
  min-height: 150px;
}

.theme-wallpaper-actions,
.theme-wallpaper-examples {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.theme-wallpaper-actions button,
.theme-wallpaper-examples button {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--hairline) 82%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.theme-wallpaper-actions button:hover,
.theme-wallpaper-examples button:hover,
.theme-wallpaper-actions button:focus-visible,
.theme-wallpaper-examples button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 62%, var(--border) 38%);
  background: color-mix(in srgb, var(--accent) 14%, var(--panel2) 86%);
}

.theme-wallpaper-examples button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.theme-wallpaper-examples span {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--accent), var(--panel2));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.theme-wallpaper-examples [data-wallpaper-example="aurora"] span {
  background: radial-gradient(circle at 30% 20%, #5cd372, #2c355f 52%, #101511);
}

.theme-wallpaper-examples [data-wallpaper-example="sand"] span {
  background: radial-gradient(circle at 30% 20%, #f0b35f, #4a321d 54%, #16120d);
}

.theme-wallpaper-examples [data-wallpaper-example="mono"] span {
  background: radial-gradient(circle at 30% 20%, #9aa4b2, #2a2d33 54%, #0f1012);
}

.translation-tools {
  display: grid;
  gap: 12px;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border) 82%);
  border-radius: 18px;
  background:
    radial-gradient(circle at 10% 0, color-mix(in srgb, var(--accent) 10%, transparent), transparent 42%),
    color-mix(in srgb, var(--panel2) 78%, transparent);
}

.translation-tools-head {
  display: grid;
  gap: 4px;
}

.translation-tools-head strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 950;
}

.translation-tools-head span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.translation-tools-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.translation-tools-actions button {
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border) 76%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel) 84%, var(--accent) 16%);
  color: var(--text);
  padding: 0 12px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.translation-tools-actions button:hover,
.translation-tools-actions button:focus-visible {
  background: color-mix(in srgb, var(--accent) 24%, var(--panel) 76%);
}

.translation-editor {
  width: 100%;
  min-height: 140px;
  resize: vertical;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel2) 88%, #000 12%);
  color: var(--text);
  padding: 12px;
  font-family: "Cascadia Mono", "JetBrains Mono", Consolas, monospace;
  font-size: 12px;
  line-height: 1.45;
  outline: none;
}

.translation-editor:focus {
  border-color: color-mix(in srgb, var(--accent) 46%, var(--border) 54%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.language-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}

.language-switch button,
.admin-badges-panel button {
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border) 78%);
  border-radius: 14px;
  background: color-mix(in srgb, var(--panel2) 86%, transparent);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}

.language-switch button.active {
  background: color-mix(in srgb, var(--accent) 26%, var(--panel2) 74%);
  border-color: color-mix(in srgb, var(--accent) 52%, transparent);
}

.language-choice-row .tg-settings-row-icon {
  border-radius: 999px;
}

.language-choice-row.enabled .tg-settings-row-icon::after {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: inherit;
  background: var(--accent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--accent) 65%, transparent);
}

.language-choice-row:not(.enabled) .tg-settings-row-value {
  color: var(--muted);
}

.admin-badges-panel {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--border) 84%);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 76%, transparent);
}

.admin-badges-panel select,
.emoji-status-tools input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel2);
  color: var(--text);
  padding: 10px 12px;
}

.admin-badges-panel label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.chat-profile-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.chat-manage-advanced {
  display: grid;
  gap: 14px;
  margin-top: 14px;
}

.chat-manage-advanced textarea {
  min-height: 76px;
  resize: vertical;
}

.chat-manage-grid {
  display: grid;
  gap: 9px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--border) 84%);
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
}

.chat-manage-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

#manageLinkedChannelSelect,
#manageChatDescriptionInput {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel2);
  color: var(--text);
  padding: 10px 12px;
}

.emoji-status-tools {
  display: grid;
  gap: 7px;
}

.emoji-status-tools label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.emoji-status-tools div {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.emoji-status-tools input[readonly] {
  cursor: default;
}

.emoji-status-tools button {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel2);
  color: var(--text);
  padding: 0 12px;
  font-weight: 900;
  cursor: pointer;
}

.emoji-status-tools .emoji-status-picker {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(38px, 1fr));
  gap: 8px;
}

.emoji-status-picker button {
  aspect-ratio: 1;
  padding: 0;
  border-radius: 14px;
  font-size: 20px;
  display: grid;
  place-items: center;
}

.emoji-status-picker button.active {
  border-color: color-mix(in srgb, var(--accent) 64%, var(--border) 36%);
  background: color-mix(in srgb, var(--accent) 24%, var(--panel2) 76%);
  transform: translateY(-1px);
}

.profile-verification-tools {
  display: grid;
  gap: 8px;
}

.verification-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.verification-line button {
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border) 72%);
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
  color: var(--text);
  padding: 0 12px;
  font-weight: 900;
  cursor: pointer;
}

.profile-verification-tools small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.profile-verification-tools small.success {
  color: color-mix(in srgb, #6dff95 78%, var(--text) 22%);
}

.profile-verification-tools small.error {
  color: color-mix(in srgb, #ff6b6b 82%, var(--text) 18%);
}

.firebase-recaptcha-container {
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 2000;
}

.sticker-panel {
  position: absolute;
  left: 18px;
  bottom: 76px;
  z-index: 30;
  width: min(380px, calc(100vw - 36px));
  max-height: min(440px, 58vh);
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border) 78%);
  border-radius: 22px;
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  box-shadow: 0 22px 54px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(18px);
  overflow: auto;
  animation: stickerPanelIn var(--motion-fast, 0.24s) ease both;
}

.sticker-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
}

.sticker-tabs button,
.sticker-content [data-create-sticker],
.custom-emoji-create [data-create-emoji] {
  min-height: 34px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--panel2);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}

.sticker-tabs button.active {
  background: var(--accent);
  color: var(--accent-text);
}

.custom-emoji-create,
.sticker-create-box {
  display: grid;
  gap: 8px;
}

.custom-emoji-create {
  grid-column: 1 / -1;
  grid-template-columns: minmax(0, 1fr);
  margin-top: 2px;
  padding-top: 8px;
  border-top: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}

.sticker-create-box {
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
}

.sticker-content {
  display: grid;
  gap: 10px;
}

.sticker-content[data-sticker-content="emoji"] {
  grid-template-columns: repeat(auto-fill, minmax(42px, 1fr));
  align-items: center;
}

.emoji-item,
.sticker-item {
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border) 86%);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
  color: var(--text);
  cursor: pointer;
}

.emoji-item {
  width: 100%;
  aspect-ratio: 1;
  min-width: 0;
  font-size: 22px;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.emoji-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 3px;
}

.emoji-item.is-custom-image {
  background: color-mix(in srgb, var(--accent) 10%, var(--panel2) 90%);
}

.sticker-pack-title {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sticker-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.sticker-item {
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  font-size: 34px;
  overflow: hidden;
}

.sticker-item img,
.sticker-message {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sticker-message {
  max-width: min(230px, 56vw);
  border-radius: 24px;
  background: transparent;
}

.sticker-content input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--panel2);
  color: var(--text);
  padding: 10px 12px;
}

.sticker-content input[type="file"] {
  cursor: pointer;
}

.tg-settings-row-text {
  display: grid;
  gap: 3px;
}

.tg-settings-row-text strong {
  font-size: 14px;
  font-weight: 900;
}

.tg-settings-row-text small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.tg-settings-row-value {
  color: color-mix(in srgb, var(--accent) 82%, #fff 18%);
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

@keyframes settingsPanelIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

body::before {
  opacity: calc(var(--wallpaper-opacity, 0.16) * 0.28);
}

body::after {
  opacity: var(--noise-opacity, 0.06);
}

body[data-pattern="dots"] #messages,
.theme-preview-chat::before {
  background-size: var(--pattern-scale, 28px) var(--pattern-scale, 28px);
}

body[data-pattern="grid"] #messages {
  background-size: var(--pattern-scale, 36px) var(--pattern-scale, 36px);
}

body[data-pattern="waves"] #messages {
  background-size: auto, calc(var(--pattern-scale, 58px) * 1.25) calc(var(--pattern-scale, 58px) * 1.25);
}

.message {
  max-width: var(--message-max-width, 65%);
}

body[data-vibe="luminous"] {
  --ink-glow: color-mix(in srgb, var(--accent) 32%, transparent);
}

body[data-vibe="luminous"] .message.out,
body[data-vibe="luminous"] .send-btn,
body[data-vibe="luminous"] .btn-primary,
body[data-vibe="luminous"] .create-chat-btn {
  box-shadow:
    0 0 var(--glow-strength, 22px) color-mix(in srgb, var(--accent) 44%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

body[data-vibe="aurora"] #chat::before,
body[data-vibe="aurora"] .theme-preview-card {
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 34%),
    radial-gradient(circle at 78% 32%, rgba(93, 164, 255, 0.16), transparent 32%),
    radial-gradient(circle at 48% 88%, rgba(255, 255, 255, 0.052), transparent 36%);
}

body[data-vibe="aurora"] .modal-content,
body[data-vibe="aurora"] .auth-box,
body[data-vibe="aurora"] .profile-home-card {
  box-shadow:
    0 0 calc(var(--glow-strength, 22px) * 1.35) color-mix(in srgb, var(--accent) 16%, transparent),
    var(--shadow-popover);
}

body[data-vibe="radar"] #messages {
  background-image:
    radial-gradient(circle at center, transparent 0 26%, color-mix(in srgb, var(--accent) 8%, transparent) 26.5% 27%, transparent 27.5% 100%),
    linear-gradient(90deg, transparent 49.7%, color-mix(in srgb, var(--accent) 9%, transparent) 50%, transparent 50.3%),
    linear-gradient(transparent 49.7%, color-mix(in srgb, var(--accent) 9%, transparent) 50%, transparent 50.3%);
  background-size:
    calc(var(--pattern-scale, 34px) * 4) calc(var(--pattern-scale, 34px) * 4),
    calc(var(--pattern-scale, 34px) * 2) calc(var(--pattern-scale, 34px) * 2),
    calc(var(--pattern-scale, 34px) * 2) calc(var(--pattern-scale, 34px) * 2);
}

body[data-composer="solid"] #messageInput {
  background: var(--panel2);
}

body[data-composer="solid"] .input-wrapper::before {
  display: none;
}

body[data-composer="terminal"] #textInput {
  border-radius: 8px;
  font-family: "Cascadia Mono", "Consolas", monospace;
  letter-spacing: -0.02em;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 9%, transparent), transparent 40%),
    #080b09;
}

body[data-composer="terminal"] .send-btn {
  border-radius: 12px;
}

body[data-avatars="circle"] .avatar,
body[data-avatars="circle"] .logo,
body[data-avatars="circle"] .profile-home-avatar {
  border-radius: 50% !important;
}

body[data-avatars="cut"] .avatar,
body[data-avatars="cut"] .logo,
body[data-avatars="cut"] .profile-home-avatar {
  border-radius: 6px 20px 6px 20px !important;
}

body[data-chrome="solid"] #sidebar,
body[data-chrome="solid"] #chatList,
body[data-chrome="solid"] #chatHeader,
body[data-chrome="solid"] #messageInput,
body[data-chrome="solid"] .modal-content {
  backdrop-filter: none;
  background-color: var(--panel);
}

body[data-chrome="rail"] #sidebar {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 12%, transparent), transparent 48%),
    #0c0f0d;
}

body[data-chrome="rail"] #chatList {
  border-right-color: color-mix(in srgb, var(--accent) 26%, var(--border) 74%);
}

body[data-chrome="rail"] #chatHeader::after,
body[data-chrome="rail"] #messageInput::before {
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.message,
.chatItem,
.theme-preview-card,
.modal-content {
  transition-duration: var(--motion-fast, 0.273s);
}

#sidebar,
#chatList,
#chat {
  animation-duration: var(--motion-shell, 0.299s);
}

.message {
  animation-duration: var(--motion-message, 0.228s);
}

body[data-vibe="calm"] .message.out {
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 12%, rgba(0, 0, 0, 0.18));
}

@media (max-width: 768px) {
  #settingsModal .modal-body {
    max-height: calc(100dvh - 150px);
  }

  .tg-settings-shell {
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: 0;
  }

  .tg-settings-nav.settings-scroll-nav {
    position: sticky;
    top: 0;
    display: flex;
    margin: -2px -2px 6px;
    padding: 8px 2px 10px;
    overflow-x: auto;
    border: 0;
    border-radius: 0;
    background:
      linear-gradient(180deg, var(--panel) 0%, color-mix(in srgb, var(--panel) 84%, transparent) 82%, transparent);
    scrollbar-width: none;
  }

  .tg-settings-nav button {
    width: auto;
    min-width: 190px;
    grid-template-columns: 24px 1fr auto;
    min-height: 46px;
    border: 1px solid var(--hairline);
    background: color-mix(in srgb, var(--panel2) 84%, transparent);
  }

  .tg-settings-panel-head h3 {
    font-size: 22px;
  }

  .tg-setting-control.form-group {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 13px 14px;
  }

  .tg-setting-hint,
  .tg-setting-control input,
  .tg-setting-control select {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .tg-settings-row {
    grid-template-columns: 24px minmax(0, 1fr);
  }

  .tg-settings-row-value {
    grid-column: 2;
    justify-self: start;
  }

  .message {
    max-width: min(var(--message-max-width, 88%), 88%);
  }
}

/* Messenger interaction polish: media, context menus and richer motion */
#sidebar .sidebar-header {
  display: none !important;
}

#logoutBtn {
  display: none !important;
}

#chatSearchBtn {
  display: none !important;
}

@media (min-width: 769px) {
  .back-btn,
  .profile-mobile-btn {
    display: none !important;
  }
}

@media (max-width: 768px) {
  .back-btn,
  .profile-mobile-btn {
    display: inline-flex !important;
  }
}

.composer-media-btn {
  background: color-mix(in srgb, var(--panel2) 82%, transparent);
  border: 1px solid var(--hairline);
  flex-shrink: 0;
}

.composer-media-btn:hover:not(:disabled) {
  border-color: color-mix(in srgb, var(--accent) 52%, var(--border) 48%);
  background: color-mix(in srgb, var(--accent) 14%, var(--panel2) 86%);
}

.composer-media-btn.recording {
  border-color: color-mix(in srgb, var(--danger) 68%, var(--accent) 32%);
  background: color-mix(in srgb, var(--danger) 18%, var(--panel2) 82%);
  animation: recordingPulse 1s ease-in-out infinite;
}

.message-context-menu {
  position: fixed;
  z-index: 3000;
  min-width: 178px;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--hairline) 78%);
  border-radius: 20px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 14%, transparent), transparent 46%),
    color-mix(in srgb, var(--panel2) 88%, transparent);
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(var(--glass-blur, 18px));
  animation: menuIslandIn var(--motion-fast, 0.22s) cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

.message-context-menu button {
  width: 100%;
  min-height: 36px;
  border: 0;
  border-radius: 13px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 8px 10px;
  font-weight: 700;
  cursor: pointer;
}

.message-context-menu button:hover,
.message-context-menu button:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.message-context-menu button.danger {
  color: #ff8b86;
}

.message-context-reactions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 6px;
  margin-bottom: 4px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.028);
}

.message-context-reactions button {
  min-height: 34px;
  text-align: center;
  padding: 0;
  font-size: 16px;
}

.message > .message-actions {
  display: none !important;
}

.media-message {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: min(280px, 68vw);
}

.media-message-label {
  font-size: 12px;
  font-weight: 800;
  color: inherit;
  opacity: 0.72;
}

.voice-message audio {
  width: 100%;
  min-width: 230px;
  max-width: 320px;
  filter: saturate(0.9);
}

.video-note-message {
  min-width: 0;
}

.video-note-message video {
  width: min(260px, 58vw);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
  background: #000;
  box-shadow:
    0 0 var(--glow-strength, 22px) color-mix(in srgb, var(--accent) 20%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.media-caption {
  margin-top: 8px;
}

.private-text-canvas {
  display: block;
  max-width: 100%;
  height: auto;
  pointer-events: none;
  user-select: none;
}

.private-text-canvas.media-caption {
  margin-top: 8px;
}

.custom-player {
  display: grid;
  gap: 10px;
  min-width: min(310px, 70vw);
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--hairline) 82%);
  border-radius: 20px;
  background:
    radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--accent) 13%, transparent), transparent 40%),
    rgba(255, 255, 255, 0.032);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  animation: playerFloatIn var(--motion-fast, 0.24s) ease both;
}

.tg-audio-player {
  grid-template-columns: auto 1fr;
  align-items: center;
  min-width: min(320px, 72vw);
  padding: 12px;
}

.tg-audio-player .player-play,
.yt-video-player .player-play,
.tg-video-note-player .player-play,
.tg-profile-music-card .player-play {
  position: relative;
  font-size: 0;
}

.tg-audio-player .player-play::before,
.yt-video-player .player-play::before,
.tg-video-note-player .player-play::before,
.tg-profile-music-card .player-play::before {
  content: "";
  width: 0;
  height: 0;
  display: block;
  margin-left: 3px;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid currentColor;
}

.tg-audio-player.playing .player-play::before,
.yt-video-player.playing .player-play::before,
.tg-video-note-player.playing .player-play::before,
.tg-profile-music-card.playing .player-play::before {
  width: 14px;
  height: 16px;
  margin-left: 0;
  border: 0;
  background:
    linear-gradient(90deg, currentColor 0 38%, transparent 38% 62%, currentColor 62% 100%);
}

.tg-audio-player .player-progress {
  height: 16px;
  margin: 0;
  border-radius: 999px;
  background:
    radial-gradient(circle at var(--player-progress, 0%) 50%, color-mix(in srgb, #fff 36%, transparent), transparent 18px),
    linear-gradient(90deg,
      color-mix(in srgb, var(--accent) 92%, #fff 8%) 0 var(--player-progress, 0%),
      color-mix(in srgb, var(--text) 13%, transparent) var(--player-progress, 0%) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    inset 0 -8px 14px rgba(0, 0, 0, 0.16),
    0 0 calc(var(--glow-strength, 22px) * 0.55) color-mix(in srgb, var(--accent) 18%, transparent);
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  transition: filter 0.2s ease, box-shadow 0.2s ease;
}

.tg-audio-player.playing .player-progress {
  animation: oneUiListenBar 1.15s ease-in-out infinite;
}

.tg-audio-player .player-progress::-webkit-slider-runnable-track {
  height: 16px;
  border-radius: 999px;
  background: transparent;
}

.tg-audio-player .player-progress::-moz-range-track {
  height: 16px;
  border-radius: 999px;
  background: transparent;
}

.tg-audio-player .player-progress::-webkit-slider-thumb {
  width: 18px;
  height: 18px;
  margin-top: -1px;
  border: 2px solid color-mix(in srgb, #fff 72%, var(--accent) 28%);
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 88%, #fff 12%);
  box-shadow: 0 4px 18px color-mix(in srgb, var(--accent) 40%, transparent);
  -webkit-appearance: none;
  appearance: none;
}

.tg-audio-player .player-progress::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border: 2px solid color-mix(in srgb, #fff 72%, var(--accent) 28%);
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 88%, #fff 12%);
  box-shadow: 0 4px 18px color-mix(in srgb, var(--accent) 40%, transparent);
}

.audio-player {
  grid-template-columns: auto 1fr;
  align-items: center;
}

.player-play {
  width: 46px;
  height: 46px;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--border) 58%);
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 18%, var(--panel2) 82%);
  color: var(--text);
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
  display: grid;
  place-items: center;
}

.custom-player.playing .player-play {
  background: var(--accent);
  color: var(--accent-text);
  box-shadow: 0 0 var(--glow-strength, 22px) color-mix(in srgb, var(--accent) 36%, transparent);
}

.tg-profile-music-card.playing .player-play {
  background: var(--accent);
  color: var(--accent-text);
  box-shadow: 0 0 var(--glow-strength, 22px) color-mix(in srgb, var(--accent) 36%, transparent);
}

.player-body {
  min-width: 0;
}

.player-title {
  margin-bottom: 6px;
  color: inherit;
  font-size: 12px;
  font-weight: 900;
  opacity: 0.76;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.player-progress {
  width: 100%;
  accent-color: var(--accent);
  cursor: pointer;
}

.player-time {
  margin-top: 3px;
  color: inherit;
  font-size: 11px;
  opacity: 0.62;
}

.custom-player.player-error {
  border-color: color-mix(in srgb, var(--danger) 42%, var(--hairline) 58%);
}

.custom-player.player-error .player-time {
  color: var(--danger);
  opacity: 1;
}

.custom-player.player-native-fallback audio,
.custom-player.player-native-fallback video {
  display: block;
  width: 100%;
  margin-top: 8px;
}

.custom-player.player-native-fallback.tg-audio-player {
  grid-template-columns: 1fr;
}

.music-notification {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 90;
  width: min(520px, calc(100vw - 28px));
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--border) 74%);
  border-radius: 24px;
  background:
    radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 44%),
    color-mix(in srgb, var(--panel) 92%, transparent);
  box-shadow:
    0 22px 70px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  overflow: hidden;
  animation: musicNoticeIn 0.26s cubic-bezier(0.2, 0.85, 0.2, 1) both;
  backdrop-filter: blur(calc(var(--glass-blur, 16px) * 0.85));
}

.music-notification-glow {
  position: absolute;
  inset: -40%;
  background:
    conic-gradient(from 180deg,
      transparent,
      color-mix(in srgb, var(--accent) 18%, transparent),
      transparent,
      color-mix(in srgb, var(--bubble-out) 16%, transparent),
      transparent);
  opacity: 0;
  pointer-events: none;
}

.music-notification.playing .music-notification-glow {
  opacity: 1;
  animation: musicNoticeGlow 4.8s linear infinite;
}

.music-notification-main {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) 86px auto auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
}

.music-notification-play,
.music-notification-stop,
.music-notification-close {
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--border) 66%);
  background: color-mix(in srgb, var(--panel2) 78%, transparent);
  color: var(--text);
  cursor: pointer;
  font-weight: 950;
}

.music-notification-play {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: grid;
  place-items: center;
}

.music-notification-play::before {
  content: "";
  width: 0;
  height: 0;
  margin-left: 3px;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid currentColor;
}

.music-notification.playing .music-notification-play {
  background: var(--accent);
  color: var(--accent-text);
}

.music-notification.playing .music-notification-play::before {
  width: 14px;
  height: 16px;
  margin-left: 0;
  border: 0;
  background:
    linear-gradient(90deg, currentColor 0 38%, transparent 38% 62%, currentColor 62% 100%);
}

.music-notification-body {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.music-notification-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.music-notification-seek,
.music-notification-volume {
  width: 100%;
  accent-color: var(--accent);
  cursor: pointer;
}

.music-notification-seek {
  height: 12px;
  border-radius: 999px;
  background:
    linear-gradient(90deg,
      var(--accent) 0 var(--music-progress, 0%),
      color-mix(in srgb, var(--text) 12%, transparent) var(--music-progress, 0%) 100%);
  -webkit-appearance: none;
  appearance: none;
}

.music-notification-seek::-webkit-slider-runnable-track {
  height: 12px;
  border-radius: 999px;
  background: transparent;
}

.music-notification-seek::-webkit-slider-thumb {
  width: 17px;
  height: 17px;
  margin-top: -2px;
  border: 2px solid color-mix(in srgb, #fff 70%, var(--accent) 30%);
  border-radius: 50%;
  background: var(--accent);
  -webkit-appearance: none;
  appearance: none;
}

.music-notification-time {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.music-notification-stop,
.music-notification-close {
  min-height: 38px;
  border-radius: 999px;
  padding: 0 13px;
}

.music-notification-close {
  width: 38px;
  padding: 0;
  font-size: 22px;
  line-height: 1;
}

@keyframes musicNoticeIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.transfer-indicator {
  position: fixed;
  right: 18px;
  bottom: calc(18px + env(safe-area-inset-bottom, 0px));
  z-index: 80;
  display: grid;
  grid-template-columns: auto minmax(170px, 240px);
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--hairline) 74%);
  border-radius: 22px;
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--accent) 18%, transparent), transparent 40%),
    color-mix(in srgb, var(--panel) 90%, #000 10%);
  color: var(--text);
  box-shadow: 0 20px 58px rgba(0, 0, 0, 0.32);
  backdrop-filter: blur(18px);
  animation: transferIn 0.22s ease both;
}

.transfer-indicator.hidden {
  display: none !important;
}

.transfer-indicator-ring {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 3px solid color-mix(in srgb, var(--accent) 20%, transparent);
  border-top-color: var(--accent);
  animation: transferSpin 0.85s linear infinite;
}

.transfer-indicator-body {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.transfer-indicator-body strong {
  font-size: 13px;
  line-height: 1.1;
}

.transfer-indicator-body span {
  color: var(--muted);
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.transfer-indicator-track {
  height: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 10%, transparent);
}

.transfer-indicator-track i {
  display: block;
  width: 38%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 55%, #fff 45%));
  transition: width 0.18s ease;
}

.transfer-indicator.indeterminate .transfer-indicator-track i {
  animation: transferBar 1s ease-in-out infinite;
}

@keyframes transferIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes transferSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes transferBar {
  0% {
    transform: translateX(-120%);
    width: 36%;
  }
  50% {
    width: 62%;
  }
  100% {
    transform: translateX(280%);
    width: 36%;
  }
}

@keyframes musicNoticeGlow {
  to {
    transform: rotate(1turn);
  }
}

@media (max-width: 720px) {
  .music-notification {
    right: 10px;
    bottom: 10px;
    width: calc(100vw - 20px);
  }

  .music-notification-main {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .music-notification-volume,
  .music-notification-stop {
    grid-column: 2 / 4;
  }
}

.custom-player.player-native-fallback.tg-audio-player .player-play,
.custom-player.player-native-fallback.tg-audio-player .player-body {
  display: none;
}

.yt-video-player video:fullscreen {
  width: 100vw;
  height: 100vh;
  max-height: none;
  border-radius: 0;
  object-fit: contain;
  background: #000;
}

.voice-transcript-popout {
  position: absolute;
  top: 8px;
  width: min(260px, 34vw);
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--hairline) 80%);
  border-radius: 16px;
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--accent) 12%, transparent), transparent 44%),
    color-mix(in srgb, var(--panel2) 88%, transparent);
  color: var(--text);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(14px);
}

.message.in .voice-transcript-popout {
  left: calc(100% + 10px);
}

.message.out .voice-transcript-popout {
  right: calc(100% + 10px);
}

.voice-transcript-popout span {
  color: color-mix(in srgb, var(--accent) 78%, #fff 22%);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.voice-transcript-popout strong {
  color: var(--text);
  font-size: 12px;
  line-height: 1.38;
  font-weight: 800;
}

.yt-video-player {
  min-width: min(360px, 72vw);
  padding: 8px;
  position: relative;
  overflow: hidden;
}

.yt-video-player video {
  display: block;
  width: min(420px, 72vw);
  max-height: 360px;
  border-radius: 18px;
  background: #000;
  object-fit: contain;
}

.tg-video-note-player {
  min-width: 0;
  width: fit-content;
  border-radius: 999px;
  padding: 8px;
  position: relative;
}

.tg-video-note-player video {
  width: min(260px, 58vw);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  object-fit: cover;
}

.video-player-controls {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(0, 0, 0, 0.42);
  color: #fff;
  backdrop-filter: blur(12px);
}

.tg-video-note-player .video-player-controls {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  margin: 8px;
  padding: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 0, 0, 0.36), transparent 52%);
  opacity: 0;
  transition: opacity 0.18s ease;
}

.tg-video-note-player:hover .video-player-controls,
.tg-video-note-player.playing .video-player-controls {
  opacity: 1;
}

.tg-video-note-player .player-play {
  width: 58px;
  height: 58px;
  background: rgba(0, 0, 0, 0.58);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.18);
}

.player-fullscreen {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.player-fullscreen:hover {
  background: rgba(255, 255, 255, 0.16);
}

.custom-player.player-loading .player-progress {
  filter: saturate(1.2) brightness(1.1);
}

.custom-player.player-loading .player-play,
.tg-profile-music-card.player-loading .player-play {
  position: relative;
  color: transparent;
}

.custom-player.player-loading .player-play::after,
.tg-profile-music-card.player-loading .player-play::after {
  content: "";
  width: 17px;
  height: 17px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  color: var(--text);
  animation: spin 0.7s linear infinite;
}

.custom-player.player-loading .player-play::before,
.tg-profile-music-card.player-loading .player-play::before {
  display: none;
}

.image-attachment {
  display: block;
  width: auto;
  max-width: min(360px, 100%);
  max-height: 420px;
  border-radius: 20px;
  object-fit: contain;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18);
}

.message,
.message .content,
.media-caption,
.custom-player,
.file-attachment-card,
.yt-video-player {
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.message .content {
  overflow: hidden;
}

.message .content > .image-attachment,
.message .content > canvas.image-attachment {
  max-width: 100%;
  height: auto;
}

.file-attachment-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  min-width: min(320px, 72vw);
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--hairline) 80%);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.034);
}

.file-attachment-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--accent) 20%, var(--panel2) 80%);
  color: var(--text);
  font-size: 10px;
  font-weight: 900;
}

.file-attachment-body {
  min-width: 0;
}

.file-attachment-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 900;
}

.file-attachment-meta {
  margin: 4px 0 8px;
  color: inherit;
  font-size: 12px;
  opacity: 0.62;
}

.file-attachment-download {
  color: inherit;
  font-weight: 900;
  text-decoration: none;
}

.file-attachment-download:hover {
  color: var(--accent);
}

.pinned-stack {
  display: flex;
  align-items: stretch;
  gap: 8px;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: thin;
}

.pinned-chip {
  min-width: min(220px, 48vw);
  max-width: 280px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 9px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border) 82%);
  border-radius: 14px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 13%, transparent), rgba(255, 255, 255, 0.025));
  color: var(--text);
  padding: 7px 9px;
  text-align: left;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.pinned-chip:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border) 62%);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 20%, transparent), rgba(255, 255, 255, 0.045));
}

.pinned-chip-thumb {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  object-fit: cover;
  background: #000;
}

.pinned-chip-thumb.round {
  border-radius: 50%;
}

.pinned-chip-body {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.pinned-chip-body strong {
  color: var(--accent);
  font-size: 11px;
  font-weight: 950;
}

.pinned-chip-body span {
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-music-tools {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-top: 8px;
}

.profile-music-tools small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}

.audio-waveform {
  position: relative;
  min-height: 34px;
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 5px 8px;
  border-radius: 999px;
  overflow: hidden;
  background:
    linear-gradient(90deg,
      color-mix(in srgb, var(--accent) 28%, transparent) 0 var(--player-progress, 0%),
      color-mix(in srgb, var(--text) 9%, transparent) var(--player-progress, 0%) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -10px 20px rgba(0, 0, 0, 0.13);
}

.audio-waveform::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at var(--player-progress, 0%) 50%, color-mix(in srgb, #fff 22%, transparent), transparent 24px);
  opacity: 0.65;
}

.audio-waveform span {
  position: relative;
  z-index: 1;
  flex: 1;
  min-width: 2px;
  height: var(--wave-h, 26%);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 76%, #fff 24%);
  opacity: 0.62;
  transform-origin: center;
  transition: height 0.09s linear, opacity 0.18s ease, filter 0.18s ease;
}

.tg-audio-player.playing .audio-waveform span {
  opacity: 0.95;
  filter: drop-shadow(0 0 8px color-mix(in srgb, var(--accent) 36%, transparent));
}

.tg-audio-player .player-body {
  position: relative;
  display: grid;
  gap: 4px;
}

.tg-audio-player .player-progress {
  position: absolute;
  inset: 0 0 auto 0;
  height: 34px;
  opacity: 0;
  z-index: 3;
}

.tg-audio-player .player-time {
  margin-left: 8px;
}

.yt-video-player {
  min-width: min(520px, 76vw);
  padding: 0 !important;
  border: 0 !important;
  border-radius: 22px;
  background: #000 !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

.yt-video-player video {
  width: min(560px, 76vw);
  max-height: 420px;
  border-radius: 22px;
}

.yt-video-player .video-player-controls {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  grid-template-columns: auto minmax(120px, 1fr) auto auto 86px auto auto;
  margin: 0;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(15, 15, 15, 0.55), rgba(0, 0, 0, 0.76));
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.yt-video-player:hover .video-player-controls,
.yt-video-player.playing .video-player-controls,
.yt-video-player:focus-within .video-player-controls,
.yt-video-player:fullscreen .video-player-controls {
  opacity: 1;
  transform: translateY(0);
}

.yt-video-player:fullscreen {
  width: 100vw;
  height: 100vh;
  display: grid;
  place-items: center;
  border-radius: 0;
  background: #000 !important;
}

.yt-video-player:fullscreen video {
  width: 100vw;
  height: 100vh;
  max-height: none;
  border-radius: 0;
  object-fit: contain;
}

.player-mute,
.player-speed,
.player-fullscreen {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.player-speed {
  color-scheme: dark;
}

.player-volume {
  width: 86px;
  accent-color: var(--accent);
  cursor: pointer;
}

.tg-video-note-player .video-player-controls {
  opacity: 1;
  pointer-events: auto;
}

.tg-video-note-player:not(.playing) .video-player-controls {
  background: radial-gradient(circle, rgba(0, 0, 0, 0.4), transparent 54%);
}

/* Global overflow guards: every tall workspace area keeps its own scroll instead of clipping. */
#layout,
#sidebar,
#chatList,
#chat,
#messages,
#messageInput,
#profileHome,
#newsHome,
#callsHome,
.news-panel,
.modal-content,
.modal-body,
.tg-settings-shell,
.tg-settings-panels,
.tg-settings-panel {
  min-height: 0;
}

#profileHome {
  overflow: auto;
  align-items: flex-start;
}

#profileHome .profile-home-card {
  margin: auto;
}

.news-panel {
  overflow: hidden;
}

.news-content,
#callsContent,
#newsContent,
.member-picker,
.forward-targets {
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
}

.news-content {
  flex: 1 1 auto;
}

.modal {
  padding: 12px;
  overflow: hidden;
}

.modal-content {
  display: flex;
  flex-direction: column;
  max-height: calc(100dvh - 24px);
  overflow: hidden !important;
}

.modal-header,
.modal-footer {
  flex: 0 0 auto;
}

.modal-body {
  min-height: 0;
  overflow: auto !important;
  overscroll-behavior: contain;
}

.tg-settings-modal .modal-body {
  display: flex;
}

.tg-settings-shell {
  flex: 1 1 auto;
  width: 100%;
  overflow: hidden;
}

.tg-settings-panels {
  overflow: auto;
  overscroll-behavior: contain;
  padding-right: 2px;
}

.tg-settings-nav.settings-scroll-nav {
  max-height: calc(100dvh - 190px);
  overflow-y: auto;
}

body.settings-save-motion {
  --motion-fast: 0.08s;
  --motion-shell: 0.1s;
  --motion-message: 0.08s;
  --glow-strength: 0px;
}

body.settings-profile-link-disabled .tg-profile-share {
  opacity: 0.46;
  pointer-events: none;
}

body.settings-compact-voice-player .tg-audio-player {
  min-width: min(260px, 68vw);
  padding: 9px;
}

body.settings-compact-voice-player .tg-audio-player .player-progress {
  height: 8px;
}

body.settings-hide-video-notes .tg-video-note-player {
  filter: saturate(0.78);
}

body.settings-compact-video-player .yt-video-player {
  min-width: min(300px, 68vw);
}

body.settings-compact-video-player .yt-video-player video {
  width: min(340px, 68vw);
  max-height: 260px;
}

#chat.chat-switching #messages {
  animation: chatSwapIn var(--motion-shell, 0.28s) ease both;
}

.chat-search-bar.hidden {
  display: none !important;
}

body:not(.chat-search-open) .chat-search-bar {
  display: none !important;
}

.message {
  transform-origin: 50% 100%;
  animation-name: messagePopIn;
}

.message.in {
  transform-origin: 0 100%;
}

.message.out {
  transform-origin: 100% 100%;
}

.chatItem {
  animation: none;
}

.pinned-bar:not(.hidden),
.chat-search-bar:not(.hidden),
.reply-bar:not(.hidden) {
  animation: slideUtilityIn var(--motion-fast, 0.24s) ease both;
}

.send-btn:not(:disabled):active,
.composer-media-btn:not(:disabled):active,
.message-context-menu button:active {
  transform: scale(0.96);
}

@keyframes menuIslandIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes recordingPulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--danger) 42%, transparent);
  }
  50% {
    box-shadow: 0 0 0 7px color-mix(in srgb, var(--danger) 0%, transparent);
  }
}

@keyframes messagePopIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.985);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes chatItemIn {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideUtilityIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes playerFloatIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes stickerPanelIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes oneUiWave {
  0%,
  100% {
    transform: scaleY(0.45);
    filter: saturate(0.9);
  }
  35% {
    transform: scaleY(1.2);
    filter: saturate(1.35);
  }
  65% {
    transform: scaleY(0.72);
  }
}

@keyframes oneUiListenBar {
  0%,
  100% {
    filter: saturate(1) brightness(1);
  }
  50% {
    filter: saturate(1.28) brightness(1.12);
  }
}

@keyframes chatSwapIn {
  from {
    opacity: 0.42;
    transform: translateX(14px);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
    filter: blur(0);
  }
}

@media (max-width: 768px) {
  :root {
    --mobile-gap: 8px;
  }

  #chatHeader {
    height: 58px;
    gap: 8px;
    padding: 0 10px;
  }

  .chat-user {
    gap: 8px;
    flex: 1 1 auto;
    min-width: 0;
  }

  .chat-user .avatar {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    font-size: 14px;
  }

  .chat-user .name {
    max-width: 42vw;
    font-size: 15px;
    line-height: 1.1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .chat-user .status {
    max-width: 42vw;
    font-size: 11px;
  }

  .chat-actions {
    gap: 5px;
    flex: 0 0 auto;
  }

  .chat-actions .action-btn,
  .composer-media-btn,
  .send-btn,
  .back-btn {
    width: 38px;
    height: 38px;
    min-width: 38px;
    min-height: 38px;
  }

  .chat-actions .action-btn img,
  .composer-media-btn img,
  .send-btn img {
    width: 18px;
    height: 18px;
  }

  #messages {
    padding: 10px;
    gap: 8px;
  }

  .message {
    max-width: min(86%, 420px);
    padding: 8px 10px;
    border-radius: 17px;
    font-size: 13px;
  }

  .message .sender {
    font-size: 11px;
    margin-bottom: 4px;
  }

  .message .content {
    font-size: 13px;
    line-height: 1.38;
  }

  .message.out {
    max-width: min(80%, 390px);
  }

  .message .reply-preview,
  .message .forward-preview {
    padding: 7px 8px;
    border-radius: 11px;
  }

  .image-attachment {
    width: auto;
    max-width: 100%;
    max-height: min(46vh, 300px);
    border-radius: 16px;
  }

  .yt-video-player {
    min-width: 0;
    width: min(100%, 82vw);
  }

  .yt-video-player video {
    width: 100%;
    max-height: min(46vh, 300px);
  }

  .tg-audio-player,
  .file-attachment-card {
    width: min(100%, 78vw);
    min-width: 0;
  }

  #messageInput {
    gap: 7px;
    padding: 8px 8px calc(8px + env(safe-area-inset-bottom, 0px));
  }

  #textInput {
    min-height: 38px;
    padding: 9px 11px;
    font-size: 13px;
  }

  .input-wrapper {
    min-width: 0;
  }

  .transfer-indicator {
    left: 10px;
    right: 10px;
    bottom: calc(76px + env(safe-area-inset-bottom, 0px));
    grid-template-columns: auto 1fr;
    padding: 10px 12px;
  }

  .transfer-indicator-ring {
    width: 28px;
    height: 28px;
  }
}

@media (max-width: 420px) {
  .chat-user .name,
  .chat-user .status {
    max-width: 34vw;
  }

  #callAudioBtn,
  #callVideoBtn,
  #chatManageBtn {
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
  }

  .message {
    max-width: 88%;
  }

  .message.out {
    max-width: 82%;
  }
}

@media (max-width: 520px) {
  #profileHome {
    padding: 8px;
  }

  #profileHome .profile-home-card.own-profile-card {
    width: 100%;
    border-radius: 24px;
  }

  .profile-home-card.own-profile-card::before {
    height: 218px;
  }

  .profile-home-card.own-profile-card .profile-home-avatar {
    width: 104px;
    height: 104px;
  }

  .profile-home-card.own-profile-card .profile-home-name {
    font-size: clamp(24px, 7vw, 30px);
  }

  .profile-home-card.own-profile-card .tg-profile-home-row {
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .composer-media-btn.recording,
  .message-context-menu,
  .custom-player,
  .message,
  .chatItem,
  .pinned-bar:not(.hidden),
  .chat-search-bar:not(.hidden),
  .reply-bar:not(.hidden) {
    animation: none !important;
  }
}
