/* ページ単位での調整 */
a.button-white,
a.button-red {
    width: 224px;
    padding: 13px;

    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 20px; 
}
a.button-white::after,
a.button-red::after {
    top: 50%;
    right: 19px;
    translate: 0 -50%;
    width: 8px;
    height: 8px;
}


/* メインビジュアル */
.main-visual {
    background: url("/-/media/ind/gred/partner-program/image/main_visual_bg.png") no-repeat center center;
    background-size: cover;
}
.main-visual .wrapper {
    margin: 0 auto;
    max-width: 836px;
}
.main-visual .content-block {
    padding: 40px 52px;
    background: rgb(255 255 255 / 60%);
    border-radius: 30px;
}
.main-visual .content-block .text-block {
    text-align: center;
}
.main-visual .content-block .text-block h1 {
    font-family: "Noto Sans JP";
    font-size: 42px;
    font-style: normal;
    font-weight: 700;
    line-height: 50px;
}
.main-visual .content-block .text-block p {
    margin-top: 30px;

    font-family: "Noto Sans JP";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px; 
}
.main-visual .content-block .cta-block {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
}
@media screen and (max-width: 767px) {
    .main-visual .content-block {
        padding: 1rem;
    }
    .main-visual .content-block .text-block h1 {
        font-size: 2.2rem;
    }
    .main-visual .content-block .text-block p {
        font-size: 1rem;
    }
    .main-visual .content-block .cta-block {
        flex-direction: column;
        gap: 1rem;
    }
}


