@layer components {
  .message__delete-button {
    font-size: var(--text-xx-small);
    line-height: 1;
    margin-block-start: 2px;
    background: none;
    border: none;
    color: var(--color-ink-dark);
    padding: 0.25rem;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.15s ease;

    .message:hover & {
      opacity: 1;
    }
  }

  .message__reactions {
    display: flex;
    align-items: center;
    position: relative;
    min-width: 32px;
    margin: 0 6px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease;

    .message:hover & {
      opacity: 1;
      pointer-events: auto;
    }
  }

  .message__reactions-toggle {
    font-size: var(--text-normal);
    text-decoration: none;
    background: none;
    border: none;
    color: var(--color-ink-dark);
    padding: 0.25rem;
    cursor: pointer;
  }

  .message__reactions-popover {
    display: flex;
    gap: 0.25rem;
    font-size: var(--text-medium);
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 100%;
    transform: translateY(-50%);
    background: var(--color-canvas);
    border-radius: 20px;
    padding: 4px 8px;
    margin-inline-start: 8px;
    box-shadow: var(--shadow);
    z-index: var(--z-dropdown);
  }

  .message__reactions-button {
    line-height: 1;
    text-decoration: none;
    background: none;
    border: none;
    padding: 0.25rem;
    cursor: pointer;
  }
}
