html { 
    /* font-family: 'Zen Kaku Gothic New', sans-serif; */
    font-family: "TazuganeGothicStdN-Regular";
    color: #1e1e1e;
    font-weight: 400;
    background-color: #f2f1ee;
    transition: color .3s;
}
html.--bg-black {
    /* background-color: #1e1e1e; */
    color: #f2f1ee;
}

.fontplus-trial-banner {
    display: none;
}

body {
    min-width: 390px;
    width: 100%;
}
body.bg-black {
    background-color: #1e1e1e;
}

@media screen and (max-width: 900px) {
    body.js-active {
        overflow: hidden;
    }
}

.bg-all {
    background-color: #1e1e1e;
    position: fixed;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    z-index: 0;
    opacity: 0;
    transition: opacity .3s;
}
html.--bg-black .bg-all {
    opacity: 1;
}

main {
    position: relative;
    padding-top: 95px;
}

.main-ofh {
    overflow: hidden;
}

@media screen and (max-width: 900px) {
    main {
        padding-top: 51px;
    }
}

::-webkit-scrollbar{
    width: 10px;
}
::-webkit-scrollbar-track{
    background-color: #f9f8f4;
}
::-webkit-scrollbar-thumb{
    background-color: #1e1e1e;
}

span {
    display: inline-block;
}

picture {
    display: block;
}

img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

a {
    display: inline-block;
}

/* utility */
.u-en {
    font-family: 'Unbounded', cursive;
}

.u-bold {
    font-family: "TazuganeGothicStdN-Bold";
}

.u-light {
    font-family: "TazuganeGothicStdN-Light";
}

/* layout */
.l-wrapper {
    padding-left: 7.35%;
    padding-right: 7.35%;
}

.l-inner {
    max-width: 1160px;
    margin: 0 auto;
}

.l-wrapper02 {
    padding-left: 50px;
    padding-right: 50px;
}

.l-inner02 {
    max-width: 1160px;
    margin: 0 auto;
}

@media screen and (max-width: 900px) {
    .l-wrapper {
        padding-left: 6.4%;
        padding-right: 6.4%;
    }

    .l-inner {
        max-width: unset;
    }

    .l-wrapper02 {
        padding-left: 6.4%;
        padding-right: 6.4%;
    }
    
    .l-inner02 {
        max-width: 1160px;
        margin: 0 auto;
    }
}

/* common */
.pc-only {
    display: block;
}

.br-pc-only {
    display: inline;
}

.sp-only {
    display: none;
}

.br-sp-only {
    display: none;
}

@media screen and (max-width: 1200px) {
    .br-tab {
        display: none;
    }
}

@media screen and (max-width: 900px) {
    .pc-only {
        display: none;
    }

    .br-pc-only {
        display: none;
    }

    .sp-only {
        display: block;
    }

    .br-sp-only {
        display: inline;
    }
}

.hover-border-wrapper {
    position: relative;
}

.hover-border {
    position: absolute;
    width: 100%;
    left: 0;
    bottom: -2px;
    height: 1px;
    overflow: hidden;
}
.hover-border::before {
    background-color: #1e1e1e;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
    transform: translate(-101%, 0);
}

.hover-link-wrap {
    position: relative;
    overflow: hidden;
}

.hover-link-txt {
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

.hover-link-txt02 {
    position: absolute;
    top: 101%;
    left: 0;
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02);
}

@media screen and (min-width: 901px) {
    a.--nomal {
        transition: opacity .4s;
    }

    a.--nomal:hover {
        opacity: .5;
    }

    .hover-border-link:hover .hover-border::before {
        transform: translate(0, 0);
    }

    .hover-link-wrap:hover .hover-link-txt,
    .hover-link-wrap:hover .hover-link-txt02 {
        transform: translate(0, -101%);
    }
}

/* component */
/* .c-ttl__wrapper {
    position: relative;
    height: 788px;
    padding-top: 100px;
    overflow: hidden;
}

.c-ttl__inner {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.c-ttl__head {
    font-size: 430px;
    line-height: .99;
    letter-spacing: -.02em;
} */

.c-ttl__wrapper {
    position: relative;
    height: 320vh;
}

.c-ttl__inner {
    height: 100vh;
    position: sticky;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.c-ttl__head {
    font-size: 600px;
    line-height: 99%;
    letter-spacing: -.02em;
    will-change: transform;
}

.c-head-en {
    font-size: 12px;
    line-height: 100%;
}

.c-head-en .fade-wrapper {
    position: relative;
}

.c-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    width: 146px;
    height: 54px;
    font-size: 10px;
    line-height: 1;
    letter-spacing: .07em;
    position: relative;
}

