// Copyright 2018-2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only

// Using BEM syntax explained here: https://csswizardry.com/2013/01/mindbemding-getting-your-head-round-bem-syntax/

// CAUTION: these styles are often overridden by other components
// if you make changes to these, you must check EVERY component that uses <Modal.../>

.module-title-bar-drag-area {
  -webkit-app-region: drag;
  height: var(--title-bar-drag-area-height);
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: $z-index-on-top-of-everything;
}

.module-splash-screen {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.module-splash-screen__logo {
  @include color-svg('../images/signal-logo.svg', $color-white);
  margin: 24px auto;

  &.module-img--256 {
    height: 256px;
    width: 256px;
  }

  &.module-img--200 {
    height: 200px;
    width: 200px;
  }

  &.module-img--150 {
    height: 150px;
    width: 150px;
  }

  &.module-img--128 {
    height: 128px;
    width: 128px;
  }

  &.module-logo-blue {
    background-color: $color-ultramarine-icon;
  }
}

// Module: Message

.module-message {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  outline: none;
  padding-left: 16px;
  padding-right: 16px;
  transition: background 0.1s ease-out;
}

.module-message__quote-story-reaction-header {
  @include font-subtitle;
  margin-bottom: 6px;

  .module-message__container-outgoing & {
    color: $color-white-alpha-80;
  }

  .module-message__container-incoming & {
    color: $color-gray-60;
  }
}

.module-message--expired {
  animation: module-message__shake 0.2s linear infinite;
}

@keyframes module-message__shake {
  0% {
    transform: translateX(0px);
  }
  25% {
    transform: translateX(-5px);
  }
  50% {
    transform: translateX(0px);
  }
  75% {
    transform: translateX(5px);
  }
  100% {
    transform: translateX(0px);
  }
}

@keyframes module-message__highlight {
  0% {
    filter: none;
  }
  33% {
    filter: brightness(50%);
  }
  66% {
    filter: brightness(50%);
  }
  100% {
    filter: none;
  }
}

@keyframes module-message__highlight-lighter {
  0% {
    filter: none;
  }
  33% {
    filter: brightness(76%);
  }
  66% {
    filter: brightness(76%);
  }
  100% {
    filter: none;
  }
}

.module-message--outgoing {
  flex-direction: row-reverse;
}

.module-message__buttons {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  opacity: 0;
}

.module-message:hover .module-message__buttons {
  opacity: 1;
}

.module-message__buttons--incoming {
  padding-left: 8px;

  & > * {
    margin-left: 12px;
    &:first-child {
      margin-left: 0;
    }
  }
}

.module-message__buttons--outgoing {
  padding-right: 8px;
  flex-direction: row-reverse;

  & > * {
    margin-right: 12px;
    &:first-child {
      margin-right: 0;
    }
  }
}

@mixin module-message__buttons__button($light-icon, $dark-icon: $light-icon) {
  cursor: pointer;
  height: 24px;
  width: 24px;

  @include light-theme {
    @include color-svg($light-icon, $color-gray-45);
    &:hover {
      @include color-svg($light-icon, $color-gray-90);
    }
  }

  @include dark-theme {
    @include color-svg($dark-icon, $color-gray-45);
    &:hover {
      @include color-svg($dark-icon, $color-gray-02);
    }
  }

  .module-message--selected & {
    @include mouse-mode {
      background-color: $color-gray-60;
    }
    @include dark-mouse-mode {
      background-color: $color-white;
    }
  }

  .module-message:focus & {
    @include keyboard-mode {
      background-color: $color-gray-60;
    }
    @include dark-keyboard-mode {
      background-color: $color-white;
    }
  }
}

.module-message__buttons__download {
  @include module-message__buttons__button(
    '../images/icons/v2/save-outline-24.svg',
    '../images/icons/v2/save-solid-24.svg'
  );
}

.module-message__buttons__react {
  @include module-message__buttons__button(
    '../images/icons/v2/add-emoji-outline-24.svg'
  );
}

.module-message__buttons__reply {
  @include module-message__buttons__button(
    '../images/icons/v2/reply-outline-24.svg',
    '../images/icons/v2/reply-solid-24.svg'
  );
}

.module-message__buttons__menu {
  @include module-message__buttons__button(
    '../images/icons/v2/more-horiz-24.svg'
  );

  &--container {
    border-radius: 4px;
    height: 24px;
    // the z-index here is so that this container is above the message and when
    // clicked on, doesn't propagate the click event to the message.
    z-index: $z-index-above-base;
  }
}

.module-message__error-container {
  min-width: 28px;
  position: relative;
}

.module-message__error {
  width: 20px;
  height: 20px;
  display: inline-block;
  position: absolute;
  bottom: 4px;

  @include light-theme {
    @include color-svg(
      '../images/icons/v2/error-outline-24.svg',
      $color-accent-red
    );
  }
  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/error-solid-24.svg',
      $color-accent-red
    );
  }
}
.module-message__error--paused {
  @include light-theme {
    @include color-svg(
      '../images/icons/v2/error-outline-24.svg',
      $color-gray-60
    );
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/error-solid-24.svg', $color-gray-45);
  }
}

.module-message__error--outgoing {
  left: 8px;
}

.module-message__error--incoming {
  right: 8px;
}

.module-message__container-outer {
  line-height: 0;
  display: flex;
  flex-direction: column;
  min-width: 0;
  max-width: 306px;

  .module-timeline--width-wide &,
  .module-message-detail & {
    // NOTE(evanhahn): I wanted this to be 66% of the timeline, but I could not make that
    //   work without introducing layout bugs for some message types. This constant,
    //   though not ideal, fixes those bugs.
    max-width: 50vw;
  }

  .module-timeline--width-medium & {
    max-width: 370px;
  }
}

$message-padding-vertical: 8px;
$message-padding-horizontal: 12px;

.module-message__container {
  $collapsed-border-radius: 4px;

  position: relative;
  display: inline-block;
  border-radius: 18px;
  margin-bottom: 6px;
  margin-top: 6px;
  min-width: 0px;
  overflow: hidden;

  padding: {
    left: $message-padding-horizontal;
    right: $message-padding-horizontal;
    top: $message-padding-vertical;
    bottom: $message-padding-vertical;
  }

  .module-message--collapsed-above & {
    margin-top: 1px;
  }
  .module-message--collapsed-below & {
    margin-bottom: 1px;
  }

  .module-message--incoming.module-message--collapsed-above & {
    border-top-left-radius: $collapsed-border-radius;
  }
  .module-message--incoming.module-message--collapsed-below & {
    border-bottom-left-radius: $collapsed-border-radius;
  }
  .module-message--outgoing.module-message--collapsed-above & {
    border-top-right-radius: $collapsed-border-radius;
  }
  .module-message--outgoing.module-message--collapsed-below & {
    border-bottom-right-radius: $collapsed-border-radius;
  }
}

.module-message__container--selected {
  @include mouse-mode {
    animation: module-message__highlight 1.2s cubic-bezier(0.17, 0.17, 0, 1);
  }
}
.module-message__container--selected-lighter {
  @include mouse-mode {
    animation: module-message__highlight-lighter 1.2s
      cubic-bezier(0.17, 0.17, 0, 1);
  }
}

.module-message:focus-within {
  @include keyboard-mode {
    background: $color-selected-message-background-light;
  }
  @include dark-keyboard-mode {
    background: $color-selected-message-background-dark;
  }
}

.module-message__container--emoji {
  padding-top: 4px;

  .module-message__text--outgoing {
    text-align: right;
  }
}

.module-message__container--outgoing {
  @include light-theme {
    background-color: $color-ultramarine;
    color: $color-white;
  }
  @include dark-theme {
    background-color: $color-ultramarine;
    color: $color-gray-05;
  }
}

// In case the color gets messed up
.module-message__container--incoming {
  background-color: $color-gray-05;
  color: $color-gray-90;

  @include dark-theme {
    background-color: $color-gray-75;
    color: $color-gray-05;
  }
}

@each $color, $value in $conversation-colors {
  .module-message__container--outgoing-#{$color} {
    background-color: $value;

    @include dark-theme {
      background-color: $value;
    }
  }
}

.module-message__container--outgoing-custom {
  background-attachment: fixed;
}

@each $color, $value in $conversation-colors-gradient {
  .module-message__container--outgoing-#{$color} {
    background-attachment: fixed;
    background-image: linear-gradient(
      map-get($value, 'deg'),
      map-get($value, 'start'),
      map-get($value, 'end')
    );
  }
}

.module-message__container--with-tap-to-view {
  min-width: 148px;
  cursor: pointer;
  user-select: none;
}

.module-message__container--with-tap-to-view-pending {
  background-color: $color-gray-15;
}

.module-message__container--with-tap-to-view-pending {
  cursor: default;
}

.module-message__container--with-tap-to-view-expired {
  @include light-theme {
    border: 1px solid $color-gray-15;
    background-color: $color-white;
  }
  @include dark-theme {
    border: 1px solid $color-gray-60;
    background-color: $color-gray-95;
  }
}

.module-message__container--with-tap-to-view-error {
  width: auto;
  cursor: default;

  @include light-theme {
    background-color: $color-white;
    border: 1px solid $color-deep-red;
  }
  @include dark-theme {
    background-color: $color-black;
    border: 1px solid $color-deep-red;
  }
}

.module-message__container--deleted-for-everyone {
  @include light-theme {
    color: $color-gray-90;
    border: 1px solid $color-gray-25;
    background-color: transparent;
    background-image: none;
  }

  @include dark-theme {
    color: $color-gray-05;
    border: 1px solid $color-gray-75;
    background-color: transparent;
    background-image: none;
  }
}

.module-message__tap-to-view {
  margin-top: 2px;
  display: flex;
  flex-direction: row;
  align-items: center;
}
.module-message__tap-to-view--with-content-above {
  margin-top: 8px;
}
.module-message__tap-to-view--with-content-below {
  margin-bottom: 8px;
}

.module-message__tap-to-view__spinner-container {
  margin-right: 6px;

  flex-grow: 0;
  flex-shrink: 0;

  width: 20px;
  height: 20px;
}

.module-message__tap-to-view__icon {
  margin-right: 6px;

  flex-grow: 0;
  flex-shrink: 0;
  width: 20px;
  height: 20px;

  @include light-theme {
    @include color-svg('../images/icons/v2/view-once-24.svg', $color-gray-90);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/view-once-24.svg', $color-gray-05);
  }
}
.module-message__tap-to-view__icon--expired {
  @include light-theme {
    @include color-svg('../images/icons/v2/viewed-once-24.svg', $color-gray-75);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/viewed-once-24.svg', $color-gray-05);
  }
}
.module-message__tap-to-view__icon--outgoing {
  background-color: $color-gray-05;
}
.module-message__tap-to-view__text {
  @include font-body-1-bold;

  color: $color-gray-05;
}
.module-message__tap-to-view__text--incoming {
  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}
.module-message__tap-to-view__text--incoming-expired {
  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}
.module-message__tap-to-view__text--incoming-error {
  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-message__tap-to-view__text--outgoing {
  color: $color-white;
}
.module-message__tap-to-view__text--outgoing-expired {
  color: $color-gray-05;
}

.module-message__attachment-container {
  // To ensure that images are centered if they aren't full width of bubble
  text-align: center;
  position: relative;

  margin: {
    left: -$message-padding-horizontal;
    right: -$message-padding-horizontal;
    top: -$message-padding-vertical;
    bottom: -$message-padding-vertical;
  }

  line-height: 0;
  overflow: hidden;

  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-95;
  }

  &--with-content-below {
    margin-bottom: 7px;
  }

  &--with-content-above {
    margin-top: 4px;
  }
}

.module-message__sticker-container {
  // To ensure that images are centered if they aren't full width of bubble
  text-align: center;

  margin: {
    left: -$message-padding-horizontal;
    right: -$message-padding-horizontal;
    top: -$message-padding-vertical - 1px;
    bottom: -$message-padding-vertical + 3px;
  }

  &--with-content-below {
    margin-bottom: 5px;
  }

  &--with-content-above {
    margin-top: 4px;
  }
}

.module-message__img-attachment {
  margin-bottom: -3px;

  // redundant with attachment-container, but we get cursor flashing on move otherwise
  cursor: pointer;
}

