/* =========================================================
   CROSSFEELING MESSENGER UX
   адаптация ЛС под новый стиль филинга
   ставить НИЖЕ стандартного messenger.css
========================================================= */

#messages {
  --msg-radius-main: 18px;
  --msg-radius-soft: 15px;
  --msg-radius-small: 10px;

  --msg-bg: var(--pun);
  --msg-card: var(--cover);
  --msg-card-2: var(--cover2);
  --msg-dark: var(--dark100);
  --msg-border: var(--borders);
  --msg-link: var(--links);
  --msg-accent: var(--accent);

  color: var(--text1);
  font-family: var(--font), Arial, sans-serif;
}

#messages,
#messages *,
#messages *:before,
#messages *:after {
  box-sizing: border-box;
}

/* =========================================================
   COMMON
========================================================= */

#messages .container:empty,
#messages.view-dialog:has(.container:empty) .user-info-actions,
#messages.messenger-cannot-reply .pl-quote {
  display: none;
}

.punbb #messages:not(.messenger-processed) {
  display: none;
}

#messages a {
  color: var(--msg-link);
  text-decoration: none;
  transition: color .2s ease, background .2s ease, opacity .2s ease;
}

#messages a:hover {
  color: var(--msg-accent);
}

/* =========================================================
   ОБЩИЙ КОНТЕЙНЕ  ЛС
========================================================= */

#pun-messages .formal #messages .fs-box {
  padding: 0 !important;
}

#pun-messages #messages .fs-box > .container {
  margin: 0 !important;
}

#pun-messages #messages.view-dialog .fs-box > .container,
#pun-messages #messages.view-search .fs-box > .container,
#pun-messages #messages.view-bookmarks .fs-box > .container {
  max-height: 64vh;
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;

  margin-top: 0 !important;
  padding: 14px !important;

  background: var(--msg-card);
  border: 1px solid var(--msg-border) !important;
  border-radius: var(--msg-radius-main);
  scrollbar-width: thin;
  scrollbar-color: var(--msg-link) var(--msg-card-2);
}

#pun-messages #messages.view-dialog .fs-box > .container::-webkit-scrollbar,
#pun-messages #messages.view-search .fs-box > .container::-webkit-scrollbar,
#pun-messages #messages.view-bookmarks .fs-box > .container::-webkit-scrollbar {
  width: 8px;
}

#pun-messages #messages.view-dialog .fs-box > .container::-webkit-scrollbar-track,
#pun-messages #messages.view-search .fs-box > .container::-webkit-scrollbar-track,
#pun-messages #messages.view-bookmarks .fs-box > .container::-webkit-scrollbar-track {
  background: var(--msg-card-2);
  border-radius: 999px;
}

#pun-messages #messages.view-dialog .fs-box > .container::-webkit-scrollbar-thumb,
#pun-messages #messages.view-search .fs-box > .container::-webkit-scrollbar-thumb,
#pun-messages #messages.view-bookmarks .fs-box > .container::-webkit-scrollbar-thumb {
  background: var(--msg-link);
  border-radius: 999px;
}

/* загрузка */

#pun-messages #messages .messenger-loading {
  position: relative;
}

.punbb .view-dialog .fs-box > .container.messenger-loading::before,
.punbb .view-search .fs-box > .container.messenger-loading::after,
.punbb .view-bookmarks .fs-box > .container.messenger-loading::after,
.punbb .dialogs-list .container.messenger-loading tbody::after {
  content: url(/img/loading.gif);
  display: block;
  margin: 14px auto;
  width: 16px;
  height: 16px;
  visibility: visible;
}

/* =========================================================
   СПИСОК ДИАЛОГОВ
========================================================= */

#pun-messages .dialogs-list .fs-box > .container {
  margin: 0 !important;
}

#pun-messages .dialogs-list table,
#pun-messages .dialogs-list tbody {
  display: block;
  width: 100%;
}

#pun-messages .dialogs-list tr.dialog {
  display: block;
  width: 100%;
  margin: 0 0 10px;
  padding: 0 !important;

  border: 0 !important;
  background: transparent !important;
}

#pun-messages .dialogs-list tr.dialog:last-child {
  margin-bottom: 0;
}

