@charset "UTF-8";

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.flex.fw_w {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.flex.jc_sb {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.flex.jc_c {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.flex.jc_fe {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end
}

.flex.ai_c {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.flex.ai_fs {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.flex.ai_fe {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end
}

.flex.fd_c {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
}

.flex.fd_rr {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

@media only screen and (max-width:767px) {
    .flex.fw_w_sp {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    .flex.jc_fs_sp {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start
    }

    .flex.jc_sb_sp {
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }

    .flex.jc_c_sp {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }

    .flex.jc_fe_sp {
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end
    }

    .flex.ai_c_sp {
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    .flex.ai_fs_sp {
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }

    .flex.ai_fe_sp {
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }

    .flex.fd_r_sp {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row
    }

    .flex.fd_c_sp {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

body {
    color: #2d2d2d
}

.en {
    font-family: "Gantari", sans-serif;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal
}

.c-heading01 {
    position: relative;
    font-family: "Gantari", sans-serif;
    font-optical-sizing: auto;
    font-size: 3.2rem;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    line-height: 1.22222;
    letter-spacing: .15em
}

.c-heading01 .ja {
    margin-top: .3rem;
    letter-spacing: 0
}

@media only screen and (max-width:991px) {
    .c-heading01 .ja {
        margin-top: .5rem
    }
}

@media only screen and (max-width:575px) {
    .c-heading01 .ja {
        font-size: 1.1rem
    }
}

@media only screen and (max-width:1199px) {
    .c-heading01 {
        font-size: 3.2rem
    }
}

@media only screen and (max-width:991px) {
    .c-heading01 {
        font-size: 3.2rem
    }
}

@media only screen and (max-width:575px) {
    .c-heading01 {
        font-size: 2.5rem
    }
}

.l-sp-menu.-overlay {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 999;
    width: 100%;
    max-width: 630px;
    height: 100%;
    background-color: #86807C;
    padding-bottom: 10rem;
    overflow: auto
}

.l-sp-menu.-overlay .l-sp-menu__close-btn {
    z-index: 99;
    position: absolute;
    top: 2.8rem;
    right: 1.8rem;
}

.l-sp-menu.-overlay .l-sp-menu__close-btn>a {
    display: block;
    position: relative;
    width: 3.2rem;
    height: 3.2rem
}

.l-sp-menu.-overlay .l-sp-menu__close-btn>a span {
    display: block;
    width: 3.2rem;
    height: 0.2rem;
    background-color: #fff;
    -webkit-transform-origin: center center;
    -ms-transform-origin: center center;
    transform-origin: center center;
    position: absolute;
    left: 0
}

.l-sp-menu.-overlay .l-sp-menu__close-btn>a span:first-child {
    transform: rotate(45deg);
    -ms-transform:rotate(45deg);
        width: 4rem;
    top: 0;
    transform: rotate(45deg);
    transform-origin: left;
    left: 1px;
}
.l-sp-menu.-overlay .l-sp-menu__close-btn>a span:last-child {
    transform: rotate(-45deg);
    -ms-transform:rotate(-45deg);
    transform-origin: left;
    right: 0;
    left: 1px;
    width: 4rem;
    top: 2.8rem;

}
@media only screen and (max-width:991px) {
    .l-sp-menu.-overlay .l-sp-menu__close-btn{
    top: -4rem;
    background: #fff;
    }
    .l-sp-menu.-overlay .l-sp-menu__close-btn>a span{
        background:#333;
    }
    .l-sp-menu.-overlay .l-sp-menu__close-btn>a span:first-child {
        left:2px;
    }
        .l-sp-menu.-overlay .l-sp-menu__close-btn>a span:last-child {
        left:2px;
}
}

/* .l-sp-menu.-overlay .l-sp-menu__close-btn>a span:nth-child(2) {
    top: .8rem;
    right: 0;
    margin: 0 auto;
    width: inherit;
    height: inherit;
    background-color: transparent;
    color: #fff;
    font-family: "Gantari", sans-serif;
    font-size: 1.1rem;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    text-align: center
} */



.l-sp-menu.-overlay .l-sp-menu__main {
    padding-top: 8.2rem
}

.l-sp-menu.-overlay .l-sp-menu__main .container {
    padding-left: 10.5rem
}

@media only screen and (max-width:991px) {
    .l-sp-menu.-overlay .l-sp-menu__main .container {
        padding-left: 3.5rem
    }
}

@media only screen and (max-width:991px) {
    .l-sp-menu.-overlay .l-sp-menu__main {
        padding-top: 3.7rem
    }
}

@media only screen and (max-width:991px) {
    .l-sp-menu.-overlay .l-sp-menu__sns {
        margin-top: 4.1rem
    }
}

@media only screen and (max-width:991px) {
    .l-sp-menu.-overlay {
        top: 5.2rem;
        max-width: 100%;
        height: auto;
        padding-bottom: 2.7rem;
        overflow: visible
    }
}

.p-sp-main-menu__item {
    font-size: 2.0rem;
    font-weight: 550;
    color:#fff;
}

.p-sp-main-menu__item a {
    padding: 1.5rem 0;
    border-bottom: none
}
.p-sp-main-menu__item strong{
    display: block;
    font-weight:bold;
    padding-left:1rem;
    font-size: 120%;
}
.p-sp-main-menu__item small{
    font-size: 80%;
    margin-bottom: 2rem;
    display: block;
}

@media only screen and (max-width:991px) {
    .p-sp-main-menu__item a {
        padding: .8rem 0
    }
}

.p-sp-main-menu__item span {
    padding-right: 0
}

.p-sp-main-menu__item span:after {
    content: none
}

@media only screen and (max-width:991px) {
    .p-sp-main-menu__item {
        font-size: 1.5rem;
    }
}

@media only screen and (max-width:991px) {
    .l-sp-menu__sns .container {
        padding-left: 3.3rem
    }
}

.p-sp-sns-list {
    /* z-index: 98;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: absolute;
    top: -6rem;
    right: 2.5rem;
    height: 100vh; */

    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 9;
    width: 8.0rem;
    height: 100vh;
}

@media only screen and (max-width:991px) {
    .p-sp-sns-list {
        display: -webkit-inline-box;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        position: relative;
        top: inherit;
        right: inherit;
        height: auto
    }
}

.p-sp-sns-list__item {
    width: 2rem;
    margin-right: 0;
    margin-bottom: 2.4rem
}

.p-sp-sns-list__item .icon {
    max-width: 2rem;
    max-height: 2rem;
}

@media only screen and (max-width:991px) {
    .p-sp-sns-list__item .icon {
        max-width: 3rem;
        max-height: 3rem
    }
}

@media only screen and (max-width:991px) {
    .p-sp-sns-list__item {
        width: 3rem;
        margin-right: 2.5rem;
        margin-bottom: 0
    }
}

.p-cta-widget {
    /* display: none */
}
.p-cta-widget__item{
    background:#86807B;
}
.p-cta-widget__item-bg{
    display: none!important;
}

.p-sns-widget {
    position: fixed
}

@media only screen and (max-width: 767px) {
    .p-cta-widget {
        bottom:1.6rem!important;
    }
}

.fixed_contact {
    z-index: 999;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 4rem;
    position: fixed;
    right: 0;
    bottom: 0;
    padding: 0 2.4rem;
    width: 100%;
    height: 6rem;
    background: #86807c;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: .05em;
    display: none;
}

.fixed_contact a {
    color: #fff;
    -webkit-transition: all .3s ease-out;
    -o-transition: all .3s ease-out;
    transition: all .3s ease-out
}

.fixed_contact a:hover {
    opacity: .7
}

.fixed_contact img {
    display: block
}

.fixed_contact .ttl {
    font-size: 1.8rem
}

@media only screen and (max-width:1350px) {
    .fixed_contact .ttl {
        font-size: 1.6rem
    }
}

@media only screen and (max-width:991px) {
    .fixed_contact .ttl {
        font-size: 1rem;
        font-weight: 700;
        letter-spacing: 0;
        line-height: 1.2
    }
}

.fixed_contact .en {
    font-size: 2.5rem;
    line-height: 1
}

@media only screen and (max-width:1350px) {
    .fixed_contact .en {
        font-size: 2.2rem
    }
}

.fixed_contact .tel {
    gap: 1.1rem
}

@media only screen and (max-width:991px) {
    .fixed_contact .tel.pc {
        display: none
    }
}

.fixed_contact .tel.sp {
    display: none
}

@media only screen and (max-width:991px) {
    .fixed_contact .tel.sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media only screen and (max-width:1350px) {
    .fixed_contact .tel {
        gap: .8rem
    }
}

@media only screen and (max-width:991px) {
    .fixed_contact .tel {
        gap: 1.5rem
    }
}

.fixed_contact .mail {
    gap: 2.4rem
}

@media only screen and (max-width:991px) {
    .fixed_contact .mail.pc {
        display: none
    }
}

.fixed_contact .mail.sp {
    display: none
}

@media only screen and (max-width:991px) {
    .fixed_contact .mail.sp {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media only screen and (max-width:1350px) {
    .fixed_contact .mail {
        gap: 1.5rem
    }
}

.fixed_contact .separator {
    width: .1rem;
    height: 3.2rem;
    background: #fff
}

.fixed_contact .btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 11.3rem;
    flex: 0 0 11.3rem;
    width: 11.3rem;
    height: 3rem;
    border: 1px solid #fff;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0
}

.fixed_contact .btn:hover {
    opacity: 1;
    background: #fff;
    color: #86807c
}

@media only screen and (max-width:1350px) {
    .fixed_contact .btn {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 9rem;
        flex: 0 0 9rem;
        width: 9rem;
        font-size: 1.2rem
    }
}

@media only screen and (max-width:1350px) {
    .fixed_contact {
        gap: 2rem;
        font-size: 1.3rem
    }
}

@media only screen and (max-width:991px) {
    .fixed_contact {
        top: initial;
        bottom: 0;
        height: 5.2rem
    }
}

.l-header.-row {
    position: inherit;
    height: 0;
    background: none
}

.l-header.-row .l-header__container {
    padding-right: 1.5rem;
    padding-left: 2.5rem;
    max-width: 100% !important
}

@media only screen and (max-width:991px) {
    .l-header.-row .l-header__container {
        padding-right: 0;
        padding-left: .4rem
    }
}

@media only screen and (max-width:991px) {
    .l-header.-row {
        position: fixed;
        top: 0;
        height: 5.2rem;
        background: #fff
    }
}

.l-header__siteID>a {
    color: #fff;
    font-family: "Gantari", sans-serif;
    font-optical-sizing: auto;
    font-style: normal
}
.l-header__siteID>a svg path{
    fill:#333;
}
.home .l-header__siteID>a:not(.on) svg path{
    fill:#fff;
}

.l-header__siteID>a.on {
    color: #2d2d2d
}

@media only screen and (max-width:991px) {
    .l-header__siteID>a {
        color: #2d2d2d
    }
}

.l-header__siteID .logo {
    z-index: 99;
    position: fixed;
    top: 2.4rem;
    left: 2.5rem;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 5.2rem;
    flex: 0 0 5.2rem;
    width: 5.2rem
}

@media only screen and (max-width:1199px) {
    .l-header__siteID .logo img {
        height: auto
    }
}

@media only screen and (max-width:991px) {
    .l-header__siteID .logo {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 4rem;
        flex: 0 0 4rem;
        width: 4rem;
        top: 1rem;
        left: 1rem
    }
}

.l-header__siteID .text {
    z-index: 99;
    position: fixed;
    top: 3.5rem;
    left: 9.5rem
}

.l-header__siteID .text .name {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.21875
}

@media only screen and (max-width:991px) {
    .l-header__siteID .text .name {
        font-size: 2.1rem;
        line-height: 1.19048
    }
    .l-header__siteID>a:not(.on) svg path{
        fill:#333!important;
    }
}

.l-header__siteID .text .copy {
    margin-top: -.3rem;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.25
}

@media only screen and (max-width:991px) {
    .l-header__siteID .text .copy {
        margin-top: -.1rem;
        font-size: 1rem;
        line-height: 1.25;
        -webkit-transform: scale(0.8);
        -ms-transform: scale(0.8);
        transform: scale(0.8);
        -webkit-transform-origin: left top;
        -ms-transform-origin: left top;
        transform-origin: left top
    }
}

@media only screen and (max-width:991px) {
    .l-header__siteID .text {
        top: 1.5rem;
        left: 5.9rem;
        mix-blend-mode: inherit
    }
    .l-header__sp-menu-btn{
        top: 1.0rem;
        right: 1.8rem;
         position: fixed;
    }

}

.l-header__menu {
    display: none
}

@media only screen and (min-width:992px) {
    .l-header__sp-menu-btn {
        z-index: 99;
        display: block;
        position: fixed;
        top: 2.8rem;
        right: 1.8rem
    }
}

.c-hamburger-btn {
    width: 3.2rem;
    height: 3.2rem;
    background-color: transparent
}

.c-hamburger-btn .c-hamburger-btn__bar--first,
.c-hamburger-btn .c-hamburger-btn__bar--second,
.c-hamburger-btn .c-hamburger-btn__bar--third {
    /* width: 4.2rem;
    height: .6rem;
    margin-bottom: .7rem;
    background-color: #e6814b */
    background-color: #333;
    margin-bottom: 1.1rem;
    width:3.2rem;
}
.home .l-header__sp-menu-btn:not(.on) .c-hamburger-btn .c-hamburger-btn__bar--first,
.home .l-header__sp-menu-btn:not(.on) .c-hamburger-btn .c-hamburger-btn__bar--second,
.home .l-header__sp-menu-btn:not(.on) .c-hamburger-btn .c-hamburger-btn__bar--third{
    background-color: #fff;
}

@media only screen and (max-width:991px) {

    .c-hamburger-btn .c-hamburger-btn__bar--first,
    .c-hamburger-btn .c-hamburger-btn__bar--second,
    .c-hamburger-btn .c-hamburger-btn__bar--third {
        /* width: 2.5rem;
        height: .3rem;
        background-color: #fff */
            width: 3.2rem;
            height: 2px;
            background-color: #333!important;
            margin-bottom: 1.1rem;
    }
}

.c-hamburger-btn .c-hamburger-btn__bar--third {
    margin-bottom: 0
}

@media only screen and (max-width:991px) {
    .c-hamburger-btn {
        width: 3.2rem;
        height: 3.2rem;
        /* background-color: #e6814b */
    }
}

#top .container,
#top .container--fluid,
#top .container--narrow,
#top .l-contents__container,
#top .l-header.-column .l-header__container,
#top .l-header.-row .l-header__container,
#top .p-life__header-container,
#top .p-main__header-container {
    max-width: 148rem
}

#top .l-contents {
    padding-bottom: 0
}

.p-jumbotron {
    position: relative;
    padding-top: 0;
    height: 100vh;
    /* min-height: 1044px */
}

.p-jumbotron .container {
    z-index: 98;
    position: absolute;
    right: 0;
    left: 0;
    bottom: 16.6rem;
    margin: 0 auto
}

.p-jumbotron .container h2 {
    color: #fff;
    font-size: 6rem;
    font-weight: 700;
    letter-spacing: .05em;
    line-height: 1.33333
}

@media only screen and (max-width:1199px) {
    .p-jumbotron .container h2 {
        font-size: 5rem
    }
}

@media only screen and (max-width:991px) {
    .p-jumbotron .container h2 {
        bottom: 9.4rem;
        left: 3.2rem;
        font-size: 4rem;
        line-height: 1.4
    }
}

@media only screen and (max-width:575px) {
    .p-jumbotron .container h2 {
        font-size: 2.5rem
    }
}

.p-jumbotron .p-jumbotron-slider,
.p-jumbotron .p-jumbotron__container,
.p-jumbotron .swiper-container {
    height: 100%
}

.p-jumbotron .p-jumbotron__container {
    /* width: calc(100% - 8.0rem) */
    width:100%;
}

@media only screen and (max-width:991px) {
    .p-jumbotron .p-jumbotron__container {
        width: 100%
    }
}

.p-jumbotron .p-jumbotron-slider__item>div {
    height: 100%
}

@media only screen and (max-width:991px) {
    .p-jumbotron {
        padding-top: 5.2rem;
        height: calc(var(--vh, 1vh) * 100);
        min-height: 640px
    }
}

.p-home-news:before {
    top: 2.2rem
}

@media only screen and (max-width:575px) {
    .p-home-news:before {
        top: 1.4rem
    }
}

.p-home-about {
    overflow: hidden
}

.p-home-about.p-section {
    margin-top: 12rem
}
.p-home-about h3{
    font-weight: 550;
    font-size: 4rem;
    margin-top: 8%;   
}
@media only screen and (max-width:991px) {
    .p-home-about.p-section {
        margin-top: 8rem
    }
    .p-home-about h3{
        font-size: 2rem;
    }
}

@media only screen and (max-width:575px) {
    .p-home-about.p-section {
        margin-top: 4rem
    }
}

.p-home-about .p-home-about__text {
    padding-right: 0;
    max-width: 77rem
}

.p-home-about .p-home-about__text .p-section__description {
    margin-top: 5.5rem
}

@media only screen and (max-width:767px) {
    .p-home-about .p-home-about__text .p-section__description {
        margin-top: 1.7rem
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .p-home-about__text {
        max-width: 100%
    }
}

.p-home-about .p-section__description {
    margin-top: 1.7rem;
    font-size: 1.5rem;
    letter-spacing: .02em;
    line-height: 1.4
}

@media only screen and (max-width:991px) {
    .p-home-about .p-section__description {
        font-size: 1.2rem;
        line-height: 1.41667
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .p-section__description {
        margin-top: 1.3rem
    }
}

.p-home-about .feature.first {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.p-home-about .feature.first .feature_each:first-child {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    margin-top: 5rem;
    margin-right: 15.7rem;
    max-width: 53.5rem
}

@media only screen and (max-width:1199px) {
    .p-home-about .feature.first .feature_each:first-child {
        margin-right: 10.7rem
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.first .feature_each:first-child {
        margin-top: 3rem;
        margin-right: 0;
        width: 100%;
        max-width: 100%
    }
}

.p-home-about .feature.first .feature_each:nth-child(2) {
    margin-top: 24rem;
    margin-right: calc(50% - 50vw);
    width: 788px;
    width: 48.04878vw
}

@media only screen and (min-width:1640px) {
    .p-home-about .feature.first .feature_each:nth-child(2) .feature_image picture img {
        height: 52.4rem;
        -o-object-fit: cover;
        object-fit: cover
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.first .feature_each:nth-child(2) {
        margin-top: 3rem;
        margin-right: 0;
        width: 100%
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.first {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

.p-home-about .feature.second .feature_each {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: -4.5rem
}

.p-home-about .feature.second .feature_each .feature_image {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    margin-right: 15.7rem;
    max-width: 53.5rem
}

@media only screen and (max-width:1199px) {
    .p-home-about .feature.second .feature_each .feature_image {
        margin-right: 10.7rem
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.second .feature_each .feature_image {
        margin-right: 0;
        width: 100%;
        max-width: 100%
    }
}

.p-home-about .feature.second .feature_each .feature_text {
    margin-top: 5.7rem;
    margin-right: calc(50% - 50vw);
    width: 788px;
    width: 48.04878vw
}

.p-home-about .feature.second .feature_each .feature_text .feature_pr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1.5rem;
    margin-top: 3rem
}

.p-home-about .feature.second .feature_each .feature_text .feature_pr img {
    width: 153px;
    width: 9.32927vw;
    max-width: 15.3rem
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.second .feature_each .feature_text .feature_pr img {
        width: 100%;
        max-width: 12rem
    }
}

@media only screen and (max-width:991px) {
    .p-home-about .feature.second .feature_each .feature_text .feature_pr {
        margin-top: 2.5rem
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.second .feature_each .feature_text .feature_pr {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        gap: 1rem
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.second .feature_each .feature_text {
        margin-top: 0;
        margin-right: 0;
        width: 100%
    }
}

@media only screen and (max-width:767px) {
    .p-home-about .feature.second .feature_each {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-top: 3rem
    }
}

.p-home-about .feature .feature_each .feature_image picture {
    display: block
}

.p-home-about .feature .feature_each .feature_image picture img {
    width: 100%
}

@media only screen and (max-width:767px) {
    .p-home-about .feature .feature_each .feature_image picture {
        margin-right: calc(50% - 50vw)
    }
}

.p-home-about .feature .feature_each .feature_headng {
    margin-top: 3rem;
    color: #757575;
    font-family: "Gantari", sans-serif;
    font-optical-sizing: auto;
    font-size: 1.2rem;
    font-weight: 600;
    font-style: normal;
    text-transform: uppercase;
    line-height: 1.25;
    letter-spacing: .15em
}

.p-home-about .feature .feature_each .feature_headng .ja {
    display: block;
    margin-top: .9rem;
    color: #2d2d2d;
    font-family: "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Verdana", "Helvetica", sans-serif;
    font-size: 2.5rem;
    line-height: 1.44
}

@media only screen and (max-width:991px) {
    .p-home-about .feature .feature_each .feature_headng .ja {
        margin-top: 0;
        font-size: 2rem
    }
}

@media only screen and (max-width:575px) {
    .p-home-about .feature .feature_each .feature_headng .ja {
        font-size: 1.8rem;
        line-height: 1.44444
    }
}

@media only screen and (max-width:991px) {
    .p-home-about .feature .feature_each .feature_headng {
        margin-top: 1.5rem
    }
}

.p-home-about .feature .feature_each .p-section__description {
    max-width: 36rem
}

@media only screen and (max-width:767px) {
    .p-home-about .feature .feature_each .p-section__description {
        max-width: 100%
    }
}

.p-home-about .p-section__btn {
    margin-top: 13rem
}

@media only screen and (max-width:767px) {
    .p-home-about .p-section__btn {
        margin-top: 5rem
    }
}

.home_flow {
    position: relative;
    padding-top: 15rem;
    height: 102.5rem;
    background: url(../add-img/flow_bg_pc.jpg) no-repeat center;
    background-size: cover;
    color: #fff
}

.home_flow:before {
    content: '';
    opacity: 0.5;
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: #393939;
    mix-blend-mode: multiply
}

.home_flow .container {
    position: relative;
    max-width: 120rem
}

.home_flow .container .p-section__description {
    margin-top: 5.5rem;
    max-width: 77rem;
    font-size: 1.5rem;
    letter-spacing: .02em;
    line-height: 1.4
}

@media only screen and (max-width:991px) {
    .home_flow .container .p-section__description {
        font-size: 1.2rem;
        line-height: 1.41667
    }
}

@media only screen and (max-width:767px) {
    .home_flow .container .p-section__description {
        margin-top: 1.7rem;
        max-width: 100%
    }
}

.home_flow .container .p-section__btn {
    margin-top: 4rem
}

.home_flow .container .p-section__btn .c-btn-outlined {
    background: transparent;
    border: 2px solid #fff;
    color: #fff
}

.home_flow .container .p-section__btn .c-btn-outlined:hover {
    background: #fff;
    color: #2d2d2d
}

.home_flow .container .p-section__btn .c-btn-outlined:hover>span:not([class]) {
    background-image: url(../tmpl-img/ico_arrow01.svg)
}

.home_flow .container .p-section__btn .c-btn-outlined>span:not([class]) {
    background-image: url(../tmpl-img/ico_arrow02.svg)
}

@media only screen and (max-width:767px) {
    .home_flow .container .p-section__btn {
        margin-top: 7rem;
        text-align: center
    }
}

@media only screen and (max-width:767px) {
    .home_flow {
        padding-top: 10rem;
        height: 480px;
        height: 141.17647vw;
        background: url(../add-img/flow_bg_sp.jpg) no-repeat center;
        background-size: cover
    }
}

.home_after_support {
    margin-top: 16rem;
    margin-bottom: 16rem
}

.home_after_support .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    max-width: 120rem
}

.home_after_support .container .left {
    margin-top: 19rem
}

@media only screen and (max-width:991px) {
    .home_after_support .container .left {
        margin-top: 10rem
    }
}

@media only screen and (max-width:767px) {
    .home_after_support .container .left {
        margin-top: 0
    }
}

.home_after_support .container .right {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    margin-left: 8rem
}

.home_after_support .container .right img {
    width: 100%
}

@media only screen and (max-width:991px) {
    .home_after_support .container .right {
        margin-left: 5rem
    }
}

@media only screen and (max-width:767px) {
    .home_after_support .container .right {
        margin-top: 4rem;
        margin-left: 0
    }
}

.home_after_support .container .p-section__description {
    margin-top: 3rem;
    max-width: 58rem;
    font-size: 1.5rem;
    letter-spacing: .02em;
    line-height: 1.4
}

@media only screen and (max-width:991px) {
    .home_after_support .container .p-section__description {
        font-size: 1.2rem;
        line-height: 1.41667
    }
}

@media only screen and (max-width:767px) {
    .home_after_support .container .p-section__description {
        margin-top: 2.2rem;
        max-width: 100%
    }
}

.home_after_support .container .p-section__btn {
    margin-top: 4rem
}

@media only screen and (max-width:767px) {
    .home_after_support .container .p-section__btn {
        margin-top: 2.8rem;
        text-align: center
    }
}

@media only screen and (max-width:767px) {
    .home_after_support .container {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

@media only screen and (max-width:767px) {
    .home_after_support {
        margin-top: 4.3rem;
        margin-bottom: 4.3rem
    }
}

.home_kadonoie {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    height: 102.5rem;
    background: url(../add-img/kadonoie_bg.jpg) no-repeat center;
    background-size: cover;
    color: #fff
}

.home_kadonoie:before {
    content: '';
    opacity: 0.5;
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: #393939;
    mix-blend-mode: multiply
}

.home_kadonoie .container {
    position: relative;
    font-size: 2.5rem;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.44
}

.home_kadonoie .container .kadonoie_ttl .ja {
    margin-top: 2rem
}

@media only screen and (max-width:767px) {
    .home_kadonoie .container .kadonoie_ttl .ja img {
        width: 22.3rem
    }
}

@media only screen and (max-width:767px) {
    .home_kadonoie .container .kadonoie_ttl .ja {
        margin-top: .5rem
    }
}

.home_kadonoie .container .p-section__description {
    margin-top: 4.7rem;
    font-weight: 700
}

@media only screen and (max-width:991px) {
    .home_kadonoie .container .p-section__description {
        font-size: 1.1rem
    }
}

@media only screen and (max-width:767px) {
    .home_kadonoie .container .p-section__description {
        margin-top: 1rem;
        text-align: center !important
    }
}

.home_kadonoie .container .p-section__btn {
    margin-top: 4rem
}

.home_kadonoie .container .p-section__btn .c-btn-outlined {
    background: transparent;
    border: 2px solid #fff;
    color: #fff
}

.home_kadonoie .container .p-section__btn .c-btn-outlined:hover {
    background: #fff;
    color: #2d2d2d
}

.home_kadonoie .container .p-section__btn .c-btn-outlined:hover>span:not([class]) {
    background-image: url(../tmpl-img/ico_arrow01.svg)
}

.home_kadonoie .container .p-section__btn .c-btn-outlined>span:not([class]) {
    background-image: url(../tmpl-img/ico_arrow02.svg)
}

@media only screen and (max-width:767px) {
    .home_kadonoie .container .p-section__btn {
        margin-top: 2.7rem
    }
}

@media only screen and (max-width:991px) {
    .home_kadonoie .container {
        font-size: 1.1rem;
        line-height: 1.45455
    }
}

@media only screen and (max-width:767px) {
    .home_kadonoie {
        height: 480px;
        height: 141.17647vw
    }
}

.home_insta_media {
    padding-bottom: 12.0rem
}

@media only screen and (max-width:991px) {
    .home_insta_media {
        padding-bottom: 6.4rem
    }
}

.p-life,
.p-main {
    padding-top: 0
}

@media only screen and (max-width:991px) {

    .p-life,
    .p-main {
        padding-top: 5.2rem
    }
}

.p-main__header-title .en,
.p-single__heading.-en,
.p-single__upper-title .en {
    font-family: "Gantari", sans-serif;
    font-size: 3.2rem;
    text-transform: uppercase;
    letter-spacing: .15em
}

@media only screen and (max-width:575px) {

    .p-main__header-title .en,
    .p-single__heading.-en,
    .p-single__upper-title .en {
        font-size: 2.5rem
    }
}

.page_flow {
    max-width: 114.0rem
}

.page_flow .page_flow_list li {
    position: relative;
    padding-bottom: 4.8rem
}

.page_flow .page_flow_list li:first-child dl,
.page_flow .page_flow_list li:last-child dl {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.page_flow .page_flow_list li:first-child dl dd h3,
.page_flow .page_flow_list li:last-child dl dd h3 {
    margin: 2.2rem 0 2.5rem
}

@media screen and (max-width:991px) {

    .page_flow .page_flow_list li:first-child dl dd h3,
    .page_flow .page_flow_list li:last-child dl dd h3 {
        margin: 2rem 0 1.2rem
    }
}

.page_flow .page_flow_list li .line {
    z-index: 0;
    position: absolute;
    top: 0;
    left: calc(7.5rem / 2);
    width: 2px;
    height: calc(100% + 4.8rem);
    background: #c9c2bd
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li .line {
        left: calc(6.5rem / 2);
        height: calc(100% + 2.8rem)
    }
}

.page_flow .page_flow_list li dl {
    z-index: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    position: relative
}

.page_flow .page_flow_list li dl dt .en {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    width: 5.5rem;
    height: 5.5rem;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border: 1rem solid #fff;
    border-radius: 50%;
    background: #86807c;
    color: #fff;
    font-size: 1.2rem
}

.page_flow .page_flow_list li dl dt .en span {
    font-size: 2rem;
    line-height: .85
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dt .en span {
        font-size: 1.8rem
    }
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dt .en {
        width: 4.5rem;
        height: 4.5rem;
        font-size: 1rem
    }
}

.page_flow .page_flow_list li dl dd {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0
}

.page_flow .page_flow_list li dl dd .flex {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.page_flow .page_flow_list li dl dd h3 {
    margin: 0;
    padding: 0;
    border-bottom: none;
    color: #e6814b;
    font-size: 2.5rem;
    -webkit-font-feature-settings: initial;
    font-feature-settings: initial;
    letter-spacing: 0
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd h3 {
        margin: 2rem 0 0;
        font-size: 1.8rem
    }
}

.page_flow .page_flow_list li dl dd p {
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: .02em;
    line-height: 1.4
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd p {
        font-size: 1.2rem
    }
}

.page_flow .page_flow_list li dl dd .contact_link a,
.page_flow .page_flow_list li dl dd a.tel {
    color: #2d2d2d
}

.page_flow .page_flow_list li dl dd a.tel {
    margin: 0 2rem;
    font-size: 2.5rem;
    letter-spacing: .05em
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd a.tel {
        margin: .8rem 0 .3rem;
        font-size: 2rem
    }
}

.page_flow .page_flow_list li dl dd .contact_link {
    margin-top: 1rem
}

.page_flow .page_flow_list li dl dd .contact_link .contact_btn {
    display: none;
    margin-top: 1.1rem;
    width: 11rem;
    height: 3rem;
    border: 1px solid #2d2d2d;
    font-size: 1.4rem;
    font-weight: 700;
    text-align: center
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .contact_link .contact_btn {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .contact_link {
        margin-top: 1.2rem
    }
}

.page_flow .page_flow_list li dl dd .speech_bubble {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    margin: 0 0 0 4rem;
    padding: 1.7rem 2.3rem;
    min-height: 8rem;
    border-radius: 2rem;
    background: #f2f2f2
}

.page_flow .page_flow_list li dl dd .speech_bubble:before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: -1.8rem;
    margin: auto 0;
    width: 2.4rem;
    height: 1.9rem;
    background: url(../flow-img/speech_bubble.svg) no-repeat;
    background-size: contain
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .speech_bubble:before {
        top: -1.4rem;
        bottom: inherit;
        left: 4.5rem;
        -webkit-transform: rotate(70deg);
        -ms-transform: rotate(70deg);
        transform: rotate(70deg)
    }
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .speech_bubble {
        margin: 2rem 0 0;
        padding: 1.4rem 1.9rem;
        min-height: 5.4rem
    }
}

.page_flow .page_flow_list li dl dd .quotation {
    margin: 0 0 0 2.5rem
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .quotation {
        margin: .9rem 0 0
    }
}

.page_flow .page_flow_list li dl dd .after_support {
    margin: 0 0 0 8rem
}

.page_flow .page_flow_list li dl dd .after_support .p-section__btn {
    margin-top: 3rem
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl dd .after_support {
        margin: 2rem 0 0
    }
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li dl {
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        gap: 0
    }
}

@media screen and (max-width:991px) {
    .page_flow .page_flow_list li {
        padding-bottom: 2.8rem
    }
}

@media screen and (max-width:991px) {
    .page_flow {
        padding-right: 2rem;
        padding-left: 1rem
    }
}

#kadonoie_lp {
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: 1.4rem;
    font-weight: 500;
    font-style: normal;
    letter-spacing: .02em;
    line-height: 1.57143
}

#kadonoie_lp a,
#kadonoie_lp input[type=submit] {
    -webkit-transition: all .3s ease-out;
    -o-transition: all .3s ease-out;
    transition: all .3s ease-out
}

#kadonoie_lp a:hover,
#kadonoie_lp input[type=submit]:hover {
    opacity: .5
}

#kadonoie_lp figure {
    margin: 0
}

#kadonoie_lp h1,
#kadonoie_lp h2,
#kadonoie_lp h3,
#kadonoie_lp h4,
#kadonoie_lp h5,
#kadonoie_lp h6 {
    font-weight: 400
}

#kadonoie_lp .en {
    font-family: "Padauk", sans-serif;
    font-weight: 400
}

#kadonoie_lp .en.bold {
    font-weight: 700
}

#kadonoie_lp>.container {
    position: relative;
    /* max-width: 164rem */
    max-width:180rem;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp>.container {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }
}

@media only screen and (max-width:768px) {
    #kadonoie_lp>.container {
        padding: 0
    }
}

#kadonoie_lp #header {
    z-index: 999;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: fixed;
    /* top: 23rem; */
    left: 50%;
    padding-left: 8rem;
    width: min(100%, 164rem);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    pointer-events: none;
    top:5rem;
}
#kadonoie_lp #header .flex{
    display: flex;
    flex-direction: column;
    align-items: center;
}
#kadonoie_lp #header .logo {
    pointer-events: all;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header .logo {
        display: block;
        margin: 2.2rem 0 0 2.4rem;
        width: 13.4rem;
        pointer-events: all;
        left: 0; 
        position:absolute;
    }
    #kadonoie_lp #header .logo svg{
        height:60px;
    }
}

#kadonoie_lp #header nav {
    pointer-events: all;

}

#kadonoie_lp #header nav ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 1rem;
}

#kadonoie_lp #header nav ul li {
    font-size: 1.3rem;
    letter-spacing: 0
}

#kadonoie_lp #header nav ul li.instagram_icn {
    border-top: 1px solid;
    border-bottom: 1px solid;
    text-align: center;
    padding: 3rem 0;
    margin: 4rem 0;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header nav ul li.instagram_icn img {
        width: 2.3rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header nav ul li {
        text-align: center
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header nav ul {
        padding-top: 7.2rem;
        gap: .8rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header nav {
        opacity: 0;
        position: fixed;
        top: 0;
        right: 0;
        width: 15rem;
        height: 100%;
        -webkit-transition: all 0.4s;
        -o-transition: all 0.4s;
        transition: all 0.4s;
        pointer-events: none
    }

    #kadonoie_lp #header nav.on {
        opacity: 1;
        background: #fff;
        pointer-events: auto
    }
}

#kadonoie_lp #header .sp_nv_btn {
    display: none
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header .sp_nv_btn.on {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg)
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header .sp_nv_btn {
        z-index: 999;
        display: block;
        position: absolute;
        top: 2.9rem;
        right: 2.4rem;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 1.3rem .75rem 0 .75rem;
        border-color: #2d2d2d transparent transparent transparent;
        -webkit-transition: all 0.4s;
        -o-transition: all 0.4s;
        transition: all 0.4s;
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
        pointer-events: all
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #header {
        top: 0;
        left: 0;
        padding-left: 0;
        width: 100%;
        -webkit-transform: inherit;
        -ms-transform: inherit;
        transform: inherit
    }
}

#kadonoie_lp .fixed_tel {
    z-index: 999;
    /* display: -webkit-box;
    display: -ms-flexbox;
    display: flex; */
    gap: 1.3rem;
    position: fixed;
    bottom: 4.4rem;
    left: 50%;
    padding-left: 8rem;
    width: min(100%, 164rem);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    pointer-events: none
}

#kadonoie_lp .fixed_tel .en {
    padding-top: .5rem;
    font-size: 1.3rem;
    letter-spacing: 0
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .fixed_tel {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
    #kadonoie_lp .fixed_tel .en {
        padding-top: 0;
        font-size: .9rem
    }
    #kadonoie_lp .fixed_tel .en:not(.bold){
        display: none;
    }
}

#kadonoie_lp .fixed_tel a {
    pointer-events: all
}

#kadonoie_lp .fixed_tel a.en.bold {
    padding: 0;
    font-size: 2.5rem;
    letter-spacing: .03em;
    line-height: 1.2
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .fixed_tel a.en.bold {
        font-size: 1.9rem;
        line-height: 1
    }
}

#kadonoie_lp .fixed_tel .open {
    font-size: 1rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .fixed_tel .open {
        font-size: .9rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .fixed_tel {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        bottom: 0;
        margin-right: 0;
        padding-left: 0;
        width: 100%;
        height: 5rem;
        background: #fff
    }
}

#kadonoie_lp .main_content {
    z-index: 99;
    position: relative;
    /* overflow: hidden; */
    /* max-width: 74rem; */
    width:65vw;
    max-width:110rem;

}

#kadonoie_lp .main_content section:not(#home){
    overflow-x:hidden;
}

