@use 'sass:color';

$listbox-font-family: $font-family !default;
$listbox-text-color: $content-font !default;
$listbox-text-disabled: rgba($disable, .54) !default;
$listbox-icon-color: $content-font !default;
$listbox-icon-disabled: rgba($disable, .54) !default;
$listbox-icon-margin-right: 16px !default;
$listbox-icon-line-height: 28px !default;
$listbox-icon-back-margin: 2px !default;
$listbox-rtl-icon-back-margin: 1px !default;
$listbox-background: $bg-base-0 !default;
$listbox-line-color: $default-bg-color !default;
$listbox-item-hover-bg: $hover-bg !default;
$listbox-item-height: 36px !default;
$listbox-item-line-height: 1 !default;
$listbox-item-padding: 9px 16px !default;
$listbox-bigger-item-padding: 12px 16px !default;
$listbox-text-hover-color: $hover-font !default;
$listbox-item-active-bg: $selection-bg !default;
$listbox-text-active-color: $selection-font !default;
$listbox-header-text-color: $selection-bg !default;
$listbox-header-text-padding: 0 16px !default;
$listbox-header-text-disabled: $disable !default;
$listbox-header-bg: $bg-base-0 !default;
$listbox-header-icon-color: $header-icon-color !default;
$listbox-header-icon-disabled: $disable !default;
$listbox-header-border: $border-default !default;
$listbox-header-font-size: 14px !default;
$listbox-header-height: 36px !default;
$listbox-header-font-weight: 600 !default;
$listbox-header-line-height: 21px !default;
$listbox-header-padding-bottom: 0 !default;
$listbox-group-first-border-bottom: 0 !default;
$listbox-group-border-top: 1px !default;
$listbox-group-border-bottom: 0 !default;
$listbox-groupheader-text-color: $header-font !default;
$listbox-groupheader-bg: $bg-base-0 !default;
$listbox-groupheader-border: $header-bg-color !default;
$listbox-groupheader-icon: $header-icon-color !default;
$listbox-groupheader-item-height: 36px !default;
$listbox-groupheader-item-line-height: 30px !default;
$listbox-groupheader-font-size: 14px !default;
$listbox-border-size: 0 !default;
$listbox-font-size: 13px !default;
$checkmark-bgcolor: $bg-base-0 !default;
$checkmark-border-color: $bg-base-0 !default;
$checkmark-color: $header-font !default;
$listbox-border-bottom: 2px !default;
$listbox-border-top: 2px !default;
$listbox-border-left: 2px !default;
$listbox-border-right: 2px !default;
$listbox-hover-border-color: $hover-border !default;
$listbox-border-bottom-color: transparent !default;
$listbox-border-top-color: transparent !default;
$listbox-border-right-color: transparent !default;
$listbox-border-left-color: transparent !default;
$listbox-back-padding-right: 20px !default;
$listbox-touch-item-height: 45px !default;
$listbox-touch-item-line-height: 1.6 !default;
$listbox-touch-item-font-size: 15px !default;
$listbox-touch-back-icon-padding: 0 !default;
$listbox-touch-groupheader-height: 45px !default;
$listbox-touch-groupheader-line-height: 45px !default;
$listbox-touch-header-height: 45px !default;
$listbox-touch-header-font-weight: 600 !default;
$listbox-touch-header-font-size: 15px !default;
$listbox-touch-header-line-height: 11px !default;
$listbox-touch-header-icon-margin-top: 0 !default;
$listbox-checkbox-right-margin: -2px 0 0 10px !default;
$listbox-checkbox-left-margin: -2px 10px 0 0 !default;
$listbox-rtl-checkbox-left-margin: -2px 0 0 10px !default;
$listbox-rtl-checkbox-right-margin: -2px 10px 0 0 !default;

$listbox-bigger-wrapper-padding: 12px !default;
$listbox-zero-margin-padding: 0 !default;
$listbox-input-grp-padding: 4px 8px !default;
$listbox-input-focus-padding: 4px 4px 4px 8px !default;
$listbox-tool-padding: 8px !default;
$listbox-template-multiline-header-font-weight: 500 !default;

