$fixed-column-width: rem(160px);
$breakpoint: 768px;

.Polaris-DataTable {
  position: relative;
  max-width: 100vw;
  overflow: hidden;
}

.Polaris-DataTable--collapsed {
  .Polaris-DataTable__Table {
    &::after {
      display: block;
    }
  }
}

.Polaris-DataTable--hasFooter {
  .Polaris-DataTable__ScrollContainer {
    margin-bottom: rem(52px);
  }
}

.Polaris-DataTable__Navigation {
  display: none;
}

.Polaris-DataTable__Pip {
  height: rem(6px);
  width: rem(6px);
  background: color('ink', 'lightest');
  border-radius: border-radius();

  &:not(:last-of-type) {
    margin-right: spacing(extra-tight);
  }
}

.Polaris-DataTable__Pip--visible {
  background: color('ink');
}

.Polaris-DataTable__ScrollContainer {
  overflow-x: auto;
  // account for a mysterious gap in Safari when not collapsed
  margin-left: rem(140px);
  -webkit-overflow-scrolling: touch;
}

.Polaris-DataTable__Table {
  width: 100%;
  border-spacing: 0;

  &::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: $fixed-column-width;
    display: none;
    width: 0.6rem;
    background: linear-gradient(
      to right,
      rgba(color('black'), 0.12),
      rgba(color('black'), 0)
    );
  }
}

.Polaris-DataTable__ScrollContainer {
  overflow-x: auto;
  margin-left: $fixed-column-width;
}

// .TableRow {
//   &:hover .Polaris-DataTable__Cell {
//     @include breakpoint-after($breakpoint) {
//       background: color('sky', 'lighter');
//     }
//   }
// }

.Polaris-DataTable__TableFoot {
  border-bottom: 0;
}

.Polaris-DataTable__Cell {
  padding: spacing();
  border-top: border();
  white-space: nowrap;
  text-align: left;
  transition: background-color 0.2s ease-in-out;
}

.Polaris-DataTable__Cell--numeric {
  text-align: right;
}

.Polaris-DataTable__Cell--fixed {
  @include text-emphasis-normal;
  @include text-breakword;
  position: absolute;
  top: auto;
  left: 0;
  width: $fixed-column-width;
  white-space: unset;
  text-align: left;
  backface-visibility: hidden; // stops painting on scroll (due to positioning)
}

.Polaris-DataTable__Cell--truncated {
  white-space: nowrap;
  overflow-x: hidden;
  text-overflow: ellipsis;
}

.Polaris-DataTable__Cell--header {
  @include text-emphasis-subdued;
  font-weight: 400;
  border-top: border();
}

.Polaris-DataTable__Cell--sortable {
  cursor: pointer;

  &:hover {
    .Polaris-DataTable__Heading {
      @include recolor-icon(color('indigo'));
      color: color('indigo');
    }

    .Polaris-DataTable__Icon {
      opacity: 1;
    }
  }
}

.Polaris-DataTable__Icon {
  display: flex;
  align-self: flex-end;
  opacity: 0;
  transition: opacity duration() easing(), fill duration() easing();
}

.Polaris-DataTable__Heading {
  @include unstyled-button;
  position: relative;
  display: inline-flex;
  justify-content: flex-end;
  align-items: baseline;
  transition: color duration() easing();

  &:hover,
  &:focus {
    @include recolor-icon(color('indigo'));
    color: color('indigo');

    .Polaris-DataTable__Icon {
      opacity: 1;
    }
  }
}

.Polaris-DataTable__Heading--left {
  justify-content: flex-start;
  flex-direction: row-reverse;
}

.Polaris-DataTable__Cell--sorted {
  .Polaris-DataTable__Icon {
    opacity: 1;
  }
}

.Polaris-DataTable__Cell--total {
  @include text-emphasis-strong;
  background: color('sky', 'lighter');
  border-top: border();
}

.Polaris-DataTable__Cell--footer {
  @include text-emphasis-normal;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  border-bottom: 0;
  background: color('sky', 'light');
  color: color('ink', 'lighter');
  white-space: unset;
  text-align: center;
  backface-visibility: hidden; // stop painting on scroll (due to positioning)
}

@media (min-width: 1100px) {
  .Polaris-DataTable--collapsed {
    position: relative;
    .Polaris-DataTable__Navigation {
      display: flex;
      align-items: center;
      justify-content: center;
      // width: 100%;
      padding: spacing() spacing(tight);

      position: absolute;
      top: rem(-62px);
      right: 0;

      @include breakpoint-after($breakpoint, inclusive) {
        justify-content: flex-end;
      }
    }
  }
}