chat-message {
  display: block;
  overflow-anchor: none;
}

.chat-message-directive {
  display: flex;
  flex: 1;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  overflow-anchor: none;
}

.chat-message-directive.message-type-audio, .chat-message-directive.message-type-voice {
  min-height: 108px;
}

.chat-message-directive.message-type-image, .chat-message-directive.message-type-video, .chat-message-directive.message-type-media {
  min-height: 198px;
}

.chat-message-directive.is-event-message {
  justify-content: center;
}

.chat-message-directive.self {
  justify-content: flex-end;
}

.chat-message-directive.is-deleted-message {
  min-height: auto;
}

.chat-message-directive .chat-message {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  border-top-left-radius: 2px;
  border-top-right-radius: 12px;
  background: rgba(var(--background-content));
  padding: 8px;
  font-size: 12pt;
  display: flex;
  margin: 8px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
  flex-direction: column;
  min-width: 160px;
  box-sizing: border-box;
  user-select: auto !important;
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  height: 100%;
}

.chat-message-directive .chat-message a {
  color: rgba(var(--primary-color));
  cursor: pointer;
}

.chat-message-directive.message-type-skeleton .chat-message {
  min-height: 75px;
}

.chat-message-directive.message-type-skeleton .chat-message .chat-message-skeleton {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
}

.chat-message-directive.message-type-skeleton .chat-message .chat-message-skeleton .chat-message-skeleton-bar {
  width: 100%;
  height: 18px;
  margin-bottom: 2px;
  background-color: rgba(var(--color-alpha-grey));
  border-radius: 2px;
  animation: animate-bars 2.1s infinite alternate;
}

.chat-message-directive.message-type-skeleton .chat-message .chat-message-skeleton .chat-message-skeleton-bar:last-child {
  width: 75%;
  margin-bottom: 0;
}

.chat-message-directive.self .chat-message {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  border-top-left-radius: 12px;
  border-top-right-radius: 2px;
}

.chat-message-directive.is-event-message .chat-message {
  border-radius: 12px;
}

.chat-message-directive .chat-message:hover .chat-message-header .chat-message-menu {
  opacity: 1;
}

.chat-message-directive .chat-message .chat-message-header {
  display: flex;
  flex: 1;
  justify-content: flex-start;
  align-items: center;
  padding-bottom: 4px;
  position: relative;
}

.chat-message-directive .chat-message .chat-message-header .chat-message-menu {
  opacity: 0;
  position: absolute;
  top: -4px;
  right: -4px;
  z-index: 1;
  transition: opacity 420ms ease;
}

.chat-message-directive .chat-message .chat-message-header .chat-message-menu .md-button.md-icon-button {
  background-color: rgba(var(--background-content));
  width: 24px;
  height: 24px;
  min-height: 24px;
  min-width: 24px;
  padding: 0;
  margin: 0;
}

.chat-message-directive.self .chat-message .chat-message-header .chat-message-who {
  flex: 1;
  font-size: 12pt;
  font-weight: bold;
}

.chat-message-directive .chat-message .chat-message-header .chat-message-who .message-is-forwarded {
  width: 14px;
  height: 14px;
  min-width: 14px;
  min-height: 14px;
  margin-right: 4px;
}

.chat-message-directive .chat-message .chat-message-header .chat-message-who .message-is-forwarded-text {
  font-weight: lighter;
  font-style: italic;
  font-size: 10pt;
}

.chat-message-directive .chat-message .chat-message-header .chat-message-who {
  font-weight: bold;
}

.chat-message-directive .chat-message .chat-message-attachments {
  display: inline-grid;
  grid-template-columns: auto auto;
  /* TODO: change grid-template-columns on large/small devices */
  column-gap: 4px;
  row-gap: 4px;
  overflow: hidden;
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment .chat-message-attachment-thumbnail {
  position: relative;
  width: 100%;
  height: 100%;
  max-width: 144px;
  max-height: 144px;
  min-width: 144px;
  min-height: 144px;
  overflow: hidden;
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment .chat-message-attachment-thumbnail md-icon {
  position: absolute;
  bottom: 8px;
  right: 8px;
  pointer-events: none;
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment .chat-message-attachment-thumbnail .chat-message-attachment-info {
  position: absolute;
  bottom: 8px;
  right: 8px;
  pointer-events: none;
  font-size: 10pt;
  overflow: hidden;
  word-break: break-word;
  text-align: right;
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment audio {
  outline: none;
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment img {
  cursor: pointer;
  user-select: none;
  width: 100%;
  height: 100%;
  max-width: 144px;
  /* max-height: 144px; */
  min-width: 90px;
  min-height: 90px;
  outline: none;
  transition: filter 420ms ease;
  flex: 1 0 calc(50% - 8px);
}

.chat-message-directive .chat-message .chat-message-attachments .chat-message-attachment img:hover {
  filter: brightness(1.1);
}

.chat-message-directive .chat-message .chat-message-content {
  word-wrap: break-word;
  word-break: break-word;
  white-space: pre-wrap;
  padding-bottom: 4px;
}

.chat-message-directive .chat-message .chat-message-content.is-deleted-message {
  font-style: italic;
  color: rgba(var(--color-alpha-black));
  font-size: 10pt;
}

.chat-message-directive.is-event-message .chat-message .chat-message-content {
  font-size: 10pt;
}

.chat-message-directive .chat-message .chat-message-info {
  display: flex;
  flex: 1;
  justify-content: flex-end;
  align-items: center;
  font-size: 9pt;
  color: rgba(var(--color-alpha-grey));
}

.chat-message-directive.message-type-skeleton .chat-message .chat-message-info {
  display: none;
}

.chat-message-directive .chat-message .chat-message-info span {
  text-align: right;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons {
  width: 20px;
  height: 16px;
  position: relative;
  display: none;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons.is-read md-icon {
  color: rgba(var(--color-success));
}

.chat-message-directive.self .chat-message .chat-message-info .chat-message-info-icons {
  display: flex;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons md-icon {
  height: 12px;
  width: 12px;
  min-height: 12px;
  min-width: 12px;
  position: absolute;
  top: 2px;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons md-icon.server-received {
  right: 1px;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons md-icon.client-received {
  left: 1px;
}

.chat-message-directive .chat-message .chat-message-info .chat-message-info-icons md-icon.server-not-received {
  height: 18px;
  width: 18px;
}

@keyframes animate-bars {
  from {
    background-color: rgba(var(--color-alpha-grey));
  }
  to {
    background-color: rgba(var(--color-alpha-black));
  }
}