//ListView In-built template variables
$listbox-template-padding: .6153em .923em !default;
$listbox-template-avatar-padding-right: .923em !default;
$listbox-template-avatar-padding-left: 4.923em !default;
$listbox-template-avatar-rightposition-padding-right: 4.923em !default;
$listbox-template-avatar-rightposition-padding-left: .923em !default;
$listbox-template-avatar-size: 3.0769em !default;
$listbox-template-avatar-top: .6153em !default;
$listbox-template-avatar-left: .923em !default;
$listbox-template-avatar-rightposition-right: .923em !default;
$listbox-template-badge-height: 1.5384em !default;
$listbox-template-badge-width: 1.5384em !default;
$listbox-template-badge-line-height: 1.3384em !default;
$listbox-template-badge-font-size: 13px !default;
$listbox-template-badge-right: .923em !default;
$listbox-template-avatar-badge-padding-right: 3.3846em !default;
$listbox-template-avatar-badge-padding-left: 4.923em !default;
$listbox-template-badgewithoutavatar-padding-right: 3.3846em !default;
$listbox-template-badgewithoutavatar-padding-left: .923em !default;
$listbox-template-item-padding: .867em 0 !default;
$listbox-template-multiline-header-color: $content-font !default;
$listbox-template-multiline-content-color: $content-font !default;
$listbox-template-multiline-header-padding: .093em 0 !default;
$listbox-template-multiline-content-padding: .093em 0 !default;
$listbox-template-multiline-header-font-size: 13px !default;
$listbox-template-multiline-padding: .6153em .923em !default;
$listbox-template-multiline-content-font-size: 13px !default;
$listbox-template-multiline-avatar-top: .6153em !default;

$listbox-border-color: $border-default;
$badge-color: $selection-font !default;
$badge-bgcolor: $selection-bg !default;

$select-all-border-color: $content-font !default;

$listbox-filter-small-height: calc(100% - 45px) !default;
$listbox-filter-bigger-small-height: calc(100% - 55px) !default;
$listbox-select-height: calc(100% - 36px) !default;
$listbox-select-bigger-height: calc(100% - 45px) !default;
$listbox-filterselect-height: calc(100% - 36px) !default;
$listbox-filterselect-bigger-height: calc(100% - 45px) !default;
$listbox-mat-filter-height: calc(100% - 50px) !default;
$listbox-mat-filter-bigger-height: calc(100% - 58px) !default;
$listbox-filter-height: calc(100% - 51px) !default;
$listbox-filter-bigger-height: calc(100% - 59px) !default;
$listbox-ej2-filterselect-height: calc(100% - 87px) !default;
$listbox-ej2-filterselect-bigger-height: calc(100% - 104px) !default;
$listbox-icon-padding: 2px !default;
$listbox-group-item-font-weight: 600 !default;
$listbox-icon-collapsible-font-size: 12px !default;
$listbox-zero-padding-margin: 0 !default;
$listbox-list-icon-margin-left: 16px !default;
$listbox-list-badge-border-radius: 50% !default;
$listbox-list-badge-font-size: 12px !default;
$listbox-wrapper-right-left-margin: 15px !default;
$listbox-tool-btn-margin-bottom: 10px !default;

$listbox-full-height: 100% !default;
$listbox-list-icon-height: 30px !default;
$listbox-hidden-select-height: 1px !default;
$listbox-placeholder-height: 1px !default;
$list-border-width: 1px !default;
$list-badge-height: 22px !default;
$list-icon-width: auto !default;
$list-icon-height: auto !default;
$list-badge-width: 22px !default;
$listbox-list-icon-width: 30px !default;
$listbox-full-width: 100% !default;
$list-box-header-view-top: 45px !default;
$list-box-half-width: 50% !default;
$checkbox-wrapper-top: 30% !default;
$list-box-list-item-height: 38px !default;
$list-box-list-badge-right: -10px !default;
$list-box-list-badge-top: -10px !default;
$list-text-checkbox-width: calc(100% - 40px);
$list-box-checkbox-icon-width: calc(100% - 90px);
$list-checkbox-right-icon-width: calc(100% - 80px);
$list-box-icon-child-width: calc(100% - 92px);
$list-box-text-width: calc(100% - 60px);
$list-tool-box-wrap-width: calc(100% - 17%);
$list-tool-nrml-box-wrap-width: calc(100% - 13%);
$list-box-full-height: 100% !default;
$list-border: 1px !default;
$zero-border: 0 !default;
$zero-width: 0% !default;

