/*----------------------------------------------
遷移元：アニメーション
----------------------------------------------*/
body{
    transition: 1s;
}
body::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color:#FFFFFF;
    z-index: 9999;
    pointer-events: none;
    opacity: 0;
    transition: opacity .5s ease;
  }

  body.transition::after {
    opacity: 1;
  }

  /* body.transition{
    transform:scale(1.05);
  } */

/*===============================================
遷移先：アニメーション
-----------------------------------------------*/
#loading {
    width: 100%;
    height: 100%;
    transition: all 1s;
    background-color: #FFFFFF;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100000;
 }

@keyframes sk-scaleout {
    0% {
        transform: scale(0);
    } 100% {
        transform: scale(1.0);
        opacity: 0;
    }
}

.loaded {
    opacity: 0;
    visibility: hidden;
}

/*===============================================
LOADING | Spinner
-----------------------------------------------*/
.spinner {
    width: 70px;
    margin: -20px 0 0 -35px;
    position: absolute;
    top:50%;
    left: 50%;
}
  
.spinner > div {
    width: 18px;
    height: 18px;
    background-color: var(--color-primary);

    border-radius: 100%;
    display: inline-block;
    -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
    animation: sk-bouncedelay 1.4s infinite ease-in-out both;
}

.spinner .bounce1 {
    -webkit-animation-delay: -0.32s;
    animation-delay: -0.32s;
}

.spinner .bounce2 {
    -webkit-animation-delay: -0.16s;
    animation-delay: -0.16s;
}

@-webkit-keyframes sk-bouncedelay {
    0%, 80%, 100% { 
        -webkit-transform: scale(0) 
    }40% { 
        -webkit-transform: scale(1.0)
    }
}

@keyframes sk-bouncedelay {
    0%, 80%, 100% { 
        -webkit-transform: scale(0);
        transform: scale(0);
    } 40% { 
        -webkit-transform: scale(1.0);
        transform: scale(1.0);
    }
}