#kadonoie_lp .main_content .container {
    padding: 0;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .main_content .container {
        padding-right: 2.4rem;
        padding-left: 2.4rem
    }
    #kadonoie_lp .main_content{
        width:100%;
    }
}

#kadonoie_lp .section_ttl {
    padding-top: 10rem
}

#kadonoie_lp .section_ttl .en {
    color: #93807e;
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: .015em
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .section_ttl .en {
        font-size: 1.6rem
    }
}

#kadonoie_lp .section_ttl .jp {
    padding-top: 1.3rem;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .05em;
    line-height: 1.5
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .section_ttl .jp {
        padding-top: .9rem;
        font-size: 1.5rem;
        line-height: 1.66667
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .section_ttl {
        padding-top: 8rem
    }
}

#kadonoie_lp .section_desc {
    padding-top: 4.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .section_desc {
        padding-top: 3rem
    }
}

#kadonoie_lp .photo_copyright {
    position: relative
}

#kadonoie_lp .photo_copyright figcaption {
    position: absolute;
    right: 2.6rem;
    bottom: 2.2rem;
    color: #ccc;
    font-size: 1rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .photo_copyright figcaption {
        right: 1.8rem;
        bottom: 1.5rem;
        font-size: .8rem
    }
}

#kadonoie_lp .photo_slider {
    overflow: visible;
    margin: 0;
    padding-top: 9rem;
    max-width: 580px
}