@include export-module('listbox-layout') {
  /* stylelint-disable property-no-vendor-prefix */
  .e-listbox-wrapper,
  .e-listbox-container,
  .e-listboxtool-wrapper {
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
    cursor: pointer;
    display: block;
    position: relative;
    user-select: none;
    width: $listbox-full-width;

    * {
      box-sizing: border-box;
    }

    @if $skin-name == 'fluent2' or $theme-name == 'bootstrap5.3' or $theme-name == 'bootstrap5.3-dark' {
      & {
        border-radius: $list-box-nrml-border-radius;
      }
    }
    @if $skin-name == 'tailwind3' {
      & {
        font-weight: $list-font-weight-medium;
        border-radius: $list-box-nrml-border-radius;
      }
    }

    &.e-listboxtool-container .e-list-wrap {
      @if $skin-name == 'FluentUI' or $skin-name == 'bootstrap5' or $skin-name == 'bootstrap5.3' or $skin-name == 'tailwind' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
      @else if $skin-name == 'material' or $skin-name == 'bootstrap4' or $skin-name == 'bootstrap' or $skin-name == 'fabric' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
      @else if $skin-name == 'highcontrast' {
        width: $list-tool-nrml-box-wrap-width !important; /* stylelint-disable-line declaration-no-important */
      }
    }

    & .e-list-wrap:focus-visible,
    &:focus {
      outline: none;
    }

    &.e-disabled {
      cursor: default;
      pointer-events: none;
    }

    & .e-list-item.e-disabled,
    & .e-list-item.e-disabled .e-list-icon {
      @if $skin-name == 'fluent2' or $skin-name == 'tailwind3' {
        color: $content-text-color-disabled;
        opacity: 1;
      }
    }

    &:not(.e-list-template) .e-list-nrt {
      text-align: center;
    }

    .e-list-parent {
      height: $listbox-full-height;
      min-height: $listbox-item-height;
    }

    & .e-list-item {
      border-bottom: $listbox-border-size solid;
      outline: none;

      &:focus-visible {
        @if $skin-name == 'fluent2' {
          background-color: $content-bg-color !important; /* stylelint-disable-line declaration-no-important */
          color: $content-text-color !important; /* stylelint-disable-line declaration-no-important */
          box-shadow: $secondary-shadow-focus;
        }
        @if $skin-name == 'tailwind3' {
          background-color: $content-bg-color !important; /* stylelint-disable-line declaration-no-important */
          color: $content-text-color !important; /* stylelint-disable-line declaration-no-important */
          box-shadow: $shadow-focus-ring2;
        }
      }

      &.e-disabled {
        pointer-events: none;
      }
    }

    .e-disable {
      opacity: .7;
    }

    & .e-list-group-item,
    & .e-list-item {
      @if $skin-name == 'fluent2' {
        margin: $list-group-item-margin;
      }
    }

    & .e-list-parent {
      margin: $listbox-zero-margin-padding;
      padding: $listbox-zero-margin-padding;
    }

    & .e-list-header .e-text.header,
    & .e-list-header .e-headertemplate-text.nested-header {
      display: none;
    }

    & .e-icon-back {
      margin-top: $listbox-icon-back-margin;
    }

    & .e-list-header {
      align-items: center;
      border-bottom: $list-border solid;
      display: flex;
      font-weight: $listbox-header-font-weight;
      height: $listbox-header-height;
      padding: $listbox-header-text-padding;
    }

    & .e-has-header > .e-view {
      top: $list-box-header-view-top;
    }

    & .e-but-back {
      cursor: pointer;
      padding-right: $listbox-back-padding-right;
    }

    & .e-list-group-item:first-child {
      @if $theme-name != 'bootstrap5.3' and $theme-name != 'bootstrap5.3-dark' {
        border: $zero-border;
        border-bottom: $listbox-group-first-border-bottom solid $listbox-border-bottom-color;
      }
    }

    & .e-list-group-item {
      border-bottom: $listbox-group-border-bottom solid $listbox-border-bottom-color;
      border-top: $listbox-group-border-top solid;
      font-weight: $listbox-group-item-font-weight;
      height: $listbox-groupheader-item-height;
      line-height: $listbox-groupheader-item-line-height;
      @if $theme-name == 'bootstrap5.3' or $theme-name == 'bootstrap5.3-dark' {
        padding: $list-group-item-padding;
      }
      @else {
        padding: $listbox-item-padding;
      }
    }

    & .e-icon-collapsible {
      cursor: pointer;
      font-size: $listbox-icon-collapsible-font-size;
      position: absolute;
      right: $zero-width;
      top: $list-box-half-width;
      transform: translateY(-50%);
    }

    & .e-text-content {
      height: $listbox-full-height;
      position: relative;
      vertical-align: middle;
    }

    & .e-text-content * {
      display: inline-block;
      vertical-align: middle;
    }

    & .e-text-content.e-checkbox .e-list-text {
      width: $list-text-checkbox-width;
    }

    & .e-text-content.e-checkbox.e-checkbox-left .e-list-icon + .e-list-text {
      width: $list-box-checkbox-icon-width;
    }

    & .e-text-content.e-checkbox.e-checkbox-right .e-list-icon + .e-list-text {
      width: $list-checkbox-right-icon-width;
    }

    & .e-list-item.e-checklist.e-has-child {
      .e-text-content.e-checkbox.e-checkbox-right {
        .e-list-icon + .e-list-text {
          width: $list-box-icon-child-width;
        }
      }
    }

    & .e-checkbox .e-checkbox-left {
      margin: $listbox-checkbox-left-margin;
    }

    & .e-checkbox .e-checkbox-right {
      margin: $listbox-checkbox-right-margin;
    }

    & .e-list-text {
      cursor: pointer;
      display: inline-block;
      overflow: hidden;
      text-overflow: ellipsis;
      vertical-align: top;
      white-space: nowrap;
      width: $listbox-full-width;
    }

    & .e-list-icon + .e-list-text,
    & .e-icon-wrapper .e-list-text,
    & .e-icon-wrapper.e-text-content.e-checkbox .e-list-text {
      width: $list-box-text-width;
    }

    & .e-list-icon {
      height: $listbox-list-icon-height;
      margin-right: $listbox-icon-margin-right;
      width: $listbox-list-icon-width;
    }

    & .e-content {
      overflow: hidden;
      position: relative;
    }

    & .e-list-header .e-text {
      cursor: pointer;
      text-indent: $listbox-zero-padding-margin;
    }

    & .e-text .e-headertext {
      display: inline-block;
      line-height: $listbox-header-line-height;
    }

    &.e-rtl {
      direction: rtl;

      & .e-list-icon {
        margin-left: $listbox-list-icon-margin-left;
        margin-right: $listbox-zero-padding-margin;
      }

      & .e-icon-collapsible {
        left: $zero-width;
        right: initial;
        top: $list-box-half-width;
        transform: translateY(-50%) rotate(180deg);
      }

      & .e-list-header .e-text {
        cursor: pointer;
      }

      & .e-but-back {
        transform: rotate(180deg);
      }

      & .e-icon-back {
        margin-top: $listbox-rtl-icon-back-margin;
      }

      & .e-checkbox .e-checkbox-left,
      .e-checkbox-wrapper {
        margin: $listbox-rtl-checkbox-left-margin;
        @if $skin-name == 'fluent2' {
          padding: $list-check-box-left-padding;
          vertical-align: top;
        }
      }

      & .e-checkbox .e-checkbox-right {
        margin: $listbox-rtl-checkbox-right-margin;
      }
    }

    .e-checkbox-wrapper {
      margin: $listbox-checkbox-left-margin;
      text-indent: $listbox-zero-padding-margin;
      vertical-align: middle;
      @if $skin-name == 'Material3' {
        position: relative;
      }
      @if $skin-name == 'fluent2' {
        padding: $list-checkbox-wrapper-padding;
        vertical-align: top;

        & .e-frame {
          margin: $listbox-zero-margin-padding !important; /* stylelint-disable-line declaration-no-important */
        }
      }
    }

    &.e-checkbox-right {
      .e-checkbox-wrapper {
        position: absolute;
        right: $listbox-zero-padding-margin;
        top: $checkbox-wrapper-top;
      }
    }

    .e-filter-parent {
      @if $skin-name == 'tailwind3' {
        padding: $listbox-filter-parent-padding;
      }
    }

    .e-input-group {
      @if $skin-name != 'tailwind' {
        padding: $listbox-input-grp-padding;
      }
      @if $skin-name == 'tailwind3' {
        padding: $listbox-zero-margin-padding;
      }
    }

    .e-input-focus {
      @if $skin-name != 'tailwind' {
        padding: $listbox-input-focus-padding;
      }
      @if $skin-name == 'tailwind3' {
        padding: $listbox-zero-margin-padding;
      }
    }

    .e-hidden-select {
      height: $listbox-hidden-select-height;
      opacity: 0;
      position: absolute;
      width: $listbox-full-width;
    }

    .e-placeholder {
      background-color: $badge-bgcolor;
      display: block;
      @if $skin-name == 'fluent2' {
        border: $placeholder-border solid $badge-bgcolor;
      }
      height: $listbox-placeholder-height;
    }
  }

  ejs-listbox {
    display: block;
  }

  .e-listbox-wrapper:not(.e-listbox-container),
  .e-listbox-wrapper.e-filter-list .e-list-parent {
    overflow: auto;
  }

  .e-listbox-wrapper.e-sortableclone,
  .e-listbox-container.e-sortableclone,
  .e-listboxtool-wrapper.e-sortableclone {
    border-width: $zero-border;
    overflow: visible;

    .e-list-item {
      list-style-type: none;
      @if $skin-name != 'fluent2' {
        height: $list-box-list-item-height !important; /* stylelint-disable-line declaration-no-important */
      }
    }

    .e-ripple {
      overflow: visible;

      .e-ripple-element {
        display: none;
      }
    }

    .e-list-badge {
      align-items: center;
      background-color: $badge-bgcolor;
      border: $list-border-width solid $badge-color;
      border-radius: $listbox-list-badge-border-radius;
      color: $badge-color;
      display: flex;
      font-size: $listbox-list-badge-font-size;
      height: $list-badge-height;
      justify-content: center;
      position: absolute;
      right: $list-box-list-badge-right;
      top: $list-box-list-badge-top;
      width: $list-badge-width;
    }
  }

  .e-listboxtool-wrapper.e-sortableclone{
    display: block;
  }

  .e-listboxtool-wrapper,
  .e-listboxtool-container {
    cursor: pointer;
    display: flex;

    * {
      box-sizing: border-box;
    }

    &.e-disabled {
      cursor: default;
      pointer-events: none;
    }

    .e-listbox-wrapper,
    .e-list-wrap {
      flex: 1;
    }

    &.e-right {
      .e-listbox-tool {
        margin-left: $listbox-wrapper-right-left-margin;
      }
    }

    &.e-left {
      .e-listbox-tool {
        margin-right: $listbox-wrapper-right-left-margin;
      }
    }

    .e-listbox-tool {
      border: $list-border-width solid $listbox-border-color;
      overflow: auto;
      padding: $listbox-tool-padding;
      @if $skin-name == 'tailwind3' {
        border-radius: $list-box-tool-tail-radius;
        .e-btn-icon {
          font-size: $text-base;
        }
      }
      .e-btn {
        display: list-item;
        list-style-type: none;
        margin-bottom: $listbox-tool-btn-margin-bottom;
      }
    }

    &.e-checkbox-right {
      .e-checkbox-wrapper {
        position: absolute;
        right: $listbox-zero-padding-margin;
        top: $checkbox-wrapper-top;
      }
    }
  }

  .e-rtl.e-listboxtool-wrapper,
  .e-rtl.e-listboxtool-container {
    &.e-right {
      .e-listbox-tool {
        margin-right: $listbox-wrapper-right-left-margin;
      }
    }

    &.e-left {
      .e-listbox-tool {
        margin-left: $listbox-wrapper-right-left-margin;
      }
    }
  }
}

