abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
    border: 0;
    box-sizing: border-box;
    font: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    word-break: break-all;
    word-wrap: break-word;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    background-color: #fff;
    line-height: 1;
}

blockquote,
q {
    quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

body {
    color: #2e2e2e;
    font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
    font-weight: 500;
    position: relative;
    width: 100%;
    -webkit-text-size-adjust: 100%;
    font-feature-settings: "palt";
}

body>iframe,
body>img {
    display: none;
}

html {
    font-size: 1.3333vw;
}

.sp {
    display: block !important;
}

.pc {
    display: none !important;
}

@media (min-width: 768px) {
    html {
        font-size: 1vw;
    }

    .sp {
        display: none !important;
    }

    .pc {
        display: block !important;
    }
}

@media (min-width: 1000px) {
    html {
        font-size: 8px;
    }
}
main {
    overflow: hidden;
}

.wrapper a,
.wrapper button {
    box-sizing: border-box;
    cursor: pointer;
    opacity: 1;
    transition: opacity .4s ease;
    color: inherit;
}

.wrapper a:hover,
.wrapper button:hover {
    opacity: 0.7;
}

.wrapper ul,
.wrapper ol {
    list-style: none;
}

.wrapper img {
    display: inline-block;
    height: auto;
    max-width: 100%;
    vertical-align: bottom;
}

.header {
    background-color: #fff;
    width: 100%;
    position: relative;
    z-index: 1;
    box-shadow: .7rem .7rem 2rem 2rem rgba(0, 0, 0, 0.055);
}

.headerInner {
    display: flex;
    align-items: center;
    height: 7.6rem;
    margin: 0 auto;
    max-width: 75rem;
    padding: 0 1.3rem;
    position: relative;
}

.headerInner h1 {
    width: 27.1rem;
}

.footer {
    background-color: #2e2e2e;
    color: #fff;
    font-size: 2rem;
    padding: 3rem 0;
    text-align: center;
    width: 100%;
}

#modal_overlay {
    background: rgba(0, 0, 0, 0.8);
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    top: 0;
    z-index: 1000;
}

#modal_wrapper {
    align-items: center;
    display: none;
    justify-content: center;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: fit-content;
    z-index: 1001;
}

#modal_block {
    background-color: #fff;
    padding: 6rem 0;
    width: 70rem;
}

.modal_txt {
    font-size: 3.6rem;
    text-align: center;
}

.modal_img {
    display: none;
    margin: 0 auto;
    width: 56rem;
    justify-content: center;
}

.modal_img.qr_a {
    width: 65.4rem;
}

.modal_img.qr_b {
    width: 64.4rem;
}

#modal_close {
    align-items: center;
    border: 1px solid #ccc;
    box-shadow: 0 .5rem .5rem #ccc;
    cursor: pointer;
    display: flex;
    font-size: 3.6rem;
    height: 12rem;
    justify-content: center;
    margin: 0 auto;
    width: 40rem;
}

@media (min-width: 750px) {
    #modal_block {
        padding: 3rem 0;
    }

    .modal_txt {
        font-size: 1.8rem;
    }

    #modal_close {
        font-size: 1.8rem;
        height: 6rem;
        width: 20rem;
    }
}

.txt_center {
    text-align: center;
}

#mv {
    background-color: #0ca26c;
}

.inner {
    margin: 0 auto;
    padding: 0 3rem;
    max-width: 75rem;
}

#mv .mv_img {
    margin: 0 auto;
}

#mv .inner {
    position: relative;
    padding: 0;
}
#mv .mv_btn {
    width: 100%;
    text-align: center;
    position: absolute;
    bottom: 4rem;
    left: 0;
}
#mv .mv_btn .btn {
    width: 69rem;
    display: block;
    margin: 0 auto;
}

.cv_ttl {
    max-width: 56rem;
    margin: 4rem auto 1.7rem;
}

.cv_bnr_img {
    max-width: 50.4rem;
    margin: 0 auto;
}

.btn_group {
    margin-top: 1.35rem;
}

.btn_group .btn {
    display: block;
    width: 69rem;
    margin: 0 auto;
}

.btn_group .btn-white {
    margin-top: -0.5rem;
}

