
@mixin xmDialogAnimationFrom() {
  & > .xm-mask {
    opacity: 0;
    transition: all 0.4s;
  }
  & > .xm-dialog {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.8);
    transition: all 0.4s;
  }
}

@mixin xmDialogAnimationTo() {
  & > .xm-mask {
    opacity: 1;
  }
  & > .xm-dialog {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
}

.xm-dialog-animation {
  @include react-animation-enter {

    @include react-animation-from {
      @include xmDialogAnimationFrom;
    }
    @include react-animation-to {
      @include xmDialogAnimationTo;
    }
  }
  @include react-animation-leave {
    @include react-animation-from {
      @include xmDialogAnimationTo;
    }
    @include react-animation-to {
      @include xmDialogAnimationFrom;
    }
  }
}

.xm-pop-dialog {
  @include xm-fixed-full;
  z-index: $zindex-modal-bg;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  > .xm-mask {
    z-index: -1;
  }
}

.xm-pop-dialog-close {
  height: rem(44px);
  width: rem(44px);
  line-height: rem(41px);
  text-align: center;
  font-size: rem(30px);
  border: 2px solid white;
  color: white;
  border-radius: 50%;
  opacity: 0.7;
  margin: 0;
}

.xm-pop-dialog-content {
  margin: rem(25px) 0;
  min-height: rem(450px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}