#pun-messages .dialog div.icon,
#pun-messages #pun-messages table .dialog .icon {
  display: none !important;
}

#pun-messages .dialog .tcl {
  display: block;
  width: 100% !important;
  padding: 13px 14px !important;

  position: relative;
  cursor: pointer;

  background: var(--msg-card);
  border: 1px solid var(--msg-border) !important;
  border-radius: var(--msg-radius-soft);

  transition:
    background .2s ease,
    border-color .2s ease,
    transform .2s ease,
    box-shadow .2s ease;
}

#pun-messages .dialog .tcl:hover {
  background:
    linear-gradient(135deg, rgba(91, 141, 141, .08), transparent 48%),
    var(--msg-card);
  border-color: rgba(91, 141, 141, .45) !important;
  transform: translateY(-1px);
}

#pun-messages .dialog .intd {
  display: block;
  min-height: 46px;
}

#pun-messages .dialog .tclcon {
  padding-left: 0;
  min-width: 0;
}

#pun-messages .punbb .dialog-avatar,
#pun-messages .dialog-avatar {
  width: 44px;
  height: 44px;
  float: left;
  margin: 0 12px 0 0;
  position: relative;
}

#pun-messages .punbb .dialog-avatar .avatar-image,
#pun-messages .dialog-avatar .avatar-image {
  display: block;
  width: 44px;
  height: 44px;

  background-position: center;
  background-size: cover;
  border-radius: 12px;
  overflow: hidden;
}

#pun-messages .punbb .dialog-avatar .isonline,
#pun-messages .dialog-avatar .isonline {
  right: -1px;
  top: 0;
}

#pun-messages .punbb .dialog-avatar + .tclcon,
#pun-messages .dialog-avatar + .tclcon {
  margin-left: 56px;
}

#pun-messages .dialog .tclcon > a,
#pun-messages .dialog .tclcon h3 a {
  display: inline-flex;
  align-items: center;
  gap: 7px;

  max-width: calc(100% - 116px);

  color: var(--text1) !important;
  font: 500 13px/120% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
  letter-spacing: -0.04em;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#pun-messages .dialog .tclcon > a:hover,
#pun-messages .dialog .tclcon h3 a:hover {
  color: var(--msg-link) !important;
}

#pun-messages .dialog-message {
  display: block;

  max-width: 100%;
  min-height: 1.4em;

  margin: 7px 92px 0 0;
  padding: 0;

  color: var(--text2);
  font: 400 11px/160% var(--font), Arial, sans-serif;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;

  text-indent: 0 !important;
}

#pun-messages .dialog.is-my .dialog-message::before,
#pun-messages .en .dialog.is-my .dialog-message::before {
  content: none !important;
  display: none !important;
}

#pun-messages .dialog-time-ago {
  float: none;
  clear: none;

  position: absolute;
  right: 14px;
  top: 14px;

  margin: 0;
  padding: 4px 8px 5px;

  background: var(--msg-card-2);
  border-radius: 999px;

  color: var(--text4);
  font: 400 9px/100% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
  opacity: 1;
}

#pun-messages .dialog-time-ago a {
  color: inherit !important;
  text-decoration: none !important;
  pointer-events: none;
}

#pun-messages .dialog-unread .dialog-message {
  display: block;

  max-width: calc(100% - 100px);
  margin: 7px 100px 0 0;
  padding: 5px 9px 6px;

  background: rgba(91, 141, 141, .12);
  border-radius: 999px;

  color: var(--text1);
  text-indent: 0 !important;
}

#pun-messages .dialog.inew .tcl {
  background:
    linear-gradient(90deg, rgba(91, 141, 141, .16), transparent 52%),
    var(--msg-card);
  border-color: rgba(91, 141, 141, .65) !important;
}

#pun-messages .dialog.inew .tcl:before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;

  width: 4px;
  border-radius: 0 999px 999px 0;
  background: var(--msg-link);
}

#pun-messages .dialog.inew .tclcon > a,
#pun-messages .dialog.inew .tclcon h3 a {
  font-weight: 700;
  color: var(--msg-link) !important;
}

#pun-messages .dialog.inew .tclcon a::after {
  content: "";
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 9px;
  height: 9px;
  margin-left: 7px;

  background: var(--msg-link);
  border-radius: 50%;
}

