@import '../../globals/scss/colors';
@import '../../globals/scss/spacing';
@import '../../globals/scss/css--reset';
@import '../../globals/scss/typography';
@import '../../globals/scss/mixins';
@import '../../globals/scss/vars';
@import '../../globals/scss/layout';
@import '../../globals/scss/import-once';

@include exports('structured-list') {
  .#{$prefix}--structured-list--selection .#{$prefix}--structured-list-td,
  .#{$prefix}--structured-list--selection .#{$prefix}--structured-list-th {
    @include padding--data-structured-list;
  }

  // Deprecated
  [data-structured-list] .#{$prefix}--structured-list-td,
  [data-structured-list] .#{$prefix}--structured-list-th {
    @include padding--data-structured-list;
  }

  .#{$prefix}--structured-list-input {
    display: none;
  }

  .#{$prefix}--structured-list {
    @include reset;
    @include font-family;
    display: table;
    overflow-x: auto;
    overflow-y: hidden;
    width: 100%;
    min-width: 500px;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 5rem;
    background-color: transparent;

    &.#{$prefix}--structured-list--border {
      border: 1px solid $ui-04;
      background-color: $ui-01;
    }

    &.#{$prefix}--structured-list--condensed .#{$prefix}--structured-list-td {
      @include padding-td--condensed;
    }
  }

  .#{$prefix}--structured-list-row {
    display: table-row;
    border-bottom: 1px solid $ui-04;
    transition: $transition--base $carbon--standard-easing;

    .#{$prefix}--structured-list--selection &:hover:not(.#{$prefix}--structured-list-row--header-row) {
      background-color: rgba($brand-02, 0.1);
      cursor: pointer;
    }

    // Deprecated
    [data-structured-list] &:hover:not(.#{$prefix}--structured-list-row--header-row) {
      background-color: rgba($brand-02, 0.1);
      cursor: pointer;
    }

    &.#{$prefix}--structured-list-row--selected {
      background-color: rgba($brand-02, 0.1);
    }

    &.#{$prefix}--structured-list-row--header-row {
      border-bottom: 2px solid $brand-01;
      cursor: inherit;
    }

    &:focus:not(.#{$prefix}--structured-list-row--header-row) {
      @include focus-outline('border');
    }
  }

  .#{$prefix}--structured-list-thead {
    display: table-header-group;
    vertical-align: middle;
  }

  .#{$prefix}--structured-list-th {
    @include reset;
    @include padding-th;
    @include typescale('zeta');
    display: table-cell;
    font-weight: 600;
    height: rem(40px);
    text-align: left;
    text-transform: $structured-list-text-transform;
    vertical-align: middle;
  }

  .#{$prefix}--structured-list-tbody {
    display: table-row-group;
    vertical-align: middle;
  }

  .#{$prefix}--structured-list-td {
    @include reset;
    @include typescale('zeta');
    @include line-height('body');
    @include padding-td;
    position: relative;
    display: table-cell;
  }

  .#{$prefix}--structured-list-content--nowrap {
    white-space: nowrap;
  }

  .#{$prefix}--structured-list-svg {
    display: inline-block;
    fill: transparent;
    vertical-align: middle;
    transition: $transition--base $carbon--standard-easing;

    .#{$prefix}--structured-list-row:hover & {
      fill: rgba($brand-02, 0.1);
    }

    .#{$prefix}--structured-list-input:checked + .#{$prefix}--structured-list-row &,
    .#{$prefix}--structured-list-input:checked + .#{$prefix}--structured-list-td & {
      fill: $brand-02;
    }
  }

  // Deprecated class
  .#{$prefix}--structured-list-content {
    @include typescale('zeta');
  }
}
