@charset "UTF-8";

html {
    background: #fff;
    font-size: 0.7vw;
}

@media screen and (min-width:1400px) {
    html {
        font-size: 9.8px;
    }
}

body {
    background: #fff;
    font-size: 1.45rem;
    letter-spacing: .03em;
}

.logo {
    width: 9.78vw;
    max-width: 137px;
    position: fixed;
    left: 2.28vw;
    top: 2.43vw;
    z-index: 10;
}

.logo img {
    transition: all .3s linear;
}

.logo .is-area03 {
    position: absolute;
    left: 0;
    top: 0;
}

.top-header p {
    text-transform: uppercase;
}

.txt-h-top {
    position: fixed;
    right: 2.28vw;
    top: 2.28vw;
    z-index: 10;
    transition: all .3s linear;
}

.txt-h-left {
    position: fixed;
    left: 2.28vw;
    top: 50%;
    z-index: 10;
    transform: translate(-50%, -50%) rotate(90deg);
    letter-spacing: 0.1em;
    transition: all .3s linear;
}

.txt-h-left.is-area03, .area03-active .txt-h-top.is-area03 {
    color: #fbfbf6;
}

.area01 {
    position: relative;
}

.area01 .arrow {
    width: 3.8rem;
    position: absolute;
    left: 50%;
    bottom: 2.2vw;
    transform: translateX(-50%);
}

.area01 .bx-wrapper {
    -webkit-box-shadow: none;
    box-shadow: none;
    border: none;
    background: #fff;
    letter-spacing: 0.1em;
}

.slide-wrap {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    height: 100vh;
    background: #000;
}

.slide-wrap > div {
    background-position: center;
    background-repeat: no-repeat;
}

.slide01 .slide-l, .slide01 .slide-r {
    width: 50%;
    background-size: cover;
}

.slide01 .slide-l {
    background-image: url(../images/01_200.jpg);
}

.slide01 .slide-r {
    background-image: url(../images/04_008.jpg);
}

.slide02 .slide-l, .slide03 .slide-l {
    width: 43%;
    background-size: cover;
}

.slide02 .slide-r, .slide03 .slide-r {
    width: 57%;
    background-size: contain;
}

.slide02 .slide-l {
    background-image: url(../images/01_002.jpg);
}

.slide02 .slide-r {
    background-image: url(../images/10_079.jpg);
}

.slide03 .slide-l {
    background-image: url(../images/08_014.jpg);
}

.slide03 .slide-r {
    background-image: url(../images/09_105.jpg);
}

.area01 h1 {
    position: absolute;
    left: 50%;
    top: 46%;
    transform: translate(-50%, -50%);
    white-space: nowrap;
    line-height: 1.4;
    font-size: 2.6rem;
    color: #fbfbf6;   
}

[data-aos="fade-up"] {
    transition-timing-function: cubic-bezier(0.230, 1.000, 0.320, 1.000)!important;
    transition-duration: 2s!important;
}

.is-area02, .is-area03 {
    opacity: 0;
}

.area01-active .is-area01, .area02-active .is-area02, .area03-active .is-area03 {
    opacity: 1;
}

.area02 {
    background: #fbfbf6;
    padding-bottom: 100px;
    margin-bottom: -100px;
}

.area03 {
    background: #111;
}

.img01 {
    width: 27.3rem;
    margin-left: 60.6rem;
    padding-top: 9.2rem;
    margin-bottom: -10rem;
}

.box-02 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding-left: 17.5rem;
}

.txt-02 h2 {
    font-size: 2.7rem;
    line-height: 1.45em;
    padding-bottom: 3rem;
    letter-spacing: .04em;
}

.txt-02 p {
    font-size: 1.3rem;
    line-height: 2.7;
}

.img02 {
    width: 34.36rem
}

.txt-03 {
    font-size: 2.6rem;
    line-height: 1.45;
    margin-top: 7.8rem;
    margin-bottom: 19rem;
}

.box-04 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-left: 8rem;
    padding-right: 15rem;
    margin-bottom: 11.2rem;
}

.img-04 img:first-child {
    animation: change01 14s linear 0s infinite;
    position: relative;
}

.img-04 img:last-child {
    position: absolute;
    left: 2rem;
    top: 2rem;
    animation: change01 14s linear 3.39s infinite;
}

@keyframes change01 {
    0% {
        opacity: 1;
        z-index: 1;
    }

    16.66% {
        opacity: 0;
        z-index: 1;
    }

    16.67% {
        opacity: 0;
        z-index: 2;
    }
    
    33.33% {
        opacity: 1;
        z-index: 2;
    }

    50% {
        opacity: 1;
        z-index: 2;
    }

    66.66% {
        opacity: 0;
        z-index: 2;
    }

    66.67% {
        opacity: 0;
        z-index: 1;
    }

    83.34% {
        opacity: 1;
        z-index: 1;
    }
    
    100% {
        opacity: 1;
        z-index: 1;
    }
}

.img-04 {
    position: relative;
    width: 44.3%;
    max-width: 520px;
}

.txt-04 {
    width: 55.7%;
    padding-left: 12.5rem;
    box-sizing: border-box;
}

.txt-04 p {
    font-size: 1.3rem;
    line-height: 2.7;
    margin-top: -1.1rem;
}

