@charset "UTF-8";

.page-wrap {
    padding-bottom: 100px;
}

.page-title .en-title {
    color: var(--green);
}

/*================================================================
#anchor
================================================================ */
.anchor .anchor__list {
    width: calc(100% / 4 - 16px);
}

.anchor .anchor__list:nth-child(n+5) {
    margin-top: 16px;
}

/*============================
.intro
============================*/
.section-wrap .intro {
    margin-top: 40px;
    padding: 0;
    background: url(../../common/img/intro_bg.png) no-repeat center bottom;
    position: relative;
}

@media screen and (min-width: 1921px) {
    .section-wrap .intro {
        background-size: 100% auto;
    }
}

.section-wrap .intro:before {
    width: 100%;
    height: 434px;
    background-color: var(--green);
    position: absolute;
    content: '';
    top: 100px;
    left: 0;
    z-index: 0;
}

.section-wrap .intro .container {
    display: flex;
    justify-content: center;
    position: relative;
}

.section-wrap .intro .left {
    margin-top: 200px;
    color: #fff;
    text-align: center;
}

.section-wrap .intro .right {
    margin-top: 220px;
    position: relative;
}

.section-wrap .intro .sub-title img {
    margin: auto;
}

.section-wrap .intro .title {
    margin-top: 24px;
    font-size: 32px;
}

.section-wrap .intro .text {
    margin-top: 16px;
}

.section-wrap .intro a:hover img {
    opacity: .7;
}

.section-wrap .intro .google_btn {
    margin-top: 24px;
}

.section-wrap .intro .qr {
    width: 157px;
    position: absolute;
    right: 115px;
    bottom: 128px;
}

.section-wrap .intro .intro_img02 {
    position: absolute;
    bottom: 99px;
    left: -268px;
    z-index: 0;
}

.section-wrap .intro .intro_img03 {
    position: absolute;
    right: -262px;
    bottom: 136px;
    z-index: 0;
}

.section-wrap .intro .intro_img04 {
    position: absolute;
    top: -22px;
    right: 182px;
    z-index: -2;
}

/*================================================================
# 主な機能
================================================================ */
.section-wrap {
    padding-bottom: 0;
}

.plan-wrap {
    padding-bottom: 64px;
    background-color: #faf8ee;
}

.function {
    margin-top: -40px;
    padding: 64px 0 0;
    position: relative;
}

.function .title-area {
    position: relative;
}

.function .function_illust01 {
    position: absolute;
    top: -38px;
    left: -91px;
}

.function .function_illust02 {
    position: absolute;
    top: 42px;
    right: -17px;
}

.function .title-area__sub-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--green);
    text-align: center;
}

.function .title-area__title {
    margin-top: 8px;
    font-size: 40px;
    font-weight: 700;
    text-align: center;
}

.function .title-area__text {
    margin-top: 16px;
    line-height: 2;
    text-align: center;
}

.function .card-title {
    text-align: center;
}

.function .card-title span {
    width: 400px;
    margin-top: 40px;
    padding: 4px;
    border-radius: 40px;
    background-color: var(--green);
    display: inline-block;
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    text-align: center;
}

.function .container {
    margin: 40px 0 0 -24px;
    display: flex;
}

.function .card {
    width: calc(100% / 4 - 24px);
    margin-left: 24px;
    padding: 32px;
    border: 1px solid #e4e1d0;
    border-radius: 24px;
    background-color: #fff;
}

.function .card__title {
    font-size: 20px;
    font-weight: 700;
    color: var(--green);
    text-align: center;
}

.function .card__aside {
    display: flex;
    justify-content: center;
    align-items: center;
}