.module-message__generic-attachment {
  @include button-reset;

  width: 100%;

  display: flex;
  flex-direction: row;
  align-items: center;

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-message__generic-attachment--with-content-below {
  padding-bottom: 6px;
}

.module-message__generic-attachment--with-content-above {
  padding-top: 4px;
}

.module-message__generic-attachment--not-active {
  cursor: default;
  pointer-events: none;
}

.module-message__generic-attachment__icon-container {
  position: relative;
  user-select: none;
}
.module-message__generic-attachment__spinner-container {
  padding-left: 4px;
  padding-right: 4px;
}

.module-message__generic-attachment__icon {
  background: url('../images/file-gradient.svg') no-repeat center;
  height: 44px;
  width: 56px;
  margin-left: -13px;
  margin-right: -14px;
  margin-bottom: -4px;

  // So we can center the extension text inside this icon
  display: flex;
  flex-direction: row;
  align-items: center;
}

.module-message__generic-attachment__icon-dangerous-container {
  position: absolute;

  top: -1px;
  right: -4px;

  height: 16px;
  width: 16px;

  border-radius: 50%;
  background-color: $color-white;
}

.module-message__generic-attachment__icon-dangerous {
  height: 16px;
  width: 16px;

  @include color-svg(
    '../images/icons/v2/error-solid-24.svg',
    $color-accent-red
  );
}

.module-message__generic-attachment__icon__extension {
  font-size: 10px;
  line-height: 13px;
  letter-spacing: 0.1px;
  text-transform: uppercase;

  // Along with flow layout in parent item, centers text
  text-align: center;
  width: 25px;
  margin-left: auto;
  margin-right: auto;

  // We don't have much room for text here, cut it off without ellipse
  overflow-x: hidden;
  white-space: nowrap;
  text-overflow: clip;

  color: $color-gray-90;
}

.module-message__generic-attachment__text {
  flex-grow: 1;
  margin-left: 8px;
  // The width of the icon plus our 8px margin plus 1px leeway
  max-width: calc(100% - 36px);
}

.module-message__generic-attachment__file-name {
  @include font-body-2-bold;

  margin-top: 2px;
  user-select: none;

  // Handling really long filenames - cut them off
  overflow-x: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;

  @include light-theme {
    color: $color-white;
  }
  @include dark-theme {
    color: $color-gray-02;
  }
}

.module-message__generic-attachment__file-name--incoming {
  color: $color-white;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-message__generic-attachment__file-size {
  @include font-body-2;

  margin-top: 3px;
  user-select: none;

  @include light-theme {
    color: $color-white;
  }
  @include dark-theme {
    color: $color-gray-02;
  }
}

.module-message__generic-attachment__file-size--incoming {
  color: $color-white;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-message__link-preview {
  cursor: pointer;

  &--nonclickable {
    cursor: inherit;
    .module-image__image {
      cursor: inherit;
    }
  }

  display: block;

  margin-left: -$message-padding-horizontal;
  margin-right: -$message-padding-horizontal;
  width: calc(100% + 24px);
  outline: none;

  margin-top: -$message-padding-vertical;
  margin-bottom: 5px;
  overflow: hidden;

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-message__link-preview--with-content-above {
  margin-top: 4px;
}

.module-message__link-preview__content {
  padding: $message-padding-vertical $message-padding-horizontal;
  display: flex;
  flex-direction: row;
  align-items: flex-start;

  @include light-theme {
    background-color: $color-gray-02;
  }
  @include dark-theme {
    background-color: $color-gray-80;
  }
}

.module-message__link-preview__icon_container {
  margin: -2px;
  margin-right: 8px;
  display: inline-block;
}

.module-message__link-preview__text--with-icon {
  margin-top: 5px;
}

.module-message__link-preview__title {
  @include font-body-1-bold;

  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-message__link-preview__description {
  @include font-body-2;

  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-message__link-preview__footer {
  @include font-body-2;

  display: flex;
  flex-flow: row wrap;
  align-items: center;
  margin-top: 2px;

  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }

  > *:not(:first-child) {
    display: flex;
    flex-grow: 1;

    &:before {
      content: '•';
      font-size: 50%;
      margin-left: 0.2rem;
      margin-right: 0.2rem;
    }
  }
}

.module-message__link-preview__location {
  text-transform: lowercase;
}

.module-message__author {
  @include font-body-2-bold;

  height: 18px;
  overflow-x: hidden;
  overflow-y: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  user-select: none;
}

.module-message__author--with-tap-to-view-expired {
  @include font-body-2-bold;

  height: 18px;
  overflow-x: hidden;
  overflow-y: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;

  @include light-theme {
    color: $color-gray-75;
  }
  @include dark-theme {
    color: $color-white;
  }
}

.module-message__author_with_sticker {
  @include font-body-2-bold;

  height: 18px;
  overflow-x: hidden;
  overflow-y: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;

  // Stickers are pretty narrow, so we allow this one element of a sticker
  //   message to go wider than normal.
  // There's a tension here, since this is width and not max-width; things will
  //   look bad for RTL users if we make it too wide.
  width: 300px;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-message__text {
  @include font-body-1;

  text-align: start;
  overflow-wrap: break-word;
  word-wrap: break-word;
  word-break: break-word;
  white-space: pre-wrap;

  @include light-theme {
    color: $color-white-alpha-90;
  }
  @include dark-theme {
    color: $color-white-alpha-90;
  }

  a {
    text-decoration: underline;
    outline: none;

    @include light-theme {
      color: $color-white-alpha-90;
    }
    @include keyboard-mode {
      &:focus {
        outline: 1px solid $color-gray-90;
      }
    }

    @include dark-theme {
      color: $color-white-alpha-90;
    }
    @include dark-keyboard-mode {
      &:focus {
        outline: 1px solid $color-white-alpha-90;
      }
    }
  }
}

.module-message__text--incoming {
  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }

  a {
    text-decoration: underline;
    outline: none;

    @include light-theme {
      color: $color-gray-90;
    }
    @include keyboard-mode {
      &:focus {
        outline: 1px solid $color-gray-90;
      }
    }

    @include dark-theme {
      color: $color-gray-05;
    }
    @include dark-keyboard-mode {
      &:focus {
        outline: 1px solid $color-gray-05;
      }
    }
  }
}

.module-message__text--error {
  @include font-body-1-italic;
}
.module-message__text--delete-for-everyone {
  user-select: none;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-message__metadata {
  align-items: center;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  margin-top: 3px;
  font-style: normal;

  &--inline {
    float: right;
    margin-top: -14px;
  }
}

// With an image and no caption, this section needs to be on top of the image overlay
.module-message__metadata--with-image-no-caption {
  position: absolute;
  bottom: 9px;
  z-index: $z-index-above-base;

  width: 100%;
  // Because this is absolutely positioned, we 100% is too big, take it down by parent
  //   padding sizes.
  padding-right: 24px;

  // This is so all clicks go right through to the underlying image.
  pointer-events: none;
}

.module-message__metadata--deleted-for-everyone {
  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-message__metadata__date {
  @include font-caption;
  user-select: none;
  white-space: nowrap;

  @include light-theme {
    color: $color-white-alpha-80;
  }
  @include dark-theme {
    color: $color-white-alpha-80;
  }
}
.module-message__metadata__tapable {
  @include button-reset;
}
.module-message__metadata__date--incoming {
  color: $color-white-alpha-80;

  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}
.module-message__metadata__date--with-image-no-caption {
  @include light-theme {
    color: $color-white;
  }
  @include dark-theme {
    color: $color-white-alpha-80;
  }
}
.module-message__metadata__date--deleted-for-everyone {
  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}
.module-message__metadata__date.module-message__metadata__date--incoming-with-tap-to-view-expired {
  color: $color-gray-75;

  @include dark-theme {
    color: $color-white-alpha-80;
  }
}
.module-message__metadata__date.module-message__metadata__date--outgoing-with-tap-to-view-expired {
  color: $color-white-alpha-80;
}

.module-message__metadata__date--with-sticker {
  @include light-theme {
    color: $color-gray-60;
  }
}

.module-message__metadata__status-icon {
  width: 12px;
  height: 12px;
  display: inline-block;
  margin-left: 6px;
  // High margin to leave space for the increase when we go to two checks
  margin-right: 6px;
  margin-bottom: 2px;
}

.module-message__metadata__status-icon--paused,
.module-message__metadata__status-icon--sending {
  @include only-when-page-is-visible {
    animation: rotate 4s linear infinite;
  }
  @include color-svg('../images/sending.svg', $color-white);
}

.module-message__metadata__status-icon--sent {
  @include light-theme {
    @include color-svg(
      '../images/check-circle-outline.svg',
      $color-white-alpha-80
    );
  }
  @include dark-theme {
    @include color-svg(
      '../images/check-circle-outline.svg',
      $color-white-alpha-80
    );
  }
}
.module-message__metadata__status-icon--delivered {
  // We reduce the margin size to keep the overall width the same
  margin-right: 0px;
  width: 18px;

  @include light-theme {
    @include color-svg('../images/double-check.svg', $color-white-alpha-80);
  }
  @include dark-theme {
    @include color-svg('../images/double-check.svg', $color-white-alpha-80);
  }
}
.module-message__metadata__status-icon--read,
.module-message__metadata__status-icon--viewed {
  // We reduce the margin size to keep the overall width the same
  margin-right: 0px;
  width: 18px;

  @include light-theme {
    @include color-svg('../images/read.svg', $color-white-alpha-80);
  }
  @include dark-theme {
    @include color-svg('../images/read.svg', $color-white-alpha-80);
  }
}

// When status indicators are overlaid on top of an image, they use different colors
.module-message__metadata__status-icon--with-image-no-caption {
  @include dark-theme {
    background-color: $color-gray-02;
  }
  @include light-theme {
    background-color: $color-white;
  }
}
.module-message__metadata__status-icon--with-sticker {
  @include light-theme {
    background-color: $color-gray-60;
  }
}

.module-message__metadata__status-icon--deleted-for-everyone {
  @include light-theme {
    background-color: $color-gray-60;
  }
  @include dark-theme {
    background-color: $color-gray-25;
  }
}

.module-message__metadata__spinner-container {
  margin-left: 6px;
}

.module-message__send-message-button {
  @include button-reset;

  width: calc(100% + 24px);

  @include font-body-2-bold;

  margin-top: $message-padding-vertical;
  margin-bottom: -$message-padding-vertical;
  margin-left: -$message-padding-horizontal;
  margin-right: -$message-padding-horizontal;

  text-align: center;
  padding: 10px;

  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 18px;

  @include light-theme {
    color: $color-ultramarine;
    background-color: $color-gray-02;
    border: 1px solid $color-black-alpha-20;
  }
  @include dark-theme {
    color: $color-ultramarine-light;
    background-color: $color-gray-75;
    border: 1px solid $color-gray-45;
  }

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-message__send-message-button--no-bottom-left-curve {
  border-bottom-left-radius: 4px;
}
.module-message__send-message-button--no-bottom-right-curve {
  border-bottom-right-radius: 4px;
}

.module-message__author-avatar-container {
  align-items: flex-end;
  display: flex;
  justify-content: center;
  margin-right: 8px;
  padding-bottom: 6px;

  &--with-reactions {
    padding-bottom: 15px;
  }
}

.module-message__unopened-gift-badge {
  width: 240px;
  height: 132px;
  background-color: $color-ultramarine;
  position: relative;

  margin: {
    left: -$message-padding-horizontal;
    right: -$message-padding-horizontal;
    top: -$message-padding-vertical;
    bottom: $message-padding-vertical;
  }

  &--outgoing {
    @include light-theme {
      border-bottom: 1px solid $color-white-alpha-80;
    }
    @include dark-theme {
      border-bottom: 1px solid $color-gray-95;
    }
  }

  &__container {
    cursor: default;
    user-select: none;
  }

  &__ribbon-horizontal {
    position: absolute;
    left: 0;
    right: 0;
    height: 16px;
    top: 50%;
    transform: translateY(-50%);
    background-color: $color-white;
  }

  &__ribbon-vertical {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 16px;
    left: 50%;
    transform: translateX(-50%);
    background-color: $color-white;
  }

  &__bow {
    position: absolute;

    // Centered
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    // For proper alignment with the ribbons
    margin-top: 3px;

    // 75.26px by 51.93px in Figma, but there's a buffer in the SVG file
    width: 81px;
    height: 60px;
  }

  &__text {
    @include font-body-2-italic;

    &--incoming {
      @include light-theme {
        color: $color-gray-60;
      }
      @include dark-theme {
        color: $color-gray-25;
      }
    }
  }

  &__container .module-message__text--incoming {
    @include font-body-2-italic;

    @include light-theme {
      color: $color-gray-60;
    }
    @include dark-theme {
      color: $color-gray-25;
    }
  }
  &__container .module-message__text--outgoing {
    @include font-body-2-italic;

    @include light-theme {
      color: $color-white-alpha-80;
    }
    @include dark-theme {
      color: $color-white-alpha-80;
    }
  }
}

.module-message__redeemed-gift-badge {
  display: flex;
  flex-direction: row;

  &__container {
    user-select: none;
  }

  &__badge {
    height: 64px;
    width: 64px;
    margin-left: 4px;
    margin-top: 8px;
    margin-right: 12px;
    margin-bottom: 16px;
    flex-grow: 0;
    flex-shrink: 0;

    &--missing-incoming {
      border-radius: 50%;

      @include light-theme {
        background-color: $color-gray-15;
      }
      @include dark-theme {
        background-color: $color-gray-60;
      }
    }
    &--missing-outgoing {
      border-radius: 50%;

      @include light-theme {
        background-color: $color-white-alpha-20;
      }
      @include dark-theme {
        background-color: $color-white-alpha-20;
      }
    }
  }

  &__text {
    flex-grow: 1;
    margin-top: 19px;
  }
  &__title {
    margin-bottom: 6px;
    @include font-body-1;
  }
  &__remaining {
    @include font-subtitle;

    &--incoming {
      @include light-theme {
        color: $color-gray-75;
      }
      @include dark-theme {
        color: $color-gray-25;
      }
    }
    &--outgoing {
      @include light-theme {
        color: $color-white-alpha-80;
      }
      @include dark-theme {
        color: $color-white-alpha-80;
      }
    }
  }

  &__button {
    @include button-reset;
    @include button-secondary;
    margin-left: auto;
    margin-right: auto;
    width: 216px;
    margin-bottom: 7px;
    text-align: center;
    border-radius: 4px;

    @include font-body-1-bold;

    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;

    &--incoming {
      @include light-theme {
        color: $color-gray-90;
        background-color: $color-white;
      }
      @include dark-theme {
        color: $color-gray-05;
        background-color: $color-gray-62;
      }

      // Disabling hover
      &:hover {
        @include mouse-mode {
          background-color: $color-white;
        }

        @include dark-mouse-mode {
          background-color: $color-gray-62;
        }
      }
    }

    &--outgoing {
      @include light-theme {
        color: $color-gray-90;
        background-color: $color-white-alpha-80;
      }
      @include dark-theme {
        color: $color-gray-90;
        background-color: $color-white-alpha-80;
      }
      &:hover {
        @include mouse-mode {
          background-color: $color-white-alpha-90;
        }

        @include dark-mouse-mode {
          background-color: $color-white-alpha-90;
        }
      }
      &:focus {
        @include keyboard-mode {
          box-shadow: 0px 0px 0px 3px $color-ultramarine-light;
        }
        @include dark-keyboard-mode {
          box-shadow: 0px 0px 0px 3px $color-ultramarine-light;
        }
      }
      &:active {
        // We need to include all four here for specificity precedence

        @include mouse-mode {
          background-color: $color-white;
        }
        @include dark-mouse-mode {
          background-color: $color-white;
        }

        @include keyboard-mode {
          background-color: $color-white;
        }
        @include dark-keyboard-mode {
          background-color: $color-white;
        }
      }
    }

    &__text {
      display: flex;
      flex-direction: row;
      align-items: center;
      height: 36px;
    }
  }

  &__icon-check {
    height: 19px;
    width: 19px;
    margin-right: 5px;
    display: inline-block;

    &--incoming {
      @include light-theme {
        @include color-svg(
          '../images/icons/v2/check-circle-outline-24.svg',
          $color-gray-90
        );
      }
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/check-circle-outline-24.svg',
          $color-gray-05
        );
      }
    }

    &--outgoing {
      @include light-theme {
        @include color-svg(
          '../images/icons/v2/check-circle-outline-24.svg',
          $color-gray-90
        );
      }
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/check-circle-outline-24.svg',
          $color-gray-90
        );
      }
    }
  }
}

.module-message__typing-container {
  height: 16px;

  display: flex;
  flex-direction: row;
  align-items: center;
}

.module-message__reactions {
  position: relative;
  z-index: $z-index-above-base;
  height: 22px;
  display: flex;
  user-select: none;

  &--incoming {
    align-self: flex-end;
    padding-right: 8px;
    margin-left: 8px;
  }
  &--outgoing {
    align-self: flex-start;
    padding-left: 8px;
    margin-right: 8px;
  }
}

.module-message__reactions__reaction {
  @include button-reset;

  min-width: 28px;
  height: 22px;
  border: 1px solid;
  border-radius: 33px;
  display: flex;
  justify-content: center;
  align-items: center;

  &--with-count {
    min-width: 40px;
    padding: 0 6px;
  }

  &__count {
    @include font-caption-bold;

    margin-left: 4px;

    &--no-emoji {
      margin-left: 0px;
    }

    @include light-theme {
      color: $color-gray-60;
    }

    @include dark-theme {
      color: $color-gray-25;
    }

    &--is-me {
      @include dark-theme {
        color: $color-gray-15;
      }
    }
  }

  &:focus {
    outline: none;
  }

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }

  @include light-theme() {
    border-color: $color-white;
    background: $color-gray-05;
  }

  @include dark-theme() {
    border-color: $color-gray-95;
    background: $color-gray-90;
  }

  &--is-me {
    @include dark-theme() {
      background: $color-gray-60;
    }

    @include light-theme() {
      background: $color-gray-25;
    }
  }
}

// Module: Expire Timer

.module-expire-timer {
  width: 12px;
  height: 12px;
  display: inline-block;
  margin-left: 6px;
  margin-bottom: 2px;

  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/timer-60-12.svg',
      $color-white-alpha-80
    );
  }
  @include light-theme {
    @include color-svg(
      '../images/icons/v2/timer-60-12.svg',
      $color-white-alpha-80
    );
  }
}

$timer-icons: '55', '50', '45', '40', '35', '30', '25', '20', '15', '10', '05',
  '00';

@each $timer-icon in $timer-icons {
  .module-expire-timer--#{$timer-icon} {
    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/timer-#{$timer-icon}-12.svg',
        $color-white-alpha-80
      );
    }
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/timer-#{$timer-icon}-12.svg',
        $color-white-alpha-80
      );
    }
  }
}

.module-expire-timer--incoming {
  background-color: $color-white-alpha-80;

  @include light-theme {
    background-color: $color-gray-60;
  }
  @include dark-theme {
    background-color: $color-gray-25;
  }
}
.module-expire-timer.module-expire-timer--incoming-with-tap-to-view-expired {
  background-color: $color-gray-75;

  @include dark-theme {
    background-color: $color-white-alpha-80;
  }
}
.module-expire-timer.module-expire-timer--outgoing-with-tap-to-view-expired {
  background-color: $color-white-alpha-80;
}
.module-expire-timer--with-sticker {
  @include light-theme {
    background-color: $color-gray-60;
  }
}

// When status indicators are overlaid on top of an image, they use different colors
.module-expire-timer--with-image-no-caption {
  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-02;
  }
}

.module-expire-timer--deleted-for-everyone {
  @include light-theme {
    background-color: $color-gray-60;
  }
  @include dark-theme {
    background-color: $color-gray-25;
  }
}

.module-about {
  &__container {
    margin-left: auto;
    margin-right: auto;
    max-width: 248px;
    text-align: center;
  }

  &__text {
    @include font-body-1;
    @include light-theme {
      color: $color-gray-60;
    }
    @include dark-theme {
      color: $color-gray-25;
    }
    max-width: 400px;

    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    overflow: hidden;
    text-overflow: ellipsis;

    img.emoji {
      height: 1em;
      margin-right: 3px;
      margin-bottom: 3px;
      vertical-align: middle;
      width: 1em;
    }
  }
}

// Module: Embedded Contact

.module-embedded-contact {
  @include button-reset;

  width: 100%;
  padding: 5px;

  display: flex;
  flex-direction: row;
  align-items: center;

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-embedded-contact--outgoing {
  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-white;
    }
  }
}

.module-embedded-contact--with-content-above {
  padding-top: 4px;
}

.module-embedded-contact--with-content-below {
  padding-bottom: 4px;
}

.module-embedded-contact__spinner-container {
  padding-left: 5px;
  padding-right: 5px;
}

.module-embedded-contact__text-container {
  flex-grow: 1;
  margin-left: 8px;

  max-width: calc(100% - 58px);
}

.module-embedded-contact__contact-name {
  @include font-body-1-bold;

  margin-top: 6px;

  max-width: 100%;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;

  @include light-theme {
    color: $color-white;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-embedded-contact__contact-name--incoming {
  color: $color-white;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-embedded-contact__contact-method {
  @include font-body-2;

  margin-top: 3px;
  max-width: 100%;
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;

  @include dark-theme {
    color: $color-white-alpha-80;
  }
  @include light-theme {
    color: $color-white-alpha-80;
  }
}

.module-embedded-contact__contact-method--incoming {
  color: $color-white-alpha-80;

  @include light-theme {
    color: $color-gray-60;
  }
}

// Module: Contact Detail

.module-contact-detail {
  text-align: center;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto;
}

.module-contact-detail__avatar {
  margin-bottom: 4px;
}

.module-contact-detail__contact-name {
  @include font-body-1-bold;
}

.module-contact-detail__contact-method {
  @include font-body-2;

  margin-top: 10px;
}

.module-contact-detail__send-message {
  @include button-reset;

  border-radius: 4px;
  background-color: $color-ultramarine;
  display: inline-block;
  padding: 6px;
  margin-top: 20px;

  color: $color-white;

  flex-direction: column;
  align-items: center;
}

.module-contact-detail__send-message__inner {
  display: flex;
  align-items: center;
  padding-right: 5px;

  @include font-body-2-bold;
}

.module-contact-detail__send-message__bubble-icon {
  height: 17px;
  width: 18px;
  display: inline-block;
  margin-right: 5px;
  @include light-theme {
    @include color-svg(
      '../images/icons/v2/message-outline-24.svg',
      $color-white
    );
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/message-solid-24.svg', $color-white);
  }
}

.module-contact-detail__additional-contact {
  text-align: left;
  margin-top: 15px;
  padding-top: 8px;

  @include light-theme {
    border-top: 1px solid $color-gray-05;
  }
  @include dark-theme {
    border-top: 1px solid $color-gray-75;
  }
}

.module-contact-detail__additional-contact__type {
  @include font-caption-bold;

  color: $color-gray-45;

  margin-bottom: 3px;
}

// Module: Inline Notification Wrapper

.module-inline-notification-wrapper {
  outline: none;

  &:focus {
    @include keyboard-mode {
      background: $color-selected-message-background-light;
    }
    @include dark-keyboard-mode {
      background: $color-selected-message-background-dark;
    }
  }
}

// Module: Group Notification

.module-group-notification__contact {
  font-weight: bold;
}

.module-safety-number__bold-name {
  font-weight: bold;
}

// Module: Error Boundary

.module-error-boundary-notification {
  text-align: center;
  cursor: pointer;

  &:focus {
    @include keyboard-mode {
      outline: 0;
    }
  }

  &:focus &__message {
    @include keyboard-mode {
      opacity: 1;
    }
  }

  &__message {
    opacity: 0.8;
  }

  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-05;
  }

  &__icon-container {
    margin-left: auto;
    margin-right: auto;
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    margin-bottom: 8px;
  }

  &__icon {
    height: 20px;
    width: 20px;
    display: inline-block;
    opacity: 0.6;

    @include light-theme {
      @include color-svg(
        '../images/icons/v2/error-solid-24.svg',
        $color-gray-60
      );
    }
    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/error-solid-24.svg',
        $color-gray-05
      );
    }
  }
}

