/**
 * Chat UI — Telegram/ВК-level стили для диалогов и бесед
 * @author Чепела Даниил Максимович
 * @version 1.0 — 2026-04-18
 *
 * Подключается ПОСЛЕ common.css и перебивает все конфликтующие legacy стили.
 */

:root {
	--chat-bg:           #e9edf2;
	--chat-bg-inner:     #e5e9f0;
	--chat-own-bg:       #c4e4fd;
	--chat-own-bg-hover: #aed8fb;
	--chat-other-bg:     #ffffff;
	--chat-text:         #1c1e21;
	--chat-text-muted:   #8a95a5;
	--chat-accent:       #4c637b;
	--chat-accent-dark:  #3a506b;
	--chat-accent-soft:  #eaeff5;
	--chat-border:       #e5e9ef;
	--chat-hover:        #f4f7f9;
	--chat-active:       #e8f0f9;
	--chat-shadow:       0 1px 2px rgba(15, 20, 25, 0.08);
	--chat-shadow-lg:    0 8px 28px rgba(15, 20, 25, 0.14);
	--chat-danger:       #e53935;
	--chat-success:      #4caf50;
	--chat-radius:       16px;
	--chat-radius-tail:  4px;
	--chat-transition:   0.18s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ══════════════════ БАЗОВЫЙ LAYOUT (override legacy) ══════════════════ */

.messagespanel {
	padding: 0 !important;
	overflow: hidden;
	border-radius: 12px;
	background: #fff;
}

.messagespanel > .row { min-height: calc(100vh - 120px); }

.messagespanel .border-r { border-right: 1px solid var(--chat-border); }

.tabmessages {
	display: flex !important;
	flex-direction: column !important;
	height: 100%;
	overflow: hidden;
	background: #fff;
}

.tabmessages > #chat-list {
	flex: 1;
	overflow-y: auto;
	padding: 4px 0 20px;
	scrollbar-width: thin;
	scrollbar-color: #d6dbe3 transparent;
}
.tabmessages > #chat-list::-webkit-scrollbar { width: 6px; }
.tabmessages > #chat-list::-webkit-scrollbar-thumb { background: #d6dbe3; border-radius: 3px; }

.messagescontent,
.nomessages {
	height: calc(100vh - 120px);
}

.messagescontent {
	display: flex !important;
	flex-direction: column !important;
	overflow: hidden;
	background: var(--chat-bg);
}
.messagescontent.hidden { display: none !important; }

.nomessages {
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #fff;
	color: var(--chat-text-muted);
}
.nomessages.hidden { display: none !important; }
.nomessages__icon {
	font-size: 64px !important;
	color: #d4dae3 !important;
	margin-bottom: 16px !important;
	padding: 0 !important;
}
.nomessages__span {
	font-size: 14px !important;
	color: var(--chat-text-muted) !important;
	padding: 0 30px !important;
	text-align: center;
}
.nomessages__link {
	color: var(--chat-accent) !important;
	text-decoration: none !important;
}
.nomessages__link:hover { text-decoration: underline !important; }

/* ══════════════════ ТАБЫ (Диалоги / Беседы) ══════════════════ */

.msg-tabs {
	display: flex !important;
	padding: 0 6px !important;
	border-bottom: 1px solid var(--chat-border) !important;
	background: #fff;
	flex-shrink: 0;
}
.msg-tabs__item {
	flex: 1;
	padding: 14px 8px !important;
	text-align: center !important;
	cursor: pointer !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--chat-text-muted) !important;
	border-bottom: 2px solid transparent !important;
	text-decoration: none !important;
	transition: color var(--chat-transition), border-color var(--chat-transition);
	background: transparent !important;
}
.msg-tabs__item:hover { color: var(--chat-accent) !important; }
.msg-tabs__item--active {
	color: var(--chat-accent) !important;
	border-bottom-color: var(--chat-accent) !important;
	background: transparent !important;
}
.msg-tabs__item i { margin-right: 6px; }

/* ══════════════════ ПОИСК ══════════════════ */

.panelsearch-messges-panel {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 10px 12px !important;
	position: relative;
	flex-shrink: 0;
	background: #fff;
}
.panelsearch-messges-panel > div:first-child {
	flex: 1;
	position: relative;
}
.panelsearch-messges-panel .panelsearch__textarea {
	width: 100%;
	padding: 8px 14px 8px 34px !important;
	background: var(--chat-bg) !important;
	border: 1px solid transparent !important;
	border-radius: 18px !important;
	font-size: 13px !important;
	line-height: 1.3 !important;
	outline: none !important;
	transition: background var(--chat-transition), border-color var(--chat-transition);
	color: var(--chat-text);
	min-height: 34px;
}
.panelsearch-messges-panel .panelsearch__textarea:focus {
	background: #fff !important;
	border-color: var(--chat-accent) !important;
}
.panelsearch-messges-panel .panelsearch__textarea:empty::before {
	content: attr(data-placeholder);
	color: var(--chat-text-muted);
	pointer-events: none;
}
.panelsearch-messges-panel .panelsearch__icon {
	position: absolute !important;
	left: 12px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	color: var(--chat-text-muted) !important;
	font-size: 12px !important;
	pointer-events: none;
	z-index: 1;
}
.panelsearch-messges-panel .btn {
	flex-shrink: 0;
	height: 34px !important;
	padding: 0 12px !important;
	border-radius: 50% !important;
	width: 34px !important;
	background: var(--chat-accent) !important;
	border-color: var(--chat-accent) !important;
}
.panelsearch-messges-panel .btn:hover {
	background: var(--chat-accent-dark) !important;
	border-color: var(--chat-accent-dark) !important;
}

/* ══════════════════ СПИСОК ЧАТОВ (sidebar) ══════════════════ */

