@use 'mixins/mixins' as *;
@use 'mixins/var' as *;
@use 'common/var' as *;

@include b(cascader-panel) {
  display: flex;
  border-radius: getCssVar('border-radius-md');
  max-width: calc(100vw - 24px);
  overflow-x: auto;

  @include when(bordered) {
    border: getCssVar('border');
    border-radius: getCssVar('border-radius-md');
  }
}

@include b(cascader-menu) {
  min-width: 180px;
  box-sizing: border-box;
  color: getCssVar('color-neutral-9');
  border-right: 1px solid getCssVar('color-neutral-2');

  &:last-child {
    border-right: none;

    .#{$namespace}-cascader-node {
      padding-right: 24px;
    }
  }

  @include e(wrap) {
    // Raise the priority
    &.#{$namespace}-scrollbar__wrap {
      height: 204px;
    }
  }

  @include e(list) {
    position: relative;
    min-height: 100%;
    margin: 0;
    padding: 8px;
    list-style: none;
    box-sizing: border-box;
  }

  @include e(hover-zone) {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
  }

  @include e(empty-text) {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    color: getCssVar('color-neutral-6');

    .is-loading {
      margin-right: 2px;
    }
  }
}

@include b(cascader-node) {
  position: relative;
  display: flex;
  align-items: center;
  padding: 8px;
  font-size: 14px;
  font-weight: 600;
  line-height: 20px;
  outline: none;
  border-radius: getCssVar('border-radius-sm');

  &.is-selectable.in-active-path {
    color: getCssVar('color-neutral-9');
  }

  &.in-active-path,
  &.is-selectable.in-checked-path,
  &.is-active {
    color: getCssVar('color-primary-3');
  }

  &:not(.is-disabled) {
    cursor: pointer;

    &:hover,
    &:focus {
      color: getCssVar('color-primary-3');
      background-color: getCssVar('color-primary-1');
    }
  }

  @include when(disabled) {
    color: getCssVar('color-neutral-6');
    cursor: not-allowed;
  }

  @include e(prefix) {
    position: absolute;
    right: 8px;
  }

  @include e(postfix) {
    position: absolute;
    right: 8px;
  }

  @include e(label) {
    flex: 1;
    text-align: left;
    padding: 0 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  > .#{$namespace}-radio {
    margin-right: 0;

    .#{$namespace}-radio__label {
      padding-left: 0;
    }
  }
}