.c-btn::before {
    background-color: #e8e6e5;
    content: '';
    height: 54px;
    left: 0;
    position: absolute;
    top: 0;
    width: 54px;
    border-radius: 100vh;
    z-index: -1;
    transition: width .4s 0s cubic-bezier(.44,.14,.09,1.02), opacity .3s;
}
.c-btn::after {
    background-color: #363636;
    content: '';
    height: 54px;
    left: 0;
    position: absolute;
    top: 0;
    width: 54px;
    border-radius: 100vh;
    z-index: -1;
    transition: width .4s 0s cubic-bezier(.44,.14,.09,1.02), opacity .3s;
    opacity: 0;
}

.p-partner__btn .c-btn::before {
    opacity: 1 !important;
    background-color: rgba(255, 255, 255, 0.11) !important;
    backdrop-filter: blur(6px);
}
.p-partner__btn .c-btn::after {
    display: none !important;
}

/* html.--bg-black .c-btn {
    color: #f2f1ee;
} */

html.--bg-black .c-btn::before {
    opacity: 0;
}
html.--bg-black .c-btn::after {
    opacity: 1;
}

html.--bg-black .c-btn span::before {
    background: url('../img/common/arrow-white.svg') no-repeat center center/contain;
}

.c-btn span {
    position: relative;
    padding-right: 18px;
}
.c-btn span::before {
    background: url('../img/common/arrow.svg') no-repeat center center/contain;
    content: '';
    height: 10px;
    right: 0;
    position: absolute;
    bottom: 1px;
    width: 10px;
}

.p-partner__btn .c-btn span::before {
    background: url('../img/common/arrow-white.svg') no-repeat center center/contain !important;
}

@media screen and (min-width: 901px) {
    .c-btn:hover:before {
        width: 100%;
    }
    .c-btn:hover:after {
        width: 100%;
    }
}

@media screen and (max-width: 900px) {
    .c-ttl__wrapper {
        height: 200vh;
        padding-top: 0;
    }
    
    .c-ttl__head {
        font-size: 200px;
    }
    
    .c-head-en {
        font-size: 11px;
        line-height: 100%;
    }
    
    .c-head-en .fade-wrapper {
        position: relative;
    }
}

/*===========================================================================*/
/*  animation  */
/*===========================================================================*/
.fade-wrap {
    display: flex;
    flex-direction: column;
}

.fade-wrapper {
    overflow: hidden;
}
/* span.fade-wrapper {
    display: inline;
} */

.fade-nomal {
    opacity: 0;
    transform: translate3d(0, 0, 0);
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02), opacity 2s 0s cubic-bezier(.24,.91,.57,.97);
}