.module-notification--with-click-handler {
  cursor: pointer;
}

.module-notification__icon {
  height: 24px;
  width: 24px;
  margin-left: auto;
  margin-right: auto;
}

// Module: Contact List Item

.module-contact-list-item {
  @include button-reset;

  cursor: inherit;

  padding: 8px;
  width: 100%;

  display: flex;
  flex-direction: row;
  align-items: center;

  @include light-theme {
    color: $color-gray-60;

    @include mouse-mode {
      &:hover {
        background-color: $color-gray-02;
      }
    }
    @include keyboard-mode {
      &:focus {
        background-color: $color-gray-02;
      }
    }
  }
  @include dark-theme {
    color: $color-gray-15;
  }
  @include dark-mouse-mode {
    &:hover {
      background-color: $color-gray-80;
    }
  }
  @include dark-keyboard-mode {
    &:focus {
      background-color: $color-gray-80;
    }
  }
}

.module-contact-list-item--with-click-handler {
  cursor: pointer;
}

.module-contact-list-item__text {
  margin-left: 8px;

  align-items: center;
  display: flex;
  flex-direction: row;

  flex-grow: 1;
  justify-content: space-between;
}

.module-contact-list-item__left {
  flex: 1;
}

.module-contact-list-item__text__name {
  @include font-body-1-bold;
  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

.module-contact-list-item__text__additional-data {
  @include font-body-2;

  margin-top: 3p;
}

.module-contact-list-item__text__verified-icon {
  display: inline-block;
  width: 20px;
  height: 20px;
  vertical-align: text-bottom;

  // Trying to account for the whitespace around the check mark
  margin-bottom: -1px;

  @include light-theme {
    @include color-svg('../images/icons/v2/check-24.svg', $color-gray-60);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/check-24.svg', $color-gray-25);
  }
}

.module-contact-list-item__admin {
  text-align: right;
  height: 100%;

  @include font-body-2;
}

// Module: In Contacts Icon

.module-in-contacts-icon__icon {
  display: inline-block;
  height: 15px;
  width: 15px;

  margin-bottom: 2px;
  vertical-align: middle;

  @include light-theme {
    @include color-svg(
      '../images/icons/v2/profile-circle-outline-24.svg',
      $color-gray-60
    );
  }
  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/profile-circle-outline-24.svg',
      $color-gray-25
    );
  }

  @include keyboard-mode {
    &:focus {
      @include color-svg(
        '../images/icons/v2/profile-circle-outline-24.svg',
        $color-ultramarine
      );
    }
  }
}

// Module: Conversation Details

.conversation-details-panel {
  max-width: 750px;
  margin: 0 auto;

  @at-root .conversation #{&} {
    overflow-y: auto;
  }
}

// Brought this up here to add specificity
button.ConversationDetails__action-button {
  margin-left: 16px;
}

// Module: Media Gallery

.module-media-gallery {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  width: 100%;
  height: 100%;
  outline: none;
}

.module-media-gallery__tab-container {
  display: flex;
  flex-grow: 0;
  flex-shrink: 0;
  cursor: pointer;
  width: 100%;
}

.module-media-gallery__tab {
  width: 100%;
  padding: 20px;
  text-align: center;

  @include light-theme {
    background-color: $color-gray-02;
  }
  @include dark-theme {
    background-color: $color-gray-90;
  }

  outline: none;

  &:focus {
    @include keyboard-mode {
      background-color: $color-gray-15;
    }
    @include dark-keyboard-mode {
      background-color: $color-gray-75;
    }
  }
}

.module-media-gallery__tab--active {
  border-bottom: 2px solid $color-ultramarine;
}

.module-media-gallery__content {
  display: flex;
  flex-grow: 1;
  overflow-y: auto;
  padding: 20px;
}

.module-media-gallery__sections {
  display: flex;
  flex-grow: 1;
  flex-direction: column;
}

// Module: Attachment Section

.module-attachment-section {
  width: 100%;
}

.module-attachment-section__header {
  @include font-body-1-bold;
}

.module-attachment-section__items {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
}

// Module: Document List Item

.module-document-list-item {
  width: 100%;
  height: 72px;
}

.module-document-list-item--with-separator {
  @include light-theme {
    border-bottom: 1px solid $color-gray-02;
  }
  @include dark-theme {
    border-bottom: 1px solid $color-gray-75;
  }
}

.module-document-list-item__content {
  @include button-reset;
  width: 100%;
  height: 100%;

  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-document-list-item__icon {
  flex-shrink: 0;

  width: 48px;
  height: 48px;
  @include color-svg('../images/file.svg', $color-gray-45);
}

.module-document-list-item__metadata {
  display: inline-flex;
  flex-direction: column;
  flex-grow: 1;
  flex-shrink: 0;
  margin-left: 8px;
  margin-right: 8px;
}

.module-document-list-item__file-size {
  display: inline-block;
  margin-top: 8px;
  @include font-body-2;
}

.module-document-list-item__date {
  display: inline-block;
  flex-shrink: 0;
}

// Module: Media Grid Item

.module-media-grid-item {
  @include button-reset;

  height: 94px;
  width: 94px;
  background-color: $color-gray-05;
  margin-right: 4px;
  margin-bottom: 4px;
  position: relative;

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }
}

.module-media-grid-item__image {
  height: 94px;
  width: 100%;
  object-fit: cover;
}

.module-media-grid-item__icon {
  position: absolute;
  top: 15px;
  bottom: 15px;
  left: 15px;
  right: 15px;
}

.module-media-grid-item__icon-image {
  @include color-svg('../images/image.svg', $color-gray-45);
}

.module-media-grid-item__image-container {
  position: relative;
}

.module-media-grid-item__circle-overlay {
  position: absolute;
  left: 50%;
  top: 50%;

  transform: translate(-50%, -50%);

  width: 42px;
  height: 42px;
  background-color: $color-white;
  border-radius: 21px;
}

.module-media-grid-item__play-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  height: 24px;
  width: 24px;
  @include color-svg(
    '../images/icons/v2/play-solid-24.svg',
    $color-ultramarine
  );
}

.module-media-grid-item__icon-video {
  @include color-svg('../images/movie.svg', $color-gray-45);
}

.module-media-grid-item__icon-generic {
  @include color-svg('../images/file.svg', $color-gray-45);
}

/* Module: Empty State*/

.module-empty-state {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-grow: 1;

  @include font-title-1;

  color: $color-gray-45;
}

// Module: Message Request Actions

.module-message-request-actions {
  padding: 8px 16px 12px 16px;

  @include light-theme {
    background: $color-white;
  }

  @include dark-theme {
    background: $color-gray-95;
  }

  &__message {
    @include font-body-2;
    text-align: center;
    margin-bottom: 12px;

    @include light-theme {
      color: $color-gray-60;
    }

    @include dark-theme {
      color: $color-gray-25;
    }

    &__name {
      @include font-body-2-bold;
    }

    &__learn-more {
      text-decoration: none;
    }
  }

  &__buttons {
    display: flex;
    flex-direction: row;
    justify-content: center;

    .module-Button {
      min-width: 80px;

      &:not(:last-of-type) {
        margin-right: 8px;
      }
    }
  }
}

// Module: Main Header

.module-main-header {
  -webkit-app-region: var(--draggable-app-region);

  height: calc(#{$header-height} + var(--title-bar-drag-area-height));
  width: 100%;

  padding-left: 16px;
  padding-right: 16px;
  padding-top: var(--title-bar-drag-area-height);

  display: flex;
  justify-content: space-between;
  flex-direction: row;
  align-items: center;

  .module-left-pane--width-narrow & {
    justify-content: center;
  }

  & > * {
    margin-right: 12px;

    &:last-child {
      margin-right: 0;
    }
  }

  &__avatar {
    -webkit-app-region: no-drag;

    &--container {
      position: relative;

      .module-left-pane--width-narrow & {
        display: none;
      }
    }

    &--badged {
      background: $color-ultramarine;
      border-radius: 100%;
      border: 1px solid $color-white;
      height: 8px;
      width: 8px;
      position: absolute;
      top: 0;
      right: 0;
    }
  }

  &__icon-container {
    display: flex;
  }

  &__compose-icon {
    -webkit-app-region: no-drag;
    align-items: center;
    background: none;
    border-radius: 4px;
    border: 2px solid transparent;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    padding: 2px;
    width: 32px;

    @include light-theme {
      &:hover,
      &:focus {
        background: $color-gray-15;
      }
      &:active {
        background: $color-gray-05;
      }
    }
    @include dark-theme {
      &:hover,
      &:focus {
        background: $color-gray-75;
      }
      &:active {
        background: $color-gray-65;
      }
    }

    @include keyboard-mode {
      &:focus {
        border-color: $color-ultramarine;
        outline: none;
      }
    }

    &::before {
      $icon: '../images/icons/v2/compose-24.svg';
      width: 24px;
      height: 24px;
      content: '';

      @include light-theme {
        @include color-svg($icon, $color-gray-75);
        &:hover,
        &:active,
        &:focus {
          @include color-svg($icon, $color-gray-90);
        }
      }
      @include dark-theme {
        @include color-svg($icon, $color-gray-15);
        &:hover,
        &:active,
        &:focus {
          @include color-svg($icon, $color-gray-02);
        }
      }
    }
  }

  &__stories-badge {
    @include rounded-corners;
    align-items: center;
    background-color: $color-accent-red;
    color: $color-white;
    display: flex;
    font-size: 10px;
    height: 16px;
    justify-content: center;
    min-width: 16px;
    overflow: hidden;
    padding: 0 2px;
    position: absolute;
    right: -6px;
    top: -4px;
    user-select: none;
    z-index: $z-index-base;
  }

  &__stories-icon {
    -webkit-app-region: no-drag;
    align-items: center;
    background: none;
    border-radius: 4px;
    border: 2px solid transparent;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    margin-right: 20px;
    padding: 2px;
    position: relative;
    width: 32px;

    .module-left-pane--width-narrow & {
      display: none;
    }

    @include light-theme {
      &:hover {
        background: $color-gray-15;
      }
      &:active {
        background: $color-gray-05;
      }
    }
    @include dark-theme {
      &:hover {
        background: $color-gray-75;
      }
      &:active {
        background: $color-gray-65;
      }
    }

    @include keyboard-mode {
      &:focus {
        border-color: $color-ultramarine;
        outline: none;
      }
    }

    &::before {
      $icon: '../images/icons/v2/stories-outline-24.svg';
      width: 24px;
      height: 24px;
      content: '';

      @include light-theme {
        @include color-svg($icon, $color-gray-75);
        &:hover,
        &:active,
        &:focus {
          @include color-svg($icon, $color-gray-90);
        }
      }
      @include dark-theme {
        @include color-svg($icon, $color-gray-15);
        &:hover,
        &:active,
        &:focus {
          @include color-svg($icon, $color-gray-02);
        }
      }
    }
  }
}

// Module: Image

.module-image {
  position: relative;
  display: inline-block;
  vertical-align: middle;
}

.module-image--tap-to-play,
.module-image--not-downloaded {
  align-items: center;
  display: flex;
  justify-content: center;

  span {
    align-items: center;
    display: flex;
    justify-content: center;
    border-radius: 48px;
    height: 48px;
    width: 48px;
    background-color: $color-black-alpha-70;
  }

  &:hover {
    span {
      background-color: $color-black-alpha-80;
    }
  }

  &:focus {
    span {
      background-color: $color-gray-75;
      border: 4px solid $color-ultramarine;
      box-sizing: border-box;
      outline: none;
    }
  }
}

.module-image--not-downloaded {
  span:after {
    content: '';
    height: 24px;
    width: 24px;

    @include color-svg('../images/icons/v2/arrow-down-24.svg', $color-white);
  }
}

.module-image--tap-to-play {
  span:after {
    display: flex;
    flex-direction: column;
    align-items: center;

    content: 'GIF';
    height: 24px;
    width: 24px;

    @include font-body-1;
    color: $color-white;
  }
}

.module-image__download-pending {
  position: relative;

  &--spinner-container {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
  }

  &--spinner {
    background-color: $color-gray-75;
    border-radius: 48px;
    height: 48px;
    width: 48px;

    .module-image-spinner {
      &__container {
        margin: 12px auto;
      }

      &__arc {
        background-color: $color-gray-75;
      }

      &__circle {
        background-color: $color-white;
      }

      @include dark-theme {
        &__arc {
          background-color: $color-gray-75;
        }
      }
    }
  }
}

.module-image--with-background {
  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-black;
  }
}

.module-image__caption-icon {
  position: absolute;
  top: 6px;
  left: 6px;
}

.module-image--cropped {
  overflow: hidden;
}

.module-image__border-overlay {
  @include button-reset;

  width: 100%;
  cursor: inherit;

  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: $z-index-above-base;
}

.module-image__border-overlay--with-click-handler {
  cursor: pointer;
}

.module-image__border-overlay--with-border {
  @include light-theme {
    box-shadow: inset 0px 0px 0px 1px $color-black-alpha-20;
  }
  @include dark-theme {
    box-shadow: inset 0px 0px 0px 1px $color-white-alpha-20;
  }
}

.module-image--gif {
  &__filesize {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 2px 8px;

    color: $color-white;
    background: $color-black-alpha-70;

    /* The height is: 14px + 2x2px from the padding */
    border-radius: 9px;

    font-size: 11px;
    line-height: 14px;
    user-select: none;
  }

  video {
    cursor: pointer;
  }
}

button.module-image__border-overlay:focus {
  @include keyboard-mode {
    box-shadow: inset 0px 0px 0px 2px $color-ultramarine;
  }
}

.module-image__border-overlay--dark {
  background-color: $color-black-alpha-20;
}

.module-image__loading-placeholder {
  display: inline-flex;
  flex-direction: row;
  align-items: center;

  @include light-theme {
    background-color: $color-black-alpha-20;
  }
  @include dark-theme {
    background-color: $color-white-alpha-20;
  }
}

.module-image__image {
  object-fit: cover;
  // redundant with attachment-container, but we get cursor flashing on move otherwise
  cursor: pointer;
}

.module-image__bottom-overlay {
  height: 48px;
  background-image: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0),
    rgba(0, 0, 0, 0) 9%,
    rgba(0, 0, 0, 0.02) 17%,
    rgba(0, 0, 0, 0.05) 24%,
    rgba(0, 0, 0, 0.08) 31%,
    rgba(0, 0, 0, 0.12) 37%,
    rgba(0, 0, 0, 0.16) 44%,
    rgba(0, 0, 0, 0.2) 50%,
    rgba(0, 0, 0, 0.24) 56%,
    rgba(0, 0, 0, 0.28) 63%,
    rgba(0, 0, 0, 0.32) 69%,
    rgba(0, 0, 0, 0.35) 76%,
    rgba(0, 0, 0, 0.38) 83%,
    rgba(0, 0, 0, 0.4) 91%,
    rgba(0, 0, 0, 0.4)
  );
  position: absolute;
  bottom: 0;
  z-index: $z-index-base;
  left: 0;
  right: 0;
}

.module-image__play-overlay__circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  width: 48px;
  height: 48px;
  background-color: $color-white;
  border-radius: 24px;
}

.module-image__play-overlay__icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  height: 24px;
  width: 24px;
  @include color-svg(
    '../images/icons/v2/play-solid-24.svg',
    $color-ultramarine
  );
}

.module-image__text-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: $z-index-above-above-base;

  // This allows click-through to the overlay button behind it
  pointer-events: none;

  color: $color-white;

  @include font-body-1;

  text-align: center;
}

.module-image__close-button {
  @include staged-attachment-close-button;

  background-image: url('../images/x-shadow-16.svg');

  @include keyboard-mode {
    &:focus {
      outline: 2px solid $color-ultramarine;
    }
  }
}

// Module: Image Grid

.module-image-grid {
  display: inline-flex;
  flex-direction: row;
  align-items: center;

  gap: 1px;
}

.module-image-grid--one-image {
  margin-bottom: -5px;
}

.module-image-grid--with-sticker {
  padding: 8px;
}

.module-image-grid__column {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
}

.module-image-grid__row {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  flex-grow: 1;
  gap: 1px;
}

// Module: Typing Animation

.module-typing-animation {
  display: inline-flex;
  flex-direction: row;
  align-items: center;

  height: 8px;
  width: 38px;
  padding-left: 1px;
  padding-right: 1px;
}

.module-typing-animation__dot {
  border-radius: 50%;

  height: 6px;
  width: 6px;
  opacity: 0.4;
  will-change: transform, opacity;

  @include dark-theme {
    background-color: $color-white;
  }
  @include light-theme {
    background-color: $color-gray-60;
  }

  @include only-when-page-is-visible {
    animation: {
      name: typing-animation;
      duration: 1600ms;
      timing-function: ease;
      iteration-count: infinite;
    }
  }
}

.module-left-pane .module-typing-animation__dot {
  @include only-when-page-is-visible {
    animation-name: typing-animation-bare;
  }
}

.module-typing-animation__dot--light {
  background-color: $color-white;

  @include light-theme {
    background-color: $color-gray-60;
  }
}

@keyframes typing-animation {
  0% {
    opacity: 0.4;
  }
  20% {
    transform: scale(1.3);
    opacity: 1;
  }
  40% {
    opacity: 0.4;
  }
}

@keyframes typing-animation-bare {
  0% {
    opacity: 0.4;
  }
  20% {
    opacity: 1;
  }
  40% {
    opacity: 0.4;
  }
}

.module-typing-animation__dot--second {
  animation-delay: 160ms;
}

.module-typing-animation__dot--third {
  animation-delay: 320ms;
}

.module-typing-animation__spacer {
  flex-grow: 1;
}

// Module: Attachments

.module-attachments__header {
  height: 24px;
  position: relative;
}

