@charset "utf-8";

.main_area {
    background-color: #fff;
}

.main_area .text_01 {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}


.main_area .text_01 p {
    background: linear-gradient(transparent 60%, #ff6 60%);
    padding: 0 1em;
    font-size: clamp(0.938rem, 0.588rem + 1.75vw, 2.75rem)
        /*15-44px*/
    ;
    text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, 0-1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF, 0 0 3px rgb(255, 255, 255);
}

.first_box {
    position: relative;
    padding: 0 0 3rem;
    background-color: #fff;
}

.first_box .img {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
}

.first_box .img img {
    aspect-ratio: 8 / 9;
    object-fit: cover;
    height: 100%;
    width: 100%;
    object-position: 70% bottom;
}


.first_box .text_box {
    position: relative;
    z-index: 4;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding: 0.2rem 10px 0 0;
    gap: 1rem 0;
}



.first_box .text_02 {
    display: flex;
    flex-direction: column;
    gap: 0.6rem 0;
}

.first_box .text_02 li {
    background-color: #fff;
    padding: 0.4em 0.5em;
    font-size: 15px;
}

.syueki_list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem 0;
}

.syueki_list li {
    background-color: white;
    font-size: clamp(0.875rem, 0.682rem + 0.96vw, 1.875rem)
        /*14-30px*/
    ;
    padding: 0.4em 1em;
    text-align: center;
}

.syueki_list li .small {
    font-size: 70%;
    display: block;
}

.logo_area {
    background-color: #ffffffe8;
    ;
    width: auto;
    margin: 0 -1rem 0 0;
    border-radius: 20px 0 0 20px;
    padding: 0.5em 0.9em;
}

.logo_area p {
    font-size: clamp(0.688rem, 0.627rem + 0.3vw, 1rem)
        /*11-16px*/
    ;
    text-align: center;
}

.logo_area .logo_img {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 0 10px;
}

.logo_area .logo_img li {
    width: 46%;
    padding: 0.3rem 0.3rem 0;
    max-width: 80px;
}

.logo_area .logo_img img {}

.main_area .btn_area {
    display: flex;
    flex-direction: column;
    margin: -2rem auto 0;
    position: relative;
    z-index: 5;
    padding: 1.4rem;
}

.main_area .btn_area .comment {
    text-align: center;
    z-index: 3;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.main_area .btn_area p {
    background-color: #ffdee1;
    font-size: clamp(0.75rem, 0.678rem + 0.36vw, 1.125rem)
        /*12-18px*/
    ;
    padding: 2px 1.4em;
    display: inline-block;
    font-weight: normal;
    white-space: nowrap;
    font-weight: normal;
    border-radius: 4px;
}

.main_area .btn_list {
    padding: 0;
    width: 90%;
    margin: 0 auto 1.2em;
}

.main_area .btn_list li {}

.main_area .btn_list li a {
    margin: 0em auto 5px;
    padding: 1em 1.8em;
}

/*600px以上*/
@media (min-width: 600px) {
    .first_box {
        padding: 0 0 3rem;
        height: 70vw;
    }

    .first_box .img img {
        aspect-ratio: 16 / 9;
        object-fit: cover;
        object-position: center;
    }
}

/*900px以上*/
@media (min-width: 900px) {
    .first_box {

        height: 40vw;
    }
}

/*900px以上*/
@media (min-width: 1200px) {
    .first_box {
        height: 33vw;
    }
}

/****sec_01*******************************/
.sec_01 {
    text-align: center;
}

.fukidashi {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
}

.fukidashi li {
    background-color: #ffe494;
    padding: 0.5em 1em;
    position: relative;
    display: inline-block;
    margin-bottom: 2em;
    line-height: 1.5;
    text-align: center;
    font-size: clamp(1rem, 0.952rem + 0.24vw, 1.25rem);
}

.fukidashi li:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 93%;
    border-style: solid;
    border-width: 9px 10px 0 10px;
    border-color: #ffe494 transparent transparent;
    translate: -50% 100%;
}

.fukidashi li:nth-child(odd):after {
    left: 11%;
}