/* とは */
.about .content-block ul {
    padding: 0;
    list-style: none;
    display: flex;
    justify-content: center;
    gap: 30px;
}
.about .content-block ul li {
    padding: 44px;
    
    background: #F2F2F2;
    border-radius: 20px;
}
.about .content-block ul li img {
    width: 317.5px;
}
.about .content-block ul li p {
    margin-top: 30px;

    font-family: "Noto Sans JP";
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 24px;
}
@media screen and (max-width: 767px) {
    .about .content-block ul {
        flex-direction: column;
    }
    .about .content-block ul li {
        padding: 1rem;
    }
    .about .content-block ul li img {
        display: block;
        margin: 0 auto;
    }
    .about .content-block ul li p {
        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
}


/* CTA */
.cta {
    background: url("/-/media/ind/gred/partner-program/image/cta_bg.png") no-repeat center center;
    background-size: cover;   
}
.cta .hedding-block {
    margin-bottom: 30px;
}
.cta .hedding-block .intro {
    color: #fff;
}
.cta .hedding-block h2 {
    color: #fff;
}
.cta .cta-block {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
}
@media screen and (max-width: 767px) {
    .cta .cta-block {
        flex-direction: column;
        gap: 1rem;
    }
}


/* メリット */
.merit {
    background: #F2F2F2;
}
.merit .content-block ul {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}
.merit .content-block ul li {
    padding: 42px 40px 41px 43px;
    display: flex;
    align-items: center;
    gap: 46px;

    background: #fff;
    border-radius: 20px;
}
.merit .content-block ul li .image-box img {
    width: 157px;
}
.merit .content-block ul li .text-box h3 {
    font-family: "Noto Sans JP";
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 37px; 
}
.merit .content-block ul li .text-box ul {
    margin-top: 20px;
    padding-left: 1.5rem;
    display: list-item;
}
.merit .content-block ul li .text-box li {
    list-style-type: disc;
    display: list-item;
    padding: 0;
    gap: 0;

    font-family: "Noto Sans JP";
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
    line-height: 32px; /* 133.333% */
    letter-spacing: 1.92px;
}
.merit .cta-block {
    margin-top: 60px;
    text-align: center;
}
.merit .cta-block a.button-red {
    width: 306px;
    padding: 19px;
    display: inline-block;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s ease;

    border-radius: 200px;
    text-align: center;
    font-family: "Noto Sans JP";
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 20px;
}
.merit .cta-block a.button-red::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 24px;
    translate: 0 -50%;
    width: 9px;
    height: 9px;
    transform: rotate(225deg);
    transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
    .merit .content-block ul li {
        padding: 1rem;
        flex-direction: column;
        gap: 1rem;
    }
    .merit .content-block ul li .image-box {
        text-align: center;
    }
    .merit .content-block ul li .text-box h3 {
        font-size: var(--sp-font-size-h3);
        line-height: var(--sp-line-height-h3);
    }
    .merit .content-block ul li .text-box li {
        margin-bottom: .5rem;
        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
    .merit .content-block ul li .text-box li:last-child {
        margin-bottom: 0;
    }
}


/* リクエスト */
.request .content-block ul {
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 44px;
}
.request .content-block ul li {
    padding: 50px 64px;
    display: flex;
    align-items: center;
    gap: 34px;

    background: #F2F2F2;
    border-radius: 20px;
}
.request .content-block ul li .image-box img {
    width: 84px;
}
.request .content-block ul li .text-box p {
    font-family: "Noto Sans JP";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px; 
}
@media screen and (max-width: 767px) {
    .request .content-block ul {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .request .content-block ul li {
        padding: 1rem;
        display: grid;
        grid-template-columns: 4rem 1fr;
        gap: 1.5rem;
    }
    .request .content-block ul li .text-box p {
        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
}


/* パートナー */
.partner {
    background: #F2F2F2;
}
.partner .content-block ul {
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 44px;
}
.partner .content-block ul li {
    padding: 31px;
    display: flex;
    align-items: center;
    gap: 44px;

    background: #fff;
    border-radius: 20px;
}
.partner .content-block ul li .image-box img {
    width: 152px;
}
.partner .content-block ul li .text-box p {
    padding: 25px;
    position: relative;

    background: #F2F2F2;
    border-radius: 10px;
    font-family: "Noto Sans JP";
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 27px; /* 150% */
    letter-spacing: 1.44px;
}
.partner .content-block ul li .text-box p::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 30px;
    height: 30px;
    translate: -60% -50%;
    clip-path: polygon(100% 100%, 0 50%, 100% 0);
    background: #F2F2F2;
}
@media screen and (max-width: 767px) {
    .partner .content-block ul {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
    .partner .content-block ul li {
        padding: 1rem;
    }
    .partner .content-block ul li {
        display: grid;
        grid-template-columns: 4rem 1fr;
        gap: 1rem;
    }
    .partner .content-block ul li .text-box p {
        padding: 1rem;
        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
}


/* 流れ */
.flow .content-block {
    margin: 0 auto;
    max-width: 633px;
}
.flow .content-block ul {
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 103px;
}
.flow .content-block ul li {
    position: relative;
    display: flex;
    gap: 44px;
}
.flow .content-block ul li::before {
    content: "";
    position: absolute;
    top: -58px;
    left: 50%;
    translate: -50% 0;
    display: block;
    width: 34px;
    height: 17px;
    background: url("/-/media/ind/gred/partner-program/image/flow_arrow.svg") no-repeat center center;
    background-size: contain;
}
.flow .content-block ul li:first-child::before {
    display: none;
}
.flow .content-block ul li .image-box img {
    width: 76px;
}
.flow .content-block ul li .text-box p {
    max-width: 441px;
    margin-top: 30px;
}
@media screen and (max-width: 767px) {
    .flow .content-block ul li {
        display: grid;
        grid-template-columns: 3rem 1fr;
        gap: 1.5rem;
    }
    .flow .content-block ul li .text-box h3 {
        font-size: var(--sp-font-size-h3);
        line-height: var(--sp-line-height-h3);
    }
    .flow .content-block ul li .text-box p {
        margin-top: 1rem;
        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
}


/* FAQ */
.faq {
    background: #F2F2F2;
}
.faq .wrapper {
    max-width: 924px;
    margin: 0 auto;
}
.faq .content-block ul {
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}
.faq .content-block ul li {
    padding: 30px 85px 33px 44px;
    
    border: 1px solid #2F7C31;
    background: #fff;
}
.faq .content-block ul li .question {
    padding-left: 63px;
    position: relative;
    cursor: pointer;

    font-family: "Noto Sans JP";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px; /* 125% */
}
.faq .content-block ul li .question::before {
    content: "";
    position: absolute;
    top: -2px;
    left: 0;
    width: 29px;
    height: 42px;
    background: url("/-/media/ind/gred/partner-program/image/faq_q.svg") no-repeat center center;
    background-size: contain;
}
.faq .content-block ul li .question::after {
    content: "";
    position: absolute;
    top: calc(50% - 4px);
    right: calc((24px + 85px) / 2 * -1);
    translate: -50%;
    width: 24px;
    height: 11px;
    background: url("/-/media/ind/gred/partner-program/image/faq_arrow.svg") no-repeat center center;
    background-size: contain;
    transform: rotate(180deg);
    transition: transform 0.3s ease;
}
.faq .content-block ul li.open .question::after {
    transform: rotate(0deg);
}
.faq .content-block ul li .answer {
    padding-left: 63px;
    position: relative;
    max-height: 0;
    overflow: hidden;
    transition: all 0.4s ease;
    opacity: 0;

    font-family: "Noto Sans JP";
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 27px; /* 150% */
    letter-spacing: 1.44px;
}
.faq .content-block ul li .answer::before {
    content: "";
    position: absolute;
    top: calc(50% + 2px);
    left: 0;
    translate: 0 -50%;
    width: 29px;
    height: 42px;
    background: url("/-/media/ind/gred/partner-program/image/faq_a.svg") no-repeat center center;
    background-size: contain;
}
.faq .content-block ul li.open .answer {
    margin-top: 30px;
    max-height: 500px; /* 十分な高さにしておく（中身によって調整可） */
    opacity: 1;
}
@media screen and (max-width: 767px) {
    .faq .content-block ul li {
        padding: 1rem 3rem 1rem 1rem;
    }
    .faq .content-block ul li .question {
        padding-left: 2.2rem;

        font-size: var(--sp-font-size-h3);
        line-height: var(--sp-line-height-h3);
    }
    .faq .content-block ul li .answer {
        padding-left: 2.2rem;

        font-size: var(--sp-font-size-p);
        line-height: var(--sp-line-height-p);
    }
    .faq .content-block ul li .question::before {
        top: calc(50% + 2px);
        left: 0;
        translate: 0 -50%;
        width: 24px;
        height: 27.5px;
    }
    .faq .content-block ul li .answer::before {
        width: 24px;
        height: 34.75px;
    }
}