.fade-bottom {
    /* opacity: 0; */
    transform: translate3d(0, 100%, 0);
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02), opacity 1s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-bottom02 {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02), opacity 1s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-bottom03 {
    transform: translate3d(0, 110%, 0);
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02), opacity 1s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-bottom04 {
    opacity: 0;
    transform: translate3d(0, 30px, 0);
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02), opacity 1s;
}
.fade-bottom-header {
    opacity: 0;
    transform: translate3d(0, 68%, 0);
    transition: transform .4s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-top-header {
    opacity: 0;
    transform: translate3d(0, -10%, 0);
    transition: transform .3s 0s cubic-bezier(.44,.14,.09,1.02), opacity .5s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-top-ttlEn {
    opacity: 0;
    transform: translate3d(0, -120%, 0);
    transition: transform .6s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-top {
    opacity: 0;
    transform: translate3d(0, -68%, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-left {
    opacity: 0;
    transform: translate3d(-25px, 0, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-right {
    opacity: 0;
    transform: translate3d(25px, 0, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02), opacity .7s 0s cubic-bezier(.24,.91,.57,.97);
}
.fade-lower-content {
    transform: translate3d(0, 96px, 0);
    transition: transform .7s 0s cubic-bezier(.44,.14,.09,1.02);
}
@media screen and (max-width: 900px) {
    .fade-lower-content {
        transform: translate3d(0, 77px, 0);
    }
}
.fade-nomal.js-active,
.fade-bottom.js-active,
.fade-bottom02.js-active,
.fade-bottom03.js-active,
.fade-bottom04.js-active,
.fade-bottom-header.js-active,
.fade-top-header.js-active,
.fade-top-ttlEn.js-active,
.fade-top.js-active,
.fade-left.js-active,
.fade-right.js-active,
.fade-lower-content.js-active {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.fade-media-img-wrapper {
    position: relative;
    opacity: 0;
    transition: opacity .4s 0s ease;
    border-radius: 6px;
    overflow: hidden;
}
.fade-media-img-bg {
    background-color: #1e1e1e;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 3;
    transition: top .4s 0s ease;
}
.fade-media-img {
    scale: 1.2;
    transition: scale .4s 0s ease;
}
.fade-media-img-wrapper.js-active {
    opacity: 1;
}
.fade-media-img-bg.js-active {
    top: calc(-100% - 10px);
}
.fade-media-img.js-active {
    scale: 1;
}

.fade-border {
    position: absolute;
    width: 0;
    left: 0;
    top: 0;
    height: 1px;
    background-color: #1e1e1e;
    transition: width .4s 0s ease-out;
}
html.--bg-black .fade-border {
    background-color: #f2f1ee;
}
.fade-border02 {
    position: absolute;
    width: 0;
    left: 0;
    top: 0;
    height: 1px;
    background-color: #1e1e1e;
}
html.--bg-black .fade-border02 {
    background-color: #f2f1ee;
}

.fade-border.js-active {
    width: 100%;
}

.delay-hamburger01.js-active {
    transition-delay: .3s !important;
}
.delay-hamburger02.js-active {
    transition-delay: .4s !important;
}
.delay-hamburger03.js-active {
    transition-delay: .5s !important;
}
.delay-hamburger04.js-active {
    transition-delay: .6s !important;
}
.delay-hamburger05.js-active {
    transition-delay: .7s !important;
}
.delay-hamburger06.js-active {
    transition-delay: .8s !important;
}
.delay-hamburger07.js-active {
    transition-delay: .9s !important;
}
.delay-hamburger08.js-active {
    transition-delay: 1s !important;
}
.delay-hamburger09.js-active {
    transition-delay: 1.1s !important;
}
.delay-hamburger10.js-active {
    transition-delay: 1.2s !important;
}
.delay-hamburger11.js-active {
    transition-delay: 1.3s !important;
}

.load-delay01.js-active {
    transition-delay: 4s !important;
}
.load-delay02.js-active {
    transition-delay: 4.2s !important;
}
.load-delay03.js-active {
    transition-delay: 4.4s !important;
}
.load-delay04.js-active {
    transition-delay: 3.6s !important;
}
.load-delay05.js-active {
    transition-delay: 5s !important;
}
.load-delay06.js-active {
    transition-delay: 5.4s !important;
}

.load-delay-lower.js-active {
    transition-delay: 1.4s !important;
}

@media screen and (max-width: 900px) {
    .load-delay03.js-active {
        transition-delay: .8s !important;
    }
    .load-delay04.js-active {
        transition-delay: 1s !important;
    }
    /* .load-delay05.js-active {
        transition-delay: 1.4s !important;
    } */
}

.delay01.js-active {
    transition-delay: .1s !important;
}
.delay02.js-active {
    transition-delay: .2s !important;
}
.delay03.js-active {
    transition-delay: .3s !important;
}
.delay04.js-active {
    transition-delay: .4s !important;
}
.delay05.js-active {
    transition-delay: .5s !important;
}
.delay06.js-active {
    transition-delay: .6s !important;
}
.delay07.js-active {
    transition-delay: .7s !important;
}
.delay08.js-active {
    transition-delay: .8s !important;
}
.delay09.js-active {
    transition-delay: .9s !important;
}
.delay10.js-active {
    transition-delay: 1s !important;
}
.delay11.js-active {
    transition-delay: 1.1s !important;
}
.delay12.js-active {
    transition-delay: 1.2s !important;
}
.delay13.js-active {
    transition-delay: 1.3s !important;
}
.delay14.js-active {
    transition-delay: 1.4s !important;
}
.delay15.js-active {
    transition-delay: 1.5s !important;
}
.delay16.js-active {
    transition-delay: 1.6s !important;
}
.delay17.js-active {
    transition-delay: 1.7s !important;
}
.delay18.js-active {
    transition-delay: 1.8s !important;
}
.delay19.js-active {
    transition-delay: 1.9s !important;
}
.delay20.js-active {
    transition-delay: 2s !important;
}
.delay21.js-active {
    transition-delay: 2.1s !important;
}

/*===========================================================================*/
/*  header  */
/*===========================================================================*/
.p-header {
    padding: 25px 30px;
    position: absolute;
    z-index: 3;
    width: 100%;
    left: 0;
    top: 0;
}
body.bg-black .p-header {
    color: #fff;
}

.p-header__inner {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.p-header__logo {
    display: flex;
    align-items: flex-start;
    width: 160px;
}
.p-header__logo .--logo {
    width: 31px;
    padding-top: 1px;
}
.p-header__logo .--txt {
    width: 123px;
    margin-left: 6px;
}

.p-header__nav {
    display: flex;
    align-items: center;
    font-size: 12px;
    line-height: 1;
}
.p-header__nav.sp-only {
    display: none;
}

.p-header__nav .hover-link-wrap {
    margin-left: 30px;
    white-space: nowrap;
}

.p-header__nav .--blank {
    position: relative;
    padding-right: 18px;
}
.p-header__nav .--blank::before {
    background: url('../img/common/icon_blank.svg') no-repeat center center/contain;
    content: '';
    height: 11px;
    right: 0;
    position: absolute;
    bottom: 0;
    width: 11px;
}

.p-header__nav--contact {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background-color: #1e1e1e;
    border: #1e1e1e solid 1px;
    border-radius: 100vh;
    width: 151px;
    height: 45px;
    margin-left: 40px;
}
body.bg-black .p-header__nav--contact {
    background-color: #373737;
    border: #373737 solid 1px;
}

.p-header__nav--contact span {
    position: relative;
    /* padding-right: 21px; */
}
/* .p-header__nav--contact span::before {
    background: url('../img/common/shake-hand.png') no-repeat center center/contain;
    content: '';
    height: 14px;
    right: 0;
    position: absolute;
    top: -3px;
    width: 15px;
} */

.p-nav {
    position: fixed;
    bottom: 30px;
    display: inline-block;
    padding: 5px 5px 5px 40px;
    border-radius: 100vh;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    z-index: 88;
    width: auto;
    color: #1e1e1e;
}

.p-nav::before {
    background-color: #fff;
    content: '';
    height: 30px;
    position: absolute;
    width: 30px;
    border-radius: 100vh;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, calc(-50% + 100px));
    -webkit-transform: translate(-50%, calc(-50% + 100px));
    -ms-transform: translate(-50%, calc(-50% + 100px));
    transition: transform .7s .8s ease, height .7s 0s ease, width .7s 0s ease;
}
.p-nav.js-active::before {
    height: 100%;
    width: 100%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transition: transform .7s 0s ease, height .7s .8s ease, width .7s .8s ease;
}

.p-nav .p-header__nav {
    opacity: 0;
    pointer-events: none;
}

.p-nav.js-active .p-header__nav {
    opacity: 1;
    pointer-events: all;
    transition: opacity .4s 1.6s ease;
}

.p-nav .p-header__nav .--nomal {
    margin-left: 25px;
}
.p-nav .p-header__nav .--nomal:nth-of-type(1) {
    margin-left: 0;
}

.p-nav .p-header__nav--contact {
    margin-left: 26px;
}

.p-header__hamburger {
    display: none;
}

@media screen and (min-width: 901px) {
    .p-header__nav--contact {
        transition: all .4s;
    }

    .p-header__nav--contact:hover {
        background-color: transparent;
        color: #1e1e1e;
    }
    body.bg-black .p-header__nav--contact:hover {
        background-color: #fff;
    }
}

@media screen and (max-width: 1090px) {
    .p-header {
        padding: 25px 15px;
    }

    .p-header__logo {
        width: 150px;
    }

    .p-header__nav .hover-link-wrap {
        margin-left: 15px;
    }
    
    .p-header__nav--contact {
        margin-left: 20px;
    }
}

@media screen and (max-width: 900px) {
    .p-header {
        padding: 25px 20px 0 25px;
    }

    .p-header__logo {
        width: 150px;
    }
    .p-header__logo .--logo {
        width: 29px;
        padding-top: 1px;
    }
    .p-header__logo .--txt {
        width: 115px;
        margin-left: 6px;
    }
    
    .p-header__nav--wrapper {
        position: fixed;
        left: 0;
        top: 0;
        overflow: hidden;
        width: 100vw;
        height: 100vh;
        z-index: 75;
        pointer-events: none;
    }
    .p-header__nav {
        justify-content: center;
        align-items: flex-start;
        flex-direction: column;
        font-size: 20px;
        color: #fff;
        line-height: 1;
        position: fixed;
        width: 100%;
        height: 100%;
        padding: 40px 60px 100px;
        pointer-events: none;
    }
    .p-header__nav.pc-only {
        display: none;
    }
    .p-header__nav.sp-only {
        display: flex;
    }

    .p-header__nav--bg {
        background-color: #1e1e1e;
        content: '';
        position: absolute;
        width: 100vw;
        height: 110vh;
        top: 102%;
        left: 0;
        z-index: -1;
        transition: top 1s 0s ease;
        overflow: hidden;
    }
    .p-header__nav.js-active .p-header__nav--bg {
        top: 0;
    }

    .p-header__nav--bg::after {
        background: url('../img/common/logo-only.svg') no-repeat center center/contain;
        content: '';
        height: 414px;
        left: calc(50% - 317px);
        position: absolute;
        top: -47px;
        width: 640px;
        z-index: 0;
    }

    .p-header .p-header__nav {
        display: none;
    }
    
    .p-header__nav .--nomal {
        margin-left: 0;
        display: block;
        text-align: center;
        margin-top: 40px;
        z-index: 2;
    }
    .p-header__nav .--nomal:nth-of-type(1) {
        margin-top: 0;
    }
    
    .p-header__nav--contact {
        margin-left: 0;
        font-size: 12px;
    }

    .p-header__nav--contact span::before {
        top: -2px;
    }

    .p-header__nav .--blank {
        position: relative;
        padding-right: 18px;
    }
    .p-header__nav .--blank::before {
        background: url('../img/common/icon_blank.svg') no-repeat center center/contain;
        content: '';
        height: 11px;
        right: 0;
        position: absolute;
        bottom: 0;
        width: 11px;
    }
    
    .p-nav {
        bottom: 20px;
        padding: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
    
    .p-nav::before {
        height: 16px;
        width: 16px;
        top: 50%;
        left: 50%;
        transform: translate(-50%, calc(-50% + 70px));
        -webkit-transform: translate(-50%, calc(-50% + 70px));
        -ms-transform: translate(-50%, calc(-50% + 100px));
        transition: transform .7s .8s ease, height .7s 0s ease, width .7s 0s ease;
    }
    .p-nav.js-active::before {
        height: calc(100% + 6px);
        width: calc(100% + 6px);
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transition: transform .7s 0s ease, height .7s .8s ease, width .7s .8s ease, opacity .4s 1.6s ease;
    }
    
    .p-nav .p-header__nav--contact {
        margin-left: 6px;
        padding-left: 3px;
        width: 142px;
        height: 48px;
        font-size: 11px;
        transition: background-color .4s 2.2s ease, color .4s 2.2s ease;
        opacity: 0;
        color: #1e1e1e;
    }
    .p-nav.js-active .p-header__nav--contact {
        opacity: 1;
        transition: opacity .4s 1.6s ease;
        background-color: #1e1e1e;
        color: #fff;
    }

    .p-nav__menu {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 142px;
        height: 48px;
        background-color: #fff;
        border-radius: 100vh;
        font-size: 11px;
        position: relative;
        z-index: 3;
        opacity: 0;
    }

    .p-nav.js-active .p-nav__menu {
        opacity: 1;
        transition: opacity .4s 1.6s ease;
    }

    .p-header__hamburger {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 26px;
        height: 26px;
    }

    .p-header__hamburger span {
        width: 3px;
        height: 3px;
        border-radius: 100vh;
        background-color: #adadad;
        margin: 0 1.5px;
    }
}

/* hamburger */
.p-hamburger {
    width: 17px;
    height: 6px;
    display: none;
    align-items: center;
    justify-content: center;
    margin-left: 6px;
    padding-bottom: 1px;
}

.p-hamburger__trigger {
    cursor: pointer;
    height: 6px;
    width: 17px;
    z-index: 99;
    position: relative;
}

.p-hamburger__trigger span {
    background-color: #1e1e1e;
    height: 2px;
    left: 0;
    position: absolute;
    width: 100%;
}

.p-hamburger__trigger, 
.p-hamburger__trigger span {
    display: inline-block;
    transition: all .3s;
    box-sizing: border-box;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -ms-transition: all .3s;
    -o-transition: all .3s;
}

.p-hamburger__trigger span:nth-of-type(1) {
    top: 0;
}

.p-hamburger__trigger span:nth-of-type(2) {
    bottom: 0;
}

.p-hamburger__trigger.js-active span:nth-of-type(1) {
    transform: translateY(2px) rotate(-38deg);
    -webkit-transform: translateY(2px) rotate(-38deg);
    -moz-transform: translateY(2px) rotate(-38deg);
    -ms-transform: translateY(2px) rotate(-38deg);
    -o-transform: translateY(2px) rotate(-38deg);
}

.p-hamburger__trigger.js-active span:nth-of-type(2) {
    transform: translateY(-2px) rotate(38deg);
    -webkit-transform: translateY(-2px) rotate(38deg);
    -moz-transform: translateY(-2px) rotate(38deg);
    -ms-transform: translateY(-2px) rotate(38deg);
    -o-transform: translateY(-2px) rotate(38deg);
}

@media screen and (max-width: 900px) {
    .js-active.p-header__nav {
        opacity: 1;
        pointer-events: all;
    }

    .p-hamburger {
        display: flex;
    }
}

/*===========================================================================*/
/*  footer  */
/*===========================================================================*/
.p-footer {
    padding: 170px 0 150px;
    background-color: #1e1e1e;
    overflow: hidden;
    position: relative;
}
.p-footer::before {
    background: url('../img/common/logo-only.svg') no-repeat center center/contain;
    content: '';
    height: 666px;
    left: calc(50% - 187px);
    position: absolute;
    top: 89px;
    width: 1031px;
}

.p-contact {
    overflow: hidden;
    position: relative;
}

.p-contact__link {
    display: flex;
    width: 100%;
    align-items: center;
    cursor: none;
}

.p-contact__txts {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
}

.p-contact__txts--inner {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    font-size: 120px;
    line-height: 1;
    color: #f2f1ee;
    font-weight: 300;
    animation: txtSlide 88s linear 0s infinite normal forwards running;
}

.p-contact__txts--inner>div {
    display: flex;
    align-items: center;
    padding-right: 40px;
    white-space: nowrap;
    -webkit-backface-visibility:hidden;
    backface-visibility:hidden;
}

.p-contact__txts--inner>div img {
    width: 203px;
    border-radius: 8px;
    margin-left: 40px;
}

#contact-cursor {
    position: fixed;
    width: 98px;
    top: 0;
    left: 0;
    height: 98px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 13px;
    line-height: 1.29;
    letter-spacing: .035em;
    color: #f2f1ee;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
    border-radius: 100vh;
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity .3s;
}

#contact-cursor.active {
    opacity: 1;
}

@keyframes txtSlide {
    0%{
        transform: translateX(0);
    }
    100%{
        transform: translateX(-100%);
    }
}

.p-footer--wrapper {
    padding: 170px 7.35% 0;
    position: relative;
    z-index: 2;
}

.p-footer__logo {
    width: 158px;
}

.p-footer__content--nav {
    margin-top: 37px;
    font-size: 12px;
    color: #fff;
    line-height: 1;
}

.p-footer__content--nav .hover-link-wrap {
    margin-right: 25px;
}

.p-footer__content--nav .--blank {
    position: relative;
    padding-right: 18px;
}
.p-footer__content--nav .--blank::before {
    background: url('../img/common/icon_blank.svg') no-repeat center center/contain;
    content: '';
    height: 11px;
    right: 0;
    position: absolute;
    bottom: 1px;
    width: 11px;
}

.p-footer__txt {
    margin-top: 37px;
    font-size: 10px;
    line-height: 1.9;
    letter-spacing: .005em;
    color: #636363;
}
.p-footer__txt.--02 {
    margin-top: 0;
}

.p-footer__office {
    margin-top: 7px;
    display: flex;
}

.p-footer__office .p-footer__txt:nth-of-type(1) {
    margin-right: 26px;
}

@media screen and (max-width: 900px) {
    .p-footer {
        padding: 110px 0 66px;
    }
    .p-footer::before {
        height: 369px;
        left: calc(50% - 270px);
        top: 222px;
        width: 570px;
    }
    
    .p-contact__txts--inner {
        font-size: 52px;
        animation: txtSlide 66s linear 0s infinite normal forwards running;
    }
    
    .p-contact__txts--inner>div {
        padding-right: 21px;
    }

    .p-contact__txts--inner>div img {
        width: 93px;
        border-radius: 8px;
        margin-left: 21px;
    }
    
    #contact-cursor {
        display: none;
    }

    .p-footer--wrapper {
        padding: 110px 8.97% 0;
        position: relative;
        z-index: 2;
    }
    
    .p-footer__logo {
        width: 133px;
    }
    
    .p-footer__content--nav {
        margin-top: 0;
        padding-top: 24px;
        font-size: 10px;
        color: #fff;
        line-height: 1;
        display: flex;
        flex-wrap: wrap;
        max-width: 260px;
    }
    
    .p-footer__content--nav .hover-link-wrap {
        margin-right: 20px;
        margin-top: 18px;
    }
    
    .p-footer__content--nav .--blank {
        position: relative;
        padding-right: 18px;
    }
    .p-footer__content--nav .--blank::before {
        background: url('../img/common/icon_blank.svg') no-repeat center center/contain;
        content: '';
        height: 11px;
        right: 0;
        position: absolute;
        bottom: 0;
        width: 11px;
    }
    
    .p-footer__txt {
        margin-top: 42px;
        font-size: 10px;
    }
    .p-footer__txt.--02 {
        margin-top: 10px;
    }
    
    .p-footer__office {
        margin-top: 0;
        display: block;
    }
    
    .p-footer__office .p-footer__txt:nth-of-type(1) {
        margin-right: 0;
    }

    .p-footer__copyRight {
        margin-top: 40px;
    }
}

/*===========================================================================*/
/*  lower mv  */
/*===========================================================================*/
.c-lowerMv {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 0;
    height: 100vh;
    color: #fff;
    display: flex;
    align-items: center;
    padding: 40px 4.4%;
    background-color: #242424;
}
.c-lowerMv.--white {
    background-color: #f9f8f4;
    color: #1e1e1e;
}

.c-lowerMv__head {
    font-size: 120px;
    line-height: .905;
    letter-spacing: -.02em;
}

.c-lowerMv__txt {
    font-size: 12px;
    font-weight: 300;
    line-height: 1.46;
    letter-spacing: -.02em;
    margin-top: 25px;
}

.c-lowerSpace {
    height: calc(100vh - 189px);
}

.c-main__scroll {
    font-size: 12px;
    font-weight: 300;
    line-height: 1.46;
    letter-spacing: .015em;
    color: #fff;
    padding: 40px 0 38px;
    position: relative;
    z-index: 2;
}

#scroll-txt {
    opacity: 1;
    transition: opacity .3s;
}
#scroll-txt.js-active {
    opacity: 0;
}

@media screen and (max-width: 900px) {
    .c-lowerMv {
        padding: 20px 6.4%;
    }
    
    .c-lowerMv__head {
        font-size: 55px;
    }
    
    .c-lowerMv__txt {
        font-size: 10px;
        margin-top: 24px;
    }
    
    .c-lowerSpace {
        height: calc(100vh - 128px);
    }

    .c-main__scroll {
        font-size: 10px;
        padding: 32px 0 30px;
    }
}

/*===========================================================================*/
/*  page next btn  */
/*===========================================================================*/
.c-pageNext {
    padding: 145px 20px;
    background-color: #242424;
    position: relative;
    z-index: 5;
    display: block;
    text-align: center;
    color: #fff;
}

.c-pageNext__subHead {
    font-size: 20px;
    font-weight: 300;
    line-height: .9;
    letter-spacing: -.02em;
}

.c-pageNext__head {
    margin-top: 24px;
    font-size: 48px;
    line-height: .9;
    letter-spacing: -.02em;
    overflow: hidden;
    position: relative;
}

.c-pageNext__head span:nth-of-type(2) {
    position: absolute;
    width: 100%;
    text-align: center;
    left: 0;
    top: -100%;
}

.c-pageNext__head span {
    transition: transform 1s 0s cubic-bezier(.44,.14,.09,1.02);
}

.c-pageNext__arrow {
    max-width: 24px;
    margin: 24px auto 0;
}
.c-pageNext.--prev .c-pageNext__arrow {
    transform: rotate(180deg);
}

@keyframes pageNextArrow {
    0% {
        transform: translate(0, 0);
    }
    50% {
        transform: translate(10px, 0);
    }
    100% {
        transform: translate(0, 0);
    }
}

@keyframes pageNextArrow02 {
    0% {
        transform: translate(0, 0) rotate(180deg);
    }
    50% {
        transform: translate(-10px, 0) rotate(180deg);
    }
    100% {
        transform: translate(0, 0) rotate(180deg);
    }
}

@media screen and (min-width: 901px) {
    .c-pageNext:hover .c-pageNext__head span {
        transform: translate(0, 100%);
    }

    .c-pageNext:hover .c-pageNext__arrow {
        animation: pageNextArrow .6s cubic-bezier(.44,.14,.09,1.02);
    }

    .c-pageNext.--prev:hover .c-pageNext__arrow {
        animation: pageNextArrow02 .6s cubic-bezier(.44,.14,.09,1.02);
    }
}

@media screen and (max-width: 900px) {
    .c-pageNext {
        padding: 70px 20px 60px;
    }
    
    .c-pageNext__subHead {
        font-size: 15px;
    }
    
    .c-pageNext__head {
        margin-top: 20px;
        font-size: 26px;
    }
    
    .c-pageNext__arrow {
        max-width: 20px;
        margin: 24px auto 0;
    }
}

/*===========================================================================*/
/*  swiper pagination  */
/*===========================================================================*/
@media screen and (max-width: 900px) {
    .swiper-bar {
        width: 87.18vw !important;
        min-width: 327px !important;
        display: flex;
        margin-top: 40px !important;
    }
    .swiper-bar.--black {
        width: 76.924vw !important;
        min-width: 288px !important;
        margin-top: 35px !important;
    }
    
    .swiper-bar>span {
        width: 50%;
        margin: 0 !important;
        opacity: 1 !important;
        background: #fff !important;
        height: 1px !important;
        border-radius: 0 !important;
    }
    .swiper-bar.--black>span {
        background: #636363 !important;
    }
    .swiper-bar>span.swiper-pagination-bullet-active {
        background: #ccc !important;
    }
    .swiper-bar.--black>span.swiper-pagination-bullet-active {
        background: #adadad !important;
    }
}

/*===========================================================================*/
/*  join us  */
/*===========================================================================*/
.p-partner {
    padding-top: 80px;
    padding-bottom: 80px;
    background-color: #f2f1ee;
    position: relative;
    z-index: 2;
}

.p-partner__link {
    display: block;
    border-radius: 20px;
    padding: 85px 93px 82px 93px;
    color: #fff;
    cursor: none;
    position: relative;
    overflow: hidden;
}
.p-partner__link::before {
    background: url('../img/common/joinUs-bg.webp') no-repeat center center/cover;
    content: '';
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    transition: scale .7s 0s cubic-bezier(.44,.14,.09,1.02);
}

.p-partner__headEn {
    position: relative;
}

.p-partner__head {
    margin-top: 18px;
    font-size: 73px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -.02em;
    position: relative;
    z-index: 2;
}

.p-partner__txt {
    margin-top: 25px;
    font-size: 16px;
    line-height: 1.82; 
    position: relative;
    z-index: 2;
}

#joinUs-cursor {
    position: fixed;
    width: 98px;
    top: 0;
    left: 0;
    height: 98px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 13px;
    line-height: 1.29;
    letter-spacing: .035em;
    color: #f2f1ee;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(9px);
    -webkit-backdrop-filter: blur(9px);
    border-radius: 100vh;
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity .3s;
    padding-bottom: 13px;
}
#joinUs-cursor::before {
    background: url('../img/common/icon_blank.svg') no-repeat center center/contain;
    content: '';
    height: 11px;
    left: 50%;
    transform: translate(-50%, 0);
    position: absolute;
    bottom: 20px;
    width: 11px;
}

#joinUs-cursor.active {
    opacity: 1;
}

@media screen and (min-width: 901px) {
    .p-partner__link:hover:before {
        scale: 1.08;
    }
}

@media screen and (max-width: 900px) {
    .p-partner {
        padding-top: 40px;
        padding-bottom: 40px;
        padding-left: 3.85%;
        padding-right: 3.85%;
        text-align: center;
    }
    
    .p-partner__link {
        border-radius: 10px;
        background: url('../img/common/joinUs-bg-sp.webp') no-repeat center center/cover;
        padding: 57px 8.333% 47px 8.333%;
    }
    .p-partner__link::before {
        display: none;
    }
    
    .p-partner__head {
        margin-top: 17px;
        font-size: 45px;
    }
    
    .p-partner__txt {
        margin-top: 16px;
        font-size: 13px;
        line-height: 1.92;
    }
    
    #joinUs-cursor {
        display: none;
    }

    .p-partner__btn {
        margin-top: 20px;
    }
    
    .p-partner__btn .c-btn::before {
        opacity: 0;
    }
    .p-partner__btn .c-btn::after {
        opacity: 1;
    }
}