.module-attachments__edit-icon {
  align-items: center;
  background: $color-black-alpha-60;
  border-radius: 100%;
  display: flex;
  height: 36px;
  justify-content: center;
  left: 50%;
  margin-left: -20px;
  margin-top: -18px;
  position: absolute;
  top: 50%;
  visibility: hidden;
  width: 36px;

  &::after {
    @include color-svg('../images/icons/v2/edit-solid-16.svg', $color-white);
    content: '';
    height: 20px;
    width: 20px;
  }
}

.module-attachments--editable {
  display: inline-block;
  position: relative;

  &:hover {
    .module-attachments__edit-icon {
      visibility: visible;
    }
  }
}

.module-attachments__close-button {
  $icon: '../images/icons/v2/x-24.svg';

  @include button-reset;

  position: absolute;
  top: 8px;
  right: 16px;

  width: 20px;
  height: 20px;

  z-index: $z-index-above-base;

  @include light-theme {
    @include color-svg($icon, $color-black);
  }
  @include dark-theme {
    @include color-svg($icon, $color-white);
  }

  @include keyboard-mode {
    &:focus {
      @include color-svg($icon, $color-ultramarine);
    }
  }
}

.module-attachments__rail {
  margin-top: 12px;
  margin-left: 12px;
  padding-right: 12px;
  overflow-x: scroll;
  max-height: 142px;
  white-space: nowrap;
  overflow-y: hidden;
  margin-bottom: 6px;
}

.module-staged-attachment {
  margin-right: 8px;

  &.module-image::before {
    background: linear-gradient(
      180deg,
      $color-black-alpha-30 0%,
      transparent 100%
    );
    content: '';
    display: block;
    height: 40px;
    opacity: 0;
    position: absolute;
    transition: opacity 0.2s ease-out;
    width: 100%;
  }

  &.module-image:hover::before {
    opacity: 1;
  }
}

// Module: Staged Generic Attachment

.module-staged-generic-attachment {
  height: 120px;
  width: 120px;
  display: inline-block;
  position: relative;
  border-radius: 4px;
  vertical-align: middle;
  white-space: nowrap;

  @include light-theme {
    box-shadow: inset 0px 0px 0px 1px $color-black-alpha-20;
    background-color: $color-gray-05;
  }
  @include dark-theme {
    box-shadow: inset 0px 0px 0px 1px $color-gray-45;
    background-color: $color-gray-75;
    color: $color-gray-02;
  }
}

.module-staged-generic-attachment__close-button {
  @include staged-attachment-close-button;

  @include light-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-black);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-gray-45);
  }
}

.module-staged-generic-attachment__icon {
  margin-top: 30px;

  background: url('../images/file-gradient.svg') no-repeat center;
  height: 44px;
  width: 56px;
  margin-left: 32px;
  margin-right: 32px;
  margin-bottom: -4px;

  // So we can center the extension text inside this icon
  display: flex;
  flex-direction: row;
  align-items: center;
}

.module-staged-generic-attachment__icon__extension {
  font-size: 10px;
  line-height: 13px;
  letter-spacing: 0.1px;
  text-transform: uppercase;

  // Along with flow layout in parent item, centers text
  text-align: center;
  width: 25px;
  margin-left: auto;
  margin-right: auto;

  // We don't have much room for text here, cut it off without ellipse
  overflow-x: hidden;
  white-space: nowrap;
  text-overflow: clip;

  color: $color-gray-90;
}

.module-staged-generic-attachment__filename {
  @include font-caption;

  margin: 7px;
  margin-top: 5px;
  text-align: center;

  overflow: hidden;
  height: 2.4em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
}

// Module: Staged Placeholder Attachment

.module-staged-placeholder-attachment {
  @include button-reset;

  margin: 1px;
  border-radius: 4px;

  height: 120px;
  width: 120px;
  display: inline-block;
  vertical-align: middle;
  position: relative;

  @include light-theme {
    border: 1px solid $color-gray-25;
    &:hover {
      background: $color-gray-05;
    }
  }
  @include keyboard-mode {
    &:focus {
      box-shadow: inset 0 0 0 2px $color-ultramarine;
    }
  }

  @include dark-theme {
    border: 1px solid $color-gray-60;

    &:hover {
      background: $color-gray-75;
    }
  }
  @include dark-keyboard-mode {
    &:focus {
      box-shadow: inset 0 0 0 2px $color-ultramarine;
    }
  }
}

.module-staged-placeholder-attachment__plus-icon {
  position: absolute;
  left: 50%;
  top: 50%;

  transform: translate(-50%, -50%);

  height: 36px;
  width: 36px;

  @include light-theme {
    @include color-svg('../images/icons/v2/plus-24.svg', $color-gray-45);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/plus-24.svg', $color-gray-60);
  }
}

// Module: Spinner

.module-spinner__container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  height: 56px;
  width: 56px;
}

.module-spinner__circle {
  position: absolute;
  top: 0;
  left: 0;

  z-index: $z-index-above-base;
  height: 100%;
  width: 100%;

  @include color-svg('../images/spinner-track-56.svg', $color-white-alpha-40);
}
.module-spinner__arc {
  position: absolute;
  top: 0;
  left: 0;

  z-index: $z-index-above-above-base;
  height: 100%;
  width: 100%;

  animation: rotate 1000ms linear infinite;

  @include light-theme {
    @include color-svg('../images/spinner-56.svg', $color-gray-60);
  }
  @include dark-theme {
    @include color-svg('../images/spinner-56.svg', $color-gray-05);
  }
}

// In these --small and --mini sizes, we're exploding our @color-svg mixin so we don't
//   have to duplicate our background colors for the dark/ios/size matrix.

.module-spinner__container--small {
  height: 24px;
  width: 24px;
}

.module-spinner__circle--small {
  -webkit-mask: url('../images/spinner-track-24.svg') no-repeat center;
  -webkit-mask-size: 100%;

  // For specificity
  @include dark-theme {
    -webkit-mask: url('../images/spinner-track-24.svg') no-repeat center;
    -webkit-mask-size: 100%;
  }
}
.module-spinner__arc--small {
  -webkit-mask: url('../images/spinner-24.svg') no-repeat center;
  -webkit-mask-size: 100%;

  // For specificity
  @include dark-theme {
    -webkit-mask: url('../images/spinner-24.svg') no-repeat center;
    -webkit-mask-size: 100%;
  }
}

.module-spinner__circle--incoming {
  background-color: $color-white-alpha-40;
}
.module-spinner__arc--incoming {
  @include light-theme {
    background-color: $color-gray-60;
  }
  @include dark-theme {
    background-color: $color-gray-02;
  }
}

.module-spinner__circle--outgoing {
  @include light-theme {
    background-color: $color-white-alpha-40;
  }
  @include dark-theme {
    background-color: $color-white-alpha-40;
  }
}
.module-spinner__arc--outgoing {
  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-05;
  }
}

.module-spinner__circle--on-avatar {
  background-color: $color-white-alpha-40;
}
.module-spinner__circle--on-background {
  @include light-theme {
    background-color: $color-gray-05;
  }
  @include dark-theme {
    background-color: $color-gray-75;
  }
}
.module-spinner__arc--on-background {
  @include light-theme {
    background-color: $color-gray-60;
  }
  @include dark-theme {
    background-color: $color-gray-25;
  }
}

.module-spinner__circle--on-captcha {
  background-color: $color-white-alpha-40;
}

.module-spinner__circle--on-progress-dialog {
  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-80;
  }
}
.module-spinner__arc--on-progress-dialog {
  background-color: $color-ultramarine;
}
.module-spinner__arc--on-avatar {
  background-color: $color-white;
}
.module-spinner__arc--on-captcha {
  background-color: $color-white;
}

// Module: Reaction Viewer

.module-reaction-viewer {
  width: 320px;
  height: 320px;
  border-radius: 8px;
  display: flex;
  flex-direction: column;

  @include popper-shadow();

  @include light-theme() {
    background: $color-white;
  }

  @include dark-theme() {
    background: $color-gray-75;
  }

  &__header {
    width: 100%;
    min-height: 44px;
    padding: 0px 8px;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    overflow-x: auto;

    &__button {
      min-height: 28px;
      border: none;
      border-radius: 18px;
      padding: 0px 8px;
      display: flex;
      justify-content: center;
      align-items: center;
      flex-basis: 45px;
      flex-shrink: 0;

      &:not(:first-of-type) {
        margin-left: 4px;
      }

      &:focus {
        outline: none;
      }
      @include keyboard-mode {
        &:focus {
          box-shadow: 0px 0px 0px 2px $color-ultramarine;
        }
      }

      background: none;

      &--selected {
        @include light-theme() {
          background: $color-gray-05;
        }

        @include dark-theme() {
          background: $color-gray-60;
        }
      }

      &__count,
      &__all {
        @include font-body-2-bold();

        white-space: nowrap;

        @include light-theme() {
          color: $color-gray-90;
        }

        @include dark-theme() {
          color: $color-gray-05;
        }
      }

      &__count {
        margin-left: 4px;
      }
    }
  }

  &__body {
    flex-grow: 1;
    padding: 0 16px;
    overflow: auto;

    &__row {
      margin-top: 12px;
      min-height: 32px;
      display: flex;
      flex-direction: row;
      justify-content: flex-start;
      align-items: center;

      &:last-of-type {
        margin-bottom: 12px;
      }

      &__avatar {
        min-width: 32px;
        flex-shrink: 1;
      }

      &__name {
        @include font-body-1-bold();
        flex-grow: 1;
        margin-left: 8px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;

        @include light-theme() {
          color: $color-gray-90;
        }

        @include dark-theme() {
          color: $color-gray-05;
        }
      }

      &__emoji {
        width: 18px;
        flex-shrink: 1;
      }
    }
  }
}

// Module: Calling
.module-calling {
  // creates a new independent stacking context that includes modals
  //
  // container has no width/height, direct children need to:
  // - size themselves explicitly (no percentage width/height or top/bottom or left/right)
  // - size themselves in relation to viewport (position: fixed)
  &__modal-container {
    position: fixed;
    top: var(--titlebar-height);
    left: 0;
    z-index: $z-index-on-top-of-everything;
  }

  &__container {
    align-items: center;
    background-color: $calling-background-color;
    display: flex;
    flex-direction: column;
    height: var(--window-height);
    justify-content: center;
    position: fixed;
    width: 100%;
    z-index: $z-index-calling;
  }

  &__header {
    color: #ffffff;
    font-style: normal;
    padding-bottom: 24px;
    padding-top: calc(24px + var(--title-bar-drag-area-height));
    text-align: center;
    @include calling-text-shadow;
    width: 100%;

    &--header-name {
      font-size: 15px;
      font-weight: 600;
      letter-spacing: -0.009em;
      line-height: 21px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
  }

  &__buttons {
    bottom: 0;
    display: flex;
    justify-content: center;
    padding-bottom: 32px;
    padding-top: 32px;
    position: absolute;
    text-align: center;
    width: 100%;

    &--inline {
      position: static;
    }
  }

  &__background {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: center;
    overflow: hidden;
    position: relative;
    width: 100%;

    &--blur {
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center;
      filter: blur(25px);
      height: 100%;
      position: absolute;
      width: 100%;
    }
  }

  &__camera-is-off {
    @include calling-text-shadow;
    @include font-body-1;
    color: $color-white;
    display: flex;
    z-index: $z-index-base;
    margin-top: 10px;

    // To match the icon height in ::before
    line-height: 24px;

    &::before {
      content: '';
      display: block;
      @include color-svg(
        '../images/icons/v2/video-off-solid-24.svg',
        $color-white
      );
      height: 24px;
      margin-right: 10px;
      width: 24px;
    }
  }
}

@keyframes module-ongoing-call__controls--fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes module-ongoing-call__controls--fade-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

.module-ongoing-call {
  $local-preview-width: 136px;
  $local-preview-height: 102px;

  &__remote-video-enabled {
    background-color: $color-gray-95;
    height: 100%;
    width: 100%;
  }

  &__remote-video-disabled {
    background-color: $color-gray-95;
    height: var(--window-height);
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  &__container {
    &--direct:not(&--call-not-started) {
      .module-ongoing-call__header {
        position: absolute;
      }
      .module-ongoing-call__footer {
        position: absolute;
      }
    }
  }

  &__header {
    background: linear-gradient($color-black-alpha-40, transparent);
    top: 0;
    width: 100%;
    z-index: $z-index-above-base;
    padding-bottom: 1rem;
  }

  &__header-message {
    font-weight: normal;
    font-size: 13px;
    font-variant: tabular-nums;
    line-height: 18px;
    letter-spacing: -0.0025em;
  }

  &__direct-call-ringing-spacer {
    flex: 1;
  }

  &__participants {
    display: flex;
    flex: 1 1 0;
    width: 100%;

    &__grid {
      flex-grow: 1;
      position: relative;
    }

    &__overflow {
      flex: 0 0 auto;
      position: relative;
      margin-left: 16px;
      margin-right: 16px;

      &__inner {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        max-height: 100%;
        overflow-y: scroll;

        &::-webkit-scrollbar,
        &::-webkit-scrollbar-thumb {
          width: 0;
          background: transparent;
        }
      }

      & .module-ongoing-call__group-call-remote-participant {
        width: 100%;
        margin-bottom: 1rem;
      }

      &__scroll-marker {
        $scroll-marker-selector: &;

        @include smooth-scroll;

        display: flex;
        justify-content: center;
        left: 0;
        opacity: 1;
        position: absolute;
        transition: opacity 200ms ease-out;
        width: 100%;
        z-index: $z-index-above-above-base;

        &--hidden {
          opacity: 0;
        }

        &__button {
          &::before {
            @include color-svg(
              '../images/icons/v2/chevron-down-24.svg',
              $color-white
            );

            content: '';
            display: block;
            height: 100%;
            width: 100%;
          }

          background: $color-gray-60;
          border-radius: 100%;
          border: 0;
          box-shadow: 0 0 5px rgba($color-gray-95, 0.5);
          height: 28px;
          margin: 12px 0;
          opacity: 0;
          outline: none;
          transition: opacity 200ms ease-out;
          width: 28px;
        }

        &--top {
          top: 0;
          background: linear-gradient(
            $calling-background-color,
            transparent 20px,
            transparent
          );

          #{$scroll-marker-selector}__button {
            transform: rotate(180deg);
          }
        }

        &--bottom {
          bottom: 0;
          background: linear-gradient(
            to top,
            $calling-background-color,
            transparent 20px,
            transparent
          );
        }
      }

      &:hover &__scroll-marker__button {
        opacity: 1;
      }
    }
  }

  &__group-call-remote-participant {
    display: flex;
    justify-content: center;
    position: relative;

    line-height: 0;
    overflow: hidden;
    border-radius: 5px;
    transition: top 200ms linear, left 200ms linear, width 200ms linear,
      height 200ms linear;

    &__remote-video {
      // The background-color is seen while the video loads.
      background-color: $color-gray-75;
    }

    &__blocked {
      @include color-svg('../images/icons/v2/block-24.svg', $color-white);
      height: 24px;
      margin-bottom: 16px;
      width: 24px;

      &--info {
        @include button-reset;
        background-color: $color-gray-75;
        border-radius: 16px;
        color: $color-white;
        line-height: 16px;
        padding: 3px 10px;
      }

      &--modal-title {
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        display: -webkit-box;
        overflow: hidden;
        text-overflow: ellipsis;
      }
    }

    &__info {
      @include font-caption;
      align-items: flex-end;
      bottom: 0;
      display: flex;
      height: 48px;
      justify-content: space-between;
      padding: 6px;
      position: absolute;
      user-select: none;
      width: 100%;
      z-index: $z-index-above-base;

      &__contact-name {
        font-size: 12px;
        color: $color-white;
        margin-right: 20px;
        overflow: hidden;
        text-overflow: ellipsis;
        visibility: hidden;
        white-space: nowrap;
        margin-bottom: 2px;
      }
    }

    &:hover {
      .module-ongoing-call__group-call-remote-participant__info {
        background: linear-gradient(
          180deg,
          transparent,
          $color-black-alpha-60 100%
        );

        &__contact-name {
          visibility: visible;
        }
      }
    }
  }

  &__local-preview-fullsize {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: $z-index-negative;

    video {
      @include lonely-local-video-preview;
    }

    &--presenting {
      video {
        transform: none;
      }
    }
  }

  &__footer {
    background: linear-gradient(transparent, $color-black-alpha-40);
    bottom: 0;
    display: flex;
    justify-content: space-between;
    width: 100%;
    z-index: $z-index-above-base;

    &__actions {
      align-items: center;
      display: flex;
      flex-grow: 1;
      justify-content: center;
    }

    // This layout-only element is not ideal, but lets us keep the actions centered until
    //   until they'd overlap with the video, at which point they start to move.
    &__local-preview-offset {
      flex: 1 0;
      max-width: $local-preview-width;
      visibility: hidden;
    }

    &__local-preview {
      border-radius: 5px;
      display: flex;
      height: $local-preview-height;
      margin: 2px 16px 16px 0;
      overflow: hidden;
      position: relative;
      width: $local-preview-width;

      &__video {
        // The background-color is seen while the video loads.
        background-color: $color-gray-75;
        height: 100%;
        transform: rotateY(180deg);
        width: 100%;

        &--presenting {
          transform: inherit;
        }
      }

      .CallingAudioIndicator {
        bottom: 6px;
        position: absolute;
        right: 6px;
        z-index: $z-index-base;
      }
    }
  }

  &__controls--fadeIn {
    animation: {
      name: module-ongoing-call__controls--fade-in;
      duration: 400ms;
      timing-function: $ease-out-expo;
      fill-mode: forwards;
    }
  }

  &__controls--fadeOut {
    animation: {
      name: module-ongoing-call__controls--fade-out;
      duration: 1200ms;
      timing-function: $ease-out-expo;
      fill-mode: forwards;
    }
  }
}

.module-calling-tools {
  display: flex;
  justify-content: flex-end;
  position: absolute;
  top: calc(24px + var(--title-bar-drag-area-height));
  width: 100%;

  &__button {
    margin-right: 25px;
  }
}

.module-calling-pip {
  backface-visibility: hidden;
  background-color: $color-gray-95;
  border-radius: 4px;
  box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.05), 0px 8px 20px rgba(0, 0, 0, 0.3);
  cursor: grab;
  height: 158px;
  position: fixed;
  width: 120px;
  z-index: $z-index-calling-pip;

  & .module-ongoing-call__group-call-remote-participant {
    border-radius: 0;
  }

  &__video {
    &--remote {
      align-items: center;
      background-color: $color-gray-95;
      border-radius: 4px 4px 0 0;
      display: flex;
      height: 120px; // This height should be kept in sync with <CallingPipRemoteVideo>'s hard-coded height.
      justify-content: center;
      overflow: hidden;
      position: relative;
      width: 100%;

      // The avatar image can be dragged on Windows.
      .module-Avatar img {
        -webkit-user-drag: none;
        -webkit-user-select: none;
      }
    }

    &--local {
      bottom: 38px;
      height: 32px;
      position: absolute;
      right: 4px;
      transform: rotateY(180deg);
      width: 32px;
    }
  }

  &__actions {
    align-items: center;
    background-color: $color-gray-02;
    border-radius: 0 0 4px 4px;
    display: flex;
    flex-direction: row;
    height: 38px;
    justify-content: space-around;

    @include dark-theme {
      background-color: $color-gray-65;
    }
  }

  &__button {
    &--hangup {
      @include color-svg(
        '../images/icons/v2/phone-down-28.svg',
        $color-gray-75
      );
      height: 28px;
      width: 28px;
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/phone-down-28.svg',
          $color-gray-15
        );
      }
    }

    &--pip {
      @include color-svg(
        '../images/icons/v2/pip-maximize-24.svg',
        $color-gray-75
      );
      height: 24px;
      width: 24px;
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/pip-maximize-24.svg',
          $color-gray-15
        );
      }
    }
  }
}

