@charset "utf-8";
html body {
    font-family: "Zen Kaku Gothic New", sans-serif;
}

html,
body,
img {
    width: 100%;
}

body {
    max-width: 640px;
    margin: auto;
    color: #2f2b28;
    background-color: #e8e8e8;
}


/* block */
.section01_wrapper {
    padding: 0 2.5%;
    background-color: #ff9814;
}

.section01_inner {
    padding: 40px 0 0;
    background-color: #fff;
}

.container_wrapper {
    position: relative;
    width: 92.1052%;
    max-width: 560px;
    padding-bottom: 24px;
    margin: 34px auto 0;
    background-color: #f85f00;
    border-radius: 20px;
    &::before {
        content: '';
        position: absolute;
        inset: 4px;
        border: 5px dotted #fff;
        border-radius: 20px;
    }
}

.section_inner02,
.section_inner03 {
    width: 92.1052%;
    max-width: 560px;
    margin: 34px auto 0;
}

.section_inner02 {
    margin-top: 48px;
    padding-bottom: 40px;
    border: 4px solid #1943f8;
}

.section_inner03 {
    margin-top: 0;
}

.accordion_wrapper {
    width: 92.8571%;
    max-width: 520px;
    margin: 42px auto 0;
}

.box__item {
    width: 44%;
    max-width: 220px;
}

.sec03__img-box {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 3.125%;
    margin-top: 26px;
}

.section_img-box01 {
    display: flex;
    justify-content: space-around;
    align-items: stretch;
    width: 85%;
    margin: auto;
}

.section_img01 {
    width: 45.625%;
    max-width: 219px;
    margin-top: 20px;
    height: auto;
    flex: 0 0 auto;
    object-fit: contain;
}

.section_img-box02 {
    margin-top: 50px;
}

.section_img02 {
    display: block;
    width: 95%;
    margin: 20px auto 0;
}

.bnr_box {
    margin-top: 24px;
}

/* heading */
.heading02_img01 {
    display: block;
    width: 84.2105%;
    max-width: 512px;
    margin: auto;
}

.heading02_img02 {
    display: block;
    width: 87.6644%;
    max-width: 533px;
    margin: 26px auto 0;
}

.heading02-img03 {
    display: block;
    width: 58.75%;
    margin: -20px auto 0;
    padding: 0 1vw;
    background-color: #fff;
}

.section_wrapper .heading02_03 {
    padding: 0 0 5%;
    font-size: 32px;
    font-weight: 900;
    text-align: center;
    letter-spacing: -0.04em;
    border-bottom: 5px dotted #f85f00;
}

@media screen and (max-width:600px) {
    .heading02-img03 {
        margin-top: -10px;
        padding: 0 1.5vw;
    }

    .section_wrapper .heading02_03 {
        font-size: 5.2vw;
    }
}

/* text */
.content_text01 {
    position: relative;
    width: 87.5%;
    padding: 34px 0 90px;
    margin: auto;
    &::after {
        content: '';
        position: absolute;
        width: 13.75%;
        height: 27px;
        bottom: 18px;
        left: 50%;
        transform: translateX(-50%);
        background-image: url(../img/img_triangle01.png);
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
    }
}

.content_text02 {
    width: 94.6428%;
    margin: auto;
}

.list_text01 {
    width: 96.9642%;
    margin: auto;
}

.list_text02 {
    font-size: 24px;
    text-align: left;
    line-height: 1.33333;
}

.annotation_text01 {
    margin-top: 0.8em;
    text-align: left;
    font-size: 18px;
    font-weight: 400;
    padding-left: 1em;
    text-indent: -1em;
}

.campaign_text02 {
    margin-top: 1em;
}

.section_text01 {
    width: 92%;
    margin: 20px auto 0;
    line-height: 1.3333;
    font-size: 24px;
    font-weight: 500;
}

.section_text02 {
    line-height: 1.6666;
    text-align: center;
    font-size: 24px;
}

.box__text {
    padding: 12px 0;
    margin-top: 16px;
    text-align: center;
    color: #fff;
    background-color: #ff550b;
    border-radius: 30px;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
}