.function .card__figure {
    width: 120px;
    height: 120px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.function .card__body {
    margin-top: 8px;
    font-size: 14px;
}

.function .card__body span {
    margin-left: 8px;
    font-size: 12px;
    color: var(--gray);
}

/*================================================================
#不死王閣公式アプリ会員の特典
================================================================ */

/*.section-title01
------------------------------------------------------ */
.plan-wrap .section-title01 {
    margin-top: 100px;
    padding: 64px 0;
    background-color: rgba(86, 174, 83, 0.2);
    position: relative;
    text-align: center;
}

.plan-wrap .section-title01__en {
    font-family: var(--text-en);
    font-weight: 800;
    color: var(--green);
}

.plan-wrap .section-title01__jp {
    margin-top: 16px;
    font-size: 40px;
    font-weight: 700;
}

.plan-wrap .section-title01__jp span {
    display: block;
    font-size: 24px;
}

.plan-wrap .section-title01__jp strong {
    color: var(--green);
}

.plan-wrap .section-text {
    margin-top: 8px;
}

/*================================================================
# benefits
================================================================ */
.benefits .wrap {
    position: relative;
}

.benefits .benefits_img01 {
    margin-top: -40px;
    text-align: center;
}

.benefits .benefits_img02 {
    position: absolute;
    bottom: 4px;
    left: 146px;
    z-index: 1;
}

.benefits .benefits_img03 {
    position: absolute;
    right: 14px;
    bottom: -76px;
    z-index: 1;
}

.benefits .black-btn-wrap {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translate(-50%, 0);
}

.benefits .black-btn-wrap .black-btn {
    font-size: 24px;
}

.benefits .black-btn-wrap .black-btn span::before {
    width: 20px;
    height: 20px;
    top: 50%;
    right: -28px;
    transform: translate(0, -50%) rotate(135deg);
}

.benefits .black-btn-wrap .black-btn:hover span::before {
    transform: translate(0, -20%) rotate(135deg);
}

/* .container01
------------------------------------------------------ */
.privilege .container01 {
    margin-top: 64px;
    display: flex;
    align-items: center;
}

.privilege .container01.reverse {
    flex-direction: row-reverse;
}

.privilege .container01 .img-area {
    width: 50%;
    position: relative;
    z-index: 2;
}

.privilege .container01 .text-area {
    width: 50%;
    padding: 100px 64px;
    position: relative;
}

.privilege .container01 .text-area:before {
    width: calc(100% + 80px);
    height: 100%;
    border-radius: 40px 40px 40px 0;
    background-color: #fff;
    position: absolute;
    content: '';
    right: 0;
    bottom: 0;
    z-index: 0;
}

.privilege .container01.reverse .text-area:before {
    border-radius: 40px 40px 0 40px;
    right: -80px;
}

.privilege .container01 .number {
    opacity: .4;
    position: absolute;
    top: -16px;
    left: 55px;
    font-family: var(--text-en);
    font-size: 40px;
    font-weight: 700;
    line-height: 1;
    color: var(--green);
    letter-spacing: 0;
    z-index: 0;
}

.privilege .container01 .sub-title {
    position: relative;
    font-weight: 700;
    color: var(--gray);
}

.privilege .container01 .title {
    margin-top: 8px;
    position: relative;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.4;
    color: var(--green);
}

.privilege .container01 .title strong {
    font-size: 64px;
}

.privilege .container01 .text {
    margin-top: 16px;
    position: relative;
    font-size: 30px;
    font-weight: 700;
    line-height: 2;
}

.privilege .container01 .note {
    margin-top: 16px;
    font-size: 12px;
    line-height: 2;
    color: var(--gray);
}

.privilege_illust01 {
    position: absolute;
    bottom: -41px;
    left: -93px;
    z-index: 1;
}

.privilege_illust02 {
    position: absolute;
    right: -145px;
    bottom: -34px;
}

.privilege_illust03 {
    position: absolute;
    bottom: -36px;
    left: -134px;
}

.privilege_illust04 {
    position: absolute;
    bottom: -45px;
    left: -151px;
}

.privilege_illust05 {
    position: absolute;
    bottom: -24px;
    left: -374px;
}

.privilege_illust06 {
    position: absolute;
    top: -63px;
    right: -88px;
}

.privilege .container01 .slick-img img {
    border-radius: 40px;
}

/*============================
.register
.alignment
============================*/
.register .container,
.alignment .container {
    margin: 64px 0 0 -24px;
    display: flex;
    justify-content: center;
}

.register .card,
.alignment .card {
    width: calc(100% / 4 - 24px);
    margin-left: 24px;
}

.register .title,
.alignment .title {
    padding: 4px;
    border-radius: 40px;
    background-color: var(--green);
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    text-align: center;
}

.register .img,
.alignment .img {
    margin-top: 16px;
}

.register .text,
.alignment .text {
    margin-top: 16px;
    font-size: 14px;
}