:host {
  --tui-height: var(--tui-height-s);

  overflow-x: hidden;
  display: flex;
  gap: 6px;
  align-items: center;

  height: 100%;
  min-height: var(--tui-height);

  font: var(--tui-font-text-s);

  &:hover {
    cursor: pointer;

    .edit-icon-container {
      opacity: 1;

      &.outline {
        border: 2px solid var(--tui-clear);
      }
    }
  }

  &[data-size='s'] {
    &.has-padding {
      padding: 0 var(--tui-padding-s);
    }
  }

  &[data-size='m'] {
    --tui-height: var(--tui-height-m);

    &.has-padding {
      padding: 0 var(--tui-padding-m);
    }
  }

  &[data-size='l'] {
    --tui-height: var(--tui-height-l);

    font: var(--tui-font-text-m);

    &.has-padding {
      padding: 0 var(--tui-padding-l);
    }
  }

  &[data-appearance='fill'] {
    background-color: var(--app-bg-color-l3);
    border-radius: 3px;
  }

  &[data-appearance='outline'] {
    position: relative;

    &::after {
      pointer-events: none;
      content: '';

      position: absolute;
      inset: 0;

      border: 1px solid var(--color-gray-eee);
      border-radius: 3px;
    }
  }
}

.content {
  overflow-x: hidden;
  display: flex;
}

.content.line-clamp {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;

  width: 100%;

  text-overflow: ellipsis;
  overflow-wrap: break-word;
}

.edit-icon-container {
  display: flex;
  flex: none;
  align-items: center;
  align-self: stretch;
  justify-content: center;

  width: 25px;

  opacity: 0;
  border-radius: 3px;

  .edit-icon {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