.btn_group .link {
    display: flex;
    justify-content: center;
    margin-top: 2.4rem;
    font-size: 3rem;
    color: #2e2e2e;
}

.banner {
    background: #fff;
}

.banner_ttl {
    text-align: center;
    max-width: 43.7rem;
    margin: 0 auto 2.1rem;
}

.banner_inner {
    padding: 4rem 0 8.6rem;
}

.banner .js_carousel_banner {
    width: 50.4rem;
    margin: 0 auto;
}

.banner .slick-prev.slick-arrow {
    background: url(/kojin/jutaku/landing/tsumitate/images/banner_arr_l.png);
    background-size: cover;
    display: block;
    width: 5rem;
    height: 5rem;
    left: -9.3rem;
}

.banner .slick-prev.slick-arrow::before {
    content: "";
}

.banner .slick-next.slick-arrow {
    background: url(/kojin/jutaku/landing/tsumitate/images/banner_arr_r.png);
    background-size: cover;
    display: block;
    width: 5rem;
    height: 5rem;
    right: -9.3rem;
}

.banner .slick-next.slick-arrow::before {
    content: "";
}

.banner .slick-dots {
    bottom: -4.5rem;
}

.banner .slick-dots li button:before {
    display: none;
}

.banner .slick-dots li {
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background-color: #cccccc;
    margin: 0 1rem;
}

.banner .slick-dots li.slick-active {
    width: 5rem;
    border-radius: 5rem;
    background-color: #0ca26c;
}

.dream_home {
    padding-top: .1rem;
    text-align: center;
    border-top-left-radius: 8rem;
    border-top-right-radius: 8rem;
    background: url(/kojin/jutaku/landing/tsumitate/images/dream_home_bg.png) center center repeat;
}

.dream_home_txt {
    position: relative;
    z-index: 1;
}

.dream_home .inner {
    padding: 0;
}

.cost {
    background: #f0f9f1;
    margin-top: -1.8rem;
    padding: 5rem 0 8rem;
}

.cost .accordion { 
    background: #fff;
    border-radius: 3rem;
    overflow: hidden;
    padding-bottom: 0;
}

.cost .accordion:not(:last-child) {
    margin-bottom: 6rem;
}

.cost .accordionTitle {
    text-align: center;
    padding: 2.3rem 2rem 2rem;
    position: relative;
    background: #0ca26c;
    cursor: pointer;
}

.cost .accordionTitle::after {
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/accordion_arr.png);
    background-size: 100%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(-180deg);
    right: 2.8rem;
    width: 3.6rem;
    height: 1.8rem;
    transition: ease .4s;
}

.cost .accordionTitle.active::after {
    transform: translateY(-50%);
}

.cost .accordionContent {
    padding: 3rem 3rem 6rem;
}

.renovation_ttl {
    max-width: 37.4rem;
    margin: 0 auto;
}

.renovation_illust {
    text-align: center;
    margin: 0 -.5rem;
}

.renovation_cap {
    text-align: center;
    font-size: 1.8rem;
    margin-top: 1.1rem;
}

.renovation .piechart {
    background: url(/kojin/jutaku/landing/tsumitate/images/renovation_piechart.png) center bottom/cover no-repeat;
    border-radius: 2rem;
    padding: 3rem;
    margin-top: 6.2rem;
}

.renovation .piechart_ttl {
    text-align: center;
    margin: 0 auto 2.6rem;
    max-width: 33.6rem;
}

.renovation .piechart_ttl_dec {
    position: relative;
}

.renovation .piechart_ttl_dec::after {
    position: absolute;
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/renovation_piechart_ttl_dec.png) center center/contain no-repeat;
    width: 5.9rem;
    height: 6.8rem;
    right: -9.4rem;
    bottom: 1.2rem;
}

.renovation .piechart_box {
    max-width: 36rem;
    width: 100%;
    margin: 0 0 0 auto;
    background: #fff;
    padding: 2.5rem 3rem;
    border-radius: 2rem;
    position: relative;
}

.renovation .piechart_box::before {
    position: absolute;
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/renovation_piechart_arr.png) center center/contain no-repeat;
    width: 5rem;
    height: 5.1rem;
    left: -2.1rem;
    top: 6.8rem;

}

