@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;800&family=Poppins:wght@500&display=swap');

main {
    font-size: 18px;
    line-height: 1.7;
}

.poppins {
    font-family: "Poppins", sans-serif;
}

.m-plus {
    font-family: "M PLUS Rounded 1c";
}

body {
    font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN', Meiryo, "メイリオ", sans-serif;
}

ul.annotation_box li {
    font-size: 1.4rem;
}

ul.annotation_box.num li {
    margin-left: 2.6rem;
}

ul.annotation_box.num li::before {
    left: -2.6rem;
}

/* パンくず */
#pankuzu, #breadCrumb, #breadCrumb_style {
    padding-top: 16px;
    margin: 0 auto 45px;
    box-sizing: content-box;
}

#pankuzu ul, ul#breadCrumb {
    display: block;
}

#pankuzu li, #breadCrumb li, #breadCrumb_style li {
    display: inline-block;
    float: left;
    color: #b2c5e0;
    font-size: 12px;
    font-weight: bold;
    height: 12px;
}

#pankuzu li:after, #breadCrumb li:after, #breadCrumb_style li:after {
    content: ' > ';
    color: var(--primary);
    font-weight: normal;
    display: inline-block;
    margin-right: 10px;
    margin-left: 10px;
}

#pankuzu li:last-child:after, #breadCrumb li:last-child:after, #breadCrumb_style li:last-child:after {
    content: none;
}

#pankuzu li a, #breadCrumb li a {
    text-decoration: none;
}

.kids #breadCrumb_style,
.beginner #breadCrumb_style {
    padding-top: 10px !important;
}

#breadCrumb_style li, #breadCrumb_style li:after {
    color: #000;
}

/* LP_Nav */
.tone-contents {
    font-size: 18px;
}

/* fv */
.fv {
    position: relative;
    max-width: 1920px;
    width: 100%;
    display: flex;
    margin: 16px auto 0;
}

.main_ttl_box {
    width: 50%;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
}

.main_img {
    width: 50%;
    height: auto;
    background: url(/assets/img/pickup/beginner/mv_img.png) center / cover no-repeat;
}

.mv_img_sp {
    display: none;
}

h1 {
    text-align: center;
}

h1.h1_ttl {
    margin-top: 60px;
    color: #333;
}

.nmb_box_balloon {
    display: inline-block;
}

h1 img {
    width: 80%;
}

.main_ttl {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 18.255px 14.936px;
    margin-top: 20px;
    border-radius: 6.638px;
    box-sizing: border-box;
    background: var(--primary);
}