.bg_gray {
    background-color: #ffe494;
    padding: 1.5rem 1rem;
    position: relative;
    margin: 0 0 60px;
}

.bg_gray.arrow:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    border-style: solid;
    border-width: 43px 61.5px 0 61.5px;
    border-color: #ffe494 transparent transparent;
    translate: -50% 100%;
}

.sec_01 .syueki_list {
    flex-direction: unset;
    justify-content: center;
    gap: 10px;
}

.sec_01 .syueki_list li {
    border: solid 2px #c01;
    background-color: #c01;
    color: #fff;
    border-radius: 5px;
}

/*600px以上*/
@media (min-width: 600px) {
    .fukidashi {
        width: 80%;
        margin: 0 auto;
    }
}

/*900px以上*/
@media (min-width: 900px) {}

/****chosen*******************************/
.chosen h2 {
    font-weight: 900;
    text-align: center;
    margin: 0 0 0.8em;
    font-size: clamp(1.125rem, 1.005rem + 0.6vw, 1.75rem)
        /*18-28*/
    ;
    color: #e2752a;
}

.point_list .point {
    text-align: center;
    font-size: clamp(1.438rem, 1.293rem + 0.72vw, 2.188rem)
        /*23-35px*/
    ;
    padding: 0 0.9rem;
    position: relative;
    border-radius: 10px;
    background-color: #ff774e;
    color: #fff;
    display: inline;
    width: fit-content;
    margin: 0 auto;
}

.point_list .point::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 30px;
    width: 0;
    height: 0;
    border: 11px solid transparent;
    border-top: 11px solid #ff774e;
}

.point_list li {
    padding: 2rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.4rem 0;
}

.point_list dl {}

.point_list dt {
    text-align: center;
    font-size: clamp(1.125rem, 1.005rem + 0.6vw, 1.75rem)
        /*18-28px*/
    ;
    margin: 0 0 0.7em;
}

.point_list dd {}

.point_list dd .text_01 {
    text-align: center;
    padding: 1rem 0;
    font-size: clamp(1rem, 0.916rem + 0.42vw, 1.438rem)
        /*16-23*/
    ;
}

.point_list .img_area {
    padding: 3rem 0;
}

.point_list .text_area {
    padding: 1em 0;
    font-weight: normal;
}

.point_list h3 {
    font-weight: 900;
    text-align: center;
    margin: 0 0 0.8em;
    font-size: clamp(1.125rem, 1.005rem + 0.6vw, 1.75rem)
        /*18-28*/
    ;
}

/******/
.resultset {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}


.imgArea {
    width: 39%;
}

.resultset .satisfaction_list {
    justify-content: flex-start;
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    gap: 0;
    width: 60%;
}

.resultset .satisfaction_list li {
    flex-direction: unset;
    padding: 0;
    gap: unset;
    align-items: center;
    justify-content: space-between;
    align-items: flex-end;
}

.resultset .satisfaction_list li:not(:last-of-type) {
    margin-bottom: 1em;
}


.resultset .icon_area {
    width: 18%;
}

.resultset .icon_area img {
    object-fit: contain;
    width: 100%;
    height: 100%;
}


