.UploadArea {
  @extend .Font__body;
  @extend .Font__body--20;
  @extend .Font__color--light;

  $this: &;
  width: 100%;
  background-color: $color-gray-140;
  padding: 16px;
  border: 1px dashed $color-indigo;
  border-radius: 4px;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  overflow: hidden;
  position: relative;

  &--dragging {
    border: 2px solid $color-indigo;
    padding: 15px;

    #{$this}__form {
      opacity: 0;
    }
  }

  &--hasFileData {
    padding: 24px 20px;
    border: none;
  }

  &--dragging#{$this}--hasFileData {
    border: 2px solid $color-indigo;

    #{$this}__form {
      opacity: 0;
    }
  }

  &__errorMessage {
    padding-top: 20px;
  }

  &__loader {
    position: absolute;
    top: 0;
    left: 0;
  }

  &__fileIcon {
    width: 38px;
    margin-right: 24px;
  }

  &__fileData {
    display: flex;
    height: 38px;

    &__name {
      color: $color-gray-00;
      margin: 0;
    }

    &__size {
      font-size: 14px;
      margin: 0;
    }
  }

  &__form {
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
  }

  &__instructions {
    font-style: italic;
  }

  &__input {
    display: none;
  }

  &__button {
    cursor: pointer;

    &--fileReady:nth-of-type(2) {
      margin-left: 8px;
    }
  }
}