#kadonoie_lp .photo_slider .swiper-slide {
    cursor: pointer
}

@media only screen and (max-width:991px) {
    #kadonoie_lp .photo_slider {
        padding-top: 6rem
    }
}

#kadonoie_lp #home {
    position: relative;
    padding-top: 5rem
}
#kadonoie_lp .lp-mv{
    position:relative;
}
#kadonoie_lp .lp-mv .swiper-wrapper{
    padding-bottom:3rem;
}
#kadonoie_lp .lp-mv .swiper-pagination{
    bottom: 0rem;
    text-align: left;
}
#kadonoie_lp .lp-mv .swiper-pagination .swiper-pagination-bullet{
    margin-right:16px;
}
#kadonoie_lp .lp-mv .swiper-pagination .swiper-pagination-bullet-active{
    background:#1F1F1F;
}
#kadonoie_lp .lp-mv .catch{
    position:absolute;
    left:-10%;
    top:30%;
    z-index:999;
    font-size:clamp(2rem,2.5vw,3.5rem);
    color:#fff;
    display: flex;
    flex-direction: column;
}
#kadonoie_lp .lp-mv .catch span.bgextend{
    display: inline-block;
    margin-bottom: 1.5rem;
    width: fit-content;
}
#kadonoie_lp .lp-mv .catch span.bgappear{
    background:#333;
    padding: 0.5rem 5rem 0.5rem 1rem;

}
#kadonoie_lp .lp-mv .catch span.bgextend:last-child .bgappear{
    background:#A0A0A0;
}
#kadonoie_lp #home .copy {
    z-index: 2;
    position: absolute;
    right: 0;
    bottom: 8rem;
    left: 0;
    margin: 0 auto;
    padding-right: 2rem;
    -webkit-transform: rotate(-10deg);
    -ms-transform: rotate(-10deg);
    transform: rotate(-10deg)
}
#kadonoie_lp .photo_copyright:not(.swiper-slide .photo_copyright){
    max-width:740px;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #home .copy {
        width: 27rem
    }
    #kadonoie_lp .lp-mv img{
        height:85vh;
        object-fit: cover;
    }
    #kadonoie_lp .lp-mv .catch{
        left:5%;
    }
    #kadonoie_lp .lp-mv .swiper-pagination{
        text-align: center;
    }
}

