@charset "UTF-8";

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

/*============================
.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: 640px;
    background-color: var(--green);
    position: absolute;
    content: '';
    top: 32px;
    left: 0;
    z-index: 0;
}

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

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

.section-wrap .intro .center {
    margin-top: 24px;
    text-align: center;
}

.section-wrap .intro .center img {
    margin-left: 10px;
}

.section-wrap .intro .right {
    position: relative;
    text-align: center;
}

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

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

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

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

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

.section-wrap .intro .qr {
    margin-top: 24px;
    text-align: center;
}

.section-wrap .intro .intro_img02 {
    width: calc(629px / 2);
    position: absolute;
    bottom: -94px;
    left: -2px;
    z-index: 0;
}

.section-wrap .intro .intro_img03 {
    width: calc(428px / 2);
    position: absolute;
    right: -39px;
    bottom: 26px;
    z-index: 0;
}

.section-wrap .intro .intro_img04 {
    display: none;
}

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

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

.function {
    padding: 140px 0 0;
    position: relative;
}

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

.function .function_illust01 {
    display: none;
}

.function .function_illust02 {
    display: none;
}

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

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

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

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

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

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

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

.function .card:nth-child(n+3) {
    margin-top: 8px;
}

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

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

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

.function .card:nth-child(1) .card__figure img {
    width: 64px;
    height: 64px;
    object-fit: contain;
}

.function .card:nth-child(2) .card__figure img {
    width: 72px;
    height: 72px;
    object-fit: contain;
}

.function .card:nth-child(3) .card__figure img {
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.function .card:nth-child(4) .card__figure img {
    width: 64px;
    height: 64px;
    object-fit: contain;
}

.function .card__body {
    font-size: 12px;
    line-height: 1.4;
}

.function .card__body span {
    display: block;
    font-size: 10px;
    color: var(--gray);
}

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

/*.section-title01
------------------------------------------------------ */
.plan-wrap .section-title01 {
    margin-top: 64px;
    padding: 40px 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: 28px;
    font-weight: 700;
}

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

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

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

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

.benefits .benefits_img01 {
    width: 140%;
    margin: -40px 0 0 -20%;
    text-align: center;
}

.benefits .benefits_img02 {
    width: calc(182px / 2);
    height: calc(296px / 2);
    position: absolute;
    bottom: -173px;
    left: -15px;
    z-index: 1;
}

.benefits .benefits_img03 {
    width: calc(304px / 2);
    height: calc(405px / 2);
    position: absolute;
    right: -74px;
    bottom: -176px;
    z-index: 1;
}

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

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

.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: 40px;
}

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

.privilege .container01 .img-area img {
    border-radius: 16px;
}

.privilege .container01 .text-area {
    margin-top: 16px;
    padding: 16px 48px 40px 24px;
    position: relative;
}

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

.privilege .container01 .number {
    opacity: .4;
    position: absolute;
    top: -32px;
    right: 16px;
    font-family: var(--text-en);
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
    color: var(--green);
    letter-spacing: -.05em;
    z-index: 2;
}

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

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

.privilege .container01 .title strong {
    font-size: 40px;
    color: var(--green);
}

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

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

.privilege_illust01 {
    width: calc(208px / 2);
    position: absolute;
    bottom: -19px;
    left: -24px;
    z-index: 2;
}

.privilege_illust02 {
    width: calc(182px / 2);
    position: absolute;
    right: -16px;
    bottom: -13px;
    z-index: 2;
}

.privilege_illust03 {
    display: none;
}

.privilege_illust04 {
    width: calc(226px / 2);
    position: absolute;
    right: -2px;
    bottom: -13px;
    z-index: 2;
}

.privilege_illust05 {
    width: calc(429px / 2);
    position: absolute;
    bottom: -24px;
    left: -147px;
    z-index: 2;
}

.privilege_illust06 {
    width: calc(278px / 2);
    position: absolute;
    top: 16px;
    right: -67px;
    z-index: 2;
}

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

/*============================
.register
.alignment
============================*/
.alignment {
    padding-bottom: 40px;
}

.register .container {
    margin: 32px 0 0 -24px;
    display: flex;
    flex-wrap: wrap;
}

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

.register .card:nth-child(n+3) {
    margin-top: 40px;
}

.alignment .container {
    margin: 32px 0 0 0;
    display: flex;
    flex-wrap: wrap;
}

.alignment .card {
    width: 80%;
    margin: auto;
}

.alignment .card:nth-child(n+2) {
    margin-top: 40px;
}

.register .title,
.alignment .title {
    padding: 4px;
    border-radius: 40px;
    background-color: var(--green);
    font-size: 18px;
    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;
}