.tabmessages__item {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	padding: 10px 14px !important;
	cursor: pointer;
	border-radius: 12px !important;
	margin: 2px 6px !important;
	transition: background var(--chat-transition), transform 0.1s;
	position: relative;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
}
.tabmessages__item:hover { background: var(--chat-hover) !important; }
.tabmessages__item:active { transform: scale(0.99); }
.tabmessages__item.tg-active,
.tabmessages__item[style*="background: rgb(240, 242, 245)"],
.tabmessages__item[style*="rgb(232, 240, 249)"] {
	background: var(--chat-active) !important;
}
.tabmessages__ava {
	width: 48px !important;
	height: 48px !important;
	border-radius: 50% !important;
	overflow: hidden;
	flex-shrink: 0;
	position: relative;
	display: block !important;
	background: #e5e9ef;
}
.tabmessages__img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	border-radius: 50% !important;
}
.tabmessages__online {
	position: absolute;
	bottom: 1px;
	right: 1px;
	width: 11px;
	height: 11px;
	border-radius: 50%;
	border: 2px solid #fff;
	background: transparent;
	z-index: 1;
}
.tabmessages__online.online { background: var(--chat-success); }
.tabmessages__online.offline { display: none; }
.tabmessages__info {
	flex: 1 !important;
	min-width: 0 !important;
	overflow: hidden !important;
	padding: 0 !important;
}
.tabmessages__name {
	display: block !important;
	font-size: 14.5px !important;
	font-weight: 600 !important;
	color: #1c1e21 !important;
	text-decoration: none !important;
	white-space: nowrap !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	line-height: 1.3 !important;
	margin: 0 !important;
}
.tabmessages__name:hover { color: #1c1e21 !important; }
.tabmessages__msg {
	font-size: 12.5px !important;
	color: var(--chat-text-muted) !important;
	white-space: nowrap !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	line-height: 1.3 !important;
	margin-top: 2px !important;
	background: transparent !important;
	padding: 0 !important;
}
.tabmessages__verify { color: var(--chat-accent); font-size: 11px; margin-left: 2px; }
.tabmessages__item .paneledit {
	position: absolute !important;
	right: 12px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	width: 24px !important;
	height: 24px !important;
	display: none !important;
	align-items: center;
	justify-content: center;
	border-radius: 50% !important;
	color: var(--chat-text-muted) !important;
	cursor: pointer;
	background: #fff !important;
	border: 1px solid var(--chat-border);
	z-index: 2;
}
.tabmessages__item:hover .paneledit { display: flex !important; }
.tabmessages__item .paneledit:hover {
	color: var(--chat-danger) !important;
	background: #fff !important;
	border-color: var(--chat-danger);
}

/* Бейдж непрочитанных */
.MsgNew {
	background: var(--chat-accent) !important;
	color: #fff !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	padding: 2px 7px !important;
	border-radius: 10px !important;
	min-width: 20px !important;
	height: 20px !important;
	text-align: center;
	flex-shrink: 0;
	display: flex !important;
	align-items: center;
	justify-content: center;
	line-height: 1 !important;
}

.messagesnew {
	background: var(--chat-accent) !important;
	color: #fff !important;
	font-size: 10px !important;
	padding: 1px 6px !important;
	border-radius: 8px !important;
	margin-left: 4px !important;
	font-weight: 600 !important;
	vertical-align: middle;
}

/* ══════════════════ ШАПКА ЧАТА ══════════════════ */

.messagescontent__userinfo {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 12px !important;
	padding: 12px 20px !important;
	background: #fff !important;
	border-bottom: 1px solid var(--chat-border) !important;
	flex-shrink: 0 !important;
	height: auto !important;
	min-height: 64px;
	position: relative;
	z-index: 10;
}
.messagescontent__back {
	cursor: pointer !important;
	padding: 6px 10px !important;
	color: var(--chat-text-muted) !important;
	font-size: 18px;
	border-radius: 50%;
	transition: background var(--chat-transition);
}
.messagescontent__back:hover { background: var(--chat-hover); color: var(--chat-accent); }
.messagescontent__back.hidden { display: none !important; }

.messagescontent__ava {
	width: 42px !important;
	height: 42px !important;
	border-radius: 50% !important;
	overflow: hidden !important;
	flex-shrink: 0 !important;
	padding: 0 !important;
	background: #e5e9ef;
	cursor: pointer;
}
.messagescontent__img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	border-radius: 50% !important;
}

.messagescontent__aboutuser {
	flex: 1 !important;
	min-width: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	gap: 1px;
}
.messagescontent__aboutusername {
	display: block !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	color: #1c1e21 !important;
	text-decoration: none !important;
	line-height: 1.2 !important;
	white-space: nowrap !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	max-width: 100%;
	cursor: pointer;
	transition: color var(--chat-transition);
	background: transparent !important;
	padding: 0 !important;
	margin: 0 !important;
}
.messagescontent__aboutusername:hover { color: var(--chat-accent) !important; }
.messagescontent__aboutuseronline {
	display: block !important;
	font-size: 12.5px !important;
	color: var(--chat-text-muted) !important;
	line-height: 1.4 !important;
	margin: 0 !important;
	background: transparent !important;
	padding: 0 !important;
}
.messagescontent__aboutuseronline.is-online { color: var(--chat-success) !important; }
.messagescontent__aboutuseronline i { margin-right: 4px; font-size: 10px; }

.talk-header__actions {
	display: flex !important;
	align-items: center !important;
	gap: 2px !important;
	flex-shrink: 0 !important;
}
.talk-header__action {
	width: 38px;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	cursor: pointer;
	color: var(--chat-text-muted);
	transition: background var(--chat-transition), color var(--chat-transition);
}
.talk-header__action:hover { background: var(--chat-hover); color: var(--chat-accent); }
.talk-header__action i { font-size: 15px; }

/* ══════════════════ ЛЕНТА СООБЩЕНИЙ ══════════════════ */