.module-calling-participants-list {
  background-color: $color-gray-80;
  border-radius: 8px;
  color: $color-white;
  margin-right: 12px;
  margin-top: 54px;
  overflow: hidden;
  padding: 14px;
  width: 280px;
  padding-bottom: 0;

  &__overlay {
    display: flex;
    width: var(--window-width);
    height: var(--window-height);
    justify-content: flex-end;
    left: 0;
    position: absolute;
    top: 0;
    z-index: $z-index-popup;
  }

  &__title {
    @include font-body-2-bold;
  }

  &__contact-icon {
    background-color: $color-gray-25;
  }

  &__list {
    height: 100%;
    margin-bottom: 0;
    margin-left: -14px;
    margin-right: -14px;
    margin-top: 22px;
    overflow: scroll;
    padding-bottom: 24px;
    padding-left: 14px;
    padding-right: 14px;
    padding-top: 0;

    &::-webkit-scrollbar {
      width: 6px;
    }

    &::-webkit-scrollbar-thumb {
      border: none;
      border-radius: 4px;
      background-color: $color-gray-45;
    }

    &::-webkit-scrollbar-track {
      background-color: $color-gray-80;
    }
  }

  &__contact {
    @include font-body-1;
    align-items: center;
    display: flex;
    justify-content: space-between;
    list-style-type: none;
    margin-bottom: 16px;
  }

  &__name {
    display: inline-block;
    margin-left: 8px;
    max-width: 130px;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
    white-space: nowrap;
  }

  &__header {
    display: flex;
    justify-content: space-between;
  }

  &__close {
    @include button-reset;

    @include color-svg('../images/x-shadow-16.svg', $color-gray-15);

    height: 16px;
    width: 16px;
    z-index: $z-index-above-base;

    @include keyboard-mode {
      &:focus {
        outline: 2px solid $color-ultramarine;
      }
    }
  }

  &__muted {
    &--video {
      @include color-svg(
        '../images/icons/v2/video-off-solid-28.svg',
        $color-white
      );
      display: inline-block;
      margin-left: 18px;
      height: 16px;
      width: 16px;
    }

    &--audio {
      @include color-svg(
        '../images/icons/v2/mic-off-solid-28.svg',
        $color-white
      );
      display: inline-block;
      margin-left: 18px;
      height: 16px;
      width: 16px;
    }
  }

  &__presenting {
    @include color-svg('../images/icons/v2/share-screen-26.svg', $color-white);
    display: inline-block;
    margin-left: 18px;
    height: 16px;
    width: 16px;
  }
}

.module-call-need-permission-screen {
  align-items: center;
  background-color: $color-gray-95;
  color: $color-gray-05;
  display: flex;
  flex-direction: column;
  height: var(--window-height);
  justify-content: center;
  position: relative;
  width: 100%;

  &__text {
    margin: 2em 1em;
    max-width: 400px;
    @include font-body-1;
    text-align: center;
  }

  &__button {
    padding: 0.5em 1em;
    border: 0;
    border-radius: 4px;
    @include font-body-1-bold;
    color: $color-gray-05;
    background: $color-gray-65;
  }
}

// Module: conversation list

.module-conversation-list {
  $normal-row-height: 72px;

  @include scrollbar;
  padding-left: 10px;
  padding-right: 10px;

  &--width-narrow {
    padding-left: 10px;
    padding-right: 10px;
  }

  &__item {
    &--archive-button {
      @include button-reset;

      align-items: center;
      display: flex;
      justify-content: center;
      border-radius: 10px;
      height: $normal-row-height;
      line-height: $normal-row-height;
      text-align: center;
      width: 100%;
      padding-left: 18px;
      padding-right: 18px;
      display: flex;

      @include light-theme {
        color: $color-gray-60;

        &:hover,
        &:focus {
          background-color: $color-gray-05;
        }
      }
      @include dark-theme {
        color: $color-gray-25;
        &:hover,
        &:focus {
          background-color: $color-gray-75;
        }
      }

      &__icon {
        &::before {
          display: block;
          content: '';
          width: 24px;
          height: 24px;

          @include light-theme {
            @include color-svg(
              '../images/icons/v2/archive-outline-16.svg',
              $color-gray-60
            );
          }
          @include dark-theme {
            @include color-svg(
              '../images/icons/v2/archive-solid-16.svg',
              $color-gray-25
            );
          }
        }
      }

      &__text {
        @include font-body-1-bold;
        margin-left: 8px;
        margin-right: 8px;
      }

      &__archived-count {
        @include font-body-2-bold;

        padding: 6px;
        padding-top: 1px;
        padding-bottom: 1px;
        border-radius: 10px;
        white-space: pre;

        @include light-theme {
          color: $color-gray-60;
          background-color: $color-gray-05;
        }
        @include dark-theme {
          color: $color-gray-25;
          background-color: $color-gray-75;
        }
      }

      .module-conversation-list--width-narrow & {
        &__icon {
          display: block;
          width: 48px;
          height: 48px;
          padding: 12px;
        }

        &__text,
        &__archived-count {
          display: none;
        }
      }
    }

    &--contact-or-conversation {
      $unread-indicator-selector: '#{&}__unread-indicator';
      $avatar-container-unread-indicator-selector: '#{&}__avatar-container #{$unread-indicator-selector}';

      @include button-reset;

      align-items: center;
      border-radius: 10px;
      cursor: inherit;
      display: flex;
      flex-direction: row;
      height: $normal-row-height;
      margin: 2px 0;
      padding: 8px 14px;
      user-select: none;
      width: 100%;

      .module-conversation-list--width-narrow & {
        padding-left: 14px;
        padding-right: 0;
      }

      &--is-button {
        cursor: pointer;

        &:disabled {
          cursor: inherit;
        }

        &:hover:not(:disabled),
        &:focus:not(:disabled) {
          @include light-theme {
            background-color: $color-black-alpha-06;
          }
          @include dark-theme {
            background-color: $color-white-alpha-06;
          }
        }
      }

      &--is-checkbox {
        cursor: pointer;

        &--disabled {
          cursor: not-allowed;
        }

        $disabled-selector: '#{&}--disabled';
        &:hover:not(#{$disabled-selector}),
        &:focus:not(#{$disabled-selector}) {
          @include light-theme {
            background-color: $color-gray-05;
          }
          @include dark-theme {
            background-color: $color-gray-75;
          }
        }
      }

      &--is-selected {
        @include light-theme {
          $background-color: $color-gray-15;
          background-color: $background-color;
          #{$avatar-container-unread-indicator-selector} {
            border-color: $background-color;
          }
        }
        @include dark-theme {
          $background-color: $color-gray-65;
          background-color: $background-color;
          #{$avatar-container-unread-indicator-selector} {
            border-color: $background-color;
          }
        }
      }

      &__avatar-container {
        position: relative;

        #{$unread-indicator-selector} {
          $border-width: 3px;
          $size: 21px + $border-width;

          @include rounded-corners;
          border: $border-width solid transparent;
          display: none;
          height: $size;
          margin: 0;
          min-width: $size;
          position: absolute;
          right: -(5px + $border-width);
          top: -(1px + $border-width);

          .module-conversation-list--width-narrow & {
            display: block;
          }

          @include light-theme {
            border-color: $color-gray-02;
          }
          @include dark-theme {
            border-color: $color-gray-80;
          }

          &--two-digits,
          &--many {
            right: -(7px + $border-width);
          }
        }
      }

      // We want this to just be the unread indicator selector, not a child of the parent.
      @at-root #{$unread-indicator-selector} {
        $size: 18px;

        @include font-caption-bold;
        border-radius: 10px;
        color: $color-white;
        font-weight: 500;
        height: $size;
        line-height: $size;
        margin-left: 10px;
        margin-top: 1px;
        min-width: $size;
        padding-left: 3px;
        padding-right: 3px;
        text-align: center;
        word-break: normal;
        display: flex;
        justify-content: center;
        align-items: center;

        .module-conversation-list--width-narrow & {
          display: none;
        }

        @include light-theme {
          background-color: $color-ultramarine;
        }
        @include dark-theme {
          background-color: $color-ultramarine-dawn;
        }

        &--two-digits,
        &--many {
          padding-left: 4px;
          padding-right: 4px;
        }

        &--many {
          font-size: 10px;

          &::after {
            content: '+';
            display: inline-block;
            font-size: 9px;
          }
        }
      }

      &__content {
        flex-grow: 1;
        margin-left: 12px;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        overflow: hidden;

        .module-conversation-list--width-narrow & {
          margin-left: 0;
        }

        &--disabled {
          opacity: 0.5;
        }

        &__header {
          display: flex;
          flex-direction: row;
          align-items: center;

          .module-conversation-list--width-narrow & {
            display: none;
          }

          &__name {
            align-items: center;
            display: flex;
            flex-grow: 1;
            flex-shrink: 1;

            @include font-body-1-bold;

            overflow: hidden;
            white-space: nowrap;
            text-overflow: ellipsis;

            @include light-theme {
              color: $color-gray-90;
            }
            @include dark-theme {
              color: $color-gray-05;
            }

            &__contact-name {
              overflow: hidden;
              text-overflow: ellipsis;
            }

            &__mute-icon {
              $size: 14px;

              height: $size;
              margin-inline-start: 8px;
              min-width: $size;
              width: $size;

              @include light-theme {
                @include color-svg(
                  '../images/icons/v2/bell-disabled-outline-24.svg',
                  $color-gray-45
                );
              }

              @include dark-theme {
                @include color-svg(
                  '../images/icons/v2/bell-disabled-solid-24.svg',
                  $color-gray-25
                );
              }
            }
          }

          &__date {
            @include font-caption;
            display: inline-block;
            flex-shrink: 0;
            margin-left: 6px;

            @include light-theme {
              color: $color-gray-60;
            }
            @include dark-theme {
              color: $color-gray-25;
            }
          }
        }

        &__message {
          display: flex;
          flex-direction: row;
          justify-content: flex-end;

          .module-conversation-list--width-narrow & {
            align-items: center;
            justify-content: flex-start;
          }

          &__text {
            .module-conversation-list__item--contact-or-conversation--is-checkbox
              & {
              /* restrict the growth so it doesn't encroach on the checkbox */
              -webkit-line-clamp: 1;
            }
          }

          &__text {
            flex-grow: 1;
            flex-shrink: 1;

            @include font-body-2;

            -webkit-box-orient: vertical;
            -webkit-line-clamp: 2;
            display: -webkit-box;
            overflow: hidden;
            text-overflow: ellipsis;
            text-align: left;

            @include light-theme {
              color: $color-gray-60;
            }
            @include dark-theme {
              color: $color-gray-25;
            }

            .module-conversation-list--width-narrow & {
              display: none;
            }

            &--always-full-size {
              height: 36px; // two lines
            }

            &__message-request {
              @include font-body-2-bold;

              @include light-theme {
                color: $color-gray-60;
              }
              @include dark-theme {
                color: $color-gray-25;
              }
            }

            &__draft-prefix,
            &__deleted-for-everyone {
              font-style: italic;
              margin-right: 3px;
            }

            &__status-icon {
              flex-shrink: 0;

              margin-top: 4px;
              width: 12px;
              height: 12px;
              display: inline-block;
              margin-left: 6px;

              .module-conversation-list--width-narrow & {
                display: none;
              }

              @mixin normal-status-icon($icon) {
                @include light-theme {
                  @include color-svg($icon, $color-gray-45);
                }
                @include dark-theme {
                  @include color-svg($icon, $color-gray-25);
                }
              }

              &--sending {
                @include only-when-page-is-visible {
                  animation: rotate 4s linear infinite;
                }
                @include light-theme {
                  @include color-svg('../images/sending.svg', $color-gray-60);
                }
                @include dark-theme {
                  @include color-svg('../images/sending.svg', $color-gray-45);
                }
              }

              &--sent {
                @include normal-status-icon(
                  '../images/check-circle-outline.svg'
                );
              }

              &--delivered {
                @include normal-status-icon('../images/double-check.svg');
                width: 18px;
              }

              &--read,
              &--viewed {
                @include normal-status-icon('../images/read.svg');
                width: 18px;
              }

              &--error,
              &--partial-sent {
                @include light-theme {
                  @include color-svg(
                    '../images/icons/v2/error-outline-12.svg',
                    $color-accent-red
                  );
                }
                @include dark-theme {
                  @include color-svg(
                    '../images/icons/v2/error-solid-12.svg',
                    $color-accent-red
                  );
                }
              }

              &--paused {
                @include light-theme {
                  @include color-svg(
                    '../images/icons/v2/error-outline-12.svg',
                    $color-gray-60
                  );
                }
                @include dark-theme {
                  @include color-svg(
                    '../images/icons/v2/error-solid-12.svg',
                    $color-gray-45
                  );
                }
              }
            }

            &__message-search-result-contents {
              display: -webkit-box;
              white-space: initial;
              -webkit-box-orient: vertical;
              -webkit-line-clamp: 2;
            }

            &__start-new-conversation {
              @include font-body-1-italic;
            }
          }
        }
      }

      &__checkbox {
        -webkit-appearance: none;
        background: $color-white;
        border-radius: 100%;
        height: 20px;
        margin-left: 16px;
        margin-right: 16px;
        width: 20px;
        min-width: 20px;
        pointer-events: none;

        @include light-theme {
          border: 1px solid $color-gray-15;
        }
        @include dark-theme {
          border: 1px solid $color-gray-80;
        }

        &:focus {
          outline: none;
        }

        @include keyboard-mode {
          &:focus {
            border-width: 2px;
            border-color: $color-ultramarine;
            &:checked {
              box-shadow: inset 0 0 0px 1px $color-white;
            }
          }
        }
        @include dark-keyboard-mode {
          &:focus {
            border-width: 2px;
            border-color: $color-ultramarine-light;

            &:checked {
              box-shadow: inset 0 0 0px 1px $color-black;
            }
          }
        }

        &:disabled:not(:checked) {
          opacity: 0.5;
        }

        &:checked {
          $icon: '../images/icons/v2/check-24.svg';

          background: $color-ultramarine;
          display: flex;
          align-items: center;
          justify-content: center;

          &::before {
            content: '';
            display: block;
            @include color-svg($icon, $color-white);
            width: 13px;
            height: 13px;
          }

          @include light-theme {
            &:disabled {
              background: $color-gray-15;
            }
          }
          @include dark-theme {
            &:disabled {
              background: $color-gray-45;
            }
          }
        }

        &--container {
          margin-left: 8px;
          /* prevent sibling content from pushing this smaller (min-width: the "!important" of width) */
          min-width: 20px;
        }
      }

      &__spinner__container {
        margin-left: 16px;
        margin-right: 16px;
      }
    }

    &--header {
      @include font-body-1-bold;

      align-items: flex-end;
      display: flex;
      height: 100%;
      overflow-x: hidden;
      padding-bottom: 8px;
      padding-left: 16px;
      text-overflow: ellipsis;
      user-select: none;
      white-space: nowrap;

      @include dark-theme {
        color: $color-gray-05;
      }

      .module-conversation-list--width-narrow & {
        @include rounded-corners;
        display: block;
        height: 2px;
        margin: 19px 0 19px 14px;
        padding-bottom: 0;
        width: 48px;

        // Hide the text, but keep it for screen readers.
        color: transparent;
        overflow: hidden;
        text-indent: -99999px;

        @include light-theme {
          background: $color-black-alpha-12;
        }

        @include dark-theme {
          background: $color-white-alpha-12;
        }
      }
    }

    &--spinner {
      width: 100%;
      padding: 10px;

      text-align: center;
    }
  }
}

// Module: Left Pane

.module-left-pane {
  border-right-style: solid;
  border-right-width: 1px;
  display: inline-flex;
  flex-direction: column;
  height: 100%;
  position: relative;

  @include light-theme {
    $background-color: $color-gray-02;

    border-color: $color-gray-15;
    background-color: $background-color;

    ::-webkit-scrollbar-thumb {
      border: 2px solid $color-gray-02;
    }

    .module-conversation-list__item--contact-or-conversation:hover
      .module-conversation-list__item--contact-or-conversation__unread-indicator {
      border-color: mix($color-black, $background-color, 6%);
    }
  }

  @include dark-theme {
    $background-color: $color-gray-80;

    border-color: $color-gray-65;
    background-color: $background-color;

    ::-webkit-scrollbar-thumb {
      border: 2px solid $color-gray-80;
    }

    .module-conversation-list__item--contact-or-conversation:hover
      .module-conversation-list__item--contact-or-conversation__unread-indicator {
      border-color: mix($color-white, $background-color, 6%);
    }
  }
}