.resultset .co01 {
    background: linear-gradient(transparent 80%, #ffdc00 80%);
}

.manzokudo {
    display: flex;
    flex-wrap: wrap;
    align-items: first baseline;
    gap: 0 0.3em;
    width: 80%;
    justify-content: space-between;
    font-size: clamp(1.438rem, 1.197rem + 1.2vw, 2.688rem)
        /*23-43px*/
    ;
}

.resultset .manzokudo dt {
    font-size: 60%;
    font-weight: bold;
    margin:
        0;
}

.resultset .manzokudo dd {
    width: unset;
    font-weight: bold;
}

.resultset .manzokudo dd .small {
    font-size: 60%;
}



/*600px以上*/
@media (min-width: 600px) {
    .point_list dd {
        width: 80%;
        margin: 0 auto;
    }
}

/*900px以上*/
@media (min-width: 900px) {}

/***other********************************/
.other_area {}

.other_list {
    width: 100%;
    margin: 0 auto;
    max-width: 500px;
    display: flex;
    flex-direction: column;
    gap: 2rem 0;
}

.other_list li {
    margin: 0 0 2rem;
}

.other_list dl {}

.other_list dt {
    border-left: 5px solid #2589d0;
    padding: 0 0 0 1em;
    font-size: 19px;
    margin: 0 0 1em;
}

.other_list dd {
    font-weight: normal;
}

.other_list dd p {}

.other_list dd .img {
    margin: 0 auto 2rem;
    max-width: 500px;
    padding: 1.5rem 0;
}

/*600px以上*/
@media (min-width: 600px) {
    .other_list dd .img {
        padding: 3rem 0;
    }
}

/*900px以上*/
@media (min-width: 900px) {}

/****voice*******************************/
h2.title_01 {
    font-weight: 900;
    text-align: center;
    margin: 0 0 0.8em;
    font-size: clamp(1.125rem, 1.005rem + 0.6vw, 1.75rem)
        /*18-28*/
    ;
}

.voice {
    padding: 0 0 3rem;
}

.voice_silde {}

.voice_silde .slick-next::before {
    /*content: '〉';*/
}

.voice_silde .slick-prev::before {
    /*content: '〈';*/
}

.voice_silde .slick-prev,
.voice_silde .slick-next {
    position: absolute;
    z-index: 9999;
    top: unset;
    bottom: -1.8rem;
}

.voice_silde .slick-prev::before,
.voice_silde .slick-next::before {
    font-size: 2rem;
    font-weight: 900;
    color: #c01;
}

.slick-prev {
    right: 17%;
    left: unset;
}

.slick-next {
    left: 88%;
    right: unset;
}

.voice_silde .slick-slide {
    border-radius: 10px;
    overflow: hidden;
    width: 100%;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
    margin: 1rem;

}

.width_1300 {
    width: 100%;
    margin: 0 auto 1rem;
    max-width: 1300px;
}

.voice_silde li .box {
    display: flex;
    gap: 1rem;
}


.voice_silde .slick-dots li {
    border: none;
}

.slick-dots {
    bottom: -45px;
}

.slick-dots li button::before {
    /*   font-size: 14px;*/
}

.slick-prev::before,
.slick-next::before {
    color: #333;
}

.slick-track {
    display: flex;
}

.slick-slide {
    height: auto !important;
}

.velem {
    position: relative;
}

.velem:after {
    content: "+MORE";
    position: absolute;
    right: 1em;
    bottom: 1em;
    color: #666;
}

/*600px以上*/
@media (min-width: 600px) {
    .width_1300 {
        margin: 0 auto 2rem;
    }

}

/*900px以上*/
@media (min-width: 900px) {}

/*************/
.modal_wrap input {
    display: none;
}

.modal_open_label,
.modal_close_label {
    cursor: pointer;
}

.modal_open_label {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0;
    border: none;
}

.voice_photo {
    position: relative;
    margin: 0 auto;
}

.voice_photo .img {}

.voice_photo .img img {
    aspect-ratio: 16 / 12;
    object-fit: cover;
    height: 100%;
    width: 100%;
    border-radius: 5px;
}

.voice_photo .text {
    position: absolute;
    bottom: 0;
    left: 0;
    color: #fff;
    background: transparent linear-gradient(180deg, #0000 0%, #0000 10%, #0000 25%, #00000005 30%, #00000015 37%, #00000095 100%) 0% 0% no-repeat padding-box;
    width: 100%;
    padding: 5em 0.6em 0.6em;
}

.voice_photo .text .add {
    font-size: 13px;
}

.voice_photo .text .name {
    font-size: 150%;
}

.one_word {
    text-align: center;
    padding: 2em 1em;
    color: #c01;
    margin: 0 auto;
    font-size: clamp(1.0rem, 1.0rem, 1.313rem)
        /*18-21*/
    ;
}

.voice_wrap {}

.modal_content_wrap {
    height: 50%;
}

#container.voice_modal_on #voice_modal {
    display: block;
}

.voice_faq {
    display: none;
}

.voice_modal_on .voice_faq {
    display: unset;
}

.modal {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: none;
}

.modal_open_input:checked+label+input+.modal {
    display: block;
    animation: modal-animation .6s;
}

.modal_content_wrap {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 98%;
    background-color: #fefefe;
    z-index: 2;
    border-radius: 5px;
    height: 90%;
    overflow-y: scroll;
    max-width: 900px;
}

.modal_close_label {
    background-color: #c01;
    color: #fff;
    border: 2px solid #fff;
    border-radius: 20px;
    width: 36px;
    height: 36px;
    line-height: 1.6;
    text-align: center;
    display: table-cell;
    position: fixed;
    top: 2px;
    right: 2px;
    z-index: 99999;
    font-size: 1.3em;
}

.modal_content {
    overflow-y: auto;
    padding: 2rem 4%;
    max-width: 900px;
    margin: 0 auto;
}

.modal_background {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(72, 72, 72, 0.96);
    z-index: 1;
}

.voice_faq {}

.voice_faq li {
    margin: 1rem 0;
}

.voice_faq dl {}

.voice_faq dt {
    font-weight: bold;
    border-bottom: dotted 2px #c01;
    padding: 0 0 0.7em;
    margin: 0 0 0.7em;
    color: #c01;
}

.voice_faq dd {
    font-weight: normal;
}

@keyframes modal-animation {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.voice_modal_on .one_word {
    text-align: left;
    padding: 1em 0;
    font-size: clamp(1rem, 0.88rem + 0.6vw, 1.625rem)
        /*16-26*/
    ;
}


.voice_modal_on .voice_photo {
    max-width: 320px;
    margin: 0 auto;
}

.voice_modal_on {}

/*600px以上*/
@media (min-width: 600px) {
    .voice_modal_on .voice_photo .text {
        position: unset;
        color: #333;
        background: unset;
    }

    .voice_modal_on .voice_photo .img {
        margin: 0;
    }

    .voice_modal_on .voice_photo {
        max-width: unset;
        margin: 0;
        display: flex;
        align-items: end;
    }

    .voice_modal_on .one_word {
        max-width: unset;
    }

}

/*900px以上*/
@media (min-width: 900px) {}

/****price*******************************/
.price {
    text-align: center;
    font-size: clamp(1.875rem, 1.634rem + 1.2vw, 3.125rem)
        /*30-50*/
    ;
    margin: 0 0 0.4em;
}

.price .kamei {
    background-color: #c01;
    font-size: 40%;
    padding: 3px 0.6em;
    color: #fff;
}

.price .small {
    font-size: 50%;
}

.price_area p {
    font-weight: normal;
    padding: 0.5em 0;
    max-width: 470px;
    margin: 0 auto;
}

.scroll table {
    width: 100%;
}

.scroll {
    overflow: auto;
    /*tableをスクロールさせる*/
    white-space: nowrap;
    /*tableのセル内にある文字の折り返しを禁止*/
}

.scroll::-webkit-scrollbar {
    /*tableにスクロールバーを追加*/
    height: 5px;
}

.scroll::-webkit-scrollbar-track {
    /*tableにスクロールバーを追加*/
    background: #F1F1F1;
}

.scroll::-webkit-scrollbar-thumb {
    /*tableにスクロールバーを追加*/
    background: #BCBCBC;
}

.hikaku .aviva {
    background-color: #fefbca;
}

.hikaku {}

.hikaku tbody th {
    background-color: unset;
    color: #333;
}

.hikaku th,
.hikaku td {
    padding: 10px 1em;
    font-size: 14px;
}

.table_img {
    width: 100%;
    overflow-x: scroll;
}

.table_img img {
    width: 300%;
    max-width: 260%;
    padding: 2rem 0;
}

.price_area .text_01 {
    text-align: center;
}

/*600px以上*/
@media (min-width: 600px) {
    .price_area p {
        text-align: center;
    }

    .table_img {
        overflow-x: unset;
    }

    .table_img img {
        width: 100%;
    }

    .price_area .text_01 {
        display: none;
    }
}

/*900px以上*/
@media (min-width: 900px) {}

/***flow********************************/
.flow {}

.flow_list {
    position: relative;
    margin: 0 auto;
    width: fit-content;
}

.flow_list:after {
    content: "";
    position: absolute;
    left: 17px;
    top: 6px;
    background: #c01;
    width: 2px;
    height: 98%;
}

.flow_list:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 8px;
    width: 0;
    height: 0;
    margin: auto;
    border-top: 15px solid #c01;
    ;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-bottom: 0 solid transparent;
    transform: translateY(1px);
    box-sizing: border-box;
}

.flow_list li {
    padding: 0.5rem 0 1rem 3.1rem;
    position: relative;
}

.flow_list li:before {
    content: "●";
    font-size: 36px;
    color: #c01;
    ;
    position: absolute;
    left: 0;
    top: -0.2em;
}

.flow_list dl {}

.flow_list dt {
    font-size: 20px;
}

.flow_list dd {
    padding: 1em 0;
    font-weight: normal;
}

/*600px以上*/
@media (min-width: 600px) {}

/*900px以上*/
@media (min-width: 900px) {}

/*****story******************************/
.story_area .logo_img {
    gap: 0 6%;
}

.story_area .text_area {
    width: 100%;
    max-width: 570px;
    margin: 0 auto;
}

.story_area .logo_area {
    padding: 1em 2em 2rem;
}

.story_area .logo_area .logo_img li {
    max-width: 160px;
}

/*600px以上*/
@media (min-width: 600px) {}

/*900px以上*/
@media (min-width: 900px) {}

/***********************************/
/*600px以上*/
@media (min-width: 600px) {}

/*900px以上*/
@media (min-width: 900px) {}

/***********************************/
/*600px以上*/
@media (min-width: 600px) {}

/*900px以上*/
@media (min-width: 900px) {}

/****************/
.faq_list {
    margin: 3rem auto;
    width: 100%;
    max-width: 600px;
}

.faq-item {
    margin-top: 20px;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    border-bottom: 1px solid #888;
}

.faq-question__wrap {
    position: relative;
    background: #fff;
    padding: 10px 3em 10px 2.5em;
    cursor: pointer;

}

.minus-icon {
    position: absolute;
    content: "";
    width: 20px;
    height: 3px;
    background: #333;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}

.plus-icon {
    position: absolute;
    content: "";
    width: 20px;
    height: 3px;
    background: #333;
    right: 10px;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    transition: ease all 0.5s;
    /* 擬似要素のトランジションを追加 */
}

.plus-icon.active {
    transform: translateY(-50%);
}

.faq-question__title {
    font-weight: bold;
    color: #333;
    position: relative;
}

.faq-question__title::before {
    position: absolute;
    color: #fff;
    content: "Q";
    top: 50%;
    left: -2.5em;
    transform: translateY(-50%);
    background-color: #333;
    width: 2em;
    height: 2em;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.faq-answer__wrap {
    background: #fff;
    padding: 10px 5px 10px 55px;
    transition: ease all 0.5s;
    /* 擬似要素のトランジションを追加 */
    height: 0;
    overflow: hidden;
    padding-top: 0;
    padding-bottom: 0;
}

.faq-answer__wrap.active {
    height: auto;
    padding: 10px 5px 10px 55px;
}

.faq-answer__wrap {
    background: #fff;
    opacity: 0;
    padding: 10px 5px 10px 55px;
    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
    transition: ease all 0.7s;
    /* 擬似要素のトランジションを追加 */
}

.faq-answer__wrap.active {
    opacity: 1;
    padding: 10px 3em 10px 2.5em;
}

.faq-answer__title {
    position: relative;
    font-weight: bold;
    font-size: 1.2em;
}

.faq-answer__title::before {
    position: absolute;
    content: "A";
    top: 50%;
    left: -27px;
    transform: translateY(-50%);
}

.faq-answer__text {
    margin-top: 5px;
    font-weight: normal;
}