.section_box-text01 {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: clamp(30%, 28vw, 180px);
    aspect-ratio: 1;
    border-radius: 50%;
    text-align: center;
    line-height: 1.3333;
    font-size: 24px;
    font-weight: bold;
    white-space: nowrap;
    color: #fff;
    background-color: #f85f00;
}

.section_box-text01._mod01 {
    margin-top: 30px;
}

.section_box-text01._mod02 {
    margin-top: 40px;
    letter-spacing: -0.08em;
}

.section_box-text01._mod01::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -1.7em;
    width: 0;
    height: 0;
    border: 24px solid transparent;
    border-left-color: #f85f00;
}

.section_box-text01._mod02::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: -1.7em;
    width: 0;
    height: 0;
    border: 24px solid transparent;
    border-right-color: #f85f00;
}

.section_box-text02 {
    position: relative;
    width: 90%;
    padding: 0.8em 0;
    margin: auto;
    background-color: #f85f00;
    color: #fff;
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    border-radius: 100px;
}

.section_box-text02::after {
    content: '';
    position: absolute;
    bottom: -1.8em;
    transform: translateX(-50%);
    left: 50%;
    width: 0;
    height: 0;
    border: 24px solid transparent;
    border-top-color: #f85f00;
}

@media screen and (max-width:769px) {

}

@media screen and (max-width:600px) {
    .content_text01 {
        padding-bottom: 66px;
    }

    .annotation_text01 {
        font-size: 3.5vw;
    }

    .list_text02 {
        font-size: 3.90625vw;
    }

    .section_text01,
    .section_box-text01,
    .section_box-text02 {
        font-size: 3.90625vw;
    }

    .section_box-text02 {
        padding: 0.8em 0.2em;
    }

    .section_box-text01._mod01::after,
    .section_box-text01._mod02::after {
        border: 4vw solid transparent;
    }

    .section_box-text01._mod01::after {
        border: 4vw solid transparent;
        border-left-color: #f85f00;
    }

    .section_box-text01._mod02::after {
        border: 4vw solid transparent;
        border-right-color: #f85f00;
    }

    .section_box-text02::after {
        border: 4vw solid transparent;
        border-top-color: #f85f00;
    }

    .section_text02 {
        font-size: 3.8vw;
    }

    .box__text {
        font-size: 2.8125vw;
    }
}


/* list */
.list_block01 {
    width: 85%;
    max-width: 512px;
    padding: 3.125%;
    margin: 24px auto 0;
    background-color: #fffa6e;
    border-radius: 20px;
    font-size: 20px;
    line-height: 1.2;
    font-weight: bold;
}

.list__detail01 {
    padding-left: 1em;
    text-indent: -1em;
    &::before {
        content: '\2713';
    }
}

.list_block02 {
    margin: 48px auto 0;
    width: 92.1052%;
    max-width: 560px;
}

.list_wrap02:not(:first-child) {
    margin-top: 48px;
}

.list_ttl02 {
    width: 40%;
    margin: auto;
    padding: 0.2em 0;
    font-size: 28px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    background-color: #f85f00;
    border-radius: 20px;
}

.list_detail02 {
    margin-top: 24px;
    text-align: center;
    font-size: 40px;
    font-weight: bold;
}

.list_container03 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: center;
    justify-items: center;
    padding: 10px 0 0;
    gap: 2%;
}

.list_card01 {
    position: relative;
    width: clamp(30%, 26vw, 170px);
    aspect-ratio: 1;
    border-radius: 50%;
    font-size: clamp(14px, 2.2vw, 20px);
    display: flex;
    justify-content: center;
    align-items: center;
    &:first-child {
        border: 5px solid #ff3947;
    }
    &:nth-child(2) {
        border: 5px solid #fc23ef;
    }
    &:nth-child(3) {
        border: 5px solid #27a800;
    }
}

.list_img03 {
    position: absolute;
    top: calc(-1 * min(24px, 12%));;
    left: 50%;
    transform: translateX(-50%);
    width: 39.4736%;
    max-width: 75px;
}

.list_num01,
.list_point01 {
    font-size: 40px;
    font-weight: 900;
}