#kadonoie_lp #home .photo_copyright img {
    width: 100%
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #home {
        padding-top: 0
    }
}

#kadonoie_lp #information .floor_ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: .8rem;
    position: relative;
    padding-top: 10rem;
    font-size: 1.5rem;
    letter-spacing: 0;
    line-height: 1.33333
}

#kadonoie_lp #information .floor_ttl:before {
    content: '';
    display: block;
    width: 39px;
    height: 1px;
    background: #707070
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #information .floor_ttl {
        padding-top: 4rem
    }
    #kadonoie_lp #information .flex{
        flex-direction: column;
    }
}

#kadonoie_lp #information .floor_illust {
    padding-top: 7rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #information .floor_illust {
        padding-top: 3rem
    }
}

#kadonoie_lp #information .facility {
    padding-top: 5.5rem
}

#kadonoie_lp #information .facility .flex {
    gap: 8rem;
    padding-top: 3rem
}

#kadonoie_lp #information .facility .flex dl {
    width: 18.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #information .facility .flex dl {
        width: 100%
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #information .facility .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        gap: 2.5rem;
        padding-top: 2.5rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #information .facility {
        padding-top: 4.5rem
    }
}

#kadonoie_lp #design .flex {
    gap: 6.6rem;
    padding-top: 7rem
}