.renovation .piechart_txt01 {
    font-size: 2.8rem;
    font-weight: bold;
    color: #f7920e;
    line-height: 1.357;
}

.renovation .piechart_txt02 {
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.545;
}

.renovation .individual {
    margin-top: 6rem;
}

.renovation .individual_ttl {
    margin-bottom: 1.4rem;
}

.renovation .individual_flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #dcf3e7;
    border-radius: 2rem;
    padding: 1.6rem 2.2rem 1.5rem;
    min-height: 12rem;
}

.renovation .individual_flex:not(:last-child) {
    margin-bottom: 2rem;
}

.renovation .individual_flex:nth-child(1) .individual_illust {
    max-width: 6.5rem;
}
.renovation .individual_flex:nth-child(1) .individual_price {
    max-width: 22rem;
}
.renovation .individual_flex:nth-child(2) .individual_illust {
    max-width: 7.9rem;
}
.renovation .individual_flex:nth-child(2) .individual_price {
    max-width: 26.2rem;
}
.renovation .individual_flex:nth-child(3) .individual_illust {
    max-width: 8.2rem;
}
.renovation .individual_flex:nth-child(3) .individual_price {
    max-width: 26.8rem;
}
.renovation .individual_flex:nth-child(4) .individual_illust {
    max-width: 8.7rem;
}
.renovation .individual_flex:nth-child(4) .individual_price {
    max-width: 24.5rem;
}

.renovation .individual_list {
    margin-bottom: 1.4rem;
}

.renovation .individual_txt {
    font-size: 3rem;
    font-weight: bold;
    margin-right: auto;
    margin-left: 1.5rem;
    line-height: 1.467;
}

.cost_flex {
    display: flex;
}

.note_list > li {
    font-size: 1.8rem;
    font-weight: 500;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 1.444;
}

.cost_note_txt {
    display: inline-flex;
    line-height: 1.444;
    font-size: 1.8rem;
    font-weight: 500;
}

.cost_note_txt > *:first-child {
    flex-shrink: 0;
    margin-right: 1rem;
}

.renovation .voice {
    margin: 8.3rem 0 2rem;
}

.renovation .voice_ttl {
    margin-bottom: 1.3rem;
}

.renovation .voice_box {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    background: #fff1cf;
    max-width: 55rem;
    border-radius: 2rem;
    padding: 2.5rem 3.3rem;
}

.renovation .voice_box:not(:last-child) {
    margin-bottom: 2rem;
}

.renovation .voice_box:nth-child(2n) {
    flex-direction: row-reverse;
    margin-left: auto;
}

.renovation .voice_illust {
    flex-shrink: 0;
    padding: .5rem 0;
}

.renovation .voice_box:nth-child(1) .voice_illust {
    max-width: 14.5rem;
}
.renovation .voice_box:nth-child(2) .voice_illust {
    max-width: 16.1rem;
}
.renovation .voice_box:nth-child(3) .voice_illust {
    max-width: 21.7rem;
}

.renovation .voice_txt {
    font-size: 2.2rem;
    line-height: 1.545;
    font-weight: 500;
    margin-right: 1rem;
}

.renovation .voice_box:nth-child(2n) .voice_txt {
    margin-left: 1rem;
    margin-right: unset;
}

.cost_btn {
    margin-top: 6rem;
}

.cost_lead {
    text-align: center;
}

.cost_lead_illust {
    margin: 1.6rem auto 3.2rem;
    max-width: 54.4rem;
}

.cost_lead_txt {
    font-size: 3.4rem;
    line-height: 1.471;
    text-align: center;
    font-weight: bold;
}

.cost_lead_txt .txt_l {
    font-size: 1.5em;
    line-height: .8;
}