#pun-messages .dialog.inew .tclcon a[data-count-unshowed]::after {
  content: attr(data-count-unshowed);

  min-width: 20px;
  width: auto;
  height: 20px;
  padding: 0 7px;
  margin-left: 8px;

  background: var(--msg-link);
  border-radius: 999px;

  color: var(--white);
  font: 600 10px/20px var(--font), Arial, sans-serif;
  text-align: center;
  -webkit-text-fill-color: var(--white);
}

#pun-messages .inew .dialog-time-ago {
  background: var(--msg-link);
  color: var(--white);
}

#pun-messages .dialog .dialog-image {
  vertical-align: middle;
  max-height: 18px;
  border-radius: 4px;
}

#pun-messages .dialog .dialog-delete {
  float: none;
  position: absolute;
  right: 11px;
  bottom: 11px;

  width: 24px;
  height: 24px;
  margin: 0;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: var(--msg-card-2);
  border-radius: 999px;

  color: var(--text4);
  font-size: 0;
  opacity: 0;
  transition: opacity .2s ease, background .2s ease, color .2s ease;
}

#pun-messages .dialog .dialog-delete:before {
  content: "\f2ed";
  font-family: FontAwesome, "Font Awesome 6 Pro", "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 10px;
}

#pun-messages .dialog:hover .dialog-delete {
  opacity: 1;
}

#pun-messages .dialog .dialog-delete:hover {
  background: var(--msg-accent);
  color: var(--white);
  opacity: 1;
}

/* печатает */

#pun-messages .dialog.is-writing .dialog-message {
  display: none;
}

#pun-messages .dialog.is-writing .dialog-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;

  margin-top: 7px;
  padding: 5px 9px 6px;

  background: var(--msg-card-2);
  border-radius: 999px;

  color: var(--text4);
  font: 400 10px/120% var(--font), Arial, sans-serif;
  opacity: 1;
}

#pun-messages .dialog.is-writing .dialog-status::before {
  content: "печатает";
}

#pun-messages .en .dialog.is-writing .dialog-status::before {
  content: "writing";
}

#pun-messages .dialog.is-writing .dialog-status::after {
  content: "...";
  animation: messenger_writing 1s linear infinite;
}

/* =========================================================
   СО ТИ ОВКА ДИАЛОГОВ
========================================================= */

#messages #dialogs-sort-dir {
  display: flex;
  align-items: center;
  gap: 5px;

  position: relative;
  width: fit-content;
  margin: 0 0 12px auto;
  padding: 6px 11px 7px;

  background: var(--cover);
  border: 1px solid var(--msg-border);
  border-radius: 999px;

  color: var(--text4);
  font: 400 10px/100% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
}

#messages #dialogs-sort-dir:before {
  content: "\f0dc";
  color: var(--msg-link);
  font-family: FontAwesome, "Font Awesome 6 Pro", "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 9px;
}

#messages[data-dir="desc"] #dialogs-sort-dir a[data-dir="asc"],
#messages[data-dir="asc"] #dialogs-sort-dir a[data-dir="desc"] {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 5;

  width: max-content;
  margin-top: 4px;
  padding: 6px 9px;

  background: var(--msg-dark);
  color: var(--text3) !important;
  border-radius: 999px;
}

#messages[data-dir="desc"] #dialogs-sort-dir:hover a[data-dir="asc"],
#messages[data-dir="asc"] #dialogs-sort-dir:hover a[data-dir="desc"] {
  display: block;
}

/* =========================================================
   ШАПКА СОБЕСЕДНИКА ВНУТ И ДИАЛОГА
========================================================= */

#messages #user-info {
  float: none;
  clear: both;

  min-height: 46px;
  margin: 0 0 12px;
  padding: 10px 12px !important;

  position: sticky;
  top: 0;
  z-index: 20;

  background:
    linear-gradient(135deg, rgba(34, 34, 34, .96), rgba(34, 34, 34, .86)),
    var(--bg-noise) repeat top left / auto;
  background-blend-mode: normal, overlay;

  border: 0 !important;
  border-radius: var(--msg-radius-soft);

  color: var(--text3);
  line-height: normal;
}

#messages #user-info:after {
  content: "";
  display: block;
  clear: both;
}