#kadonoie_lp #design .flex a {
    display: block;
    padding-top: 2rem;
    text-decoration: underline
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #design .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 4rem
    }
}

#kadonoie_lp #design .section_desc {
    padding-top: 6rem;
    max-width: 58rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #design .section_desc {
        padding-top: 4rem
    }
}

#kadonoie_lp #design .photo_copyright {
    padding-top: 8.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #design .photo_copyright {
        padding-top: 4rem
    }
}

#kadonoie_lp #case_study .flex {
    gap: 5rem;
    padding-top: 5rem
}
#kadonoie_lp #case_study .photo_slider2{
   padding-top: 4.5rem;
    width: 100%;
    margin-left: 0;
    margin-right: auto;
}
#kadonoie_lp #case_study .photo_slider2 .swiper-wrapper{
    justify-content: flex-start;
}
#kadonoie_lp #case_study .photo_slider2 .swiper-slide {
	height: auto;
}

#kadonoie_lp #case_study .photo_slider2 figure { 
	height: 100%;
}
#kadonoie_lp #case_study .photo_slider2 figure img{
    /* object-fit: cover; */
    height:100%;
}

#kadonoie_lp #case_study .flex figcaption {
    padding-top: 2rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #case_study .flex figcaption {
        text-align: center
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #case_study .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        gap: 2rem;
        padding-top: 4rem
    }
}