.cost_conclude {
    border: .4rem #f7920e solid;
    border-radius: 2rem;
    padding: 2rem 1.5rem 2.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cost_conclude_illust {
    flex-shrink: 0;
    max-width: 17.3rem;
}

.cost_conclude_txt {
    font-size: 2.8rem;
    margin-left: 2rem;
    line-height: 1.429;
    font-weight: 500;
}

.education_ttl {
    max-width: 24.9rem;
    margin: 0 auto;
}

.education_tbl {
    margin: 5.3rem 0 1.4rem;
}

.education .average {
    margin-bottom: 5.7rem;
}

.education .average_ttl {
    margin-top: 5.7rem;
}

.education .average_sub {
    font-size: 3.2rem;
    font-weight: bold;
    text-align: center;
    margin: 2rem auto;
}

.education .average_tbl {
    margin-bottom: 1.4rem;
}

.secondlife_ttl {
    max-width: 31.9rem;
    margin: 0 auto;
}

.secondlife .cost_lead_illust {
    max-width: 35.2rem;
    transform: translateX(-1rem);
}

.secondlife .monthly_ttl {
    margin-top: 6rem;
}

.secondlife .monthly_txt {
    font-size: 1.8rem;
    font-weight: 500;
    text-align: right;
    margin-bottom: 2.1rem;
}

.secondlife .monthly_tbl {
    margin-bottom: 1.4rem;
}

.secondlife .average_ttl {
    margin: 5.7rem 0 1.2rem;
}

.secondlife .average_tbl {
    margin-bottom: 1.1rem;
}

.secondlife .retirement_ttl {
    font-size: 3.4rem;
    font-weight: bold;
    line-height: 1.471;
    text-align: center;
    margin: 2.1rem 0 5.2rem;
}

.secondlife .retirement_ttl .txt_dec_line01 {
    margin-bottom: 1.4rem;
}

.secondlife .retirement_ttl .txt_l {
    font-size: 1.5em;
    line-height: .8;
}

.secondlife .retirement {
    margin-bottom: 5.7rem;
}

.secondlife .retirement_chart {
    margin-bottom: 1.4rem;
}

.txt_dec_line01 {
    font-size: 3.2rem;
    line-height: 1;
    font-weight: bold;
    position: relative;
    display: inline-block;
    margin-bottom: 2rem;
}

.txt_dec_line01::before {
    content: '';
    position: absolute;
    top: .2rem;
    left: -2.7rem;
    height: 3.5rem;
    width: .4rem;
    background: #0ca26c;
    border-radius: .4rem;
    transform: rotate(-30deg);
}

.txt_dec_line01::after {
    content: '';
    position: absolute;
    top: .2rem;
    right: -2.7rem;
    height: 3.5rem;
    width: .4rem;
    background: #0ca26c;
    border-radius: .4rem;
    transform: rotate(30deg);
}

.txt_dec_line01.line_orange::before {
    background: #f7920e;
}

.txt_dec_line01.line_orange::after {
    background: #f7920e;
}

.txt_dec_line01.line_white {
    font-size: 3.4rem;
    color: #fff;
}

.txt_dec_line01.line_white::before {
    background: #fff;
}

.txt_dec_line01.line_white::after {
    background: #fff;
}

.point .intro {
    background: url(/kojin/jutaku/landing/tsumitate/images/point_intro_bg.png) center center repeat;
}

.point .intro_inner {
    position: relative;
    padding: 5.5rem 4rem 0;
}

.point .intro_inner::after {
    position: absolute;
    bottom: -8rem;
    left: 0;
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/point_intro_bg01.png) center center/contain no-repeat;
    height: 8rem;
    width: 100%;
}

.point .intro_flex {
    display: flex;
    align-items: center;
    justify-content: center;
}

.point .intro_flex:nth-child(2n) {
    flex-direction: row-reverse;
}

.point .intro_txt {
    font-size: 3.2rem;
    line-height: 1.438;
    font-weight: bold;
    text-align: center;
    background: url(/kojin/jutaku/landing/tsumitate/images/point_intro_dec01.png) center center/contain no-repeat;
    max-width: 66.6rem;
    padding: 6rem 23rem 6rem 6rem;
    margin: 0 auto;
}

.point .intro_txt:nth-child(2n) {
    background: url(/kojin/jutaku/landing/tsumitate/images/point_intro_dec02.png) center center/contain no-repeat;
    max-width: 63.1rem;
    padding: 6rem 6rem 5rem 21.5rem;
    transform: translateX(1rem);
}