.list_block03 {
    margin-top: 32px;
    text-align: left;
    font-size: 24px;
    line-height: 1.33333;
}

.list_ttl04 {
    margin-top: 0.5em;
}

.list_detail04 {
    word-break: break-all;
}

.list_block05 {
    margin-top: 40px;
}

.list_item05 {
    position: relative;
    padding: 31px 23px 25px 25px;
    background-color: #fffa6e;
    border-radius: 0 30px 30px 30px;
    text-align: left;
    line-height: 1.25;
    word-break: auto-phrase;
    font-size: 28px;
    font-weight: 900;
    &:not(:first-child) {
        margin-top: 45px;
    }
    &:nth-child(2) {
        letter-spacing: -0.1em;
        word-break: normal;
    }
    &:nth-child(3) {
        word-break: normal;
    }
}

.list_img05,
.list_img06 {
    position: absolute;
    top: -22px;
    left: 0;
}

.list_img05 {
    max-width: 209px;
}

.list_img06 {
    max-width: 218px;
    top: -25px;
    left: 43%;
}

.text_font01 {
    font-size: 32px;
    letter-spacing: 0;
    color: #0d3bfc;
}

.list_block06 {
    margin-top: 35px;
    padding-left: 1em;
    text-indent: -1em;
    font-size: 18px;
    line-height: 1.33333;
    text-align: left;
    font-weight: 500;
}

.campaign_ttl01 {
    margin-top: 1.5em;
}

.campaign_ttl02 {
    margin-top: 1em;
}

.campaign_details02 {
    padding-left: 4em;
    text-indent: -4em;
}

.campaign_ttl03 {
    margin-top: 0.5em;
}

.list_item07 {
    padding-left: 2em;
    text-indent: -2em;
}

.list_item08,
.list_item09 {
    padding-left: 1em;
    text-indent: -1em;
}

@media screen and (max-width:600px) {
    .list_block01 {
        font-size: 3.90625vw;
    }

    .list_ttl02 {
        padding: 0.5em 0;
        font-size: 4vw;
    }

    .list_detail02 {
        font-size: 6vw;
    }

    .list_num01,
    .list_point01 {
        font-size: 6vw;
    }

    .list_block03 {
        font-size: 3.8vw;
    }

    .list_item05 {
        font-size: 5vw;
        word-break: break-all;
    }

    .text_font01 {
        font-size: 5.5vw;
    }

    .list_img05 {
        top: -16px;
        width: 38%;
    }

    .list_img06 {
        top: -20px;
        width: 39%;
    }
}

/* link */
.list_link08,
.annotation_link01 {
    display: inline;
}


/* btn */
.btn__box {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 68.75%;
    min-height: 80px;
    max-width: 440px;
    margin: 30px auto 0;
    background-color: #ff3947;
    border-radius: 10px;
    box-shadow: 7px 7px #c62b36;
}

.floating_btn {
    display: flex;
    justify-content: center;
    align-items: center;
    position: sticky;
    bottom: 0;
    width: 100%;
    min-height: 80px;
    border-top: 2px solid #fff;
    background-color: #ff3947;
}

.btn__link,
.floating_link {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    font-weight: bold;
    color: #fff;
}

.floating_link {
    font-size: 28px;
    font-weight: 900;
}

.btn__img {
    position: absolute;
    right: 5.68181%;
    width: 14px;
    height: 22px;
}

.floating_img {
    position: absolute;
    right: 5.68181%;
    width: 14px;
    height: 22px;
}

@media screen and (max-width:769px) {
    .btn__box {
        min-height: 60px;
    }

    .btn__img {
        width: 2.1875vw;
        height: auto;
    }
}

@media screen and (max-width:600px) {
    .btn__link {
        font-size: 3.75vw;
    }

    .floating_link {
        font-size: 6vw;
    }
}

/* accordion */
.accordion_btn01 {
    pointer-events: all;
    cursor: pointer;
}

.accordion_container01[aria-hidden="true"] {
    display: none;
}

.accordion_container01 {
    padding: 1em;
    line-height: 1.1;
    border: 3px solid #d00e31;
    border-top: none;
}

@media screen and (max-width:769px) {

}

@media screen and (max-width:600px) {

}