#kadonoie_lp #case_study .pr {
    padding-top: 7rem;
    font-size: 1.7rem;
    line-height: 1.58824
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #case_study .pr {
        padding-top: 3rem;
        font-size: 1.4rem;
        line-height: 1.57143
    }
}

#kadonoie_lp #case_study .section_desc {
    max-width: 58rem
}

#kadonoie_lp #case_study .photo_copyright {
    padding-top: 8.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #case_study .photo_copyright {
        padding-top: 4rem
    }
}

#kadonoie_lp #instagram .flex {
    gap: 2rem;
    padding-top: 6rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #instagram .flex img {
        width: 4rem
    }
}

#kadonoie_lp #instagram .flex p {
    font-size: 1rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #instagram .flex {
        padding-top: 3rem
    }
}

#kadonoie_lp #calendar iframe {
    padding-top: 5rem;
    width: 100%;
    max-width:740px;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #calendar iframe {
        padding-top: 3rem
    }
}

#kadonoie_lp #calendar .photo_copyright {
    padding-top: 8.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #calendar .photo_copyright {
        padding-top: 4rem
    }
}

#kadonoie_lp #news{
    max-width:740px;

}
#kadonoie_lp #news .news_list {
    padding: 5rem 0;
}

#kadonoie_lp #news .news_list li {
    margin-top: 2.5rem;
    padding-top: 2.5rem;
    border-top: .5px solid #707070
}