.point_lead {
    text-align: center;
    max-width: 53.8rem;
    margin: 12.4rem auto 5.5rem;
}

.point_bg {
    background: #0ca26c;
    padding: 4rem 0 6rem;
}

.point_ttl {
    text-align: center;
    margin: 0 auto 2.9rem;
    max-width: 58.1rem;
}

.point_num {
    max-width: 6rem;
}

.point_box {
    background: #fff;
    border-radius: 2rem;
    display: flex;
    padding: 1.2rem 2rem 1.5rem;
    min-height: 12.2rem;
    align-items: center;
}

.point_box:not(:last-child) {
    margin-bottom: 2.1rem;
}

.point_txt {
    font-size: 3.8rem;
    font-weight: bold;
    line-height: 1.158;
    margin-left: 2rem;
}

.point_txt .sub {
    font-size: 3.2rem;
    display: inline-block;
    margin-bottom: .5rem;
}

.point_txt .txt_l {
    font-size: 2em;
    line-height: .7;
}

.simulation .intro {
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_intro_bg.png) center bottom repeat;
}

.simulation .intro_inner {
    position: relative;
    padding: 4.1rem 0 0;
}

.simulation .intro_inner::after {
    position: absolute;
    bottom: -8rem;
    left: 0;
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_intro_bg.png) center 2px repeat;
    clip-path: polygon(
        0% 0%,
        100% 0%,
        100% 2px,
        50% 100%,
        0% 2px
    );
    height: calc(8rem + 2px);
    width: 100%;
}

.simulation .intro_txt {
    font-size: 3.6rem;
    font-weight: bold;
    text-align: center;
    background: #fff;
    border-radius: 2rem;
    padding: 1.4rem 2rem 1.8rem;
    line-height: 1.222;
    position: relative;
    max-width: 63rem;
    margin: 0 auto 2.3rem;
}

.simulation .intro_txt::after {
    position: absolute;
    bottom: -2rem;
    left: calc(50% - 2.5rem);
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_intro_arr.png) center center/contain no-repeat;
    height: 3.6rem;
    width: 5rem;
}

.simulation .intro_illust {
    text-align: center;
    max-width: 39.9rem;
    margin: 0 auto;
}

.simulation .chart-tabs {
    margin: 4rem 0 5rem;
    position: relative;
    z-index: 0;
}

.simulation .chart-tabs::after {
    position: absolute;
    bottom: -4rem;
    left: calc(50% - 7.4rem);
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_tab_arr.png) center center/contain no-repeat;
    height: 7rem;
    width: 14.8rem;
    z-index: -1;
}

.simulation .chart-tabs .tab-ttl {
    width: 61.8rem;
    margin: 0 auto;
}

.simulation .tab_button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    margin-top: 2.2rem;
}

.simulation .tab_button .button {
    background: #c0c0c0;
    font-size: 2.6rem;
    line-height: 1.154;
    font-weight: bold;
    color: #fff;
    text-align: center;
    flex: 1;
    padding: 1.55rem 2.6rem;
    border-top-left-radius: 2rem;
    border-top-right-radius: 2rem;
    cursor: pointer;
}

.simulation .tab_button .button.active {
    color: #0ca26c;
    background: #fff;
    border: .4rem solid #0ca26c;
    padding: 1.55rem 2.2rem;
    border-bottom: 0;
    position: relative;
}

.simulation .tab_button .button.active::after {
    content: '';
    position: absolute;
    bottom: -.4rem;
    left: 0;
    width: 100%;
    height: .4rem;
    background-color: #fff;
    z-index: 1;
}

.simulation .tab_button .button span {
    font-size: 4.4rem;
}

.simulation .tab_content {
    margin-top: -.2rem;
}

.simulation .tab_content .tab_content-inner {
    background-color: #fff;
    border: .4rem solid #0ca26c;
    border-bottom-left-radius: 2rem;
    border-bottom-right-radius: 2rem;
    padding: 3.2rem 2.3rem 3.8rem;
    display: none;
}

.simulation .tab_content .tab_content-inner.active {
    display: block;
}