#messages #user-info .user-info-content {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 30px;
  max-width: calc(100% - 170px);
}

#messages #user-info .user-info-username {
  display: inline-block;

  color: var(--text3);
  font: 500 14px/120% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
  letter-spacing: -0.04em;
}

#messages #user-info .user-info-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;

  margin-left: 0;
  padding: 4px 8px 5px;

  background: rgba(232, 223, 217, .1);
  border-radius: 999px;

  color: var(--text3);
  font: 400 9px/100% var(--font2), Arial, sans-serif;
  opacity: .8;
}

#messages #user-info .user-info-status:before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--msg-link);
}

#messages #user-info .user-info-actions {
  float: right;
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;

  max-width: 165px;
}

#messages #user-info .user-info-actions a {
  margin-left: 0;
  padding: 6px 9px;

  background: rgba(232, 223, 217, .1);
  border-radius: 999px;

  color: var(--text3) !important;
  font: 400 9px/100% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
}

#messages #user-info .user-info-actions a:hover {
  background: var(--msg-link);
  color: var(--white) !important;
}

#messages #user-info .user-info-multicheck {
  display: none;
  color: var(--text3);
  font: 500 12px/120% var(--font2), Arial, sans-serif;
  text-transform: lowercase;
}

#messages #user-info .user-info-multicheck::after {
  content: attr(data-count);
  margin-left: 6px;
  color: var(--msg-link);
}

#messages .multi-checked #user-info .user-info-multicheck {
  display: inline-block;
}

#messages .multi-checked #user-info .user-info-content {
  display: none;
}

#messages .multi-checked #user-info #user-action-search,
#messages .multi-checked #user-info #user-action-delete {
  display: none;
}

#messages .fs-box:not(.multi-checked) #user-info #user-action-multidelete,
#messages .fs-box:not(.multi-checked) #user-info #user-action-uncheck {
  display: none;
}

/* статус печати в диалоге */

#messages #user-status {
  margin: -4px 0 10px;
  padding: 0 12px;
}

#messages #user-status .user-status-text {
  color: var(--text4);
  font: 400 10px/140% var(--font), Arial, sans-serif;
  opacity: 1;
}

#messages #user-status .user-status-text::before {
  content: "\200B";
}

#messages #user-status.is-writing .user-status-text::before {
  content: attr(data-username) " печатает";
}

.en #messages #user-status.is-writing .user-status-text::before {
  content: attr(data-username) " is writing";
}

#messages #user-status.is-writing .user-status-text::after {
  content: "...";
  animation: messenger_writing 1s linear infinite;
}

/* =========================================================
   СООБЩЕНИЯ ВНУТ И ДИАЛОГА
========================================================= */

#pun-messages #messages.view-dialog .post,
#pun-messages #messages.view-search .post,
#pun-messages #messages.view-bookmarks .post {
  margin: 0 0 10px !important;
  padding: 12px !important;

  position: relative;

  background: var(--msg-bg);
  border: 1px solid var(--msg-border) !important;
  border-radius: var(--msg-radius-soft);
}

#pun-messages #messages.view-dialog .post:last-child,
#pun-messages #messages.view-search .post:last-child,
#pun-messages #messages.view-bookmarks .post:last-child {
  margin-bottom: 0 !important;
}

.punbb #messages.view-dialog .post.post-selected {
  background:
    linear-gradient(135deg, rgba(135, 73, 19, .13), transparent 45%),
    var(--msg-bg);
  border-color: rgba(135, 73, 19, .5) !important;
}

.punbb #messages.view-dialog .post.post-selected > * {
  opacity: .9;
}

.punbb #messages .post.post-new,
.punbb #messages .post.post-unread {
  border-color: rgba(91, 141, 141, .65) !important;
}

.punbb #messages .post.post-new:before,
.punbb #messages .post.post-unread:before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;

  width: 4px;
  border-radius: 0 999px 999px 0;
  background: var(--msg-link);
}

.punbb .formal #messages .post .container {
  margin: 0 !important;
  padding: 0 !important;
}

.punbb .view-dialog .fs-box > .container,
.punbb .view-search .fs-box > .container,
.punbb .view-bookmarks .fs-box > .container,
.punbb .formal #messages .post .post-box {
  border: 0 !important;
  margin: 0 !important;
  padding-bottom: 0 !important;
}