.btn a {
    display: inline-block;
    border: 1px solid rgba(0, 0, 0, 1);
    background: #111;
    color: #fbfbf6;
    border-color: #111;
    width: 28.4rem;
    height: 5.6rem;
    font-size: 1.9rem;
    line-height: 5.6rem;
    text-align: center;
    border-radius: 3.3rem;
    transition: all .3s linear;
}

.btn.white a {
    border-color: #fbfbf6;
    background: #fbfbf6;
    color: #111;
}

.btn a:hover {
    background: transparent;
    color: #111;
}

.btn.white a:hover {
    background: transparent;
    color: #fbfbf6;
}

.box-05 {
    padding-bottom: 19rem
}

.area03 * {
    color: #fbfbf6;
}

.txt-06 {
    font-size: 2.6rem;
    line-height: 1.45;
    padding-top: 34rem;
    padding-bottom: 27.7rem;
}

.box-07 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 9rem;
}

.box-07 > div {
    width: 37.4rem;
    margin: 0 4.4rem;
}

.txt-08 {
    font-size: 1.3rem;
    line-height: 2.7;
    text-align: center;
    margin-bottom: 8.5rem;
}

.txt-09 {
    font-size: 2.1rem;
    margin-bottom: 2.2rem;
}

.box-10 {
    padding-bottom: 16.5rem;
}

@media screen and (max-width:999px) {
 
    .logo {
        width: 16.27vw;;
        left: 4vw;
        top: 4vw;
    }

    .txt-h-top {
        text-align: right;
        right: 4vw;
        top: 4vw;
        font-size: 10px;
        line-height: 1.2;
    }

    .txt-h-left {
        position: fixed;
        left: 4.5vw;
        top: 50%;
        font-size: 10px;
    }

    .slide-wrap {
        background-size: cover;
        background-position: center;
    }
    
    .slide01 .slide-wrap {
        background-image: url(../images/01_200.jpg);
    }
    
    .slide02 .slide-wrap {
        background-image: url(../images/04_008.jpg);
    }

    .slide03 .slide-wrap {
        background-image: url(../images/01_002.jpg);
    }

    .slide04 .slide-wrap {
        background-image: url(../images/10_079.jpg);
    }

    .slide05 .slide-wrap {
        background-image: url(../images/08_014.jpg);
    }

    .slide06 .slide-wrap {
        background-image: url(../images/09_105.jpg);
    }
    
    .slides-logo {
        z-index: 9;
    }
    
    .area01 h1 {
        font-size: 7.2rem;
    }
    
    .area01 .arrow {
        width: 9.5vw;
    }
    
    .img01 {
        width: 71.2vw;
        margin: 0 auto 0;
        padding-top: 85px;
    }

    .box-02 {
        display: block;
        padding-left: 0;
    }

    .txt-02 h2 {
        font-size: 17px;
        text-align: center;
        line-height: 1.45em;
        padding-top: 30px;
        padding-bottom: 3rem;
        letter-spacing: .04em;
    }

    .txt-02 p {
        font-size: 11px;
        line-height: 2.4;
        text-align: center;
        padding-top: 8px;
        padding-bottom: 34px;
    }

    .img02 {
        width: 100%;
    }

    .txt-03 {
        font-size: 18px;
        line-height: 1.4;
        margin-top: 35px;
        margin-bottom: 40px;
    }

    .box-04 {
        display: block;
        padding-left: 14%;
        padding-right: 14%;
        margin-bottom: 58px;
    }

    .img-04 {
        width: 100%;
        margin-bottom: 52px;
    }
    
    .img-04 img:last-child {
        position: absolute;
        left: 3.5vw;
        top: 3.5vw;
        animation: change01 14s linear 3.39s infinite;
    }

    @keyframes change01 {
        0% {
            opacity: 1;
            z-index: 1;
        }

        16.66% {
            opacity: 0;
            z-index: 1;
        }

        16.67% {
            opacity: 0;
            z-index: 2;
        }

        33.33% {
            opacity: 1;
            z-index: 2;
        }

        50% {
            opacity: 1;
            z-index: 2;
        }

        66.66% {
            opacity: 0;
            z-index: 2;
        }

        66.67% {
            opacity: 0;
            z-index: 1;
        }

        83.34% {
            opacity: 1;
            z-index: 1;
        }

        100% {
            opacity: 1;
            z-index: 1;
        }
    }


    .txt-04 {
        width: 100%;
        padding-left: 0;
    }

    .txt-04 p {
        font-size: 11px;
        line-height: 2;
        margin-top: 0;
    }

    .btn a {
        width: 230px;
        height: 45px;
        font-size: 14px;
        line-height: 46px;
        border-radius: 25px;
    }

    .box-05 {
        padding-bottom: 80px;
    }

    .area03 * {
        color: #fff;
    }

    .txt-06 {
        font-size: 18px;
        line-height: 1.4;
        margin-bottom: 40px;

    }

    .box-07 {
        display: block;
        padding-left: 14%;
        padding-right: 14%;
        margin-bottom: 58px;
    }

    .box-07 > div {
        width: 100%;
        margin: 0 0 35px;
    }

    .txt-08 {
        font-size: 11px;
        line-height: 2;
        padding-top: 30px;
        margin-bottom: 34px;
        padding-left: 14%;
        padding-right: 14%;
        text-align: left;
    }

    .txt-09 {
        font-size: 15px;
        margin-bottom: 18px;
    }

    .box-10 {
        padding-bottom: 75px;
    }

}