.module-left-pane__dialogs {
  &:first-child {
    margin-top: 8px;
  }
}

.module-left-pane__empty {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  padding: 0 32px;
  text-align: center;

  .module-left-pane--width-narrow & {
    display: none;
  }

  &--composer_icon {
    align-items: center;
    background-color: $color-gray-05;
    border-radius: 100%;
    display: inline-flex;
    height: 28px;
    justify-content: center;
    margin-bottom: -2px;
    margin-left: 4px;
    vertical-align: bottom;
    width: 28px;

    &--icon {
      $icon: '../images/icons/v2/compose-outline-24.svg';
      @include color-svg($icon, $color-gray-90);
      display: inline-block;
      height: 16px;
      width: 16px;
    }
  }
}

.module-left-pane__header {
  flex-grow: 0;
  flex-shrink: 0;
  user-select: none;

  &__contents {
    height: calc(#{$header-height} + var(--title-bar-drag-area-height));
    width: 100%;

    display: inline-flex;
    flex-direction: row;
    align-items: center;
    padding-top: var(--title-bar-drag-area-height);

    &__back-button {
      @include button-reset;

      margin-left: 7px;
      margin-right: 5px;

      width: 24px;
      height: 24px;

      &:disabled {
        cursor: not-allowed;
      }

      @include light-theme {
        @include color-svg(
          '../images/icons/v2/chevron-left-24.svg',
          $color-gray-60
        );
      }
      @include keyboard-mode {
        &:focus {
          @include color-svg(
            '../images/icons/v2/chevron-left-24.svg',
            $color-ultramarine
          );
        }
      }

      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/chevron-left-24.svg',
          $color-gray-25
        );
      }
      @include dark-keyboard-mode {
        &:hover {
          @include color-svg(
            '../images/icons/v2/chevron-left-24.svg',
            $color-ultramarine-light
          );
        }
      }
    }

    &__text {
      @include font-body-1-bold;
      flex-grow: 1;
      padding-right: 16px;

      @include light-theme {
        color: $color-gray-90;
      }
      @include dark-theme {
        color: $color-gray-05;
      }
    }
  }

  &__form {
    display: flex;
    flex-direction: column;

    &__expire-timer {
      display: flex;
      flex-direction: row;
      align-items: center;

      margin: 0 16px 16px 16px;

      &__label {
        margin-right: 12px;
      }

      .module-disappearing-timer-select {
        width: 144px;
      }
    }
  }
}

.module-left-pane__archive-helper-text {
  @include font-body-2;

  flex-grow: 0;
  flex-shrink: 0;
  user-select: none;

  padding: 1em;

  @include light-theme {
    color: $color-gray-60;
    background-color: $color-gray-05;
  }
  @include dark-theme {
    color: $color-gray-25;
    background-color: $color-gray-75;
  }
}

.module-left-pane__no-search-results,
.module-left-pane__compose-no-contacts {
  flex-grow: 1;
  margin-top: 27px;
  padding-left: 1em;
  padding-right: 1em;
  width: 100%;
  text-align: center;
  outline: none;
}

.module-left-pane__no-search-results__sms-only {
  margin-top: 12px;
  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-left-pane__compose-search-form {
  &__input {
    flex-grow: 1;
  }
}

.module-left-pane__list--measure {
  flex-grow: 1;
  flex-shrink: 1;
  outline: none;
}

.module-left-pane__list--wrapper {
  position: relative;
}

.module-left-pane__list {
  position: absolute;
  outline: none;
}

.module-left-pane__footer {
  bottom: 0;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  left: 0;
  padding: 12px;
  position: absolute;
  width: 100%;

  @include light-theme {
    background: linear-gradient(transparent, $color-gray-02);
  }

  @include dark-theme {
    background: linear-gradient(transparent, $color-gray-80);
  }
}

.module-left-pane__resize-grab-area {
  position: absolute;
  width: 8px;
  height: 100%;
  right: -8px;
  top: 0;
  z-index: $z-index-above-base;
  cursor: col-resize;
}

// Module: Timeline

.module-timeline {
  display: flex;
  height: 100%;
  overflow: hidden;
}

.module-timeline--disabled {
  user-select: none;
}

.module-timeline__messages__container {
  flex: 1 1;
  overflow-x: hidden;
  overflow-y: overlay;
  display: flex;
  flex-direction: column;
}

.module-timeline__messages {
  display: flex;
  flex-direction: column;
  flex: 1 1;
  padding-bottom: 6px;
  position: relative;
  justify-content: flex-end;

  // This is a modified version of ["Pin Scrolling to Bottom"][0].
  // [0]: https://css-tricks.com/books/greatest-css-tricks/pin-scrolling-to-bottom/
  &--have-newest {
    & > * {
      overflow-anchor: none;
    }

    &::after {
      content: '';
      height: 1px;
      display: block;
      overflow-anchor: auto;
    }
  }

  &--have-oldest {
    justify-content: flex-start;
  }

  &__at-bottom-detector {
    position: absolute;
    bottom: 0;
  }
}

.ReactVirtualized__List {
  outline: none;
}

// Module: CompositionPopper

%module-composition-popper {
  width: 332px;
  border-radius: 8px;
  margin-bottom: 6px;
  z-index: $z-index-context-menu;
  user-select: none;
  overflow: hidden;

  @include popper-shadow();

  @include light-theme {
    background: $color-gray-02;
    ::-webkit-scrollbar-thumb {
      border: 2px solid $color-gray-02;
    }
  }

  @include dark-theme {
    background: $color-gray-75;
    ::-webkit-scrollbar-thumb {
      border: 2px solid $color-gray-75;
    }
  }
}

// Module: StickerPicker

.module-sticker-picker {
  @extend %module-composition-popper;
  height: 400px;
  display: grid;
  grid-template-rows: 44px 1fr;
  grid-template-columns: 1fr;
  z-index: $z-index-context-menu;
}

.module-sticker-picker__header {
  display: flex;
  flex-direction: row;
  padding: 0 8px;
  justify-content: flex-start;
  align-items: center;
}

.module-sticker-picker__header__packs {
  width: 288px;
  overflow: hidden;
  position: relative;

  &__slider {
    display: flex;
    flex-direction: row;
    transform: translateX(0);
    transition: transform 200ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
}

.module-sticker-picker__header__button {
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: none;
  margin-right: 4px;

  outline: none;

  &:active,
  &:focus {
    @include keyboard-mode {
      background: $color-gray-05;
    }
    @include dark-keyboard-mode {
      background: $color-gray-60;
    }
  }

  &--selected {
    @include light-theme {
      background: $color-gray-15;
    }
    @include dark-theme {
      background: $color-gray-45;
    }
  }

  &--recents,
  &--add-pack {
    &::after {
      content: '';
      display: block;
      min-width: 20px;
      min-height: 20px;
    }
  }

  &--recents {
    &::after {
      @include light-theme {
        @include color-svg(
          '../images/icons/v2/recent-outline-20.svg',
          $color-gray-60
        );
      }
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/recent-solid-20.svg',
          $color-gray-25
        );
      }
    }
  }

  &--add-pack {
    &::after {
      @include light-theme {
        @include color-svg('../images/icons/v2/plus-20.svg', $color-gray-60);
      }
      @include dark-theme {
        @include color-svg('../images/icons/v2/plus-20.svg', $color-gray-25);
      }
    }
  }

  &--prev-page,
  &--next-page {
    top: 0;
    margin: 0;
    border-radius: 0;

    &::after {
      content: '';
      display: block;
      min-width: 16px;
      min-height: 16px;
    }

    @include light-theme {
      background: $color-gray-02;
    }

    @include dark-theme {
      background: $color-gray-75;
    }
  }

  &--prev-page {
    position: absolute;
    left: 0;

    &::after {
      @include light-theme {
        @include color-svg(
          '../images/icons/v2/chevron-left-16.svg',
          $color-gray-60
        );
      }
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/chevron-left-16.svg',
          $color-gray-25
        );
      }
    }
  }

  &--next-page {
    position: absolute;
    right: 0;

    &::after {
      @include light-theme {
        @include color-svg(
          '../images/icons/v2/chevron-right-16.svg',
          $color-gray-60
        );
      }
      @include dark-theme {
        @include color-svg(
          '../images/icons/v2/chevron-right-16.svg',
          $color-gray-25
        );
      }
    }
  }

  &--error {
    position: relative;

    &::before {
      display: block;
      content: '';
      width: 12px;
      height: 12px;
      position: absolute;
      left: 14px;
      top: 2px;
      @include color-svg(
        '../images/icons/v2/error-solid-24.svg',
        $color-accent-red
      );
    }
  }

  &--hint {
    position: relative;
    &::before {
      display: block;
      content: '';
      position: absolute;
      top: 0;
      right: 0;
      width: 14px;
      height: 14px;
      border-radius: 7px;
      background: $color-ultramarine;
    }
  }
}

.module-sticker-picker__header__button__image {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.module-sticker-picker__header__button__image--placeholder {
  min-width: 20px;
  min-height: 20px;
  max-width: 20px;
  max-height: 20px;
  background-color: $color-gray-05;
}

.module-sticker-picker__body {
  position: relative;

  &__content {
    width: 332px;
    height: 356px;
    padding: 8px 13px 16px 13px;
    overflow-y: auto;
    display: grid;
    grid-gap: 8px;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 68px;

    &--under-text {
      height: 320px;
    }

    &--under-long-text {
      height: 304px;
    }
  }

  &__cell {
    border: none;
    background: none;
    padding: 0;
    width: 68px;
    height: 68px;
    display: flex;
    justify-content: center;
    align-items: center;

    @include mouse-mode {
      outline: none;
    }

    &__image,
    &__placeholder {
      width: 100%;
      height: 100%;
      object-fit: contain;
    }

    &__placeholder {
      border-radius: 4px;

      @include light-theme() {
        background-color: $color-gray-05;
      }

      @include dark-theme() {
        background-color: $color-gray-60;
      }
    }
  }

  &--empty {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
  }

  &__text {
    @include font-body-1-bold;

    text-align: center;
    padding: 8px 16px 12px 0;

    @include light-theme() {
      color: $color-gray-60;
    }

    @include dark-theme() {
      color: $color-gray-25;
    }

    &:only-child {
      padding: 0 0 28px 0; // header height to offset the text so it is centered in the whole picker
    }

    &--error {
      @include light-theme() {
        color: $color-accent-red;
      }
      @include dark-theme() {
        color: $color-accent-red;
      }
    }

    &--hint {
      @include light-theme() {
        color: $color-ultramarine;
      }

      @include dark-theme() {
        color: $color-ultramarine-light;
      }
    }

    &--pin {
      padding: 8px 16px 12px 0px;
      position: absolute;
      top: 0;
    }
  }
}

// Module: StickerManager

.module-sticker-manager {
  padding: 0 16px;
  outline: none;
}

.module-sticker-manager__text {
  height: 18px;

  letter-spacing: 0px;
  line-height: 18px;

  @include light-theme() {
    color: $color-gray-60;
  }

  @include dark-theme() {
    color: $color-gray-25;
  }

  &--heading {
    @include font-body-1-bold;

    @include light-theme() {
      color: $color-gray-90;
    }

    @include dark-theme() {
      color: $color-gray-05;
    }
  }
}

.module-sticker-manager__empty {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 64px;
  border-radius: 8px;

  @include light-theme {
    background: $color-gray-02;
    color: $color-gray-60;
  }

  @include dark-theme {
    background: $color-gray-90;
    color: $color-gray-25;
  }
}

%blessed-sticker-pack-icon {
  height: 14px;
  width: 14px;
  border-radius: 8px;
  background-color: $color-white;
  display: inline-block;
  vertical-align: middle;
  margin: {
    left: 5px;
    bottom: 2px;
  }
  position: relative;

  &::before {
    content: '';
    display: block;
    width: 16px;
    height: 16px;
    position: absolute;
    top: -1px;
    left: -1px;

    @include light-theme {
      @include color-svg(
        '../images/icons/v2/check-circle-solid-24.svg',
        $color-accent-blue
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/check-circle-solid-24.svg',
        $color-accent-blue
      );
    }
  }
}

.module-sticker-manager__pack-row {
  @include button-reset;

  display: flex;
  flex-direction: row;
  padding: 16px;

  @include light-theme {
    & + & {
      border-top: 1px solid $color-gray-15;
    }
  }

  @include dark-theme {
    & + & {
      border-top: 1px solid $color-gray-75;
    }
  }

  @include keyboard-mode {
    &:focus {
      box-shadow: 0px 0px 0px 2px $color-ultramarine;
    }
  }

  &__cover {
    width: 48px;
    height: 48px;
    object-fit: contain;
  }
  &__cover-placeholder {
    width: 48px;
    height: 48px;
    background: $color-gray-05;
  }

  &__meta {
    flex-grow: 1;
    display: flex;
    flex-direction: column;

    &:not(:first-child) {
      padding: 0 12px;
    }

    &__title {
      flex: 1;
    }

    &__author {
      flex: 1;

      @include light-theme() {
        color: $color-gray-45;
      }

      @include dark-theme() {
        color: $color-gray-25;
      }
    }

    &__blessed-icon {
      @extend %blessed-sticker-pack-icon;
    }
  }

  &__controls {
    flex-shrink: 1;
    display: flex;
    justify-content: center;
    align-items: center;

    &__button {
      background: none;
      border: 0;
      &--menu {
        &::after {
          content: '';
          display: block;
          min-width: 24px;
          min-height: 24px;
          @include light-theme {
            @include color-svg(
              '../images/icons/v2/more-horiz-24.svg',
              $color-gray-60
            );
          }
          @include dark-theme {
            @include color-svg(
              '../images/icons/v2/more-horiz-24.svg',
              $color-gray-25
            );
          }
        }
      }
    }
  }
}

.module-sticker-manager__install-button {
  background: none;
  border: 0;
  color: $color-gray-90;

  @include font-body-1-bold;

  height: 24px;
  background: $color-gray-05;
  border-radius: 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 12px;

  @include dark-theme {
    color: $color-gray-05;
    background: $color-gray-75;
  }

  @include mouse-mode {
    outline: none;
  }

  &--blue {
    @include light-theme {
      background: $color-ultramarine;
      color: $color-white;
    }
    @include dark-theme {
      background: $color-ultramarine-light;
      color: $color-white;
    }
  }
}

.module-sticker-manager__preview-modal {
  &__overlay {
    background: $color-black-alpha-40;
    position: fixed;
    left: 0;
    top: 0;
    width: var(--window-width);
    height: var(--window-height);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: $z-index-popup-overlay;
  }

  &__container {
    position: relative;
    border-radius: 8px;
    box-shadow: 0 4px 12px 0 $color-black-alpha-20;
    width: 440px;
    height: 360px;
    overflow: hidden;
    display: flex;
    flex-direction: column;

    @include light-theme {
      background: $color-white;
    }
    @include dark-theme {
      background: $color-gray-75;
    }

    &__error {
      color: $color-accent-red;
      display: flex;
      justify-content: center;
      align-items: center;
      text-align: center;
      width: 100%;
      height: 100%;
      padding: 0 80px 30px 80px;

      @include font-body-1-bold;
    }

    &__header {
      display: flex;
      flex-direction: row;
      flex-shrink: 0;
      height: 36px;
      padding: 0 8px 0 16px;
      justify-content: space-between;
      align-items: center;

      &__text {
        @include font-body-1-bold;

        color: $color-gray-90;
        @include dark-theme {
          color: $color-gray-05;
        }
      }

      &__close-button {
        border: none;
        width: 20px;
        height: 20px;
        @include light-theme {
          @include color-svg('../images/icons/v2/x-24.svg', $color-gray-60);
        }
        @include dark-theme {
          @include color-svg('../images/icons/v2/x-24.svg', $color-gray-05);
        }
      }
    }

    &__sticker-grid {
      width: 100%;
      display: grid;
      grid-gap: 8px;
      grid-template-columns: repeat(4, 1fr);
      overflow-y: auto;
      overflow-x: hidden;
      padding: 0 16px;

      &::after {
        content: '';
        display: block;
        height: 80px;
        grid-column: 1 / span 4;
      }

      &__cell {
        width: 96px;
        height: 96px;
        display: flex;
        justify-content: center;
        align-items: center;

        &__image {
          width: 100%;
          height: 100%;
          object-fit: contain;
        }

        &--placeholder {
          border-radius: 4px;

          @include light-theme() {
            background: $color-gray-05;
          }

          @include dark-theme() {
            background: $color-gray-60;
          }
        }
      }
    }

    &__meta-overlay {
      border-radius: 4px;
      width: 408px;
      height: 52px;
      position: absolute;
      left: 16px;
      bottom: 16px;
      padding: 0 12px;
      display: flex;
      flex-direction: row;
      align-items: center;

      @include light-theme {
        background: $color-gray-05;
      }

      @include dark-theme {
        background: $color-gray-60;
      }

      &__info {
        display: flex;
        flex-direction: column;
        justify-content: center;
        flex-grow: 1;
        flex-shrink: 1;
        overflow: hidden;

        &__title {
          margin: 0;
          overflow: hidden;
          text-overflow: ellipsis;

          @include font-body-1-bold;

          @include light-theme {
            color: $color-gray-90;
          }

          @include dark-theme {
            color: $color-gray-05;
          }
        }

        &__author {
          margin: 0;
          overflow: hidden;
          white-space: nowrap;
          text-overflow: ellipsis;

          @include light-theme {
            color: $color-gray-45;
          }

          @include dark-theme {
            color: $color-gray-25;
          }
        }

        &__blessed-icon {
          @extend %blessed-sticker-pack-icon;
        }
      }

      &__install {
        flex-shrink: 0;
        overflow: hidden;
      }
    }
  }
}

// Module: Sticker button (launches the sticker picker)

.sticker-button-wrapper {
  height: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: 6px;
}

.module-sticker-button__button {
  border: 0;
  border-radius: 4px;
  background: none;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;

  @include keyboard-mode {
    &:focus {
      outline: 2px solid $color-ultramarine;
    }
  }

  outline: none;

  &::after {
    display: block;
    content: '';
    width: 24px;
    height: 24px;
    flex-shrink: 0;

    @include light-theme {
      @include color-svg(
        '../images/icons/v2/sticker-outline-24.svg',
        $color-gray-75
      );
    }
    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/sticker-outline-24.svg',
        $color-gray-15
      );
    }
  }

  &--active {
    @include light-theme() {
      background: $color-gray-05;
    }

    @include dark-theme() {
      background: $color-gray-75;
    }

    opacity: 1;
  }
}