/*===========================================================================*/
/*  office  */
/*===========================================================================*/
.p-office {
    position: relative;
    overflow: hidden;
}

.p-office__wrapper {
    display: flex;
    align-items: center;
}

.p-office__inner {
    display: flex;
    align-items: flex-start;
    animation: officeSlide 66s linear infinite normal;
    position: relative;
    z-index: 2;
}

.p-office__img01 {
    overflow: hidden;
    width: 29.041vw;
    min-width: 29.041vw;
    aspect-ratio: 395/251;
    margin-right: 2.35vw;
    margin-top: 2.13vw;
    border-radius: 4px;
}
.p-office__img01 img {
    height: 100%;
    object-fit: cover;
}

.p-office__img02 {
    overflow: hidden;
    width: 29.041vw;
    min-width: 29.041vw;
    aspect-ratio: 395/251;
    margin-right: 2.35vw;
    border-radius: 4px;
}
.p-office__img02 img {
    height: 100%;
    object-fit: cover;
}

@keyframes officeSlide {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}

@media screen and (max-width: 900px) {
    .p-office__inner {
        animation: officeSlide 32s linear infinite normal;
    }
    
    .p-office__img01 {
        width: 242px;
        min-width: 242px;
        margin-right: 20px;
        margin-top: 17px;
    }
    
    .p-office__img02 {
        width: 242px;
        min-width: 242px;
        margin-right: 20px;
    }
}