.simulation .tab_content .tab_content-txt {
    font-size: 3.4rem;
    line-height: 1.412;
    font-weight: bold;
    text-align: center;
    letter-spacing: .1rem;
    margin-bottom: 2.4rem;
}

.simulation .tab_content .tab_content-ttl {
    text-align: center;
    margin: 0 auto;
}

.simulation .tab_content-inner:nth-child(1) .tab_content-ttl {
    max-width: 47.1rem;
}
.simulation .tab_content-inner:nth-child(2) .tab_content-ttl {
    max-width: 54.9rem;
}
.simulation .tab_content-inner:nth-child(3) .tab_content-ttl {
    max-width: 54rem;
}

.simulation .tab_content .tab_content-chart {
    margin: 3.2rem auto 0;
    text-align: center;
}

.simulation .tab_content .tab_content-note {
    font-size: 1.8rem;
    line-height: 1.444;
    margin-top: 1.4rem;
    color: #2e2e2e;
    padding-left: 1.2rem;
}

.simulation .tab_content .indent-list {
    font-size: 1.8rem;
    line-height: 1.444;
    font-weight: 500;
    color: #2e2e2e;
    padding-left: .3rem;
    letter-spacing: .15rem;
}

.simulation .tab_content .indent-list li {
    padding-left: 1.8rem;
    text-indent: -1.8rem;
}

.simulation_con {
    padding: 14rem 0 8rem;
}

.simulation_conclude {
    text-align: center;
    max-width: 64.5rem;
    margin: 0 auto;
    transform: translateX(0.7rem);
}

.simulation_btn {
    max-width: 69rem;
    margin-top: 5.7rem;
}

.follow {
    background: #f0f9f1;
    padding: 4rem 0 8rem;
}

.follow_ttl {
    max-width: 46rem;
    margin: 0 auto;
}

.follow_bnr {
    border-radius: 3rem;
    border: .4rem solid #0ca26c;
    position: relative;
    z-index: 0;
    margin: 3.5rem 0 4.1rem;
}

.follow_bnr_illust {
    max-width: 13.6rem;
}

.follow_bnr_inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2.1rem 3.6rem 0;
    background: #fff;
    border-radius: 3rem;
}

.follow_bnr::after {
    position: absolute;
    bottom: -3.4rem;
    left: calc(50% - 7.4rem);
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_tab_arr.png) center center/contain no-repeat;
    height: 7rem;
    width: 14.8rem;
    z-index: -1;
}

.follow_bnr_lbl {
    background: #0ca26c;
    font-size: 3.2rem;
    font-weight: bold;
    padding: .4rem 3.3rem 1rem;
    color: #fff;
    border-bottom-left-radius: 1.5rem;
    border-bottom-right-radius: 1.5rem;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.follow_bnr_txt {
    font-size: 3.6rem;
    font-weight: bold;
    line-height: 1.389;
    margin-top: 1.5rem;
}

.follow .problem + .follow_bnr {
    margin: 6rem 0 4.1rem;
}

.follow .problem + .follow_bnr .follow_bnr_illust {
    max-width: 15.4rem;
}

.follow .problem {
    background: #fff;
    border-radius: 3rem;
    padding: 3.5rem 3rem 6rem;
}

.follow .problem_ttl {
    max-width: 49.7rem;
    margin: 0 auto;
}

.follow .problem_flex_illust {
    margin: -.6rem 0 0 1.8rem;
    max-width: 28.2rem;
}

.follow .problem_flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: 4.3rem;
}

.follow .problem_txtbox_wrap {
    max-width: 31rem;
    width: 100%;
}

.follow .problem_txtbox {
    background: #0ca26c;
    color: #fff;
    border-radius: 3.5rem;
    font-size: 3rem;
    font-weight: bold;
    text-align: center;
    padding: 2rem;
}

.follow .problem_txtbox:not(:last-child) {
    margin-bottom: 2rem;
}

.follow .problem_graybox {
    background: #e9e9e9;
    border-radius: 1.5rem;
    font-size: 2.8rem;
    text-align: center;
    font-weight: bold;
    padding: 1.7rem 2rem;
    margin-bottom: 5.9rem;
}