/* убираем тяжёлую форумную шапку поста и чёрную плашку у мета */

#pun-messages #messages .post > h3 {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;

  min-height: 18px;
  margin: 0 0 7px !important;
  padding: 0 !important;

  background: none !important;
  background-image: none !important;
  border: 0 !important;
  border-top: 0 !important;
  box-shadow: none !important;

  color: var(--text4);
  font: 400 9px/120% var(--font2), Arial, sans-serif !important;
  text-transform: lowercase;
}

#pun-messages #messages .post > h3:before,
#pun-messages #messages .post > h3:after,
#pun-messages #messages .post > h3 span:before,
#pun-messages #messages .post > h3 span:after {
  display: none !important;
  content: none !important;
}

#pun-messages #messages .post > h3 span {
  display: inline-flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;

  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;

  background: none !important;
  background-image: none !important;
  border: 0 !important;
  border-top: 0 !important;
  box-shadow: none !important;

  color: var(--text4) !important;
}

#pun-messages #messages .post h3 span a,
#pun-messages #messages .post h3 span em,
#pun-messages #messages .post h3 span strong {
  background: none !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--text4) !important;
  font: inherit !important;
}

#pun-messages #messages .post h3 span a:hover {
  color: var(--msg-link) !important;
}

.punbb .view-dialog .post.post-unread h3 span::after {
  content: "не прочитано";

  display: inline-flex;
  align-items: center;

  float: none;
  margin-left: 8px;
  padding: 4px 7px;

  background: var(--msg-link);
  border-radius: 999px;

  color: var(--white);
  font: 400 8px/100% var(--font2), Arial, sans-serif;
  opacity: 1;
}

.en .punbb .view-dialog .post.post-unread h3 span::after {
  content: "not read";
}

/* компактный автор сообщения: только имя, без аватара */

#pun-messages #messages.view-dialog .post .post-author,
#pun-messages #messages.view-search .post .post-author,
#pun-messages #messages.view-bookmarks .post .post-author {
  width: auto !important;
  min-height: 0 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: var(--text1);
}

#pun-messages #messages.view-dialog .post .post-author > ul,
#pun-messages #messages.view-search .post .post-author > ul,
#pun-messages #messages.view-bookmarks .post .post-author > ul {
  display: block !important;

  width: 100%;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;

  color: var(--text1);
  text-align: left !important;
}

/* скрываем всё из мини-профиля внутри сообщения */
#pun-messages #messages .post .post-author li {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* возвращаем только имя отправителя */
#pun-messages #messages .post .post-author li.pa-author,
#pun-messages #messages .post .pa-author {
  display: inline-flex !important;
  align-items: center !important;

  max-width: 100%;
  margin: 0 !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;

  color: var(--text1);
  font: 500 12px/130% var(--font2), Arial, sans-serif !important;
  text-transform: lowercase;
  letter-spacing: -0.04em;
}

#pun-messages #messages .post .pa-author:before,
#pun-messages #messages .post .pa-author:after {
  display: none !important;
  content: none !important;
}

#pun-messages #messages .post .pa-author a {
  color: var(--text1) !important;
  border: 0 !important;
  text-decoration: none !important;
}

#pun-messages #messages .post .pa-author a:hover {
  color: var(--msg-link) !important;
}

/* текст сообщения идёт с новой строки после имени */
#pun-messages #messages .post .post-body,
#pun-messages #messages .post .post-box,
#pun-messages #messages .post .post-content {
  clear: both;
}

/* тело сообщения */

#pun-messages #messages .post .post-body {
  margin: 0 !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;
}

#pun-messages #messages .post .post-box {
  margin: 0 !important;
  padding: 0 !important;

  background: transparent !important;
  border: 0 !important;

  color: var(--text2);
  font: 400 12px/165% var(--font), Arial, sans-serif;
  text-align: left;
}

#pun-messages #messages .post .post-content {
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible;
}

#pun-messages #messages .post .post-content p {
  margin: 0 0 10px !important;
  padding: 0 !important;
  color: var(--text2);
  font: 400 12px/165% var(--font), Arial, sans-serif;
}

#pun-messages #messages .post .post-content p:last-child {
  margin-bottom: 0 !important;
}