#kadonoie_lp #news .news_list li:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none
}

#kadonoie_lp #news .news_list li figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 3rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .news_list li figure img {
        width: 8.4rem
    }
}

#kadonoie_lp #news .news_list li figure figcaption {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
}

#kadonoie_lp #news .news_list li figure figcaption .time_cat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 3rem;
    line-height: 1.28571
}

#kadonoie_lp #news .news_list li figure figcaption .time_cat time {
    position: relative
}

#kadonoie_lp #news .news_list li figure figcaption .time_cat time:after {
    content: '';
    position: absolute;
    right: -1.5rem;
    width: .05rem;
    height: 100%;
    background: #707070
}

#kadonoie_lp #news .news_list li figure figcaption .news_ttl {
    margin-top: .6rem;
    font-size: 1.6rem;
    line-height: 1.375
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .news_list li figure figcaption .news_ttl {
        font-size: 1.4rem;
        line-height: 1.57143
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .news_list li figure {
        gap: 1.5rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .news_list {
        padding: 4rem 0
    }
}

#kadonoie_lp #news .viewmore_btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    border-radius: 1.8rem;
    background: #f2f0ef;
    width: 15rem;
    height: 3.5rem;
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: .05em
}

#kadonoie_lp #news .viewmore_btn:hover {
    opacity: 1;
    background: #86807c;
    color: #fff
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .viewmore_btn {
        background: #86807c;
        color: #fff
    }
}

#kadonoie_lp #news .photo_copyright {
    padding-top: 8.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #news .photo_copyright {
        padding-top: 8rem
    }
}

#kadonoie_lp #contact{
    max-width:740px;
}
#kadonoie_lp #contact .c-form-table {
    margin-top: 3rem;
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .c-form-table {
        margin-top: 2.5rem
    }
}

#kadonoie_lp #contact .c-form-table td,
#kadonoie_lp #contact .c-form-table th {
    padding: 1.75rem 0;
    border-bottom: none
}

@media screen and (max-width:991px) {

    #kadonoie_lp #contact .c-form-table td,
    #kadonoie_lp #contact .c-form-table th {
        padding: 1rem 0
    }
}

#kadonoie_lp #contact .c-form-table th {
    width: 10.7rem;
    background-color: transparent;
    font-size: 1.5rem;
    font-weight: 500
}

#kadonoie_lp #contact .c-form-table th .required {
    display: block;
    margin-bottom: -.3rem;
    color: #f00;
    font-size: .8rem
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .c-form-table th .required {
        margin-bottom: 0
    }
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .c-form-table th {
        font-size: 1.3rem
    }
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .c-form-table td {
        padding: 1.2rem 0 2.0rem
    }
}

#kadonoie_lp #contact .c-form input[type=email],
#kadonoie_lp #contact .c-form input[type=number],
#kadonoie_lp #contact .c-form input[type=password],
#kadonoie_lp #contact .c-form input[type=tel],
#kadonoie_lp #contact .c-form input[type=text],
#kadonoie_lp #contact .c-form textarea {
    padding: 1.3rem 0.8rem;
    width: 100%;
    border: none;
    background: #f2f0ef
}

#kadonoie_lp #contact .c-form textarea {
    height: 23rem
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .c-form textarea {
        height: 14rem
    }
}

#kadonoie_lp #contact .zip {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-bottom: 1.7rem
}

#kadonoie_lp #contact .zip .note {
    padding-right: 1.4rem
}

#kadonoie_lp #contact .zip #zip {
    width: 20rem
}

