@charset "UTF-8";

html {
    font-size: 0.7vw;
}

@media screen and (min-width:1400px) {
    html {
        font-size: 9.8px;
    }
}

body {
    background-color: #fff;
    font-size: 1.45rem;
    letter-spacing: .03em;
}

body.area03-active .area03-bg, body.area02-active .area03-bg {
    background-image: url(../images/img_02_01.jpg);
    background-size: cover;
    background-position: center;
    background-color: transparent;
    width: 100%;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -1;
}

.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;
    transform: scaleX(0.6);
    transform-origin: top right;
    font-weight: 700;
}

.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;
}

.swiper-container {
    overflow: hidden;
}

.area01 {
    position: relative;
}

.area01 .arrow {
    width: 3.8rem;
    position: absolute;
    left: 50%;
    bottom: 2.2vw;
    transform: translateX(-50%);
    z-index: 1;
}

.area01 .slides, .area02 .slides {
    letter-spacing: 0.1em;
}

.slide-wrap {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    height: 100vh;
    background: #000;
}

@keyframes zoomUp {
    0% {
        transform: scale(1);
    }
    100% {
        transform: scale(1.15);
    }
}

.key-slider .swiper-slide-active img,
.key-slider .swiper-slide-duplicate-active img,
.key-slider .swiper-slide-prev img {
    animation: zoomUp 10s linear 0s 1 normal both;  
}


.key-slider .slides {
    width: 100%;
    position: relative;
}

.key-slider .slides img {
    width: 100%;
    height: 100%;
    max-width: none;
    object-fit: cover;
    object-position: center;
}

.key-slider .slides div {
    position: absolute;
    left: 50%;
    top: 46%;
    transform: translate(-50%, -50%);
}

.key-slider .slides p {
    white-space: nowrap;
    line-height: 1.25;
    font-size: 1.8rem;
    color: #fbfbf6;   
}

.area02-inner {
    position: relative;
    max-width: 1400px;
    padding-left: 30px;
    padding-right: 30px;
    margin-left: auto;
    margin-right: auto;
}

.area02-inner.txt-area {
    padding-left: 45px;
    padding-right: 45px;
}

.top-inner {
    padding-top: 153px;
    box-sizing: border-box;
}

.top-slider {
    width: 100%;
    aspect-ratio: 1340 / 1552;
}

.top-slider .slides {
    width: 100%;
    height: 100%;
    background: #fbfbf6;
}

.top-slider .slides {
    position: relative;
}

.top-slider .slides > div {
    position: absolute;
}

.img-pos01 {
    width: 34.18%;
    left: 0;
    top: 4.70%;
}

.img-pos02 {
    width: 18.13%;
    left: 69.10%;
    top: 0%;
}

.img-pos03 {
    width: 17.31%;
    left: 25.97%;
    top: 53.54%;
}

.img-pos04 {
    width: 31.80%;
    left: 54.48%;
    top: 29.70%;
}

.img-pos05 {
    width: 20.15%;
    left: 0;
    top: 72.62%;
}

.img-pos06 {
    width: 26.57%;
    right: 0;
    bottom: 0;
}

.sticky-txt-wrap {
    width: 100%;
    height: calc(100% + 50vh + 153px);
    position: absolute;
    left: 0;
    top: 0;
}

.area02 h1 {
    height: 100vh;
    position: sticky;
    left: 0;
    top: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    z-index: 9;
    pointer-events: none;
}

.sticky-txt-wrap h1 div {
    width: 409px;
    padding-right: 2.39%;
    transition: all 1.2s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    box-sizing: content-box;
}

@media screen and (min-width:1000px) {
    
    .area02.st-anchor .sticky-txt-wrap h1 div {
        transform: translateY(50%);
        padding-right: calc(2.39% + 15px);
        padding-top: 8px;
        width: 233px;
    }
    
    .top-slider a img {
        transition: .2s linear;
    }

    .top-slider a:hover img {
        opacity: 0.8;
    }

}

@media screen and (max-width:999px) {
    
    .area02 h1 {
        justify-content: center;
    }
    
    .sticky-txt-wrap h1 div {
        width: 84vw;
        line-height: 1;
        padding-right: 0;
        transition: all 1.2s cubic-bezier(0.230, 1.000, 0.320, 1.000);
    }
    
    .area02.st-anchor .sticky-txt-wrap h1 div {
        width: 54.67vw;
    }

    .key-slider .slides {
        width: 100%;
        height: 100vh;
    }

    .key-slider .slides div {
        position: absolute;
        left: 50%;
        top: 46%;
        transform: translate(-50%, -50%);
        width: 94%;
    }
    
    .key-slider .slides div p {
        white-space: inherit;
        line-height: 1.25;
        font-size: 3.36vw;
    }
    
    .area02-inner, .area02-inner.txt-area {
        padding-left: 5vw;
        padding-right: 5vw;
    }
    
    .area02-inner {
        padding-top: 20px;
    }
    
    .top-inner {
        padding-top: 110px;
    }

    .top-slider {
        aspect-ratio: 335 / 980;
    }

    .top-slider .slides {
        width: 100%;
        height: 100%;
    }

    .img-pos01 {
        width: 43.28%;
        left: 0;
        top: 13.06%;
    }

    .img-pos02 {
        width: 35.52%;
        left: 57.91%;
        top: 0%;
    }

    .img-pos03 {
        width: 30.75%;
        left: 6.57%;
        top: 51.73%;
    }

    .img-pos04 {
        width: 48.95%;
        left: 51.04%;
        top: 35.31%;
    }

    .img-pos05 {
        width: 36.12%;
        left: 60.30%;
        top: 69.59%;
    }

    .img-pos06 {
        width: 42.99%;
        left: 6.57%;
        right: auto;
        bottom: 0;
    }

}