/* цитаты внутри сообщений */

#messages .post .quote-box.answer-box {
  cursor: pointer;
}

#messages .post .quote-box.answer-box,
#messages .post .quote-box.answer-box blockquote {
  position: relative;
  overflow-y: hidden;
}

#messages .post .quote-box.answer-box blockquote {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;

  max-width: 100%;
  max-height: 1.6em;

  text-overflow: ellipsis;
}

#messages .post .quote-box.answer-box blockquote.blockquote-toggle,
#messages .post .quote-box .quote-box.answer-box blockquote {
  display: block;
}

#messages .post .quote-box .quote-box.answer-box blockquote {
  max-height: unset;
}

#messages .post .quote-box.answer-box blockquote:not(.blockquote-toggle)::after {
  content: "";
  width: 100%;
  height: 1.6em;

  position: absolute;
  display: block;
  left: 0;
  bottom: 0;

  background: linear-gradient(to bottom, transparent 0%, var(--cover) 82%, var(--cover) 100%);
}

#messages .post .quote-box .quote-box blockquote::after {
  content: unset !important;
}

#messages .post-checker {
  vertical-align: middle;
}

/* =========================================================
   ИКОНКА ЗАКЛАДКИ
========================================================= */

#pun-messages .post h3 .bookmarklink {
  visibility: hidden;
  float: none;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 22px;
  height: 22px;
  margin: 0 0 0 5px;

  background: var(--msg-card-2);
  border-radius: 999px;

  color: var(--text4);
  font-size: 10px;
  -webkit-text-stroke: 0;
  text-stroke: 0;
}

#pun-messages .post:not(.post-bookmark) h3 .bookmarklink i {
  -webkit-text-fill-color: transparent;
  text-fill-color: transparent;
  -webkit-text-stroke: 1px currentColor;
}

#pun-messages .post:hover h3 .bookmarklink,
#pun-messages .post.post-bookmark h3 .bookmarklink {
  display: inline-flex;
  visibility: visible;
}

#pun-messages .post h3 .bookmarklink:hover {
  background: var(--msg-link);
  color: var(--white);
  opacity: 1;
}

@media (hover: none) {
  #pun-messages .post h3 .bookmarklink {
    display: inline-flex;
    visibility: visible;
  }
}

/* =========================================================
   ФО МА ОТВЕТА
========================================================= */

#pun-messages .view-dialog #post-form {
  margin-top: 12px !important;
  padding: 14px !important;

  background: var(--msg-card);
  border: 1px solid var(--msg-border);
  border-radius: var(--msg-radius-main);
}

#pun-messages .view-dialog #main-reply[rows],
#pun-messages .view-dialog #main-reply[rows] ~ #wysi-reply {
  height: 118px;
  min-height: 118px;

  background: var(--msg-card-2) !important;
  border: 1px solid var(--msg-border) !important;
  border-radius: var(--msg-radius-soft) !important;

  color: var(--text1);
  font: 400 12px/160% var(--font), Arial, sans-serif !important;
}

#pun-messages .view-dialog #post-form .fs-box + p,
#pun-messages .view-dialog .areafield {
  padding-bottom: unset !important;
}

#pun-messages .view-dialog #post-form .fs-box + p {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;

  margin: 10px 0 0 !important;
}

#pun-messages .view-dialog #post-form .fs-box + p span {
  float: unset !important;
}

#pun-messages .view-dialog #post-form .fs-box + p .checkfield {
  display: none;
}

#pun-messages .view-dialog #post-form .fs-box + p.messenger-loading::after {
  content: url(/img/loading.gif);
  margin-left: 1em;
}

#pun-messages .view-dialog #post-preview {
  margin-top: 1em;
}

/* подсказки отправки */

#messages[data-send-mode] .fs-box + p::after {
  margin-left: auto;
  float: none;

  color: var(--text4);
  font: 400 9px/140% var(--font2), Arial, sans-serif;
  text-align: right;
  text-transform: lowercase;
  opacity: 1;
  white-space: pre;
}

#messages[data-send-mode="1"] .fs-box + p::after {
  content: "ctrl + enter — отправка";
}

.en #messages[data-send-mode="1"] .fs-box + p::after {
  content: "ctrl + enter — send";
}