.follow .problem_graybox small {
    font-size: 1.8rem;
    font-weight: 500;
}

.follow .problem_greenbox {
    background: #dcf3e7;
    border-radius: 2rem;
    padding: 2.6rem 2rem 3.4rem;
}

.follow .problem_greenbox_ttl {
    margin: 0 auto 2.1rem;
    max-width: 42.9rem;
}

.follow .problem_link {
    text-align: right;
    margin-top: 1.4rem;
}

.follow .problem_btn {
    margin-top: 6.1rem;
}

.follow .problem_link > a {
    color: #0ca26c;
    font-size: 2.2rem;
    font-weight: 500;
    text-underline-offset: .7rem;
}

.follow .problem_investment {
    margin-top: 3.7rem;
    position: relative;
}

.follow .problem_investment_btn {
    max-width: 41rem;
    position: absolute;
    bottom: 6.9rem;
    right: 3rem;
    display: block;
}

.follow .step_wrap {
    position: relative;
    z-index: 0;
}

.follow .follow_illust_b {
    margin: 6.1rem auto 6.2rem;
    max-width: 57.8rem;
}

.follow .step {
    background: #dcf3e7;
    border-radius: 2rem;
    padding-bottom: 2.2rem;
}

.follow .step_wrap + .step_wrap {
    margin-top: 6rem;
}

.follow .step_wrap:has(+ .step_wrap)::after {
    position: absolute;
    bottom: -3rem;
    left: calc(50% - 7.4rem);
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/simulation_tab_arr.png) center center/contain no-repeat;
    height: 7rem;
    width: 14.8rem;
    z-index: -1;
}

.follow .step_inner {
    padding: 2.4rem 2rem 3.8rem;
    position: relative;
}

.follow .step_inner:not(:last-child) {
    border-bottom: .4rem solid #fff;
}

.follow .step_lbl {
    position: absolute;
    top: 0;
    left: 3rem;
    max-width: 10rem;
}

.follow .step_ttl {
    font-size: 3rem;
    font-weight: bold;
    padding-left: 13.3rem;
    line-height: 1.4;
    color: #0ca26c;
    margin-bottom: 1.4rem;
}

.follow .step_ttl .sub {
    font-size: .8em;
    color: #2e2e2e;
}

.follow .step_flex {
    display: flex;
    justify-content: space-between;
    padding: 1.7rem 0 0 1rem;
}

.follow .step_num {
    margin: .1rem 0 .8rem;
    max-width: 5rem;
}

.follow .step .note_list > li {
    font-weight: bold;
} 

.follow .step_illust.it01 {
    max-width: 29.9rem;
    margin: 0;
}

.follow .step_illust {
    flex-shrink: 0;
    max-width: 27rem;
    margin: 0 1.1rem;
    text-align: center;
}

.follow .step_txt {
    font-size: 2.4rem;
    line-height: 1.583;
    font-weight: 500;
    letter-spacing: .08em;
    margin-bottom: .7rem;
}

.follow .step_txt .arr {
    display: block;
    width: 70%;
    text-align: center;
}

.follow .step_txt .arr.it02 {
    width: 90%;
}

.follow .step_txt .ico {
    display: inline-flex;
    margin: 0 .3rem;
    transform: translateY(.35rem);
    max-width: 2.6rem;
}

.saving_bg {
    background: #0ca26c;
    padding: 5.8rem 0 0;
}

.saving_bg .inner {
    position: relative;
    padding-bottom: 3.3rem;
}

.saving_bg .inner::after {
    position: absolute;
    bottom: -8rem;
    left: 0;
    content: '';
    background: #0ca26c;
    clip-path: polygon(
        0% 0%,
        100% 0%,
        100% 2px,
        50% 100%,
        0% 2px
    );
    height: calc(8rem + 2px);
    width: 100%;
}

.saving_think {
    padding: 8.1rem 0 14.3rem;
}

.saving_think_illust {
    margin-bottom: -.4rem;
}

.saving_lead {
    padding: 5.6rem 0 0;
}

.saving_lead_ttl {
    max-width: 57.7rem;
    margin: 0 auto;
}

.saving_ttl {
    max-width: 54.9rem;
    margin: 0 auto;
}