.messagescontent__feed {
	flex: 1 !important;
	overflow-y: auto !important;
	overflow-x: hidden !important;
	padding: 14px 20px 8px !important;
	background: var(--chat-bg) !important;
	position: relative;
	scrollbar-width: thin;
	scrollbar-color: #c8cfda transparent;
	scroll-behavior: smooth;
}
.messagescontent__feed::-webkit-scrollbar { width: 8px; }
.messagescontent__feed::-webkit-scrollbar-thumb {
	background: #c8cfda;
	border-radius: 4px;
	border: 2px solid var(--chat-bg);
}
.messagescontent__feed::-webkit-scrollbar-thumb:hover { background: #a9b2bf; }

.all_messages {
	display: flex;
	flex-direction: column;
	gap: 0;
	min-height: 100%;
	padding-bottom: 4px;
}

/* ══════════════════ ДАТА-РАЗДЕЛИТЕЛЬ ══════════════════ */

.message__date {
	display: flex !important;
	justify-content: center !important;
	margin: 14px 0 8px !important;
	pointer-events: none;
	position: sticky;
	top: 4px;
	z-index: 3;
}
.messages__datespan {
	background: rgba(30, 42, 56, 0.55) !important;
	color: #fff !important;
	font-size: 12px !important;
	font-weight: 500 !important;
	padding: 4px 12px !important;
	border-radius: 12px !important;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	letter-spacing: 0.2px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.message__date::before,
.message__date::after { content: none !important; display: none !important; }

/* ══════════════════ СИСТЕМНОЕ СООБЩЕНИЕ ══════════════════ */

.message__system {
	display: flex !important;
	justify-content: center !important;
	margin: 8px 0 !important;
	background: none !important;
	padding: 0 !important;
	box-shadow: none !important;
	border-radius: 0 !important;
}
.message__systemtext {
	background: rgba(30, 42, 56, 0.08) !important;
	color: #5a6876 !important;
	font-size: 12.5px !important;
	padding: 5px 14px !important;
	border-radius: 12px !important;
	line-height: 1.4 !important;
	max-width: 80%;
	text-align: center;
}

/* ══════════════════ ПУЗЫРИ СООБЩЕНИЙ ══════════════════ */

.message__left,
.message__right {
	display: flex !important;
	align-items: flex-end !important;
	margin: 1px 0 !important;
	padding: 0 !important;
	background: transparent !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	width: 100% !important;
	position: relative;
	animation: msgAppear 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}
.message__left { justify-content: flex-start !important; text-align: left !important; }
.message__right { justify-content: flex-end !important; text-align: right !important; }

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

/* Аватар слева (беседы) */
.message__talk-ava {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	margin-right: 8px;
	margin-bottom: 4px;
	background: #e5e9ef;
}
.message__talk-ava img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.message__left.msg-grouped .message__talk-ava { visibility: hidden; }

/* Тело (беседы) */
.message__talk-body {
	display: flex !important;
	flex-direction: column !important;
	max-width: 68% !important;
	min-width: 0 !important;
	align-items: flex-start !important;
}
.message__right .message__talk-body { align-items: flex-end !important; }

.message__talk-name {
	font-size: 12.5px !important;
	font-weight: 600 !important;
	color: var(--chat-accent) !important;
	margin: 0 12px 2px !important;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 100%;
	background: transparent !important;
	padding: 0 !important;
}
.message__talk-name a { color: inherit; text-decoration: none; }
.message__talk-name a:hover { text-decoration: underline; }
.message__left.msg-grouped .message__talk-name { display: none !important; }

/* Сам пузырь */
.message__align-left,
.message__align-right {
	display: inline-flex !important;
	flex-direction: column !important;
	padding: 7px 12px 6px !important;
	border-radius: var(--chat-radius) !important;
	word-wrap: break-word;
	word-break: break-word;
	max-width: 100% !important;
	position: relative;
	line-height: 1.45;
	font-size: 14px;
	box-shadow: var(--chat-shadow);
	text-align: left;
	transition: transform 0.1s;
}
.message__align-left {
	background: var(--chat-other-bg) !important;
	color: var(--chat-text) !important;
	border-bottom-left-radius: var(--chat-radius-tail) !important;
}
.message__align-right {
	background: var(--chat-own-bg) !important;
	color: var(--chat-text) !important;
	border-bottom-right-radius: var(--chat-radius-tail) !important;
}
/* Группировка: у не-последних сообщений — более округлый угол снизу + скрыть дату */
.message__right.msg-grouped .message__align-right { border-bottom-right-radius: var(--chat-radius) !important; }
.message__left.msg-grouped .message__align-left { border-bottom-left-radius: var(--chat-radius) !important; }
.message__right.msg-grouped > .message__spandate,
.message__left.msg-grouped > .message__spandate,
.message__right.msg-grouped .message__talk-body > .message__spandate,
.message__left.msg-grouped .message__talk-body > .message__spandate {
	display: none !important;
}
/* Уменьшаем зазор между сгруппированными сообщениями */
.message__left.msg-grouped,
.message__right.msg-grouped { margin-bottom: 0 !important; margin-top: 0 !important; }
.message__left.msg-grouped + .message__left,
.message__right.msg-grouped + .message__right { margin-top: 0 !important; }

/* Текст */
.message__align-left .message__span,
.message__align-right .message__span {
	display: block !important;
	word-wrap: break-word !important;
	white-space: pre-wrap !important;
	background: transparent !important;
	padding: 0 !important;
	color: inherit !important;
	font-size: 14px !important;
	line-height: 1.45 !important;
	border-radius: 0 !important;
}
.message__span a {
	color: var(--chat-accent) !important;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Время + статус */
.message__spandate {
	display: flex !important;
	align-items: center;
	gap: 4px;
	font-size: 11px !important;
	color: var(--chat-text-muted) !important;
	margin: 2px 10px 0 !important;
	line-height: 1;
	background: transparent !important;
	padding: 0 !important;
}
.message__right .message__spandate,
.message__right .message__talk-body .message__spandate { justify-content: flex-end; }
.message__left .message__spandate { justify-content: flex-start; }
.message__status {
	font-size: 10px;
	color: var(--chat-accent);
}
.message__status.read,
.fa-check-double.read { color: var(--chat-success) !important; }

/* Картинки */
.massage__img-left,
.massage__img-right {
	display: block !important;
	max-width: 280px;
	max-height: 280px;
	border-radius: 12px !important;
	cursor: pointer;
	margin: 0 !important;
	transition: transform var(--chat-transition);
}
.massage__img-left:hover,
.massage__img-right:hover { transform: scale(1.01); }

/* Пузырь с ТОЛЬКО картинкой — прозрачный */
.message__align-left:has(> .massage__img-left:only-child),
.message__align-right:has(> .massage__img-right:only-child) {
	background: transparent !important;
	padding: 0 !important;
	box-shadow: none !important;
	overflow: hidden;
}
/* Стикеры без пузыря */
.message__align-left:has(.im_gift),
.message__align-right:has(.im_gift) {
	background: transparent !important;
	padding: 0 !important;
	box-shadow: none !important;
}
.im_gift {
	display: block !important;
	max-width: 160px !important;
	max-height: 160px !important;
}

/* ══════════════════ ГОЛОСОВОЕ ══════════════════ */

.voice__msg {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 2px 2px !important;
	cursor: pointer;
	user-select: none;
	min-width: 180px;
}
.voice__button {
	width: 38px !important;
	height: 38px !important;
	border-radius: 50% !important;
	background: var(--chat-accent) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	color: #fff !important;
	flex-shrink: 0;
	transition: background var(--chat-transition);
}
.voice__msg:hover .voice__button { background: var(--chat-accent-dark) !important; }
.voice__button .voice__play,
.voice__button .voice__stop {
	font-size: 13px !important;
	color: #fff !important;
	line-height: 1;
}
.voice__button .voice__stop { display: none !important; }
.voise__title {
	display: flex !important;
	flex-direction: column !important;
	font-size: 13.5px !important;
	color: var(--chat-text) !important;
	line-height: 1.3 !important;
}
.voise__title span {
	font-size: 11px !important;
	color: var(--chat-text-muted) !important;
}

/* ══════════════════ HOVER ACTIONS (как в Telegram) ══════════════════ */

.message__left,
.message__right { padding-right: 6px; padding-left: 6px; }

.msg-actions {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: none;
	align-items: center;
	gap: 2px;
	background: #fff;
	border: 1px solid var(--chat-border);
	border-radius: 20px;
	padding: 3px;
	box-shadow: var(--chat-shadow-lg);
	z-index: 4;
}
.message__right .msg-actions { right: calc(100% - 2px); }
.message__left .msg-actions { left: calc(100% - 2px); }
.message__left:hover > .msg-actions,
.message__right:hover > .msg-actions { display: flex; }

.msg-actions__btn {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--chat-text-muted);
	cursor: pointer;
	background: transparent;
	border: none;
	transition: background var(--chat-transition), color var(--chat-transition);
}
.msg-actions__btn:hover {
	background: var(--chat-hover);
	color: var(--chat-accent);
}
.msg-actions__btn.is-danger:hover {
	background: #fde4e4;
	color: var(--chat-danger);
}
.msg-actions__btn i { font-size: 13px; }

/* ══════════════════ REPLY-БЛОК (цитата в пузыре) ══════════════════ */

.msg-reply {
	display: flex;
	gap: 8px;
	align-items: flex-start;
	padding: 5px 8px;
	margin: 0 0 4px;
	border-left: 3px solid var(--chat-accent);
	background: rgba(76, 99, 123, 0.06);
	border-radius: 4px;
	cursor: pointer;
	font-size: 12.5px;
	max-width: 100%;
}
.msg-reply__name {
	font-weight: 600;
	color: var(--chat-accent);
	display: block;
	line-height: 1.3;
}
.msg-reply__text {
	color: var(--chat-text-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
	max-width: 240px;
}

/* Preview над input при ответе */
.chat-reply-preview {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 20px;
	background: #fff;
	border-top: 1px solid var(--chat-border);
	border-bottom: 1px solid var(--chat-border);
	animation: slideInUp 0.2s ease;
}
.chat-reply-preview__icon {
	color: var(--chat-accent);
	font-size: 18px;
}
.chat-reply-preview__body {
	flex: 1;
	min-width: 0;
	border-left: 3px solid var(--chat-accent);
	padding-left: 8px;
}
.chat-reply-preview__name {
	font-size: 12.5px;
	font-weight: 600;
	color: var(--chat-accent);
}
.chat-reply-preview__text {
	font-size: 12.5px;
	color: var(--chat-text-muted);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.chat-reply-preview__close {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--chat-text-muted);
	cursor: pointer;
	transition: background var(--chat-transition);
}
.chat-reply-preview__close:hover { background: var(--chat-hover); color: var(--chat-danger); }

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

/* ══════════════════ TYPING INDICATOR ══════════════════ */

.chat-typing {
	display: none;
	padding: 4px 20px;
	font-size: 12px;
	color: var(--chat-accent);
	font-style: italic;
	flex-shrink: 0;
	background: #fff;
	border-top: 1px solid var(--chat-border);
}
.chat-typing.is-active { display: flex; align-items: center; gap: 6px; }
.chat-typing__dots {
	display: inline-flex;
	gap: 3px;
}
.chat-typing__dots span {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--chat-accent);
	animation: typingDot 1.4s infinite ease-in-out both;
}
.chat-typing__dots span:nth-child(2) { animation-delay: 0.16s; }
.chat-typing__dots span:nth-child(3) { animation-delay: 0.32s; }
@keyframes typingDot {
	0%, 80%, 100% { opacity: 0.3; transform: translateY(0); }
	40%           { opacity: 1; transform: translateY(-3px); }
}

/* ══════════════════ SCROLL-TO-BOTTOM КНОПКА ══════════════════ */

.chat-scrolldown {
	position: absolute;
	right: 24px;
	bottom: 90px;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: #fff;
	border: 1px solid var(--chat-border);
	display: none;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: var(--chat-shadow-lg);
	color: var(--chat-text-muted);
	transition: transform var(--chat-transition), background var(--chat-transition);
	z-index: 5;
}
.chat-scrolldown.is-visible { display: flex; }
.chat-scrolldown:hover {
	background: var(--chat-accent);
	color: #fff;
	transform: translateY(-2px);
}
.chat-scrolldown__badge {
	position: absolute;
	top: -4px;
	right: -4px;
	background: var(--chat-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 600;
	min-width: 20px;
	height: 20px;
	border-radius: 10px;
	padding: 0 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid #fff;
}

/* ══════════════════ DRAG-N-DROP OVERLAY ══════════════════ */

.chat-dropzone {
	position: absolute;
	top: 0; left: 0; right: 0; bottom: 0;
	background: rgba(76, 99, 123, 0.1);
	backdrop-filter: blur(3px);
	display: none;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	z-index: 20;
	border: 3px dashed var(--chat-accent);
	border-radius: 8px;
}
.chat-dropzone.is-active { display: flex; }
.chat-dropzone__inner {
	text-align: center;
	color: var(--chat-accent);
}
.chat-dropzone__inner i {
	font-size: 48px;
	margin-bottom: 12px;
	display: block;
}
.chat-dropzone__inner span {
	font-size: 16px;
	font-weight: 600;
}

/* ══════════════════ CONTEXT MENU ══════════════════ */

.chat-ctxmenu {
	position: fixed;
	background: #fff;
	border: 1px solid var(--chat-border);
	border-radius: 10px;
	box-shadow: var(--chat-shadow-lg);
	padding: 6px;
	min-width: 200px;
	z-index: 10050;
	animation: fadeIn 0.1s;
}
.chat-ctxmenu__item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 12px;
	font-size: 13.5px;
	color: var(--chat-text);
	cursor: pointer;
	border-radius: 6px;
	transition: background var(--chat-transition);
}
.chat-ctxmenu__item:hover { background: var(--chat-hover); }
.chat-ctxmenu__item.is-danger { color: var(--chat-danger); }
.chat-ctxmenu__item.is-danger:hover { background: #fde4e4; }
.chat-ctxmenu__item i { width: 18px; text-align: center; font-size: 13px; color: var(--chat-text-muted); }
.chat-ctxmenu__item.is-danger i { color: var(--chat-danger); }
.chat-ctxmenu__divider {
	height: 1px;
	background: var(--chat-border);
	margin: 4px 0;
}

@keyframes fadeIn {
	from { opacity: 0; transform: scale(0.95); }
	to   { opacity: 1; transform: scale(1); }
}

/* ══════════════════ ПОЛЕ ВВОДА ══════════════════ */

.typemessage {
	display: flex !important;
	align-items: flex-end !important;
	gap: 6px !important;
	padding: 10px 16px !important;
	background: #fff !important;
	border-top: 1px solid var(--chat-border);
	flex-shrink: 0 !important;
	height: auto !important;
	position: relative;
}
.typemessage__smiles,
.typemessage__actitem {
	width: 38px !important;
	height: 38px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	cursor: pointer;
	border-radius: 50% !important;
	color: var(--chat-text-muted) !important;
	transition: background var(--chat-transition), color var(--chat-transition);
	flex-shrink: 0;
	background: transparent !important;
	border: none !important;
}
.typemessage__smiles:hover,
.typemessage__actitem:hover {
	background: var(--chat-hover) !important;
	color: var(--chat-accent) !important;
}
.typemessage__acticon { font-size: 17px !important; color: inherit !important; }
.typemessage__textarea {
	flex: 1 !important;
	min-height: 38px !important;
	max-height: 140px !important;
	overflow-y: auto !important;
	padding: 9px 14px !important;
	background: var(--chat-bg) !important;
	border: 1px solid transparent !important;
	border-radius: 19px !important;
	font-size: 14px !important;
	line-height: 1.4 !important;
	outline: none;
	word-wrap: break-word;
	color: var(--chat-text);
	transition: background var(--chat-transition), border-color var(--chat-transition);
}
.typemessage__textarea:focus {
	background: #fff !important;
	border-color: var(--chat-accent) !important;
}
.typemessage__textarea[data-placeholder]:empty::before {
	content: attr(data-placeholder);
	color: var(--chat-text-muted);
	pointer-events: none;
}
.typemessage__actions {
	display: flex !important;
	align-items: center !important;
	gap: 2px !important;
	flex-shrink: 0;
}
.typemessage__button .btn {
	padding: 9px 18px !important;
	border-radius: 19px !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.typemessage__button .btn-primary {
	background: var(--chat-accent) !important;
	border-color: var(--chat-accent) !important;
	color: #fff !important;
}
.typemessage__button .btn-primary:hover {
	background: var(--chat-accent-dark) !important;
	border-color: var(--chat-accent-dark) !important;
}
.typemessage__button .btn.is-disabled,
.typemessage__button .btn:disabled {
	opacity: 0.5 !important;
	cursor: not-allowed !important;
	pointer-events: none;
}

.typemessage__actions .record {
	color: var(--chat-danger) !important;
	animation: recordPulse 1s ease-in-out infinite;
}
.typemessage__actions .record__text {
	color: var(--chat-danger) !important;
	font-weight: 500;
	font-size: 12px;
	margin-left: 6px;
}
@keyframes recordPulse { 0%,100% {opacity:0.6;} 50% {opacity:1;} }

/* ══════════════════ EMOJI PICKER ══════════════════ */

.emoji-picker {
	position: absolute;
	bottom: 72px;
	left: 12px;
	width: 340px;
	max-width: calc(100% - 24px);
	background: #fff;
	border: 1px solid var(--chat-border);
	border-radius: 14px;
	box-shadow: var(--chat-shadow-lg);
	padding: 10px;
	z-index: 30;
	display: none;
	animation: fadeIn 0.15s;
}
.emoji-picker.is-open { display: block; }
.emoji-picker__tabs {
	display: flex;
	gap: 4px;
	border-bottom: 1px solid var(--chat-border);
	padding: 0 0 8px;
	margin-bottom: 6px;
}
.emoji-picker__tab {
	width: 34px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border-radius: 6px;
	font-size: 18px;
	transition: background var(--chat-transition);
}
.emoji-picker__tab:hover,
.emoji-picker__tab.is-active {
	background: var(--chat-hover);
}
.emoji-picker__grid {
	display: grid;
	grid-template-columns: repeat(8, 1fr);
	gap: 2px;
	max-height: 260px;
	overflow-y: auto;
}
.emoji-picker__item {
	width: 100%;
	aspect-ratio: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border-radius: 6px;
	font-size: 22px;
	transition: background var(--chat-transition), transform 0.08s;
	user-select: none;
}
.emoji-picker__item:hover { background: var(--chat-hover); transform: scale(1.15); }

/* ══════════════════ SKELETON LOADING ══════════════════ */

.chat-skeleton {
	padding: 14px 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.skeleton-row {
	display: flex;
	align-items: flex-end;
	gap: 8px;
}
.skeleton-row--own { justify-content: flex-end; }
.skeleton-row--other { justify-content: flex-start; }
.skeleton-ava {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: linear-gradient(90deg, #e5e9ef 0%, #eff2f7 50%, #e5e9ef 100%);
	background-size: 200% 100%;
	animation: shimmer 1.4s infinite linear;
	flex-shrink: 0;
}
.skeleton-bubble {
	height: 38px;
	border-radius: 14px;
	background: linear-gradient(90deg, #e5e9ef 0%, #eff2f7 50%, #e5e9ef 100%);
	background-size: 200% 100%;
	animation: shimmer 1.4s infinite linear;
}
@keyframes shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* ══════════════════ "Показать предыдущие" ══════════════════ */

.talk-load-more {
	display: flex !important;
	justify-content: center !important;
	margin: 6px 0 10px !important;
}
.talk-load-more span {
	font-size: 12px;
	color: var(--chat-accent);
	background: #fff;
	padding: 6px 16px;
	border-radius: 16px;
	cursor: pointer;
	box-shadow: var(--chat-shadow);
	transition: background var(--chat-transition);
}
.talk-load-more span:hover { background: var(--chat-hover); }

/* Выделение (админ беседы — удаление) */
.talk-msg-selected .message__align-left,
.talk-msg-selected .message__align-right {
	outline: 2px solid var(--chat-danger);
	outline-offset: 2px;
}

/* ══════════════════ МОДАЛКА: РАЗДЕЛЫ НАСТРОЕК/СОЗДАНИЯ ══════════════════ */

.tg-settings { padding: 0; }
.tg-settings__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 22px 20px 18px;
	border-bottom: 1px solid var(--chat-border);
	background: linear-gradient(180deg, #fafbfd 0%, #fff 100%);
}
.tg-settings__avawrap {
	position: relative;
	width: 96px;
	height: 96px;
	margin-bottom: 12px;
}
.tg-settings__ava {
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	background: #e5e9ef;
}
.tg-settings__avaedit {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 32px;
	height: 32px;
	background: var(--chat-accent);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0,0,0,0.12);
	border: 2px solid #fff;
	transition: background var(--chat-transition);
}
.tg-settings__avaedit:hover { background: var(--chat-accent-dark); }
.tg-settings__avaedit i { font-size: 13px; }
.tg-settings__titlewrap {
	display: flex;
	align-items: center;
	gap: 8px;
	width: 100%;
	max-width: 360px;
}
.tg-settings__titleinput {
	flex: 1;
	padding: 9px 14px;
	border: 1px solid var(--chat-border);
	border-radius: 10px;
	font-size: 15px;
	font-weight: 600;
	color: var(--chat-text);
	text-align: center;
	outline: none;
	background: #fff;
	transition: border-color var(--chat-transition);
}
.tg-settings__titleinput:focus { border-color: var(--chat-accent); }
.tg-settings__titlesave {
	width: 36px;
	height: 36px;
	border: none;
	background: var(--chat-accent);
	color: #fff;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background var(--chat-transition);
}
.tg-settings__titlesave:hover { background: var(--chat-accent-dark); }
.tg-settings__title {
	font-size: 17px;
	font-weight: 600;
	color: var(--chat-text);
	text-align: center;
	width: 100%;
}
.tg-settings__sub {
	font-size: 13px;
	color: var(--chat-text-muted);
	margin-top: 4px;
}
.tg-settings__section {
	padding: 10px 0 6px;
	border-bottom: 1px solid var(--chat-border);
}
.tg-settings__section:last-child { border-bottom: none; }
.tg-settings__sectitle {
	font-size: 12px;
	font-weight: 600;
	color: var(--chat-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	padding: 6px 20px 6px;
}
.tg-settings__adduser {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 9px 20px;
	cursor: pointer;
	transition: background var(--chat-transition);
}
.tg-settings__adduser:hover { background: var(--chat-hover); }
.tg-settings__addicon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--chat-accent);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.tg-settings__addtext {
	font-size: 14px;
	color: var(--chat-accent);
	font-weight: 500;
}
.tg-settings__footer { padding: 6px 0 8px; }
.tg-settings__action {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 11px 20px;
	cursor: pointer;
	transition: background var(--chat-transition);
}
.tg-settings__action:hover { background: var(--chat-hover); }
.tg-settings__action i {
	width: 22px;
	text-align: center;
	font-size: 15px;
}
.tg-settings__action span { font-size: 14px; font-weight: 500; }
.tg-settings__action--warn { color: #d47026; }
.tg-settings__action--danger { color: var(--chat-danger); }

/* Участник в настройках */
.tg-member {
	display: flex;
	align-items: center;
	padding: 8px 20px;
	gap: 12px;
	position: relative;
	transition: background var(--chat-transition);
}
.tg-member:hover { background: var(--chat-hover); }
.tg-member__link {
	display: flex;
	align-items: center;
	gap: 12px;
	flex: 1;
	min-width: 0;
	text-decoration: none !important;
	color: inherit;
}
.tg-member__ava {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	background: #e5e9ef;
}
.tg-member__info { flex: 1; min-width: 0; }
.tg-member__name {
	font-size: 14px;
	font-weight: 500;
	color: var(--chat-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.tg-member__sub {
	font-size: 11px;
	color: var(--chat-text-muted);
	line-height: 1.3;
}
.tg-member__role {
	display: inline-block;
	font-size: 10.5px;
	padding: 1px 8px;
	border-radius: 8px;
	background: var(--chat-hover);
	color: var(--chat-text-muted);
	font-weight: 500;
	letter-spacing: 0.2px;
}
.tg-member__role--owner { background: #fff4dc; color: #c89128; }
.tg-member__role--admin { background: #e3eef9; color: var(--chat-accent); }
.tg-member__dots {
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border-radius: 50%;
	color: var(--chat-text-muted);
	flex-shrink: 0;
	transition: background var(--chat-transition), color var(--chat-transition);
}
.tg-member__dots:hover {
	background: var(--chat-hover);
	color: var(--chat-text);
}
.tg-member__menu { display: none !important; }
.tg-member__dropdown {
	position: fixed !important;
	display: block !important;
	background: #fff;
	border: 1px solid var(--chat-border);
	border-radius: 10px;
	box-shadow: var(--chat-shadow-lg);
	padding: 6px;
	min-width: 220px;
	z-index: 10020 !important;
}
.tg-member__menuitem {
	padding: 9px 12px;
	font-size: 13px;
	color: var(--chat-text);
	cursor: pointer;
	border-radius: 6px;
	transition: background var(--chat-transition);
}
.tg-member__menuitem:hover { background: var(--chat-hover); }
.tg-member__menuitem--danger { color: var(--chat-danger); }
.tg-member__menuitem--danger:hover { background: #fde4e4; }

/* Создание беседы */
.talk-create {
	padding: 16px 20px;
}
.talk-create__label {
	margin: 8px 0 10px;
	font-size: 12.5px;
	color: var(--chat-text-muted);
	font-weight: 500;
	letter-spacing: 0.2px;
}
.talk-create__friends {
	max-height: 340px;
	overflow-y: auto;
	margin: 0 -4px;
}
.talk-friend {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 12px;
	cursor: pointer;
	border-radius: 8px;
	transition: background var(--chat-transition);
}
.talk-friend:hover { background: var(--chat-hover); }
.talk-friend.selected { background: var(--chat-active); }
.talk-friend__ava {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
}
.talk-friend__name {
	flex: 1;
	font-size: 14px;
	color: var(--chat-text);
}
.talk-friend__check {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--chat-accent);
	color: #fff;
	display: none;
	align-items: center;
	justify-content: center;
	font-size: 11px;
}
.talk-friend.selected .talk-friend__check { display: flex; }
.talk-create .form-control,
.talk-create input[type="text"] {
	width: 100%;
	padding: 9px 14px !important;
	border: 1px solid var(--chat-border) !important;
	border-radius: 10px !important;
	font-size: 14px !important;
	outline: none;
	transition: border-color var(--chat-transition);
	box-shadow: none !important;
}
.talk-create .form-control:focus { border-color: var(--chat-accent) !important; }

/* ══════════════════ МОДАЛКИ (общие переопределения) ══════════════════ */

.modal-content {
	border-radius: 14px !important;
	border: none !important;
	overflow: hidden !important;
	box-shadow: var(--chat-shadow-lg) !important;
}
.modal-header {
	padding: 14px 20px !important;
	border-bottom: 1px solid var(--chat-border) !important;
	background: #fff;
}
.modal-title {
	font-size: 16px !important;
	font-weight: 600 !important;
	color: var(--chat-text) !important;
}
.modal-header .close {
	opacity: 0.5;
	font-size: 22px;
	line-height: 1;
}
.modal-header .close:hover { opacity: 1; }
.modal-body { padding: 0 !important; max-height: 78vh; overflow-y: auto; }

/* ══════════════════ RESPONSIVE (mobile) ══════════════════ */

@media (max-width: 768px) {
	.messagespanel > .row { min-height: calc(100vh - 80px); }
	.messagescontent,
	.nomessages { height: calc(100vh - 80px); }

	.tabmessages { height: calc(100vh - 80px); }

	/* При открытом чате — скрываем sidebar */
	.is-chat-open .col-md-5,
	.is-chat-open .col-lg-4 { display: none !important; }
	.is-chat-open .col-md-7,
	.is-chat-open .col-lg-8 {
		flex: 0 0 100% !important;
		max-width: 100% !important;
	}
	.is-chat-open .messagescontent__back { display: flex !important; align-items: center; justify-content: center; }

	.message__align-left,
	.message__align-right { max-width: 80% !important; }
	.message__talk-body { max-width: 75% !important; }

	.messagescontent__feed { padding: 10px 12px 6px !important; }
	.typemessage { padding: 8px 10px !important; }

	.emoji-picker { width: calc(100% - 20px); left: 10px; }
}

@media (min-width: 769px) {
	.messagescontent__back { display: none !important; }
}

/* Production polish overrides for chat alignment and rhythm */
.all_messages {
	gap: 0 !important;
	padding: 12px 18px 10px !important;
}

.message__left,
.message__right {
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
	margin: 5px 0 !important;
	clear: both !important;
}

.message__left {
	justify-content: flex-start !important;
	text-align: left !important;
	padding-left: 2px !important;
	padding-right: 18% !important;
}

.message__right {
	justify-content: flex-end !important;
	text-align: left !important;
	padding-left: 18% !important;
	padding-right: 2px !important;
}

.message__left > .message__align-left,
.message__left .message__talk-body {
	margin-right: auto !important;
	margin-left: 0 !important;
}

.message__right > .message__align-right,
.message__right .message__talk-body {
	margin-left: auto !important;
	margin-right: 0 !important;
	align-items: flex-end !important;
}

.message__align-left,
.message__align-right {
	max-width: min(620px, 100%) !important;
	padding: 8px 12px 7px !important;
	line-height: 1.5 !important;
}

.message__talk-body {
	max-width: min(620px, 100%) !important;
}

.message__talk-name {
	margin-bottom: 4px !important;
}

.message__left.msg-grouped,
.message__right.msg-grouped {
	margin-top: 2px !important;
	margin-bottom: 2px !important;
}

.message__left.msg-grouped + .message__left,
.message__right.msg-grouped + .message__right {
	margin-top: 2px !important;
}

.message__left:not(.msg-grouped) + .message__right,
.message__right:not(.msg-grouped) + .message__left,
.message__system + .message__left,
.message__system + .message__right {
	margin-top: 9px !important;
}

.message__date + .message__left,
.message__date + .message__right,
.message__date + .message__system {
	margin-top: 10px !important;
}

.message__spandate {
	margin-top: 4px !important;
	opacity: 0.78;
}

.message__left .message__spandate {
	justify-content: flex-start !important;
}

.message__right .message__spandate,
.message__right .message__talk-body .message__spandate {
	justify-content: flex-end !important;
}

@media (max-width: 768px) {
	.all_messages { padding: 10px 10px 8px !important; }
	.message__left { padding-right: 8% !important; }
	.message__right { padding-left: 8% !important; }
	.message__align-left,
	.message__align-right,
	.message__talk-body { max-width: 100% !important; }
}

/* Final chat rhythm pass */
.emoji-picker {
	display: none !important;
	right: auto !important;
}
.emoji-picker.is-open {
	display: block !important;
}

.all_messages {
	padding: 14px 18px 12px !important;
}

.message__left,
.message__right {
	margin: 6px 0 !important;
	padding-left: 8px !important;
	padding-right: 8px !important;
}

.message__left {
	justify-content: flex-start !important;
}

.message__right {
	justify-content: flex-end !important;
}

.message__align-left,
.message__align-right {
	max-width: min(520px, 76%) !important;
	padding: 9px 12px 7px !important;
	border-radius: 16px !important;
	line-height: 1.48 !important;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.07) !important;
}

.message__talk-body {
	max-width: min(520px, 76%) !important;
}

.message__talk-body .message__align-left,
.message__talk-body .message__align-right {
	max-width: 100% !important;
}

.message__align-left {
	background: #ffffff !important;
	border-bottom-left-radius: 5px !important;
}

.message__align-right {
	background: #e8f3ff !important;
	border-bottom-right-radius: 5px !important;
}

.message__span {
	font-size: 14px !important;
	line-height: 1.48 !important;
}

.message__spandate {
	margin: 4px 8px 0 !important;
	font-size: 10.5px !important;
}

.message__left.msg-grouped,
.message__right.msg-grouped {
	margin-top: 3px !important;
	margin-bottom: 3px !important;
}

.message__left.msg-grouped + .message__left,
.message__right.msg-grouped + .message__right {
	margin-top: 3px !important;
}

.message__left:not(.msg-grouped) + .message__right,
.message__right:not(.msg-grouped) + .message__left,
.message__system + .message__left,
.message__system + .message__right {
	margin-top: 12px !important;
}

.message__system {
	margin: 12px 0 !important;
}

.message__systemtext {
	background: rgba(70, 84, 102, 0.09) !important;
	color: #667085 !important;
	padding: 6px 13px !important;
}

.message__date {
	margin: 18px 0 12px !important;
	position: static !important;
}

.messages__datespan {
	background: rgba(71, 84, 103, 0.72) !important;
	box-shadow: none !important;
}

.message__talk-ava {
	margin-right: 9px !important;
	margin-bottom: 5px !important;
}

.message__talk-name {
	margin: 0 10px 5px !important;
}

@media (max-width: 768px) {
	.all_messages { padding: 12px 8px 10px !important; }
	.message__left,
	.message__right {
		padding-left: 4px !important;
		padding-right: 4px !important;
	}
	.message__align-left,
	.message__align-right,
	.message__talk-body {
		max-width: 88% !important;
	}
}

/* Keep bubbles close to chat edges; spacing is vertical, not horizontal */
.all_messages {
	padding-left: 8px !important;
	padding-right: 8px !important;
}

.message__left,
.message__right {
	padding-left: 2px !important;
	padding-right: 2px !important;
}

.message__left {
	padding-right: 0 !important;
}

.message__right {
	padding-left: 0 !important;
}

.message__align-left,
.message__align-right {
	max-width: min(540px, 82%) !important;
}

.message__talk-body {
	max-width: min(540px, 82%) !important;
}

@media (max-width: 768px) {
	.all_messages {
		padding-left: 6px !important;
		padding-right: 6px !important;
	}
	.message__align-left,
	.message__align-right,
	.message__talk-body {
		max-width: 92% !important;
	}
}

/* Edge correction: no artificial side gutters in the message lane */
.messagescontent__feed {
	padding-left: 4px !important;
	padding-right: 4px !important;
}

.all_messages {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.message__left,
.message__right {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.message__left {
	padding-right: 0 !important;
}

.message__right {
	padding-left: 0 !important;
}

.message__left > .message__align-left,
.message__left .message__talk-body {
	margin-left: 0 !important;
	margin-right: auto !important;
}

.message__right > .message__align-right,
.message__right .message__talk-body {
	margin-left: auto !important;
	margin-right: 0 !important;
}

.message__align-left,
.message__align-right,
.message__talk-body {
	max-width: min(560px, 88%) !important;
}

@media (max-width: 768px) {
	.messagescontent__feed {
		padding-left: 4px !important;
		padding-right: 4px !important;
	}
	.message__align-left,
	.message__align-right,
	.message__talk-body {
		max-width: 94% !important;
	}
}

/* Give the last message room above the input bar */
.messagescontent__feed {
	padding-bottom: 22px !important;
}

.all_messages {
	padding-bottom: 18px !important;
}

.all_messages > :last-child {
	margin-bottom: 8px !important;
}

@media (max-width: 768px) {
	.messagescontent__feed {
		padding-bottom: 18px !important;
	}
	.all_messages {
		padding-bottom: 14px !important;
	}
}

/* Keep hover actions inside the chat lane after edge correction */
.message__left,
.message__right {
	overflow: visible !important;
}

.msg-actions {
	z-index: 20 !important;
}

.message__left .msg-actions {
	left: 4px !important;
	right: auto !important;
	transform: translateY(-50%) translateX(0) !important;
}

.message__right .msg-actions {
	right: 4px !important;
	left: auto !important;
	transform: translateY(-50%) translateX(0) !important;
}

.message__left:hover .message__align-left,
.message__left:hover .message__talk-body {
	margin-left: 42px !important;
}

.message__right:hover .message__align-right,
.message__right:hover .message__talk-body {
	margin-right: 42px !important;
}

.message__left .msg-actions,
.message__right .msg-actions {
	background: rgba(255, 255, 255, 0.96) !important;
	backdrop-filter: blur(6px);
}

@media (max-width: 768px) {
	.message__left:hover .message__align-left,
	.message__left:hover .message__talk-body {
		margin-left: 36px !important;
	}
	.message__right:hover .message__align-right,
	.message__right:hover .message__talk-body {
		margin-right: 36px !important;
	}
}

/* Telegram-like lane: small gutters, actions beside the bubble, no overlap */
.messagescontent__feed {
	padding-left: 12px !important;
	padding-right: 12px !important;
	padding-bottom: 34px !important;
}

.all_messages {
	padding-bottom: 28px !important;
}

.message__left,
.message__right {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.msg-actions {
	top: 50% !important;
	right: auto !important;
	transform: translateY(-50%) !important;
	display: none;
	pointer-events: auto !important;
}

.message__left:hover > .msg-actions,
.message__right:hover > .msg-actions {
	display: flex !important;
}

.message__left:not(:hover) > .msg-actions,
.message__right:not(:hover) > .msg-actions {
	display: none !important;
}

.message__left:hover .message__align-left,
.message__left:hover .message__talk-body,
.message__right:hover .message__align-right,
.message__right:hover .message__talk-body {
	margin-left: inherit !important;
	margin-right: inherit !important;
}

.all_messages > :last-child {
	margin-bottom: 16px !important;
}

@media (max-width: 768px) {
	.messagescontent__feed {
		padding-left: 8px !important;
		padding-right: 8px !important;
		padding-bottom: 28px !important;
	}
	.all_messages {
		padding-bottom: 22px !important;
	}
}