.main_ttl span {
    text-align: center;
    color: var(--white, #FFF);
    text-shadow: 3.321px 4.429px 4.429px rgba(0, 0, 0, 0.25);
    font-size: 77px;
    font-style: normal;
    font-weight: 800;
    line-height: 1.1;
}

.main_ttl_box .cvArea_ttl_wrap {
    padding: 20px 0 24px;
}

.main_ttl_box .cvArea_ttl_wrap h2 span.bold {
    font-size: 38px;
}

.main_ttl_box .cvArea_ttl_split {
    font-size: 48px;
}

.main_ttl_box .cvArea_contents {
    max-width: 100%;
}

.main_ttl_box .cvArea_contents::after {
    content: none;
}

.main_ttl_box .cvArea_conditions {
    max-width: 550px;
}

.main_ttl_box .cvArea_conditions h3 {
    font-size: 24px;
}

.main_ttl_box .cvArea_conditions_list {
    padding: 14px 0 10px;
}

.main_ttl_box .cvArea_conditions_list li {
    font-size: 20px;
}

.main_ttl_box .cvArea_conditions_list li span {
    font-size: 28px;
}

.main_ttl_box .cvArea_contents {
    padding: 24px 16px 20px;
    background: url(/assets/img/pickup/beginner/main_ttl_bg@2x.png) center / cover no-repeat;
}

/* cvArea */
.cvArea_ttl_wrap {
    display: flex;
    padding: 40px 20px 20px 20px;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    align-self: stretch;
    background: var(--primary);
}

.cvArea_ttl_wrap h2 {
    color: var(--white);
    font-size: 28px;
    font-weight: bold;
    line-height: normal;
    text-align: center;
}

.cvArea_ttl_wrap h2 span.bold {
    font-size: 42px;
}

.cvArea_ttl_split_wrap {
    display: flex;
    justify-content: space-between;
    gap: 7.407px;
    align-self: center;
}

.cvArea_ttl_split {
    padding: 7.407px;
    font-size: 56px;
    font-style: normal;
    font-weight: 800;
    line-height: 100%;
    /* 48px */
    background-color: var(--white);
    color: var(--primary);
    border-radius: 3.703px;
}

.cvArea_contents {
    position: relative;
    display: flex;
    max-width: 700px;
    width: 100%;
    margin: auto;
    padding: 50px 16px 40px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 30px;
    box-sizing: border-box;
}

.cvArea_contents::after {
    content: "";
    position: absolute;
    top: -1px;
    right: 0;
    left: 0;
    margin: auto;
    max-width: 400px;
    width: 100%;
    height: calc(88px / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    background-color: var(--primary);
}

.cvArea_conditions {
    max-width: 768px;
    width: 100%;
    margin: auto;
    container-type: inline-size;
    container-name: cvArea_conditions-container;
}

.cvArea_conditions h3 {
    position: relative;
    display: block;
    text-align: center;
    font-size: 32px;
}

.cvArea_conditions h3::after, .cvArea_conditions h3::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 120px;
    height: 1px;
    background-color: var(--black);
}

/* .cvArea_conditions-containerが500px以上の時 */
@container cvArea_conditions-container (min-width:500px) {
    .cvArea_conditions h3::after, .cvArea_conditions h3::before {
        width: 200px;
    }
}

.cvArea_conditions h3::after {
    left: 0;
}

.cvArea_conditions h3::before {
    right: 0;
}

.cvArea_conditions_list_wrap {
    border-bottom: 1px solid var(--black);
    text-align: center;
    margin-bottom: 10px;
}

.cvArea_conditions_list {
    display: inline-block;
    padding: 24px 0 16px;
    gap: 6px;
}

.cvArea_conditions_list li {
    text-align: left;
    font-size: 28px;
    font-weight: bold;
    line-height: 1;
}

.cvArea_conditions_list li:not(:last-of-type) {
    padding-bottom: 6px;
}

.cvArea_conditions_list li:last-of-type {
    line-height: 1.4;
}

.cvArea_conditions_list li span {
    font-size: 36px;
}

.underline_yellow {
    background: linear-gradient(transparent 60%, #FFF166 50%);
}

.cvButton_contents {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.text_link {
    position: relative;
    color: var(--Logo-red, #FF6043);
    text-align: center;
    font-size: 20px;
    font-style: normal;
    font-weight: 600;
    line-height: 120%;
    margin-right: 20px;
}

.text_link::after {
    position: absolute;
    top: 0;
    bottom: 0;
    right: -32px;
    margin: auto;
    height: 27px;
    font-size: 1.6em;
    font-weight: normal;
    height: fit-content;
    color: var(--Logo-red, #FF6043);
    content: "\f105";
    font-family: "FontAwesome";
}

/* recommended */
.recommended {
    position: relative;
    display: flex;
    padding: 60px 5%;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    background: var(--light-blue02, #F2F8FF);
    z-index: 1;
}

.radialPattern_pc {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.recommended .ttl_area {
    display: inline-flex;
    max-width: 500px;
    width: 100%;
    padding: 22px 14px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 3px;
    color: var(--white);
    background: var(--primary);
    box-sizing: border-box;
}

.recommended .ttl_area span {
    color: var(--white, #FFF);
    text-shadow: 2.768px 3.69px 3.69px rgba(0, 0, 0, 0.25);
    font-size: 32px;
    font-style: normal;
    font-weight: 500;
    line-height: 100%;
}

.recommended .ttl_area span.bold {
    font-size: 48px;
    font-weight: 800;
}

.radialPattern_pc {
    display: block;
}

.radialPattern_sp {
    display: none;
}

.nmb_box_balloon {
    position: relative;
    text-align: center;
    font-size: 24px;
    font-weight: bold;
}

.nmb_box_balloon::after, .nmb_box_balloon::before {
    content: "";
    position: absolute;
    width: 3px;
    height: 100%;
    top: 0;
    background-color: var(--black);
    border-radius: 5px;
}

.nmb_box_balloon::after {
    right: -24px;
    transform: rotate(35deg);
}

.nmb_box_balloon::before {
    left: -24px;
    transform: rotate(-35deg);
}

.nmb_contents_list_wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    align-self: stretch;
}

.nmb_contents_list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
}

.nmb_contents_list li {
    display: flex;
    max-width: 500px;
    width: 100%;
    margin: auto;
    padding: 16px;
    justify-content: center;
    align-items: center;
    align-self: stretch;
    box-sizing: border-box;
    border-bottom: 1px solid var(--primary);
    background: #FFF;
}

.nmb_box_count {
    width: 37.629px;
    height: 24.328px;
    display: flex;
    padding: 9.41px 5.41px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 7.407px;
    text-align: center;
    font-size: 28px;
    font-weight: 500;
    line-height: 1.5;
    color: var(--white, #FFF);
    border-radius: 3.703px;
    background: var(--primary);
}

.nmb_box_txt {
    max-width: 400px;
    width: 100%;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
}

.nmb_box_txt span {
    color: var(--Logo-red, #FF6043);
}

/* docomo */
.docomo {
    display: flex;
    padding: 64px 16px;
    flex-direction: column;
    align-items: center;
    gap: 32px;
}

.h2_ttl_box {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.h2_ttl_box .nmb {
    width: 37.629px;
    height: 24.328px;
    display: flex;
    padding: 9.41px 5.41px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 7.407px;
    text-align: center;
    font-size: 28px;
    font-weight: 500;
    line-height: 1.5;
    color: var(--white, #FFF);
    border-radius: 3.703px;
    background: var(--primary);
}

.h2_ttl_box h2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 130%;
    text-align: center;
}

.h2_ttl_box h2 span {
    font-size: 40px;
}

.h2_ttl_box h2 span.docomo-red {
    color: var(--primary);
}

.docomo_contents {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    align-self: stretch;
}

.docomo_contents h3 {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    line-height: 150%;
}

.card_contents {
    display: flex;
    max-width: 400px;
    width: 100%;
    margin: auto;
    flex-direction: column;
    align-items: flex-start;
    align-self: stretch;
}

.card_contents_ttl {
    display: flex;
    padding: 10px 0px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    align-self: stretch;
    color: #FFF;
    text-align: center;
    font-size: 20px;
    font-style: normal;
    font-weight: bold;
    line-height: 150%;
    border-radius: 10px 10px 0px 0px;
}

.docomo .card_contents_ttl {
    background: var(--docomo-red, #C03);
}

.card_contents_box {
    display: flex;
    padding: 16px 0px;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    align-self: stretch;
    border-radius: 0px 0px 10px 10px;
    background: var(--base-color, #FFF);
}

.docomo .card_contents_box {
    border: 2px solid var(--docomo-red, #C03);
}

.docomo .card_contents_box .flexbox {
    display: flex;
    justify-content: center;
    gap: 24px;
}

/* lifelog */
.lifelog {
    display: flex;
    padding: 72px 0;
    flex-direction: column;
    align-items: center;
    gap: 50px;
    background: var(--light-blue02, #F2F8FF);
}

.lifelog .h2_ttl_box {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.lifelog .h2_ttl_box h2 p {
    font-weight: bold;
    font-size: 32px;
    line-height: 1;
}

.lifelog .h2_ttl_box h2 .flexbox {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;
}

.lifelog_main_img {
    max-width: 500px;
    width: 100%;
    margin: auto;
}

.lifelog_contents {
    max-width: 768px;
    width: 100%;
}

.lifelog_worries_wrap {
    display: flex;
    padding: 32px 0px 24px;
    justify-content: center;
    align-items: flex-start;
    align-content: flex-start;
    align-self: stretch;
    flex-wrap: wrap;
    background: #b1b9c4;
}

.lifelog_worries_txt {
    position: relative;
}

.worries_ilust01 {
    position: absolute;
    top: 0;
    left: 0;
}

.worries_ilust02 {
    position: absolute;
    top: 0;
    right: 0;
}

.lifelog_worries_txt {
    text-align: center;
    color: #053061;
    font-size: 36px;
    line-height: 130%;
}

.lifelog_worries_txt span {
    font-weight: bold;
}

.lifelog_worries_txt span.big {
    font-size: 48px;
}

.lifelog_solution_wrap {
    position: relative;
    width: 100%;
    display: flex;
    padding: 48px 0px 20px 0px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    align-self: stretch;
    background: var(--Logo-red, #FF6043);
}

.lifelog_solution_wrap::after {
    content: "";
    position: absolute;
    top: -1px;
    right: 0;
    left: 0;
    margin: auto;
    max-width: 400px;
    width: 100%;
    height: calc(88px / 2);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    background: #b1b9c4;
}

.lifelog_solution_box01 p {
    color: var(--white, #FFF);
    text-align: center;
    font-size: 32px;
    font-weight: bold;
    line-height: 200%;
}

.lifelog_solution_box01 p span {
    font-size: 48px;
}

.lifelog_solution_box02 {
    display: flex;
    padding: 30px 0;
    flex-direction: column;
    align-items: center;
    gap: 25px;
    align-self: stretch;
    background: var(--white);
}

.lifelog_solution_box02_illustWrap {
    position: relative;
    max-width: 300px;
    width: 100%;
    margin: auto;
    text-align: center;
}

.solution_ilust01, .solution_ilust02 {
    position: absolute;
    top: 0;
}

.solution_ilust01 {
    left: 0;
}

.solution_ilust02 {
    right: 0;
}

.lifelog_solution_box02_txtWrap {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    font-size: 20px;
}

.solution_box02_txt {
    position: relative;
    max-width: 300px;
    width: 100%;
    margin: auto;
    color: var(--Logo-red, #FF6043);
    text-align: center;
    font-size: 36px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
}

.solution_box02_txt::after,
.solution_box02_txt::before {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    border-top: 3px solid var(--Logo-red, #FF6043);
    border-left: 3px solid var(--Logo-red, #FF6043);
}

.solution_box02_txt::after {
    top: -10px;
    left: -20px;
}

.solution_box02_txt::before {
    bottom: -10px;
    right: -20px;
    transform: rotate(180deg);
}

.lifelog_features {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    padding: 0 16px;
    box-sizing: border-box;
    align-self: stretch;
}

.lifelog_features h3 {
    font-size: 28px;
    line-height: 180%;
    text-align: center;
}

.lifelog_features h3 span {
    font-size: 42px;
}

.lifelog_features h3 span.big {
    font-size: 60px;
}

.lifelog_features_contents {
    position: relative;
    max-width: 768px;
    width: 100%;
    margin: auto;
    display: flex;
    padding: 24px;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    align-self: stretch;
    background: var(--white);
    box-sizing: border-box;
}

.lifelog_features_contents::after {
    position: absolute;
    left: 16px;
    top: -28px;
    color: var(--primary);
    text-align: center;
    font-family: Poppins;
    font-size: 58px;
    font-style: normal;
    font-weight: 500;
    line-height: 100%;
    /* 58px */
    opacity: 0.3;
}

.lifelog_features_contents:first-of-type::after {
    content: "01";
}

.lifelog_features_contents:nth-of-type(2)::after {
    content: "02";
}

.lifelog_features_contents:nth-of-type(3)::after {
    content: "03";
}

.lifelog_features_contents h4 {
    font-size: 24px;
    line-height: 1.3;
    text-align: center;
}

.accordion_wrap {
    max-width: 650px;
    width: 100%;
    margin: auto;
}

.accordion_btn {
    position: relative;
    display: block;
    max-width: 400px;
    width: 100%;
    margin: auto;
    padding: 12px 8px;
    border-radius: 100px;
    border: 2px solid var(--black);
    background: var(--white);
    color: var(--black);
    transition: 0.3s ease-in-out;
}

.accordion_btn_box {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    padding-right: 20px;
}

.accordion_btn_box p {
    font-size: 20px;
    font-weight: bold;
    line-height: 2;
}

.accordion_btn::after {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 32px;
    margin: auto;
    height: 27px;
    font-size: 1.6em;
    font-weight: normal;
    height: fit-content;
    color: var(--black);
    content: "\f105";
    font-family: "FontAwesome";
    transform: rotate(90deg);
    transition: 0.3s ease-in-out;
}

.accordion_btn.open::after {
    transform: rotate(-90deg);
}

@media (hover:hover) {
    .accordion_btn:hover {
        opacity: 0.6;
    }
}

.accordion_contents {
    display: none;
    margin-top: 20px;
    padding: 20px 16px;
    height: 500px;
    overflow: scroll;
    border-radius: 8px;
    background: var(--background-blue);

    #confirmed_operation_device {
        .device_select_box, #smartphoneList {
            padding: 24px 16px;
        }
    }
}

.accordion_contents h5:nth-of-type(n+1) {
    margin: 24px 0 8px;
    font-size: 18px;
}

.lifelog_features .card_contents {
    max-width: 768px;
}

.lifelog_features .card_contents_ttl {
    border: 1px solid var(--primary);
    font-size: 32px;
    gap: 24px;
    background: var(--primary);
}

.lifelog_features .card_contents_box {
    padding: 24px 20px;
    border: 2px solid var(--primary);
}

/* toneCare */
.toneCare {
    display: flex;
    max-width: 768px;
    width: 100%;
    margin: auto;
    padding: 64px 0;
    flex-direction: column;
    align-items: center;
    box-sizing: border-box;
    gap: 32px;
}

.h2_ttl_box h2 span.green {
    color: var(--primary);
}

.toneCare .annotation_box {
    width: 100%;
}

/* price */
.price {
    display: flex;
    padding: 60px 24px;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    box-sizing: border-box;
    background: var(--light-blue02, #F2F8FF);
}

.price_contents {
    display: flex;
    padding: 24px 16px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 14px;
    max-width: 768px;
    width: 100%;
    margin: auto;
    border-radius: 8px;
    box-sizing: border-box;
    background: var(--white);
}

.price_contents h3 {
    width: 100%;
    padding: 12px 0px;
    gap: 8px;
    border-radius: 4px;
    background-color: var(--Logo-red, #FF6043);
    color: var(--white);
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    line-height: 130%;
}

.prcie_txt_1gb {
    text-align: center;
    font-size: 19px;
    line-height: 1.2;
}

.prcie_txt_1gb span {
    position: relative;
    font-size: 23px;
    font-weight: 700;
}

.prcie_txt_1gb span::after {
    content: "※1";
    position: absolute;
    font-size: 14px;
}

.price_contents strong {
    font-size: 48px;
    color: var(--secondary);
    line-height: 1;
}

.price_contents .plus {
    font-size: 40px;
    line-height: 1;
}

.option_contents {
    display: flex;
    width: 100%;
    padding: 18px 20px 14px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 4px;
    align-self: stretch;
    border-radius: 2px;
    background: #F5F5F5;
    text-align: center;
    box-sizing: border-box;
}

.option_contents_txt {
    position: relative;
    font-weight: bold;
    font-size: 22px;
}

.option_contents_txt::after {
    content: "※2";
    position: absolute;
    top: -14px;
    right: 0;
    font-size: 12px;
}

.option_contents .cmt {
    font-size: 14px;
}

.commission_wrap {
    display: flex;
    height: 90px;
    padding: 0px 16px;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    align-self: stretch;
}

.commission_box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    max-width: 375px;
    width: 100%;
    margin: auto;
}

.commission_box:first-of-type {
    padding-bottom: 16px;
    border-bottom: 1px solid #000;
}

.price .annotation_box {
    max-width: 768px;
    width: 100%;
    margin: auto;
}

/* qa */
.qa {
    display: flex;
    padding: 72px 16px;
    flex-direction: column;
    align-items: center;
    gap: 56px;
    background: #FFEFEC;
}

.qa_conntens {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    align-self: stretch;
    max-width: 650px;
    width: 100%;
    margin: auto;
}

.qa_balloon_box {
    display: flex;
    align-items: center;
    gap: 24px;
}

.qa_balloon {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 16px 30px;
    min-width: 120px;
    max-width: 100%;
    min-height: 90px;
    font-size: 20px;
    line-height: 1.7;
    background: #FFF;
    border: solid 3px var(--black);
    color: var(--black);
    box-sizing: border-box;
    border-radius: 6px;
    font-weight: bold;
}

.qa_balloon:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-right: 12px solid var(--white);
    z-index: 2;
}

.qa_balloon:after {
    content: "";
    position: absolute;
    top: 50%;
    left: -30px;
    margin-top: -14px;
    border: 14px solid transparent;
    border-right: 14px solid var(--black);
    z-index: 1;
}

.qa_balloon span {
    margin: 0;
    padding: 0;
}

.qa_balloon.yellow {
    display: inline-block;
    padding: 16px;
    background: #FBFF49;
    line-height: 1.3;
}

.qa_balloon.yellow span {
    font-size: 28px;
}

.qa_balloon.yellow::before {
    left: auto;
    right: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-left: 12px solid #FBFF49;
}

.qa_balloon.yellow::after {
    left: auto;
    right: -30px;
    margin-top: -14px;
    border: 14px solid transparent;
    border-left: 14px solid var(--black);
}

.qa_answer_box {
    display: flex;
    padding: 24px 16px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 16px;
    align-self: stretch;
    width: 100%;
    margin: auto;
    border-radius: 8px;
    box-sizing: border-box;
    background: var(--white);
}

.qa_answer_box h3 {
    width: 100%;
    padding: 8px;
    text-align: center;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 130%;
    color: var(--white);
    border-radius: 4px;
    background: var(--Logo-red, #FF6043);
    box-sizing: border-box;
}

.qa_answer_price {
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.qa_answer_price {
    font-size: 20px;
}

.qa_answer_price .orange {
    color: var(--Logo-red, #FF6043);
    font-weight: bold;
    font-size: 18px;
}

.qa_answer_price .orange span {
    font-size: 64px;
    line-height: 1;
}

.qa_answer_box .annotation_box {
    width: 100%;
}

.qa_answer_price .price_img {
    position: relative;
}

.qa_answer_price .price_img::after {
    content: "※2";
    position: absolute;
    top: 0;
    right: 0;
    font-size: 14px;
    color: var(--black);
}

/* Closing */
.Closing {
    display: flex;
    padding: 50px 16px 0px 16px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    background: url(/assets/img/lp_ac_b2/Closing_bg.png) center /cover no-repeat;
}

/* affiliate */
.affiliate {
    margin: 64px auto;
    padding: 0;
    background-color: var(--white);
    box-sizing: border-box;
}

.affiliate h2 {
    text-align: center;
}

.affiliate img {
    width: 90%;
    max-width: 500px;
    margin: 0 auto;
}

.affiliate p.affiliate_coupon_txt {
    font-size: 20px;
    text-align: center;
    color: var(--black);
    font-weight: bold;
    margin-top: 16px;
    margin-bottom: 16px;
}

.affiliate span {
    font-size: 30px;
    color: #fff;
    line-height: 1.7;
    padding: 8px;
    background-color: var(--Logo-red, #FF6043);
}

.affiliate-contents {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
}

.affiliate-contents h3 {
    text-align: center;
    font-size: 18px;
}

.affiliate-txt {
    line-height: 170%;
    margin: 10px auto 20px;
}

/* .fvが1440px以上の時 */
@media screen and (min-width: 1440px) {
    .main_ttl span {
        font-size: min(7vw, 110px);
    }
}

/* タブレット */
@media screen and (max-width: 1024px) {
    .fv {
        flex-direction: column;
        justify-content: center;
    }

    .main_ttl_box {
        width: 100%;
    }

    .main_img {
        width: 100%;
        height: min(60vw, 600px);
    }

    .cvArea_contents {
        max-width: 1024px;
    }

    .cvArea_ttl_wrap h2 span.bold {
        font-size: 38px;
    }

    .cvArea_ttl_split {
        font-size: 48px;
    }

    .cvArea_conditions h3 {
        font-size: 24px;
    }

    .cvArea_conditions_list li span {
        font-size: 28px;
    }

    .cvArea_conditions_list li {
        font-size: 20px;
    }

    .recommended .ttl_area span {
        font-size: 24px;
    }

    .recommended .ttl_area span.bold {
        font-size: 36px;
    }

    .lifelog_worries_txt {
        font-size: 29.091px;
        line-height: 130%;
    }

    .lifelog_worries_txt span.big {
        font-size: 34.909px;
    }

    .lifelog_solution_box01 p {
        font-size: 23px;
    }

    .lifelog_solution_box01 p span {
        font-size: 36px;
    }

    .solution_box02_txt {
        font-size: 28px;
    }

    .solution_box02_txt::after {
        top: 0;
        left: 0px;
    }

    .solution_box02_txt::before {
        bottom: 0;
        right: 0px;
        transform: rotate(180deg);
    }
}

@media screen and (max-width: 869px) {

    /* fv */
    .main_img {
        display: none;
    }

    .mv_img_sp {
        width: 100%;
        display: block;
    }

    .main_ttl {
        max-width: 327px;
    }

    .main_ttl span {
        font-size: 67px;
    }

    /* lifelog */
    .worries_ilust01 {
        position: absolute;
        top: -50px;
        left: -10px;
    }

    .worries_ilust02 {
        position: absolute;
        top: -50px;
        right: -10px;
    }

    .lifelog_features_contents {
        padding: 24px 12px;
    }

    /* price */
    .price {
        padding: 60px 16px;
    }

    .affiliate-contents {
        padding: 0 16px;
    }
}

@media screen and (max-width: 500px) {
    .h1_ttl .nmb_box_balloon {
        font-size: min(4.8vw, 22px);
    }

    .radialPattern_pc {
        display: none;
    }

    .radialPattern_sp {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 100%;
        height: auto;
        z-index: -1;
    }

    .qa_answer_price .orange span {
        font-size: 52px;
    }

    .qa_balloon {
        padding: 16px 12px;
        font-size: 18px;
    }

    .qa_balloon.yellow {
        font-size: 16px;
    }

    .qa_balloon.yellow span {
        font-size: 22px;
    }

    .qa_balloon_box {
        gap: 16px;
    }

    .accordion_contents {
        padding: 20px 0;
    }
}

@media screen and (max-width: 360px) {
    .main_ttl span {
        font-size: 62px;
    }

    .recommended .ttl_area span.bold {
        font-size: 34px;
    }

    .radialPattern_sp {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 100%;
        height: auto;
        z-index: -1;
    }

    .accordion_btn_box {
        justify-content: flex-start;
    }

    .qa_balloon, .qa_balloon.yellow {
        padding: 12px 6px;
    }
}