#kadonoie_lp #contact .flex {
    padding-top: 4rem
}

@media screen and (max-width:991px) {
    #kadonoie_lp #contact .flex {
        padding-top: 2rem
    }
}

#kadonoie_lp #contact .wpcf7-submit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    border-radius: 1.8rem;
    background: #f2f0ef;
    width: 15rem;
    height: 3.5rem;
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: .05em
}

#kadonoie_lp #contact .wpcf7-submit:hover {
    opacity: 1;
    background: #86807c;
    color: #fff
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #contact .wpcf7-submit {
        background: #86807c;
        color: #fff
    }
}

#kadonoie_lp #contact .wpcf7-spinner {
    display: none
}

#kadonoie_lp #contact .wpcf7-not-valid-tip {
    padding-top: .5rem
}

#kadonoie_lp #contact .wpcf7 .wpcf7-response-output,
#kadonoie_lp #contact .wpcf7 .wpcf7-validation-errors {
    font-size: 1.5rem
}

#kadonoie_lp #contact .photo_copyright {
    padding-top: 8.5rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #contact .photo_copyright {
        padding-top: 5rem
    }
}

#kadonoie_lp #address .company_info {
    padding-top: 5.5rem
}

#kadonoie_lp #address .company_info li {
    padding-top: 1.4rem;
    font-size: 1.5rem
}

#kadonoie_lp #address .company_info li:first-child {
    padding-top: 0
}

#kadonoie_lp #address .company_info li dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

#kadonoie_lp #address .company_info li dl dt {
    width: 13rem
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .company_info li dl dt {
        width: 7rem
    }
}

#kadonoie_lp #address .company_info li dl dd {
    width: calc(100% - 13rem)
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .company_info li dl dd {
        width: calc(100% - 7rem);
        font-size: 1.1rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .company_info li {
        padding-top: 1rem;
        font-size: 1.2rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .company_info {
        padding-top: 3rem
    }
}

#kadonoie_lp #address .gmap {
    padding-top: 6rem
}

#kadonoie_lp #address .gmap iframe {
    display: block;
    width: 100%;
    max-width:740px;
    filter:grayscale(1.0);
}
#kadonoie_lp #address .gmap iframe .place-card{
    display: none;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .gmap iframe {
        height: 23rem
    }
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #address .gmap {
        padding-top: 3rem
    }
}

#kadonoie_lp #footer .flex {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    gap: 8rem;
    padding: 6rem 0 5rem
}
#kadonoie_lp #footer .flex div{
    writing-mode: vertical-lr;
    position: fixed;
    bottom: 5%;
    right: 2rem;
}
#kadonoie_lp #footer .flex a{
    display: none;
}

@media only screen and (max-width:991px) {
    #kadonoie_lp #footer .flex {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end;
        gap: .5rem;
        padding: 3rem 0 8rem;
        font-size: 1rem
    }
    #kadonoie_lp #footer .flex a{
        display: block;
    }
    #kadonoie_lp #footer .flex div{
        position: static;
        writing-mode: initial;
    }
}

/*20251022*/
.l-page.-fixed{
    position:relative;
}
.c-btn-outlined{
    border-width: 2px;
    font-weight: 450;
}
.home .p-sns-widget:not(.on) .p-sns-widget__item .icon{
    fill:#fff;
}
.p-jumbotron-slider__pagination{
    bottom:2rem!important;
}
.p-jumbotron-slider__pagination .swiper-pagination-bullet{
    width:8px;
    height:8px;
    background-color:#A0A0A0;
}
.p-jumbotron-slider__pagination .swiper-pagination-bullet-active{
    background-color:#1F1F1F;
}
.p-jumbotron__container .catch h2{
    font-weight: 500;
    font-size: 4rem;
}
.p-jumbotron__container .p-section__btn{
    margin-top:2rem;
}
.p-jumbotron__container .c-btn-outlined{
    background: transparent;
    border: 2px solid #fff;
    color: #fff
}
.p-jumbotron__container .c-btn-outlined>span:not([class]){
    background-image: url(../tmpl-img/ico_arrow02.svg)
 }
.p-jumbotron__container .p-section__btn .c-btn-outlined:hover {
    background: #fff;
    color: #2d2d2d
}

.p-jumbotron__container .p-section__btn .c-btn-outlined:hover>span:not([class]) {
    background-image: url(../tmpl-img/ico_arrow01.svg)
}

#kadonoie_lp.lp-news .news_list{
    min-width: 25vw;
    max-width: 500px;
}
#kadonoie_lp .pagination{
    text-align: center;
    margin-bottom: 4rem
}
#kadonoie_lp .pagination .page-numbers{
    font-weight: bold;
    padding: 5px;
}
#kadonoie_lp .pagination .page-numbers:not(.current){
    color:#86807C;
}
#kadonoie_lp .pagination .page-numbers.current{
    text-decoration: underline;
}
@media only screen and (max-width:991px) {
    #kadonoie_lp.lp-news .main_content{
        margin-top:2rem;
    }
}

.bgextend{
	animation-name:bgextendAnimeBase;
	animation-duration:2.2s;
	animation-fill-mode:forwards;
	position: relative;
	overflow: hidden;/*　はみ出た色要素を隠す　*/
	opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

/*中の要素*/
.bgappear{
	animation-name:bgextendAnimeSecond;
	animation-duration:1.2s;
	animation-delay: 0.6s;
	animation-fill-mode:forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond{
	0% {
	opacity: 0;
	}
	100% {
	opacity: 1;
}
}

/*左から右*/
.bgLRextend::before{
	animation-name:bgLRextendAnime;
	animation-duration:1s;
	animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #333;
}
.bgLRextend:last-child:before{
    background-color:#A0A0A0;
}
@keyframes bgLRextendAnime{
	0% {
		transform-origin:left;
		transform:scaleX(0);
	}
	50% {
		transform-origin:left;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:right;
	}
	100% {
		transform-origin:right;
		transform:scaleX(0);
	}
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgLRextendTrigger{
    opacity: 0;
}

/* 上から */
.fade-section {
  position: relative;
  width: 100%;
  height:100%;
  max-height: 534px;
  display: flex;
  align-items: center;
  justify-content: left;
  overflow: hidden;
  max-width:740px;
  margin-top:8.5rem;
}

.mask-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* ==== マスク ==== */
.image-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0%;
  background: #eee;
  transition: height 0.6s cubic-bezier(0.83, 0, 0.17, 1); 
  z-index: 2;
}

/* ==== 画像 ==== */
.fade-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform:  translateY(-200%);
  transition: transform 0.8s cubic-bezier(0.83, 0, 0.17, 1) 0.3s; 
  z-index: 100;
  padding-top:0!important;
}

/* ==== アクティブ状態 ==== */
.fade-section.active .image-mask {
  height: 100%;
}

.fade-section.active .fade-image {
  transform: translateY(0);
}

/* ==== スクロールアウトでリセット ==== */
.fade-section:not(.active) .image-mask {
  height: 0%;
  transition-delay: 0s;
}

.fade-section:not(.active) .fade-image {
  transform: translateY(-100%);
  transition-delay: 0s;
}