.module-sticker-button__tooltip {
  @include button-reset;

  height: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 7px 12px;
  border-radius: 8px;
  margin-bottom: 6px;
  z-index: $z-index-tooltip;

  @include light-theme {
    background: $color-white;
  }

  @include dark-theme {
    background: $color-gray-75;
  }

  @include popper-shadow();

  &__triangle {
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 8px 0 8px;

    @include light-theme {
      border-color: $color-white transparent transparent transparent;
    }

    @include dark-theme {
      border-color: $color-gray-75 transparent transparent transparent;
    }

    &--top-end {
      top: 34px;
    }

    &--introduction {
      top: 72px;
    }
  }

  &__image {
    width: 20px;
    height: 20px;
    object-fit: contain;
  }
  &__image-placeholder {
    width: 20px;
    height: 20px;
    background-color: $color-gray-05;
  }

  &__text {
    margin-left: 4px;
    cursor: default;

    @include light-theme {
      color: $color-gray-90;
    }

    @include dark-theme {
      color: $color-gray-05;
    }

    &__title {
      font-weight: bold;
    }
  }

  &--introduction {
    width: 420px;
    height: 72px;
    display: flex;
    flex-direction: row;

    &__image {
      width: 52px;
      height: 52px;
    }

    &__meta {
      flex-grow: 1;
      padding: 0 12px;
      display: flex;
      flex-direction: column;
      justify-content: center;

      @include light-theme {
        color: $color-gray-90;
      }

      @include dark-theme {
        color: $color-gray-05;
      }

      &__title {
        margin: 0;

        @include font-body-1-bold;
        height: 16px;
      }

      &__subtitle {
        margin-top: 3px;
        height: 16px;
      }
    }

    &__close {
      flex-shrink: 1;
      height: 100%;
      &__button {
        width: 20px;
        height: 20px;
        border: none;

        @include light-theme {
          @include color-svg('../images/icons/v2/x-24.svg', $color-gray-60);
        }

        @include dark-theme {
          @include color-svg('../images/icons/v2/x-24.svg', $color-gray-05);
        }
      }
    }
  }
}

// Module: Emoji Picker

%module-emoji-picker--ribbon {
  height: 44px;
  display: flex;
  flex-direction: row;
  align-items: center;
}

.module-emoji-picker {
  @extend %module-composition-popper;
  height: 428px;
  display: grid;
  grid-template-rows: 44px 1fr;
  grid-template-columns: 1fr;

  &__header {
    @extend %module-emoji-picker--ribbon;
    justify-content: space-between;
    margin: 0 12px;

    &__search-field {
      flex-grow: 1;
      margin-left: 8px;
      position: relative;

      @include font-body-2;

      &::after {
        display: block;
        content: '';
        width: 16px;
        height: 16px;
        position: absolute;
        left: 8px;
        top: 6px;

        @include light-theme {
          @include color-svg(
            '../images/icons/v2/search-16.svg',
            $color-gray-60
          );
        }
        @include dark-theme {
          @include color-svg(
            '../images/icons/v2/search-16.svg',
            $color-gray-25
          );
        }
      }

      &__input {
        width: 100%;
        height: 28px;

        @include font-body-1;

        line-height: 28px;

        border-radius: 17px;
        border-width: 1px;
        border-style: solid;
        padding: 0 8px 0 30px;

        &:focus {
          outline: none;
        }

        @include light-theme {
          background: $color-white;
          color: $color-gray-90;
          border-color: $color-gray-60;

          &:focus {
            border-color: $color-ultramarine;
          }

          &:placeholder {
            color: $color-gray-45;
          }
        }

        @include dark-theme {
          border-color: $color-gray-25;
          background: $color-gray-75;
          color: $color-gray-05;

          &:focus {
            border-color: $color-ultramarine;
          }

          &:placeholder {
            color: $color-gray-45;
          }
        }
      }
    }
  }

  &__footer {
    @extend %module-emoji-picker--ribbon;
    justify-content: center;

    &__skin-tones {
      align-items: center;
      display: flex;
      flex-direction: row;
      flex-grow: 1;
      justify-content: center;
    }

    &__settings-spacer {
      width: 28px;
      margin-right: 12px;
    }
  }

  &__button {
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 8px;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background: none;

    @include mouse-mode {
      outline: none;
    }

    &--footer {
      &:not(:last-of-type) {
        margin-right: 4px;
      }
    }

    &--settings {
      margin-left: 12px;
      border-radius: 100%;

      @include light-theme {
        background: $color-white;
        box-shadow: 0px 0px 4px $color-black-alpha-20;
      }

      @include dark-theme {
        background: $color-gray-65;
      }

      &::before {
        display: block;
        width: 20px;
        height: 20px;
        content: '';

        @include light-theme {
          @include color-svg(
            '../images/icons/v2/settings-outline-16.svg',
            $color-gray-75
          );
        }

        @include dark-theme {
          @include color-svg(
            '../images/icons/v2/settings-solid-16.svg',
            $color-gray-25
          );
        }
      }
    }

    &--selected {
      @include light-theme {
        background: $color-gray-05;
      }

      @include dark-theme {
        background: $color-gray-60;
      }
    }

    &--icon {
      display: flex;
      justify-content: center;
      align-items: center;

      &::after {
        display: block;
        content: '';
        width: 20px;
        height: 20px;
      }

      &--search {
        &::after {
          @include light-theme {
            @include color-svg(
              '../images/icons/v2/search-16.svg',
              $color-gray-60
            );
          }
          @include dark-theme {
            @include color-svg(
              '../images/icons/v2/search-16.svg',
              $color-gray-25
            );
          }
        }
      }

      &--close {
        &::after {
          @include light-theme {
            @include color-svg('../images/icons/v2/x-24.svg', $color-gray-60);
          }
          @include dark-theme {
            @include color-svg('../images/icons/v2/x-24.svg', $color-gray-25);
          }
        }
      }

      &--recents {
        &::after {
          @include light-theme {
            @include color-svg(
              '../images/icons/v2/recent-outline-20.svg',
              $color-gray-60
            );
          }
          @include dark-theme {
            @include color-svg(
              '../images/icons/v2/recent-solid-20.svg',
              $color-gray-25
            );
          }
        }
      }

      &--emoji {
        &::after {
          @include light-theme {
            @include color-svg(
              '../images/icons/v2/emoji-smiley-outline-20.svg',
              $color-gray-60
            );
          }
          @include dark-theme {
            @include color-svg(
              '../images/icons/v2/emoji-smiley-solid-20.svg',
              $color-gray-25
            );
          }
        }
      }

      $categories: animal food activity travel object symbol flag;

      @each $cat in $categories {
        &--#{$cat} {
          &::after {
            @include light-theme {
              @include color-svg(
                '../images/icons/v2/emoji-#{$cat}-outline-20.svg',
                $color-gray-60
              );
            }
            @include dark-theme {
              @include color-svg(
                '../images/icons/v2/emoji-#{$cat}-solid-20.svg',
                $color-gray-25
              );
            }
          }
        }
      }
    }
  }

  &__body {
    padding: 8px 16px 0 12px;
    outline: none;

    &__emoji-cell {
      display: flex;
      flex-direction: row;
      justify-content: center;
      align-items: flex-start;
    }

    &--empty {
      display: flex;
      padding: 0;
      justify-content: center;
      align-items: center;
      @include font-body-1;

      @include light-theme {
        color: $color-gray-60;
      }

      @include dark-theme {
        color: $color-gray-25;
      }
    }
  }
}

// Module: EmojiButton

.emoji-button-wrapper {
  height: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 6px;
  padding-top: 4px;
}

.module-emoji-button__button {
  border: 0;
  border-radius: 4px;
  background: none;
  width: 32px;
  height: 32px;
  display: flex;
  justify-content: center;
  align-items: center;

  @include keyboard-mode {
    &:focus {
      outline: 2px solid $color-ultramarine;
    }
  }

  outline: none;

  &::after {
    display: block;
    content: '';
    width: 24px;
    height: 24px;
    flex-shrink: 0;

    @include light-theme {
      @include color-svg(
        '../images/icons/v2/emoji-smiley-outline-24.svg',
        $color-gray-75
      );
    }
    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/emoji-smiley-outline-24.svg',
        $color-gray-15
      );
    }
  }

  &--profile-editor::after {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/add-emoji-outline-24.svg',
        $color-gray-75
      );
    }
    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/add-emoji-outline-24.svg',
        $color-gray-15
      );
    }
  }

  &--has-emoji {
    opacity: 1;

    &::after {
      display: none;
    }
  }

  &--active {
    @include light-theme() {
      background: $color-gray-05;
    }

    @include dark-theme() {
      background: $color-gray-75;
    }

    opacity: 1;
  }
}

// Module: Emoji
@mixin emoji-size($size) {
  &--#{$size} {
    width: $size;
    height: $size;
    &--inline {
      display: inline-block;
      vertical-align: bottom;
      background-size: $size $size;
    }
  }
  &__image--#{$size} {
    width: $size;
    height: $size;
    transform: translate3d(0, 0, 0);
    vertical-align: baseline;
  }
}

.module-emoji {
  display: flex;
  justify-content: center;
  align-items: center;
  color: transparent;
  font-family: auto;

  @include light-theme() {
    caret-color: $color-gray-90;
  }

  @include dark-theme() {
    caret-color: $color-gray-05;
  }

  @include emoji-size(16px);
  @include emoji-size(18px);
  @include emoji-size(20px);
  @include emoji-size(24px);
  @include emoji-size(28px);
  @include emoji-size(32px);
  @include emoji-size(48px);
  @include emoji-size(64px);
  @include emoji-size(66px);
}

// Module: CompositionInput
.module-composition-input {
  &__quill {
    height: 100%;

    .ql-editor {
      caret-color: transparent;
      padding: 0;
      text-align: start;
      white-space: break-spaces;
      line-height: inherit;

      &--loaded {
        caret-color: auto;
      }

      &.ql-blank::before {
        left: 0;
        right: 0;
        font-style: normal;
      }

      .emoji-blot {
        width: 20px;
        height: 20px;
        vertical-align: text-bottom;
      }
    }
  }

  &__at-mention {
    background-color: $color-gray-20;
    border-radius: 4px;
    display: inline;
    padding-left: 4px;
    padding-right: 4px;
    height: 22px;
    line-height: 22px;

    @include dark-theme {
      background-color: $color-gray-60;
    }
  }

  &__input {
    $border-size: 1px;

    border-radius: 18px;
    overflow: hidden;
    word-break: break-word;

    // Override Quill styles
    .ql-container {
      @include font-body-1;
    }

    .ql-blank::before {
      @include light-theme() {
        color: $color-gray-45;
      }

      @include dark-theme() {
        color: $color-gray-25;
      }
    }

    @include light-theme() {
      // Same as background color
      background-color: $color-gray-05;
      color: $color-gray-90;
    }

    @include dark-theme() {
      // Same as background color
      background-color: $color-gray-75;
      color: $color-gray-05;
    }

    &__scroller {
      $padding-top: 5px;
      padding: $padding-top 10px $padding-top 10px;

      min-height: calc(32px - 2 * $border-size);
      max-height: calc(72px - 2 * $border-size);
      overflow: auto;

      &::-webkit-scrollbar-thumb {
        @include light-theme {
          border: 2px solid $color-gray-05;
        }
        @include dark-theme {
          border: 2px solid $color-gray-75;
        }
      }

      &--large {
        max-height: calc(212px - 2 * $border-size);
        min-height: calc(212px - 2 * $border-size);

        .DraftEditor-root {
          height: calc(212px - 2 * $padding-top - 2 * $border-size);
        }
      }
    }

    border: $border-size solid transparent;

    &:focus-within {
      outline: 0;
      @include keyboard-mode {
        border: $border-size solid $color-ultramarine;
      }
    }
  }

  &__suggestions {
    padding: 0;
    margin-bottom: 6px;
    border-radius: 8px;
    z-index: $z-index-above-popup;
    overflow: hidden;

    &--scroller {
      max-height: 300px;
      overflow-y: auto;
    }

    @include popper-shadow();

    @include light-theme() {
      background: $color-white;
    }

    @include dark-theme() {
      background: $color-gray-75;
    }

    &__row {
      height: 34px;
      padding: 0 12px;
      display: flex;
      flex-direction: row;
      align-items: center;
      justify-content: flex-start;
      background: none;
      border: none;
      width: 100%;

      &--mention {
        height: 40px;
      }

      &:focus {
        outline: 0;
      }

      @include font-body-2;

      @include light-theme() {
        color: $color-gray-60;
      }

      @include dark-theme() {
        color: $color-gray-25;
      }

      &__short-name {
        margin-left: 4px;
      }

      &--selected,
      &:hover {
        @include light-theme() {
          background: $color-gray-05;
          color: $color-gray-90;
        }

        @include dark-theme() {
          background: $color-gray-60;
          color: $color-gray-05;
        }
      }
    }

    &__title {
      padding-left: 8px;
    }

    stroke: $color-white;
  }
}

// Module: Last Seen Indicator

.module-last-seen-indicator {
  padding-top: 25px;
  padding-bottom: 35px;
  user-select: none;
}

.module-last-seen-indicator__bar {
  background-color: $color-gray-45;
  width: 100%;
  height: 1px;
}

.module-last-seen-indicator__text {
  margin-top: 3px;

  @include font-body-2-bold;

  text-align: center;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-05;
  }
}

// Module: Avatar Popup

.module-avatar-popup {
  min-width: 240px;
  max-width: 320px;

  border-radius: 4px;
  padding-bottom: 4px;

  @include popper-shadow;

  @include light-theme {
    color: $color-gray-90;
    background-color: $color-white;
  }
  @include dark-theme {
    color: $color-gray-05;
    background-color: $color-gray-75;
  }
}

.module-avatar-popup__profile {
  @include button-reset();
  align-items: center;
  display: flex;
  flex-direction: row;
  width: 100%;

  @include light-theme {
    &:hover {
      background-color: $color-gray-05;
    }
  }
  @include dark-theme {
    &:hover {
      background-color: $color-gray-60;
    }
  }
  @include keyboard-mode {
    &:hover {
      background-color: inherit;
    }
    &:focus {
      background-color: $color-gray-05;
    }
  }
  @include dark-keyboard-mode {
    &:hover {
      background-color: inherit;
    }
    &:focus {
      background-color: $color-gray-60;
    }
  }
}

.module-avatar-popup__profile {
  padding: 12px;
}

.module-avatar-popup__profile__text {
  margin-left: 10px;
  overflow: hidden;
}

.module-avatar-popup__profile__name {
  @include font-body-1-bold;
}
.module-avatar-popup__profile__number {
  @include font-subtitle;

  @include light-theme {
    color: $color-gray-60;
  }
  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-avatar-popup__profile__name,
.module-avatar-popup__profile__number {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.module-avatar-popup__divider {
  border: none;
  padding: 0;
  margin: 0;

  height: 1px;
  width: 100%;
  margin-bottom: 6px;

  @include light-theme {
    background-color: $color-gray-15;
  }
  @include dark-theme {
    background-color: $color-gray-60;
  }
}

.module-avatar-popup__item {
  @include font-body-2;
  @include button-reset;

  display: flex;
  flex-direction: row;
  align-items: center;

  width: 100%;
  height: 32px;
  padding: 6px;

  @include light-theme {
    &:hover {
      background-color: $color-gray-05;
    }
  }
  @include keyboard-mode {
    &:hover {
      background-color: inherit;
    }
    &:focus {
      background-color: $color-gray-05;
    }
  }
  @include dark-theme {
    &:hover {
      background-color: $color-gray-60;
    }
  }
  @include dark-keyboard-mode {
    &:hover {
      background-color: inherit;
    }
    &:focus {
      background-color: $color-gray-60;
    }
  }
}

.module-avatar-popup__item__icon {
  margin-left: 6px;

  height: 16px;
  width: 16px;

  &--update {
    @include light-theme {
      @include color-svg('../images/icons/v2/refresh-24.svg', $color-gray-75);
    }
    @include dark-theme {
      @include color-svg('../images/icons/v2/refresh-24.svg', $color-gray-15);
    }
  }
}
.module-avatar-popup__item__icon-settings {
  @include light-theme {
    @include color-svg(
      '../images/icons/v2/settings-outline-16.svg',
      $color-gray-75
    );
  }
  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/settings-solid-16.svg',
      $color-gray-15
    );
  }
}
.module-avatar-popup__item__icon-archive {
  @include light-theme {
    @include color-svg(
      '../images/icons/v2/archive-outline-16.svg',
      $color-gray-75
    );
  }
  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/archive-solid-16.svg',
      $color-gray-15
    );
  }
}

.module-avatar-popup__item__text {
  flex-grow: 1;
  margin-left: 8px;
}

.module-avatar-popup__item--badge {
  background: $color-ultramarine;
  border-radius: 100%;
  height: 8px;
  margin-right: 10px;
  width: 8px;
}

// Module: Shortcut Guide Modal

.module-shortcut-guide-modal {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;

  padding: 20px;

  display: flex;
  flex-direction: row;
  align-items: center;

  background-color: $color-black-alpha-40;
  z-index: $z-index-above-context-menu;
}

.module-shortcut-guide-container {
  flex-grow: 1;
  overflow: hidden;
}

// Module: Shortcut Guide