.saving_box {
    background: #fff;
    border-radius: 3rem;
    padding: 2rem 2rem 2.9rem;
    display: flex;
    margin: 3rem 0 4.6rem;
}

.saving_box_illust {
    flex-shrink: 0;
    max-width: 13rem;
}

.saving_box_txt {
    font-size: 3rem;
    font-weight: 500;
    line-height: 1.467;
    margin: .5rem 0 0 2rem;
}

.saving_box_txt .txt_orange {
    font-weight: bold;
}

.saving_sub {
    margin-bottom: 1rem;
}
.saving_boxlight {
    font-size: 3rem;
    line-height: 1.467;
    font-weight: 500;
    padding: 2.9rem 3rem;
    border-radius: 2rem;
    background: #dcf3e7;
}

.saving_boxlight .txt_green {
    font-weight: bold;
}

.saving_step {
    margin-bottom: 3.5rem;
}

.saving_cta {
    text-align: center;
    border-bottom-left-radius: 8rem;
    border-bottom-right-radius: 8rem;
    background: url(/kojin/jutaku/landing/tsumitate/images/saving_cta_bg.png) center center repeat;
    margin-bottom: 10rem;
}

.saving_cta_txt {
    max-width: 57.5rem;
    margin: 0 auto;
}

.saving_cta_inner {
    position: relative;
    padding-top: 6.9rem;
    padding-bottom: 5.9rem;
}

.precautions .accordionTitle {
    background-color: #0ca26c;
}
.precautions .accordionTitle .inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    padding: 3.6rem 3rem;
    cursor: pointer;
    position: relative;
}

.precautions .accordionTitle .inner::after {
    content: '';
    background: url(/kojin/jutaku/landing/tsumitate/images/accordion_arr.png);
    background-size: 100%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(-180deg);
    right: 2.8rem;
    width: 3.6rem;
    height: 1.8rem;
    transition: ease .4s;
}

.precautions .accordionTitle.active .inner::after {
    transform: translateY(-50%);
}

.precautions .accordionTitle .accordionTxt {
    font-size: 4.8rem;
    font-weight: bold;
    color: #fff;
    text-align: center;
    width: unset;
}

.precautions .accordionContent {
    padding: 3.1rem 0 12.6rem;
}

.precautions_ttl01 {
    font-size: 3rem;
    font-weight: bold;
    color: #0ca26c;
    border-bottom: .4rem solid #0ca26c;
    line-height: 1.5;
    padding-bottom: .4rem;
    margin-bottom: 2.5rem;
}

.precautions_list > li {
    list-style: none;
    font-weight: 500;
    font-size: 2rem;
    line-height: 1.5;
    position: relative;
    padding-left: 1.2em;
    letter-spacing: .05em;;
}

.precautions_list > li::before {
    content: "◯";
    position: absolute;
    top: 0;
    left: 0;
}

.precautions_list .txt_underline {
    text-decoration: underline;
    text-underline-offset: .5rem;
}

.precautions_list + .precautions_ttl01 {
    margin-top: 4.6rem;
}

.precautions_txt {
    font-size: 2rem;
    line-height: 1.5;
    padding-left: 1rem;
    margin-top: 7rem;
}

.txt_orange {
    color: #f7920e !important;
}

.txt_green {
    color: #0ca26c !important;
}
/* ============================================ */

.btn_fixed {
    display: none;
    position: sticky;
    width: 100%;
    bottom: 0;
    padding: 2.4rem 0 2rem;
    background-color: rgba(58, 179, 135, 0.8);
    z-index: 99;
    opacity: 1;
    visibility: visible;
    transition: opacity .4s ease;
}

.btn_fixed.is-hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.btn_fixed .inner {
    display: flex;
    align-items: center;
    justify-content: center;
}

.btn_fixed a {
    display: block;
}

.btn_fixed .btn {
    width: 34.8rem;
    margin-left: auto;
}

.btn_fixed .btn.btn-white {
    margin-left: unset;
    margin-right: auto;
}

.btn_fixed .link {
    display: flex;
    justify-content: center;
    font-size: 3rem;
    color: #fff;
    margin-top: 1.2rem;
}