#messages[data-send-mode="2"] .fs-box + p::after {
  content: "enter — отправка \A shift + enter — новая строка";
}

.en #messages[data-send-mode="2"] .fs-box + p::after {
  content: "enter — send \A shift + enter — new line";
}

/* =========================================================
   ПОИСК
========================================================= */

#messages #search-keywords {
  width: 100%;
  max-width: 100% !important;

  padding: 10px 13px !important;

  background: var(--msg-card-2);
  border: 1px solid var(--msg-border) !important;
  border-radius: 999px;

  color: var(--text1);
  font: 400 12px/120% var(--font), Arial, sans-serif !important;
  box-sizing: border-box;
}

#messages #search-keywords:focus {
  outline: none !important;
  border-color: rgba(91, 141, 141, .65) !important;
}

#messages #search-submit {
  display: none;
}

/* таблица пользователей в поиске */

#messenger-usertable {
  width: 100%;
}

#messenger-usertable table,
#messenger-usertable tbody,
#messenger-usertable tr {
  display: block;
  width: 100%;
}

#messenger-usertable .messenger-user-item {
  display: block;

  height: auto;
  min-height: 52px;
  padding: 0 !important;
  margin: 0 0 8px;

  cursor: pointer;
  line-height: normal;

  background: var(--msg-card);
  border: 1px solid var(--msg-border) !important;
  border-radius: var(--msg-radius-soft);

  overflow: hidden;
}

#messenger-usertable tbody tr:first-child > .messenger-user-item,
#messenger-usertable tbody tr:last-child > .messenger-user-item {
  border-top: 1px solid var(--msg-border) !important;
  border-bottom: 1px solid var(--msg-border) !important;
}

#messenger-usertable .messenger-user-item div {
  min-height: 52px;
  padding: 8px 12px !important;
}

#messenger-usertable .messenger-user-item:hover div {
  background: rgba(91, 141, 141, .08);
}

#messenger-usertable .messenger-user-avatar {
  display: inline-block;
  width: 36px;
  height: 36px;

  margin: 0 10px 0 0;
  float: left;

  background-position: center;
  background-size: cover;
  border-radius: 10px;
}

#messenger-usertable .messenger-user-username {
  display: inline-block;
  padding-left: 0;
  line-height: 36px;

  color: var(--text1);
  font: 500 12px/36px var(--font2), Arial, sans-serif;
  text-transform: lowercase;
  letter-spacing: -0.04em;
}

/* =========================================================
   УДАЛЕНИЕ / П ОЧЕЕ
========================================================= */

.delete_confirm .checkfield {
  margin-top: .5em;
}

#default-mode-check #fld-default_mode {
  vertical-align: middle;
}

#__MESSENGER_FOCUS_ANCHOR__ {
  display: block !important;
  font-size: 0;
  height: 0;
  width: 0;
  line-height: 0;
  position: absolute;
  left: -9999px;
  overflow: hidden;
}

link[rel="stylesheet"][href*="/messenger."]::before {
  content: "1.0.7";
  display: none;
}

/* =========================================================
   АНИМАЦИЯ ПЕЧАТИ
========================================================= */

@keyframes messenger_writing {
  0% {
    content: "";
  }

  30% {
    content: ".";
  }

  60% {
    content: "..";
  }

  90% {
    content: "...";
  }
}

@-moz-keyframes messenger_writing {
  0% {
    content: "";
  }

  30% {
    content: ".";
  }

  60% {
    content: "..";
  }

  90% {
    content: "...";
  }
}

@-webkit-keyframes messenger_writing {
  0% {
    content: "";
  }

  30% {
    content: ".";
  }

  60% {
    content: "..";
  }

  90% {
    content: "...";
  }
}

/* =========================================================
   МОБИЛЬНАЯ АДАПТАЦИЯ
========================================================= */

@media screen and (hover: none) {
  #pun-messages .dialog .dialog-delete {
    opacity: 1;
  }

  #pun-messages .view-dialog #post-form .fs-box + p {
    text-align: right;
  }
}

@media screen and (max-width: 760px) {
  #pun-messages #messages.view-dialog .fs-box > .container,
  #pun-messages #messages.view-search .fs-box > .container,
  #pun-messages #messages.view-bookmarks .fs-box > .container {
    max-height: 62vh;
    padding: 10px !important;
    border-radius: 15px;
  }

  #pun-messages .dialog .tcl {
    padding: 12px !important;
  }

  #messages #user-info {
    position: relative;
    top: auto;
  }
}