.module-shortcut-guide {
  border-radius: 4px;
  padding: 16px;

  max-height: calc(var(--window-height) - 40px);
  max-width: 1150px;
  margin-left: auto;
  margin-right: auto;

  display: flex;
  flex-direction: column;

  @include popper-shadow;

  @include light-theme {
    color: $color-gray-90;
    background-color: $color-white;
  }
  @include dark-theme {
    color: $color-gray-05;
    background-color: $color-gray-75;

    ::-webkit-scrollbar-thumb {
      border: 2px solid $color-gray-75;
    }
  }
}

.module-shortcut-guide__header {
  display: flex;
  flex-direction: row;
  align-items: center;

  margin-bottom: 20px;
}

.module-shortcut-guide__header-text {
  @include font-title-2;

  flex-grow: 1;
}
.module-shortcut-guide__header-close {
  @include button-reset;

  height: 24px;
  width: 24px;

  @include light-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-gray-60);
  }
  @include dark-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-gray-05);
  }

  &:focus {
    @include keyboard-mode {
      @include color-svg('../images/icons/v2/x-24.svg', $color-ultramarine);
    }
    @include dark-keyboard-mode {
      @include color-svg(
        '../images/icons/v2/x-24.svg',
        $color-ultramarine-light
      );
    }
  }
}

.module-shortcut-guide__section-header {
  @include font-body-1-bold;

  margin-bottom: 8px;
}

.module-shortcut-guide__scroll-container {
  outline: none;
  overflow-y: scroll;
}

.module-shortcut-guide__section {
  &:not(:last-child) {
    margin-bottom: 25px;
  }
}

@media (min-width: 900px) {
  .module-shortcut-guide__section-list {
    column-count: 2;
    column-gap: 20px;
    column-span: none;
    column-fill: auto;
  }
}

.module-shortcut-guide__shortcut {
  display: flex;
  flex-direction: row;
  align-items: center;
  break-inside: avoid;

  padding-left: 4px;
  min-height: 40px;
  outline: none;

  &:focus {
    @include keyboard-mode {
      background-color: $color-gray-05;
    }
    @include dark-keyboard-mode {
      background-color: $color-gray-90;
    }
  }

  @include light-theme {
    border-bottom: 1px solid $color-gray-05;
  }
  @include dark-theme {
    border-bottom: 1px solid $color-gray-90;
  }
}

.module-shortcut-guide__shortcut__description {
  flex-grow: 1;
  margin-top: 4px;
  margin-bottom: 4px;
}
.module-shortcut-guide__shortcut__key-container {
  margin-bottom: 4px;
}
.module-shortcut-guide__shortcut__key-inner-container {
  text-align: right;
  margin-top: 4px;
  margin-right: 4px;
  white-space: nowrap;
}

.module-shortcut-guide__shortcut__key {
  display: inline-block;

  border-radius: 2px;
  padding: 3px;
  padding-left: 8px;
  padding-right: 8px;
  margin-left: 4px;

  height: 30px;
  text-align: center;

  @include light-theme {
    border: 1px solid $color-gray-15;
  }
  @include dark-theme {
    border: 1px solid $color-gray-90;
  }
}

.module-shortcut-guide__shortcut__key--square {
  width: 30px;
  padding-left: 0px;
  padding-right: 0px;
}

/* Calling: Device Selection */

.module-calling-device-selection {
  position: relative;
}

.module-calling-device-selection__close-button {
  @include button-reset;

  @include color-svg('../images/icons/v2/x-24.svg', $color-gray-15);

  height: 24px;
  position: absolute;
  right: 5px;
  top: 0;
  width: 24px;
  z-index: $z-index-above-base;

  @include keyboard-mode {
    &:focus {
      outline: 2px solid $color-ultramarine;
    }
  }
}

.module-calling-device-selection__title {
  @include font-title-2;
  margin-top: 12px;
  margin-bottom: 20px;
}

.module-calling-device-selection__label {
  @include font-body-1-bold;
  display: block;
  margin-bottom: 16px;
}

.module-calling-device-selection__select {
  margin-bottom: 20px;
  position: relative;

  select {
    @include font-body-1;
    background: $color-gray-75;
    color: $color-gray-02;
    -webkit-appearance: none;
    border-radius: 4px;
    border: 1px solid $color-gray-45;
    cursor: pointer;
    height: 40px;
    outline: 0;
    padding: 10px;
    padding-right: 32px;
    text-overflow: ellipsis;
    width: 100%;
  }

  &::after {
    border: 2px solid $color-gray-75;

    border-radius: 2px;
    border-right: 0;
    border-top: 0;
    content: ' ';
    display: block;
    height: 10px;
    pointer-events: none;
    position: absolute;
    right: 15px;
    top: 16px;
    transform-origin: center;
    transform: rotate(-45deg);
    width: 10px;
    z-index: $z-index-above-base;
  }
}

// Module: GroupV1 Disabled Actions

.module-group-v1-disabled-actions {
  padding: 8px 16px 12px 16px;
  max-width: 650px;
  margin-left: auto;
  margin-right: auto;

  @include light-theme {
    background: $color-white;
  }

  @include dark-theme {
    background: $color-gray-95;
  }
}

.module-group-v1-disabled-actions__message {
  @include font-body-2;
  text-align: center;
  margin-bottom: 12px;

  @include light-theme {
    color: $color-gray-60;
  }

  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-group-v1-disabled-actions__message__learn-more {
  text-decoration: none;
}

.module-group-v1-disabled-actions__buttons {
  display: flex;
  flex-direction: row;
  justify-content: center;
}
.module-group-v1-disabled-actions__buttons__button {
  @include button-reset;
  @include font-body-1-bold;

  border-radius: 4px;

  padding: 8px;
  padding-left: 30px;
  padding-right: 30px;

  @include button-primary;
}

// Module: GroupV2 Pending Approval Actions

.module-group-v2-pending-approval-actions {
  padding: 8px 16px 12px 16px;
  max-width: 650px;
  margin-left: auto;
  margin-right: auto;

  @include light-theme {
    background: $color-white;
  }

  @include dark-theme {
    background: $color-gray-95;
  }
}

.module-group-v2-pending-approval-actions__message {
  @include font-body-2;
  text-align: center;
  margin-bottom: 12px;

  @include light-theme {
    color: $color-gray-60;
  }

  @include dark-theme {
    color: $color-gray-25;
  }
}

.module-group-v2-pending-approval-actions__buttons {
  display: flex;
  flex-direction: row;
  justify-content: center;
}
.module-group-v2-pending-approval-actions__buttons__button {
  @include button-reset;
  @include font-body-1-bold;

  border-radius: 4px;

  padding: 8px;
  padding-left: 30px;
  padding-right: 30px;

  @include button-secondary;

  @include light-theme {
    color: $color-gray-60;
    background-color: $color-gray-05;
  }
}

// Module: Modal Host

.module-modal-host__overlay {
  background: $color-black-alpha-40;
  width: var(--window-width);
  height: var(--window-height);
  left: var(--window-border);
  top: var(--titlebar-height);
  position: fixed;
  z-index: $z-index-modal-host;
}

.module-modal-host__overlay-container {
  display: flex;
  flex-direction: row;
  width: var(--window-width);
  height: var(--window-height);
  left: var(--window-border);
  top: var(--titlebar-height);
  justify-content: center;
  align-items: center;
  overflow: hidden;
  padding: 20px;
  position: fixed;
  z-index: $z-index-modal-host;
}

.module-modal-host__width-container {
  max-width: 360px;
  width: 95%;
}

.module-modal-host--on-top-of-everything {
  $loading-screen-modal-overlay: $z-index-on-top-of-everything + 1;

  .module-modal-host__overlay,
  .module-modal-host__overlay-container {
    z-index: $loading-screen-modal-overlay;
  }
}

// Module: GroupV2 Join Dialog

.module-group-v2-join-dialog {
  @include font-body-1;
  border-radius: 8px;
  width: 360px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;

  position: relative;

  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-95;
  }
}
.module-group-v2-join-dialog__close-button {
  @include button-reset;

  position: absolute;
  right: 12px;
  top: 12px;

  height: 24px;
  width: 24px;

  @include light-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-gray-75);
  }

  @include dark-theme {
    @include color-svg('../images/icons/v2/x-24.svg', $color-gray-15);
  }

  &:focus {
    @include keyboard-mode {
      background-color: $color-ultramarine;
    }
    @include dark-keyboard-mode {
      background-color: $color-ultramarine-light;
    }
  }
}
.module-group-v2-join-dialog__title {
  @include font-title-2;
  text-align: center;
  margin-top: 12px;
  margin-bottom: 2px;
}
.module-group-v2-join-dialog__avatar {
  text-align: center;
}
.module-group-v2-join-dialog__metadata {
  color: $color-gray-60;
  text-align: center;
}
.module-group-v2-join-dialog__prompt {
  margin-top: 40px;

  &--approval {
    @include font-subtitle;
    color: $color-gray-45;
    margin-top: 40px;
  }
}
.module-group-v2-join-dialog__buttons {
  margin-top: 16px;

  text-align: center;

  display: flex;
}
.module-group-v2-join-dialog__button {
  // Start flex basis at zero so text width doesn't affect layout. We want the buttons
  //   evenly distributed.
  flex: 1 1 0px;

  &:not(:first-of-type) {
    margin-left: 16px;
  }
}
.module-group-v2-join-dialog__description {
  color: $color-gray-60;
  margin-top: 12px;
}

// Module: Progress Dialog

.module-progress-dialog {
  width: 138px;
  padding: 18px;
  border-radius: 8px;
  @include popper-shadow();

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  @include light-theme() {
    background: $color-white;
    color: $color-gray-90;
  }

  @include dark-theme() {
    background: $color-gray-80;
    color: $color-gray-05;
  }
}

.module-progress-dialog__spinner {
  padding: 10px;
}

.module-progress-dialog__text {
  @include font-body-2;
}

.module-progress-dialog__overlay {
  background: $color-black-alpha-40;
  position: fixed;
  left: var(--window-border);
  top: var(--titlebar-height);
  width: var(--window-width);
  height: var(--window-height);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: $z-index-popup-overlay;
}

// Module: Error Modal

.module-error-modal__button-container {
  margin-top: 10px;
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
}

.module-button {
  &__small {
    @include font-body-2;
    @include button-reset;

    @include keyboard-mode {
      &:focus {
        box-shadow: 0px 0px 0px 2px $color-ultramarine;
      }
    }

    @include light-theme {
      color: $color-gray-90;
      border-color: $color-gray-15;
    }

    @include dark-theme {
      color: $color-gray-05;
      border-color: $color-gray-65;
    }

    border-radius: 4px;
    border-style: solid;
    border-width: 1px;
    outline: none;
    padding: 7px 12px;
  }
}

.module-background-color {
  &__default {
    background-color: $color-black-alpha-40;
  }

  @include avatar-colors();
}

.module-tooltip {
  --tooltip-text-color: #{$color-gray-75};
  --tooltip-background-color: #{$color-gray-02};

  @mixin tooltip-dark-theme-variables {
    --tooltip-text-color: #{$color-gray-05};
    --tooltip-background-color: #{$color-gray-65};
  }
  &--dark-theme {
    @include tooltip-dark-theme-variables;
  }
  @include dark-theme {
    @include tooltip-dark-theme-variables;
  }

  background-color: var(--tooltip-background-color);
  border-radius: 8px;
  color: var(--tooltip-text-color);
  display: inline-block;
  padding: 8px 21px;
  position: fixed;
  text-align: center;
  z-index: $z-index-tooltip;

  .module-tooltip-arrow {
    position: absolute;
  }

  .module-tooltip-arrow::after {
    border: solid 6px transparent;
    content: '';
    display: block;
    height: 0;
    margin-left: -6px;
    margin-top: -6px;
    position: absolute;
    width: 0;
  }

  &[data-placement='top'] {
    .module-tooltip-arrow {
      bottom: 0;
    }

    .module-tooltip-arrow::after {
      bottom: -12px;
      border-top-color: var(--tooltip-background-color);
    }
  }

  &[data-placement='right'] {
    .module-tooltip-arrow {
      left: 0;
    }

    .module-tooltip-arrow::after {
      left: -6px;
      border-right-color: var(--tooltip-background-color);
    }
  }

  &[data-placement='bottom'] {
    .module-tooltip-arrow {
      top: 0;
    }

    .module-tooltip-arrow::after {
      top: -6px;
      border-bottom-color: var(--tooltip-background-color);
    }
  }

  &[data-placement='left'] {
    .module-tooltip-arrow {
      right: 0;
    }

    .module-tooltip-arrow::after {
      right: -12px;
      border-left-color: var(--tooltip-background-color);
    }
  }
}

// Module: Chat Session Refreshed Dialog

.module-chat-session-refreshed-dialog {
  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-95;
  }
}
.module-chat-session-refreshed-dialog__image {
  text-align: center;
}
.module-chat-session-refreshed-dialog__title {
  @include font-body-1-bold;
  margin-top: 10px;
  margin-bottom: 3px;
}
.module-chat-session-refreshed-dialog__buttons {
  text-align: right;
  margin-top: 20px;
  padding: 3px;
}
.module-chat-session-refreshed-dialog__button {
  @include font-body-1-bold;
  @include button-reset;
  @include button-primary;

  border-radius: 4px;
  padding: 7px 14px;
  margin-left: 12px;
}
.module-chat-session-refreshed-dialog__button--secondary {
  @include button-secondary;
}

// Module: Delivery Issue Dialog

.module-delivery-issue-dialog__image {
  text-align: center;
}
.module-delivery-issue-dialog__title {
  @include font-body-1-bold;
  margin-top: 10px;
  margin-bottom: 3px;
}

/* Third-party module: react-contextmenu*/

.react-contextmenu {
  @include popper-shadow();

  outline: none;
  border-radius: 4px;
  min-width: 220px;
  padding: 6px 0;
  opacity: 0;
  user-select: none;
  visibility: hidden;

  @include light-theme {
    background-color: $color-white;
  }
  @include dark-theme {
    background-color: $color-gray-75;
  }
}

.react-contextmenu--visible {
  opacity: 1;
  visibility: visible;
  z-index: $z-index-context-menu;
}

.react-contextmenu-item {
  outline: none;
  cursor: pointer;
  white-space: nowrap;

  @include font-body-2;

  padding: 7px 12px;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-02;
  }

  &--divider {
    height: 1px;
    margin: 6px 0;
    padding: 0;

    @include light-theme {
      background-color: $color-gray-15;
    }
    @include dark-theme {
      background-color: $color-gray-60;
    }
  }
}

.react-contextmenu-item--checked:before {
  content: '✓';
  display: inline-block;
  position: absolute;
  right: 7px;

  @include light-theme {
    color: $color-gray-90;
  }
  @include dark-theme {
    color: $color-gray-02;
  }
}

.react-contextmenu-item.react-contextmenu-submenu {
  padding: 0;
}

.react-contextmenu-item.react-contextmenu-submenu > .react-contextmenu-item {
  padding-right: 36px;
}

.react-contextmenu-item.react-contextmenu-submenu
  > .react-contextmenu-item:after {
  content: ' ';
  display: inline-block;
  height: 18px;
  position: absolute;
  right: 7px;
  width: 12px;

  @include light-theme {
    @include color-svg(
      '../images/icons/v2/chevron-right-16.svg',
      $color-gray-75
    );
    color: $color-gray-90;
  }
  @include dark-theme {
    @include color-svg(
      '../images/icons/v2/chevron-right-16.svg',
      $color-gray-15
    );
    color: $color-gray-02;
  }
}

.react-contextmenu-item.react-contextmenu-item--active,
.react-contextmenu-item.react-contextmenu-item--selected {
  color: $color-black;
  @include light-theme {
    background-color: $color-gray-15;
  }
  @include dark-theme {
    background-color: $color-gray-60;
    color: $color-white;
  }
}

.react-contextmenu-item--disabled.react-contextmenu-item--selected {
  background-color: inherit;
  cursor: inherit;
}

.react-contextmenu-item.react-contextmenu-item--active.react-contextmenu-item--checked:before,
.react-contextmenu-item.react-contextmenu-item--selected.react-contextmenu-item--checked:before {
  color: $color-black;
  @include dark-theme {
    color: $color-white;
  }
}

.react-contextmenu-item.react-contextmenu-submenu
  > .react-contextmenu-item.react-contextmenu-item--active:after,
.react-contextmenu-item.react-contextmenu-submenu
  > .react-contextmenu-item.react-contextmenu-item--selected:after {
  color: $color-black;
  @include dark-theme {
    color: $color-white;
  }
}

// To limit messages with things forcing them wider, like long attachment names
.module-message__container {
  max-width: 100%;

  &--incoming {
    align-self: flex-start;
  }

  &--outgoing {
    align-self: flex-end;
  }

  &--with-reactions {
    margin-bottom: -6px;
  }

  &--deleted-for-everyone {
    font-style: italic;
  }
}

.module-message__context {
  &--icon::before {
    content: ' ';
    display: inline-block;
    height: 14px;
    margin-right: 8px;
    width: 14px;
    vertical-align: middle;
  }

  &__download::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/save-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/save-solid-24.svg',
        $color-gray-15
      );
    }
  }

  &__reply::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/reply-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/reply-solid-24.svg',
        $color-gray-15
      );
    }
  }

  &__react::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/add-emoji-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/add-emoji-outline-24.svg',
        $color-gray-15
      );
    }
  }

  &__more-info::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/info-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/info-outline-24.svg',
        $color-gray-15
      );
    }
  }

  &__retry-send::before {
    @include light-theme {
      @include color-svg('../images/icons/v2/send-24.svg', $color-black);
    }

    @include dark-theme {
      @include color-svg('../images/icons/v2/send-24.svg', $color-gray-15);
    }
  }

  &__forward-message::before {
    transform: scaleX(-1);
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/reply-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/reply-solid-24.svg',
        $color-gray-15
      );
    }
  }

  &__delete-message::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/trash-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/trash-solid-24.svg',
        $color-gray-15
      );
    }
  }

  &__delete-message-for-everyone::before {
    @include light-theme {
      @include color-svg(
        '../images/icons/v2/trash-outline-24.svg',
        $color-black
      );
    }

    @include dark-theme {
      @include color-svg(
        '../images/icons/v2/trash-solid-24.svg',
        $color-gray-15
      );
    }
  }
}