[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 .top-inner {
    background: #111;
}

.area03-bg-space + .top-inner {
    background: #111;
    position: relative;
    z-index: 1;
}


.img01 {
    width: 27.3rem;
    margin-left: 60.6rem;
    padding-top: 9.2rem;
    margin-bottom: -10rem;
}

.txt-02 h2 {
    font-size: 2.7rem;
    line-height: 1.45em;
    padding-bottom: 3rem;
    letter-spacing: .04em;
}

.txt-02 p {
    font-size: 1.4rem;
    line-height: 2.5;
    padding-bottom: 20px;
}

.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 #111;
    background: transparent;
    color: #111;
    width: 23.4rem;
    height: 4.6rem;
    font-size: 1.7rem;
    line-height: 4.6rem;
    text-align: center;
    border-radius: 2.3rem;
    transition: all .3s linear;
    backdrop-filter: blur(3px);
}
.btn.white a {
    border-color: #fbfbf6;
    background: transparent;
    color: #fbfbf6;
}

@media screen and (min-width:1000px) {
    
    .btn a:hover {
        background: #111;
        color: #fbfbf6;
    }

    .btn.white a:hover {
        background: #fbfbf6;
        color: #111;
    }

}

.sticky-btn01, .sticky-btn02 {
    position: sticky;
    bottom: 40px;
    padding-top: 70px;
    z-index: 2;
}

.sticky-space {
    width: 100%;
    height: 19rem;
}

.area03 * {
    color: #fbfbf6;
}

.txt-06 {
    font-size: 1.74rem;
    line-height: 1.25;
    padding-top: 15rem;
    padding-bottom: calc(15rem + 80px);
}

.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.4rem;
    line-height: 2.5;
    text-align: center;
    margin-bottom: 8.5rem;
}

.area03 {
    position: relative;
}

.area03::after {
    content: "";
    display: block;
    position: absolute;
    background: #111;
    width: 100%;
    height: 500px;
    left: 0;
    bottom: 0;
    z-index: 0;
}

.txt-09 {
    font-size: 2.4rem;
    margin-bottom: 2.9rem;
}

.area03-bg-space {
    width: 100%;
    height: 486px;
}

@media screen and (max-width:999px) {
 
    .logo {
        width: 16.27vw;;
        left: 5vw;
        top: 21px;
    }

    .txt-h-top {
        text-align: right;
        right: 5vw;
        top: 26px;
        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;
    }
    
    .slides-logo {
        z-index: 9;
    }
    
    .area01 .arrow {
        width: 9.5vw;
        bottom: 5vw;
    }
    
    .img01 {
        width: 71.2vw;
        margin: 0 auto 0;
        padding-top: 85px;
    }

    .box-02 {
        padding-top: 80px;
        margin-bottom: -10px;
    }
    
    #sticky-txt-anchor {
        padding-bottom: 70px;
    }
    
    .sticky-txt-wrap {
        height: calc(100% + 50vh + 120px);
        position: absolute;
        left: 0;
        top: 0;
    }

    .txt-02 h2 {
        font-size: 4.533vw;
        text-align: center;
        line-height: 1.45em;
        padding-top: 30px;
        padding-bottom: 3rem;
        letter-spacing: .04em;
    }

    .txt-02 p {
        font-size: 3.58vw;
        line-height: 1.7;
        padding-top: 8px;
        padding-bottom: 5.3vw;
    }

    .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: 200px;
        height: 36px;
        font-size: 14px;
        line-height: 36px;
        border-radius: 18px;
    }

    .area03 * {
        color: #fff;
    }

    .txt-06 {
        font-size: 3.2vw;
        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: 3.58vw;
        line-height: 1.7;
        padding-top: 0;
        margin-top: -20px;
        margin-bottom: 0;
        padding-left: 5vw;
        padding-right: 5vw;
        text-align: left;
    }

    .txt-09 {
        font-size: 18px;
        margin-bottom: 23px;
    }
    
    .area03-bg-space {
        height: 276px;
    }
    
    .sticky-btn01, .sticky-btn02 {
        position: sticky;
        bottom: 30px;
        padding-top: 60px;
    }

    .sticky-space {
        width: 100%;
        height: 90px;
    }


}