.e-listbox-wrapper,
.e-listbox-container,
.e-listboxtool-wrapper .e-listbox-wrapper {
  &:not(.e-list-template) .e-list-item,
  .e-list-nrt,
  .e-selectall-parent {
    height: $listbox-item-height;
    line-height: $listbox-item-line-height;
    padding: $listbox-item-padding;
    position: relative;
    @if $skin-name == 'fluent2' {
      font-size: $list-box-item-font-size;
      border-radius: $list-box-item-border-radius !important; /* stylelint-disable-line declaration-no-important */
    }
  }

  .e-list-icon {
    display: inline;
    vertical-align: middle;
    width: $list-icon-width;
    height: $list-icon-height;
    padding-bottom: $listbox-icon-padding;
  }
}

@mixin avatar {
  height: $listbox-template-avatar-size;
  left: $listbox-template-avatar-left;
  position: absolute;
  width: $listbox-template-avatar-size;
}

@include export-module('listbox-theme') {
  .e-small .e-listbox-wrapper.e-filter-list .e-list-parent,
  .e-small .e-listbox-container.e-filter-list .e-list-parent {
    height: $listbox-filter-small-height !important; /* stylelint-disable-line declaration-no-important */
  }

  .e-listbox-container.e-filter-list .e-selectall-parent + .e-list-parent {
    height: $listbox-filterselect-bigger-height !important; /* stylelint-disable-line declaration-no-important */
  }

  .e-listbox-wrapper.e-filter-list:not(.e-listbox-container) .e-list-parent {
    height: $listbox-filter-height !important; /* stylelint-disable-line declaration-no-important */
  }

  .e-listbox-wrapper.e-filter-list:not(.e-listbox-container) .e-selectall-parent + .e-hidden-select + .e-listbox + .e-list-parent {
    height: $listbox-ej2-filterselect-height !important;/* stylelint-disable-line declaration-no-important */
  }

  .e-listbox-wrapper,
  .e-listbox-container:not(.e-listboxtool-container):not(.e-sortableclone),
  .e-listboxtool-container.e-listbox-container .e-ul {
    border: 1px solid $listbox-border-color;
  }

  .e-listbox-wrapper,
  .e-listbox-container,
  .e-listboxtool-wrapper {
    font-family: $listbox-font-family;
    font-size: $listbox-font-size;
    @if $skin-name == 'tailwind3' {
      .e-filter-parent {
        background: $listbox-groupheader-bg;
        box-shadow: none;
        .e-input-group {
          .e-input-filter {
            color: $placeholder-text-color;
          }
        }
      }
    }
    @at-root {
      & .e-list-header {
        background-color: $listbox-header-bg;
        border-color: $listbox-header-border;
        color: $listbox-header-text-color;
        font-size: $listbox-header-font-size;
      }

      &.e-filter-list .e-list-parent {
        height: $listbox-filter-height;
      }

      &.e-filter-list .e-selectall-parent + .e-list-parent {
        height: $listbox-filterselect-height !important; /* stylelint-disable-line declaration-no-important */
      }

      & .e-selectall-parent + .e-list-parent {
        height: $listbox-select-height !important; /* stylelint-disable-line declaration-no-important */
      }

      // & .e-icons {
      //   @if $skin-name != 'bootstrap5' {
      //     color: $listbox-icon-color;
      //   }
      // }

      & .e-list-item {
        background-color: $listbox-background;
        border-bottom: $listbox-border-bottom solid $listbox-border-bottom-color;
        border-left: $listbox-border-left solid $listbox-border-left-color;
        border-right: $listbox-border-right solid $listbox-border-right-color;
        border-top: $listbox-border-top solid $listbox-border-top-color;
        color: $listbox-text-color;
        @if $skin-name == 'tailwind3' {
          overflow: hidden;
          text-overflow: ellipsis;
          vertical-align: middle;
          white-space: nowrap;
        }
      }

      & .e-list-item:hover:not(.e-selected):not(.e-disabled),
      & .e-list-item:hover.e-selected.e-checklist:not(.e-disabled) {
        background-color: $listbox-item-hover-bg;
        border-color: $listbox-hover-border-color;
        color: $listbox-text-hover-color;
      }

      & .e-list-item.e-selected.e-checklist {
        background-color: $listbox-background;
        color: $listbox-text-color;
      }

      & .e-list-item.e-focused,
      & .e-list-item.e-focused.e-selected.e-checklist,
      & .e-list-item.e-selected {
        background-color: $listbox-item-active-bg;
        @if $skin-name == 'bootstrap5' or $skin-name == 'bootstrap5.3' {
          color: $listbox-text-selected-color;
        }
        @else {
          color: $listbox-text-active-color;
        }
      }

      & .e-list-item.e-focused .e-checkbox-wrapper .e-frame.e-check,
      & .e-list-item.e-focused .e-css.e-checkbox-wrapper .e-frame.e-check {
        @if $skin-name != 'fluent2' {
          background-color: $checkmark-bgcolor;
          border-color: $checkmark-border-color;
          color: $checkmark-color;
        }
      }

      & .e-list-group-item {
        background-color: $listbox-groupheader-bg;
        border-color: $listbox-header-border;
        color: $listbox-groupheader-text-color;
        font-size: $listbox-groupheader-font-size;
      }

      & .e-selectall-parent {
        background-color: $listbox-background;
        border-bottom: 1px solid $select-all-border-color;
        color: $listbox-text-color;
      }

      & .e-sortableclone.e-ripple .e-ripple-element {
        background-color: transparent;
      }
    }

    &.e-list-template {
      .e-list-wrapper {
        height: inherit;
        position: relative;

        &:not(.e-list-multi-line) {
          padding: $listbox-template-padding;
        }

        &.e-list-multi-line {
          padding: $listbox-template-multiline-padding;

          .e-list-item-header {
            color: $listbox-template-multiline-header-color;
            display: block;
            font-size: $listbox-template-multiline-header-font-size;
            font-weight: $listbox-template-multiline-header-font-weight;
            margin: $listbox-zero-margin-padding;
            overflow: hidden;
            padding: $listbox-template-multiline-header-padding;
            text-overflow: ellipsis;
            white-space: nowrap;
          }

          .e-list-content {
            color: $listbox-template-multiline-content-color;
            display: block;
            font-size: $listbox-template-multiline-content-font-size;
            margin: $listbox-zero-margin-padding;
            padding: $listbox-template-multiline-content-padding;
            word-wrap: break-word;
          }

          .e-list-content:not(.e-text-overflow) {
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
          }
        }

        &.e-list-avatar {
          .e-avatar {
            @include avatar;
            left: $listbox-template-avatar-left;
          }
        }

        &.e-list-avatar:not(.e-list-badge) {
          padding-left: $listbox-template-avatar-padding-left;
          padding-right: $listbox-template-avatar-padding-right;
        }

        &.e-list-avatar-right:not(.e-list-badge) {
          padding-left: $listbox-template-avatar-rightposition-padding-left;
          padding-right: $listbox-template-avatar-rightposition-padding-right;

          .e-avatar {
            @include avatar;
            right: $listbox-template-avatar-rightposition-right;
          }
        }

        &.e-list-multi-line.e-list-avatar,
        &.e-list-multi-line.e-list-avatar-right:not(.e-list-badge) {
          .e-avatar {
            top: $listbox-template-multiline-avatar-top;
          }
        }

        &.e-list-badge {
          .e-badge {
            font-size: $listbox-template-badge-font-size;
            height: $listbox-template-badge-height;
            line-height: $listbox-template-badge-line-height;
            padding: $listbox-zero-margin-padding;
            position: absolute;
            right: $listbox-template-badge-right;
            top: 50%;
            transform: translateY(-50%);
            width: $listbox-template-badge-width;
          }
        }

        &.e-list-badge.e-list-avatar {
          padding-left: $listbox-template-avatar-badge-padding-left;
          padding-right: $listbox-template-avatar-badge-padding-right;
        }

        &.e-list-badge:not(.e-list-avatar) {
          padding-left: $listbox-template-badgewithoutavatar-padding-left;
          padding-right: $listbox-template-badgewithoutavatar-padding-right;
        }

        &:not(.e-list-multi-line) {
          .e-list-content {
            display: block;
            margin: $listbox-zero-margin-padding;
            overflow: hidden;
            padding: $listbox-template-item-padding;
            text-overflow: ellipsis;
            white-space: nowrap;
          }
        }
      }

      .e-list-item {
        &.e-list-item:hover .e-list-item-header,
        &.e-list-item:hover .e-list-content {
          color: $listbox-text-hover-color;
        }

        &.e-selected .e-list-item-header,
        &.e-selected .e-list-content {
          color: $listbox-text-active-color;
        }
      }
    }

    &.e-rtl {
      &.e-list-template .e-list-wrapper {
        &.e-list-avatar {
          .e-avatar {
            left: inherit;
            right: $listbox-template-avatar-left;
          }
        }

        &.e-list-avatar:not(.e-list-badge) {
          padding-left: $listbox-template-avatar-padding-right;
          padding-right: $listbox-template-avatar-padding-left;
        }

        &.e-list-avatar-right:not(.e-list-badge) {
          padding-left: $listbox-template-avatar-rightposition-padding-right;
          padding-right: $listbox-template-avatar-rightposition-padding-left;

          .e-avatar {
            left: $listbox-template-avatar-rightposition-right;
            right: inherit;
          }
        }

        &.e-list-badge {
          .e-badge {
            left: $listbox-template-badge-right;
            right: inherit;
          }
        }

        &.e-list-badge.e-list-avatar {
          padding-left: $listbox-template-avatar-badge-padding-right;
          padding-right: $listbox-template-avatar-badge-padding-left;
        }

        &.e-list-badge:not(.e-list-avatar) {
          padding-left: $listbox-template-badgewithoutavatar-padding-right;
          padding-right: $listbox-template-badgewithoutavatar-padding-left;
        }
      }
    }
  }

  .e-listbox-wrapper.e-sortableclone,
  .e-listbox-container.e-sortableclone {
    @if $skin-name == 'fluent2' or $theme-name == 'bootstrap5.3' or $theme-name == 'bootstrap5.3-dark' {
      & .e-list-item {
        background-color: $listbox-dragged-item-bg-color !important; /* stylelint-disable-line declaration-no-important */
        color: $listbox-dragged-item-text-color !important; /* stylelint-disable-line declaration-no-important */
      }
    }
  }

  .e-listbox-container {
    @at-root {
      &.e-filter-list .e-list-parent,
      &.e-filter-list .e-selectall-parent + .e-list-parent,
      & .e-selectall-parent + .e-list-parent {
        height: 100%;
      }

      &.e-filter-list .e-list-wrap {
        height: $listbox-mat-filter-height !important; /* stylelint-disable-line declaration-no-important */
      }

      &.e-filter-list .e-selectall-parent + .e-list-wrap {
        height: $listbox-filterselect-height !important; /* stylelint-disable-line declaration-no-important */
      }

      & .e-selectall-parent + .e-list-wrap {
        height: $listbox-select-height !important; /* stylelint-disable-line declaration-no-important */
      }
    }
  }
}

@include export-module('list-box-highcontrast-icons') {
  .e-listbox-tool .e-moveup::before {
    content: '\e651';
  }

  .e-listbox-tool .e-movedown::before {
    content: '\e652';
  }

  .e-listbox-tool .e-moveto::before {
    content: '\e653';
  }

  .e-listbox-tool .e-movefrom::before {
    content: '\e654';
  }

  .e-listbox-tool .e-moveallto::before {
    content: '\e655';
  }

  .e-listbox-tool .e-moveallfrom::before {
    content: '\e656';
  }
}