@media screen and (max-width: 540px) {
  #pun-messages table .dialog .icon {
    display: none !important;
  }

  #pun-messages table .dialog .tclcon {
    margin-left: 52px !important;
  }

  #pun-messages .punbb .dialog-avatar,
  #pun-messages .dialog-avatar {
    width: 40px;
    height: 40px;
    margin-right: 10px;
  }

  #pun-messages .punbb .dialog-avatar .avatar-image,
  #pun-messages .dialog-avatar .avatar-image {
    width: 40px;
    height: 40px;
  }

  #pun-messages .dialog .tclcon > a,
  #pun-messages .dialog .tclcon h3 a {
    max-width: calc(100% - 86px);
    font-size: 12px;
  }

  #pun-messages .dialog-message {
    margin: 7px 0 0 0;
    font-size: 10px;
  }

  #pun-messages .dialog-unread .dialog-message {
    max-width: 100%;
    margin: 7px 0 0 0;
  }

  #pun-messages .dialog-time-ago {
    right: 12px;
    top: 12px;
    font-size: 8px;
  }

  #messages #user-info .user-info-content {
    width: calc(100% - 74px);
    max-width: calc(100% - 74px);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  #messages #user-info .user-info-username {
    display: block;
    font-size: 13px;
    line-height: 1.1;
    margin: 0;
  }

  #messages #user-info .user-info-status {
    margin: 0;
    line-height: 1;
  }

  #messages #user-info .user-info-actions {
    max-width: 70px;
    gap: 4px;
  }

  #messages #user-info .user-info-actions a {
    padding: 6px 7px;
    font-size: 0;
  }

  #messages #user-info .user-info-actions a:before {
    font-family: FontAwesome, "Font Awesome 6 Pro", "Font Awesome 6 Free";
    font-weight: 900;
    font-size: 10px;
  }

  #messages #user-info #user-action-search:before {
    content: "\f002";
  }

  #messages #user-info #user-action-delete:before {
    content: "\f2ed";
  }

  #messages #user-info #user-action-multidelete:before {
    content: "\f00c";
  }

  #messages #user-info #user-action-uncheck:before {
    content: "\f00d";
  }

  #pun-messages .view-dialog #main-reply[rows],
  #pun-messages .view-dialog #main-reply[rows] ~ #wysi-reply {
    height: 86px;
    min-height: 86px;
  }

  #messages[data-send-mode] .fs-box + p::after {
    width: 100%;
    margin-left: 0;
    text-align: left;
  }

  #pun-messages #messages.view-dialog .post,
  #pun-messages #messages.view-search .post,
  #pun-messages #messages.view-bookmarks .post {
    padding: 10px !important;
  }

  .punbb .view-dialog .post.post-unread h3 span::after {
    font-size: 0;
    width: 8px;
    height: 8px;
    padding: 0;
    margin-left: 5px;
    border-radius: 50%;
  }

  #pun-messages .view-dialog .user-avatar,
  #pun-messages .dialog .user-avatar {
    margin: 1px 9px 1px 0;
    float: left;
  }
}

/* =========================================================
   ФИНАЛЬНЫЙ СБ ОС ДЛЯ СООБЩЕНИЙ
   страховка от базового стиля форума
========================================================= */

#pun-messages #messages.view-dialog .post .pa-avatar,
#pun-messages #messages.view-search .post .pa-avatar,
#pun-messages #messages.view-bookmarks .post .pa-avatar,
#pun-messages #messages.view-dialog .post .pa-avatar img,
#pun-messages #messages.view-search .post .pa-avatar img,
#pun-messages #messages.view-bookmarks .post .pa-avatar img {
  display: none !important;
}

#pun-messages #messages.view-dialog .post > h3,
#pun-messages #messages.view-search .post > h3,
#pun-messages #messages.view-bookmarks .post > h3,
#pun-messages #messages.view-dialog .post > h3 span,
#pun-messages #messages.view-search .post > h3 span,
#pun-messages #messages.view-bookmarks .post > h3 span {
  background: none !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
}
