@charset "UTF-8";

/*!
Theme Name: ほけんサプリ
Template:   cocoon-master
*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

html,
body,
div,
span,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
address,
del,
em,
img,
small,
strong,
sub,
i,
dl,
dt,
dd,
ol,
ul,
li,
form,
label,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
figcaption,
figure,
footer,
header,
menu,
nav,
section,
time,
mark,
audio,
video {
    background: transparent;
    border: 0;
    font-size: 100%;
    letter-spacing: 0.5px;
    margin: 0;
    outline: 0;
    padding: 0;
    vertical-align: baseline;
}

*,
::before,
::after {
    box-sizing: border-box;
    border-style: solid;
    border-width: 0;
}

a {
    text-decoration: none;
    transition: .25s;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
menu,
nav,
section {
    display: block;
}

nav,
ul,
ol {
    list-style: none;
}

del {
    text-decoration: line-through;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

img {
    height: auto;
    max-width: 100%;
    max-height: 100%;
    vertical-align: bottom;
    width: 100%;
}

input,
select {
    vertical-align: middle;
}

li {
    letter-spacing: normal;
    list-style-type: none;
}

html {
    font-size: 62.5%;
}

section {
    overflow: hidden;
}

@font-face {
    font-family: 'LINE';
    src: url('./fonts/LINESeedJP_OTF_Rg.woff') format('woff');
    font-display: swap;
    font-weight: 400;
}

@font-face {
    font-family: 'LINE';
    src: url('./fonts/LINESeedJP_OTF_Bd.woff') format('woff');
    font-display: swap;
    font-weight: 700;
}

@font-face {
    font-family: 'LINE';
    src: url('./fonts/LINESeedJP_OTF_Eb.woff') format('woff');
    font-display: swap;
    font-weight: 800;
}

.noto-sans-jp-<uniquifier> {
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: <weight>;
    font-style: normal;
}

body {
    color: #3C3C3C;
    font-family: 'LINE', 'Noto Sans JP', sans-serif;
    font-size: 1.6rem;
    line-height: 1;
    font-weight: 400;
    text-align: justify;
    width: 100%;
    height: 100%;
}

p {
    line-height: 2;
}

.flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.pc {
    display: block;
}

.sp {
    display: none;
}

.wrap {
    max-width: 1040px;
    margin: auto;
}

.cont_ttl {
    font-size: 3.2rem;
    text-align: center;
    position: relative;
    line-height: 1.4;
}

.cont_ttl span {
    color: #06CFAA;
}

.cont_ttl::before {
    content: "";
    position: absolute;
    bottom: -45px;
    left: 0;
    right: 0;
    margin: auto;
    width: 55px;
    height: 25px;
    background: linear-gradient(90deg, #06CFAA 50%, #04BB9A 50%);
    border: solid 4px #fff;
    border-radius: 40px;
}

header {
    position: fixed;
    width: 100%;
    left: 0;
    top: 50px;
    z-index: 99;
}

header img {
    max-width: 185px;
    margin-left: 3%;
}

#mv {
    padding: 90px 0 0;
    background: repeat center / contain url(./img/mv_bg.jpg);
}

.mv_l {
    width: 45%;
    margin: 40px 0 0;
}

.mv_l h1 {
    font-size: 4.6rem;
    line-height: 1.7;
    margin: 0 0 20px;
}

.mv_l p {
    font-size: 1.7rem;
    font-weight: 500;
    font-family: "Noto Sans JP", sans-serif;
}

.mv_r {
    width: 50%;
}

.mv_point {
    max-width: 840px;
    position: relative;
    top: -40px;
    margin: auto;
}

.cta {
    position: relative;
    padding: 50px 0;
    text-align: center;
    z-index: 0;
    background: #FFFFF7;
}

.mv_cta {
    padding: 0 0 50px;
    background: transparent;
}

.cta::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: #0EDCB6;
    z-index: -2;
    transform-origin: center;
    transition: width .8s ease, border-radius 0.8s ease;
}

.cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: #06CFAA;
    z-index: -1;
    transform-origin: center;
    transition: width .5s ease, border-radius 0.6s ease;
}

.cta.animate::before {
    width: 75%;
    border-radius: 30px;
}

.cta.animate::after {
    width: 75%;
    border-radius: 30px;
    transition-delay: 0.2s;
}

.cta .wrap {
    position: relative;
}

.cta .wrap::before {
    content: "";
    position: absolute;
    bottom: -55px;
    left: 0;
    margin: auto;
    width: 100px;
    height: 160px;
    background: no-repeat center / contain url(./img/cta_l.png);
}

.cta .wrap::after {
    content: "";
    position: absolute;
    bottom: -55px;
    right: 0;
    margin: auto;
    width: 100px;
    height: 160px;
    background: no-repeat center / contain url(./img/cta_r.png);
}

.mv_cta .wrap::before,
.mv_cta .wrap::after {
    display: none;
}

.cta h2 {
    color: #fff;
    font-size: 3.6rem;
    line-height: 1.4;
}

.cta h2 strong {
    color: #FFF420;
    font-size: 5.2rem;
}

.cta p {
    font-size: 1.9rem;
    color: #fff;
    font-weight: 700;
    margin: 30px 0 0;
}

.cta p span {
    color: #FFF420;
}

.cta a {
    display: block;
    max-width: 400px;
    min-width: 300px;
    color: #fff;
    font-size: 2.8rem;
    font-weight: 700;
    border: solid 4px #fff;
    border-radius: 60px;
    box-shadow: 0 4px 20px #00A587;
    background: #F49D3A;
    padding: 30px 0;
    margin: 30px auto 50px;
}

.cta a:hover {
    background: #fff;
    color: #F49D3A;
    border: solid 4px #F49D3A;
}

.cta ul {
    width: 70%;
    margin: auto;
}

.cta ul li {
    width: 30%;
    position: relative;
}

.cta ul li::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 30px;
    height: 30px;
    background: no-repeat center / contain url(./img/check.png);
}

.cta ul li {
    color: #fff;
    line-height: 1;
    font-size: 2.8rem;
    font-weight: 700;
    text-align: left;
    padding: 0 0 0 6%;
}

.cta ul li span {
    color: #FFF420;
}

#feature {
    background: #FFFFF7;
}

.issue {
    background: #EBFCFF;
    padding: 80px 0 0;
    position: relative;
    text-align: center;
    z-index: 0;
}

.issue:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 15vw 50vw 0 50vw;
    border-color: #EBFCFF transparent transparent transparent;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: -1;
}

.issue h2 {
    max-width: 730px;
    margin: auto;
}

.issue ul {
    margin: 70px 0 100px;
}

.issue ul li {
    width: 23.5%;
    background: #fff;
    border: solid 4px #3C3C3C;
    border-radius: 20px;
    padding: 35px 1% 0;
    display: flex;
    flex-direction: column;
}

.issue ul li p {
    font-size: 2rem;
    line-height: 1.6;
    font-weight: 700;
    flex-grow: 1;
}

.issue ul li p span {
    color: #5F92C7;
}

.issue ul li img {
    position: relative;
    bottom: -30px;
}

.issue_txt {
    font-size: 3.6rem;
    font-weight: 700;
    position: absolute;
    bottom: -25%;
    left: 0;
    right: 0;
}

.solution {
    padding: 150px 0 120px;
}

.solution h2 {
    text-align: center;
    font-size: 2.8rem;
    color: #06CFAA;
    position: relative;
    width: fit-content;
    margin: auto;
    line-height: 1.6;
}

.solution h2::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -55%;
    margin: auto;
    width: 100%;
    height: 100%;
    background: no-repeat center / contain url(./img/solution_l.png);
}

.solution h2::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: -55%;
    margin: auto;
    width: 100%;
    height: 100%;
    background: no-repeat center / contain url(./img/solution_r.png);
}

.issue_logo {
    display: block;
    max-width: 430px;
    margin: 20px auto 80px;
}

.solution ul {
    margin: 0 0 90px;
}

.solution ul li {
    width: 24%;
    background: #06CFAA;
    border-radius: 20px;
    padding: 50px 0 60px;
    text-align: center;
    position: relative;
    align-content: center;
}

.solution ul li p {
    color: #fff;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.8;
}

.solution ul li strong {
    font-size: 4.5rem;
    color: #FFF462;
}

.point {
    font-size: 2.1rem;
    color: #FFF462;
    font-weight: 700;
    background: linear-gradient(90deg, #06CFAA 50%, #04BB9A 50%);
    border: solid 4px #fff;
    border-radius: 40px;
    max-width: 70%;
    line-height: 1.8;
    margin: auto;
    position: absolute;
    top: -30px;
    left: 0;
    right: 0;
}

.point span {
    font-size: 2.8rem;
}

.solution table {
    margin: 100px 0 0;
    position: relative;
}

.solution table::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    background: #FFFFF7;
    width: 30px;
    height: 30px;
    border-radius: 50%;
}

.solution table td {
    width: 50%;
    border: none;
}

.solution table tr:nth-child(1) td:nth-child(1) {
    border-right: solid 2px #06CFAA;
    border-bottom: solid 2px #06CFAA;
}

.solution table tr:nth-child(2) td:nth-child(2) {
    border-left: solid 2px #06CFAA;
    border-top: solid 2px #06CFAA;
}

.solution table tr:nth-child(1) td:nth-child(1) {
    padding: 0 3% 30px 0;
}

.solution table tr:nth-child(1) td:nth-child(2) {
    padding: 0 0 30px 3%;
}

.solution table tr:nth-child(2) td:nth-child(1) {
    padding: 30px 3% 0 0;
}

.solution table tr:nth-child(2) td:nth-child(2) {
    padding: 30px 0 0 3%;
}

.solution table tr {
    background: transparent;
}

.feature_head {
    display: flex;
    align-items: center;
}

.feature_head h4 {
    font-size: 2.3rem;
    display: inline-block;
    line-height: 1.6;
    margin-left: 3%;
}

.feature_head h4 span {
    color: #fff;
    background: #06CFAA;
    line-height: 1.2;
    display: inline-block;
    font-size: 2.8rem;
}

.feature_head img {
    display: inline-block;
    max-width: 17%;
}

.solution table td p {
    margin: 20px 0 0;
}

#future {
    padding: 0 0 110px;
}

#future ul {
    position: relative;
    top: -90px;
}

#future ul li {
    margin: 0 0 40px;
    align-items: center;
}

#future ul li:nth-child(even) {
    flex-direction: row-reverse;
}

.future_l {
    width: 40%;
}

.future_r {
    width: 50%;
}

.future_r h3 {
    font-size: 3rem;
    color: #06CFAA;
    margin: 0 0 30px;
    line-height: 1.4;
}

.future_r p {
    font-size: 1.8rem;
}

.future_txt {
    font-size: 3rem;
    font-weight: 700;
    text-align: center;
}

.future_txt span {
    color: #FFAD20;
}

.future_txt strong {
    color: #06CFAA;
}

#step {
    padding: 100px 0;
    background: #E9FCF9;
}

#step h2 {
    font-size: 4rem;
    text-align: center;
}

#step h2 span {
    font-size: 5.6rem;
    color: #06CFAA;
}

#step img {
    max-width: 210px;
}

.step_txt {
    text-align: center;
    font-size: 2.6rem;
    margin: 30px auto 70px;
    font-weight: 700;
}

#step ul li {
    background: #fff;
    border: solid 6px #06CFAA;
    border-radius: 630px;
    padding: 50px 5% 70px 10%;
    margin: 0 0 80px auto;
    position: relative;
    width: 90%;
}

#step ul li:nth-child(4) {
    border: dashed 6px #EF82B4;
}

#step ul li::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -50%;
    margin: auto;
    width: 100%;
    height: 50%;
}

#step ul li:nth-child(1):before {
    background: no-repeat center / contain url(./img/step1.png);
}

#step ul li:nth-child(2):before {
    background: no-repeat center / contain url(./img/step2.png);
}

#step ul li:nth-child(3):before {
    background: no-repeat center / contain url(./img/step3.png);
}

#step ul li:nth-child(4):before {
    background: no-repeat center / contain url(./img/step4.png);
}

#step ul li::after {
    content: "";
    position: absolute;
    bottom: -55%;
    left: 0;
    margin: auto;
    width: 5px;
    height: 200px;
    background: no-repeat center / contain url(./img/step_line.png);
}

#step ul li:nth-child(3):after {
    background: no-repeat center / contain url(./img/step_line2.png);
}

#step ul li:nth-child(4):after {
    display: none;
}

.step_l {
    width: 15%;
}

.step_r {
    width: 80%;
}

.step_r h3 {
    font-size: 3.3rem;
    color: #06CFAA;
    margin: 0 0 30px;
    line-height: 1.4;
}

#step ul li:nth-child(4) h3 {
    color: #EF82B4;
}

.step_r p {
    font-size: 2.2rem;
}

#step ul li h4 {
    background: #04BB9A;
    border-radius: 50px;
    color: #fff;
    font-size: 1.6rem;
    width: 90%;
    margin: auto;
    font-weight: 700;
    padding: 20px 4%;
    position: absolute;
    bottom: -30px;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
}

#step ul li h4 strong {
    font-size: 2.8rem;
    padding: 0 5% 0 0;
}

#step ul li:nth-child(4) h4 {
    background: #EF82B4;
    font-size: 2rem;
}

#voice {
    padding: 100px 0;
}

#voice ul {
    margin: 100px 0 0;
}

#voice ul li {
    width: 31%;
    border: solid 1px #B7EFE5;
    border-radius: 24px;
    box-shadow: 0 4px 16px #C2F1E9;
    margin: 0 0 50px;
    padding: 20px 2% 30px;
}

#voice ul li img {
    max-width: 165px;
    margin: auto;
    display: block;
}

.profile {
    text-align: center;
    font-size: 1.4rem;
    background: #DDFAF4;
    border-radius: 12px;
    padding: 5px 0;
}

#voice ul li h3 {
    text-align: center;
    font-size: 1.9rem;
    line-height: 1.4;
    margin: 10px 0 10px;
}

.rating {
    text-align: center;
    font-size: 1.8rem;
    color: #FBBA62;
}

#voice ul li p {
    font-size: 1.4rem;
    margin: 10px 0 0;
}

#faq {
    background: #EBFCFF;
    padding: 100px 0;
}

#faq ul {
    margin: 110px 0 0;
}

#faq ul li {
    background: #fff;
    border: solid 1px #d9d9d9;
    margin: 0 0 20px;
    border-radius: 10px;
    padding: 0 3%;
}

.title {
    font-size: 2.3rem;
    line-height: 1.4;
    color: #595959;
    position: relative;
    display: block;
    font-weight: 700;
    padding: 30px 5%;
    cursor: pointer;
}

.title::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 30px;
    height: 30px;
    background: no-repeat center / contain url(./img/faq_q.png);
}

.title::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    width: 35px;
    height: 35px;
    background: no-repeat center / contain url(./img/faq_plus.png);
}

.toggle {
    display: none;
}

.title,
.answer {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s;
}

.toggle:checked+.title+.answer {
    max-height: 1800px;
    transition: all 1.5s;
}

.answer {
    max-height: 0;
    overflow: hidden;
    position: relative;
    padding: 0 5%;
}

.answer::before {
    content: "";
    position: absolute;
    top: 30px;
    left: 0;
    margin: auto;
    width: 30px;
    height: 30px;
    background: no-repeat center / contain url(./img/faq_a.png);
}

.answer p {
    font-size: 2rem;
    line-height: 1.6;
    margin: 30px 0;
}

#contact {
    padding: 100px 0;
}

footer {
    padding: 30px 0;
    background: #06CFAA;
}

footer p {
    font-size: 1.2rem;
    color: #fff;
    text-align: center;
}

.fadein {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.8s ease, transform 0.8s ease;
    will-change: opacity, transform;
}

.fadein.show {
    opacity: 1;
    transform: translateY(0);
}

.contact_page {
    padding: 200px 0 100px;
    background-color: #f1fffc;
    background-image: radial-gradient(circle, #afe9e7 .15rem, transparent .15rem);
    background-position: 0 0;
    background-size: 1rem 1rem;
}

header h1 img {
    max-width: 565px;
}

.contact_page h2 {
    text-align: center;
    font-size: 3.6rem;
    line-height: 1.6;
}

.contact_head {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.contact_head div {
    width: fit-content;
    margin: 0 0 0 3%;
}

.contact_head img {
    display: block;
    width: 10%;
    min-width: 90px;
}

.contact_head h2 {
    font-size: 2.8rem;
}

.contact_head p {
    text-align: center;
    font-size: 1.8rem;
    margin: 10px 0;
    line-height: 1.6;
}

.form_box {
    max-width: 960px;
    margin: 70px auto 60px;
    padding: 50px 9% 60px;
    background: #fff;
    border-radius: 2.8rem;
    box-shadow: 0px 4px 16px 0 rgb(6, 220, 181, .4);
}

.step0 h3 {
    text-align: center;
    font-size: 2.4rem;
    color: #06CFAA;
    margin: 0 0 40px;
}

.step0 ul li,
.step2 ul li {
    width: 47%;
}

.step2 ul li {
    margin: 0 0 20px;
}

input[type="radio"],
input[type="checkbox"] {
    display: none;
}

.c_btn {
    border: solid 2px #06CFAA;
    border-radius: 2rem;
    text-align: center;
    font-weight: 700;
    font-size: 2.4rem;
    transition: .25s;
    min-height: 120px;
    display: block;
    align-content: center;
}

.c_btn:has(input[type="radio"]:checked),
.c_btn:has(input[type="checkbox"]:checked) {
    background: #06CFAA;
    color: #fff;
}

.c_btn small {
    display: block;
    font-size: 1.8rem;
    font-weight: 400;
    margin: 0 0 10px;
}

.error_txt {
    color: red;
    text-align: center;
    display: block;
    margin: 30px auto 0;
    font-size: 1.4rem;
}

.step_btn {
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    display: block;
    width: 320px;
    padding: 2.2rem 0;
    margin: auto;
    background: #FFAD20;
    border-radius: 70px;
    position: relative;
    cursor: pointer;
}

.step_btn::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 7%;
    margin: auto;
    width: 1rem;
    height: 1.5rem;
    background: no-repeat center / contain url(./img/btn_arrow.png);
}

.btn_prev {
    background: #7A7A7A;
}

.btn_prev::before {
    right: auto;
    left: 7%;
    transform: rotate(180deg);
}

.step1 h3 {
    font-size: 1.6rem;
    margin: 0 0 30px;
}

.step1 h3 span {
    color: #A9EADE;
}

.radio_area {
    justify-content: center;
}

.r_btn {
    position: relative;
    cursor: pointer;
    padding-left: 5%;
    font-size: 1.8rem;
    display: block;
    width: fit-content;
    margin: auto;
}

.r_btn::before,
.r_btn::after {
    content: "";
    display: block;
    border-radius: 50%;
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
    transition: .25s;
}

.r_btn::before {
    background-color: #fff;
    border: 3px solid #CCCCCC;
    border-radius: 50%;
    width: 2.8rem;
    height: 2.8rem;
    left: 5%;
}

.r_btn::after {
    background-color: #06CFAA;
    border-radius: 50%;
    opacity: 0;
    width: 1.6rem;
    height: 1.6rem;
    left: 13%;
}

.r_btn:has(input[type="radio"]:checked)::after {
    opacity: 1;
}

.step1 ul li {
    margin: 0 0 40px;
}

.step1 ul li:last-child {
    margin: 0;
}

.step1 input[type="number"],
.step4 input[type="number"] {
    border: solid 2px #CECECE;
    background: #FAFAFA;
    border-radius: 7px;
    font-size: 1.8rem;
    padding: 20px 3%;
    width: 28%;
    margin: 0 2%;
}

#step2-2 .c_btn {
    font-size: 2rem;
}

.result_cell h3 {
    font-size: 2rem;
    margin: 0 0 10px;
}

.result_cell h3 span {
    color: #06CFAA;
    padding-right: 1%;
}


.result_profile span,
.result_check span,
.result_cover span {
    font-size: 1.8rem;
    padding: 7px 2%;
    background: #ECECEC;
    margin: 0 1% 10px 0;
    display: inline-block;
    border-radius: 4px;
}

.h_contents {
    width: 49%;
    border: solid 2px #06CFAA;
    border-radius: 2.8rem;
    padding: 20px 3% 40px;
    margin: 0 0 20px;
}

.h_contents h3 {
    padding: 2% 0 0 15%;
    font-size: 1.8rem;
}

.h_contents h4 {
    padding: 15px 0;
    text-align: center;
    font-size: 1.8rem;
    border-top: solid 1px #06CFAA;
    border-bottom: solid 1px #06CFAA;
    margin: 20px 0 0;
}

.h_contents table {
    width: 100%;
}

.h_contents table th,
.h_contents table td {
    background: #fff;
    border-left: none;
    border-right: none;
    border-top: none;
    border-bottom: solid 1px #CCCCCC;
    padding: 15px 1%;
    font-size: 1.4rem;
}

.h_contents table td {
    text-align: end;
    width: 50%;
}

.table_txt tr:last-child td {
    text-align: left;
}

.h_contents table {
    min-height: 120px;
    position: relative;
}

.h_contents:has(.vm_btn) table tr:nth-child(n+4) {
    display: none;
}

.h_contents.expanded table tr:nth-child(n+4) {
    display: table-row;
}

.vm_btn {
    color: #06CFAA;
    text-align: center;
    cursor: pointer;
    margin-top: 20px;
    transition: .3s;
}

.vm_btn:hover {
    opacity: .6;
}

.h_contents.expanded .vm_btn {
    color: #666;
}

.h_contents table td span {
    text-align: end;
    font-size: 2.3rem;
    font-weight: 700;
    color: #808080;
}

.h_contents table tr:nth-child(1) td span {
    color: #FF8E22;
}

.h_contents_head {
    position: relative;
}

.h_contents_head::before {
    content: "";
    background: repeat center / contain url(./img/hoken_check.png);
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 3rem;
    height: 3rem;
    cursor: pointer;
    z-index: 10;
}

.result_cell {
    border-bottom: solid 2px #EDEDED;
    padding: 0 0 20px;
    margin: 0 0 20px;
}

.total_result {
    margin: 30px 0;
    text-align: center;
    padding: 0 0 20px;
    font-size: 3.6rem;
    border-bottom: solid 2px #06CFAA;
}

.total_result span {
    font-weight: 700;
    color: #FF8E22;
    font-size: 6.8rem;
}

.reminder {
    margin: 30px 0;
    text-align: center;
}

.reminder p {
    font-size: 2.2rem;
    line-height: 1.8;
}

.reminder p span {
    font-weight: 700;
    color: #06CFAA;
    font-size: 3.2rem;
}

.reminder_attention {
    padding: 15px 2%;
    margin: 20px 0;
    background: #D4F7F1;
    border-radius: 12px;
    line-height: 1.7;
    font-size: 1.8rem;
}

.reminder_attention strong {
    font-weight: 700;
}

.reminder small {
    display: block;
    font-size: 1.4rem;
    color: #3C3C3C;
}

.reminder p small {
    display: inline;
    font-size: 1.2rem;
}

.tax_saving {
    background: #F7F6F3;
    border-radius: 2.8rem;
    padding: 40px 4% 50px;
    text-align: center;
}

.tax_saving h3 {
    font-size: 2.4rem;
    margin: 0 0 30px;
}

.tax_saving p {
    font-size: 1.6rem;
    font-weight: 700;
}

p.tax_total {
    margin: 0 0 20px;
}

p.tax_total span {
    font-size: 4rem;
    color: #06CFAA;
}

.tax_box {
    background: #fff;
    border-radius: 2.8rem;
    border: solid 1px #CDCDCD;
    padding: 30px 6% 35px;
}

.tax_box h4 {
    text-align: left;
    font-size: 2rem;
    margin: 0 0 10px;
}

.tax_box h5 {
    color: #fff;
    font-size: 1.8rem;
    padding: 15px 0;
    margin: 0 0 10px;
}

.tax_l h5 {
    background: #9776D1;
}

.tax_r h5 {
    background: #06CFAA;
}

.tax_l,
.tax_r {
    width: 49%;
}

.result_submit {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 30px 0 40px;
}

.result_submit .step_btn {
    background: linear-gradient(90deg, #FFAD20 0%, #FF7E39 100%);
}

.result_submit .detail_btn {
    background: linear-gradient(90deg, #F082B4 0%, #E8428E 100%);
}

.result_submit .btn_prev {
    margin: 0 30% 40px;
    background: #7A7A7A;
}

.step4 h3.step_ttl,
.step4 h2 {
    text-align: center;
    font-size: 2.8rem;
    margin: 0 0 60px;
}

.step4 h3.step_ttl span {
    color: #06CFAA;
}

.step4 h2 span {
    font-size: 3.8rem;
    color: #06CFAA;
}

.step_list {
    margin: 0 0 50px;
}

.step_list li {
    width: 32%;
    background: #06CFAA;
    border-radius: 2.8rem;
    padding: 20px 2%;
    position: relative;
    text-align: center;
}

.step_list li::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: -15%;
    margin: auto;
    width: 6rem;
    height: 6rem;
    z-index: 2;
    background: no-repeat center / contain url(./img/contact_arrow.png);
}

.step_list li:last-child:after {
    display: none;
}

.step_list span {
    color: #FFF420;
    display: block;
    font-size: 1.4rem;
    font-weight: 700;
}

.step_list h3 {
    font-size: 1.9rem;
    color: #fff;
    line-height: 1.7;
    margin: 20px 0 0;
}

.step_list li img {
    display: block;
    max-width: 95px;
    margin: 30px auto;
}

.step_list li p {
    text-align: left;
    font-size: 1.4rem;
    color: #fff;
}

.step_list li p span {
    display: inline;
}

.plan_confirm {
    padding: 40px 0 0;
    border-top: solid 2px #06CFAA;
}

.contact_form {
    padding: 40px 0 0;
}

.contact_form ul li {
    margin: 0 0 30px;
}

.contact_form ul li p {
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0 0 10px;
}

.contact_form ul li p strong {
    color: #06CFAA;
}

.contact_form ul li p span {
    font-weight: 400;
    color: #FF2C4F;
    padding-left: 3%;
}

.step4 input[type="text"],
.step4 input[type="tel"],
.step4 input[type="email"] {
    border: solid 2px #CECECE;
    background: #FAFAFA;
    border-radius: 7px;
    font-size: 1.8rem;
    padding: 20px 3%;
}

.form_radio label {
    position: relative;
    cursor: pointer;
    padding-left: 15%;
    font-size: 1.8rem;
    display: block;
    width: fit-content;
    margin: auto;
}

.form_radio label::before,
.form_radio label::after {
    content: "";
    display: block;
    border-radius: 50%;
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
    transition: .25s;
}

.form_radio label::before {
    background-color: #fff;
    border: 3px solid #CCCCCC;
    width: 2.8rem;
    height: 2.8rem;
    left: 5%;
}

.form_radio label::after {
    background-color: #06CFAA;
    opacity: 0;
    width: 1.6rem;
    height: 1.6rem;
    left: 12%;
}

.form_radio label:has(input[type="radio"]:checked)::after {
    opacity: 1;
}

.form_radio .wpcf7-list-item {
    width: 40%;
}

.contact_form input.wpcf7-submit {
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    display: block;
    width: 320px;
    padding: 2.2rem 0;
    margin: auto;
    border-radius: 70px;
    position: relative;
    cursor: pointer;
    background: linear-gradient(90deg, #FFAD20 0%, #FF7E39 100%);
    border: none;
}

.contact_form input.wpcf7-submit::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 7%;
    margin: auto;
    width: 1rem;
    height: 1.5rem;
    background: no-repeat center / contain url(./img/btn_arrow.png);
}


#step4-2 .contact_form input.wpcf7-submit {
    background: linear-gradient(90deg, #F082B4 0%, #E8428E 100%);
}

.thanks_cont {
    text-align: center;
}

.thanks_cont h2 {
    font-size: 2.4rem;
    margin: 0 0 50px;
}

.confirm_content h2 {
    font-size: 2rem;
    margin: 0 0 60px;
    font-weight: 400;
}

.confirm_table {
    width: 100%;
    margin: 0 0 60px;
}

.confirm_table td,
.confirm_table th {
    background: #fff;
    border: none;
    font-size: 1.6rem;
    font-weight: 700;
}

.confirm_table th strong {
    color: #06CFAA;
}

.step0,
.step1,
.step2,
.step3,
.step4,
.step5 {
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
}

.step0.fade-in,
.step1.fade-in,
.step2.fade-in,
.step3.fade-in,
.step4.fade-in,
.step5.fade-in {
    opacity: 1;
}

.rating span {
    color: #C8C8C8;
}

.step4 .result_submit {
    display: block;
}

.step4 .result_submit .btn_prev {
    margin: 0 auto;
}

.step4 .step_btn::before {
    display: none;
}

@media screen and (max-width: 1200px) {
    html {
        font-size: 58%;
    }

    .wrap {
        max-width: 93%;
    }
}

@media screen and (max-width: 1000px) {
    header {
        top: 30px;
    }

    .mv_point {
        top: -20px;
    }

    .mv_l {
        margin: 0;
    }

    .mv_l h1 {
        font-size: 4rem;
        margin: 0 0 10px;
    }

    .issue ul li p {
        font-size: 1.5rem;
    }

    .solution h2 {
        font-size: 2.3rem;
    }

    .solution ul li p {
        font-size: 2.3rem;
    }

    .solution ul li strong {
        font-size: 4rem;
    }

    .feature_head h4 span {
        font-size: 2.4rem;
    }

    .feature_head h4 {
        font-size: 1.8rem;
    }

    .cta ul li {
        font-size: 2.2rem;
    }

    .step_r p {
        font-size: 1.8rem;
    }

    .step_r h3 {
        font-size: 2.5rem;
    }

    #step ul li h4 strong {
        font-size: 1.8rem;
        padding: 0;
        width: 25%;
    }

    #step ul li::after {
        bottom: -60%;
    }

    .cta.animate::after,
    .cta.animate::before {
        width: 90%;
    }

    .form_box {
        padding: 50px 3% 60px;
    }
}

@media screen and (max-width: 780px) {
    html {
        font-size: 62.5%;
    }

    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    header {
        top: 20px;
    }

    header img {
        max-width: 120px;
    }

    .mv_l {
        width: 100%;
        text-align: center;
    }

    .mv_r {
        width: 75%;
        margin: auto;
    }

    .mv_l h1 {
        font-size: 3rem;
    }

    .mv_l p {
        font-size: 1.4rem;
    }

    #mv {
        padding: 70px 0 0;
    }

    .cta h2 {
        font-size: 2.3rem;
    }

    .cta h2 strong {
        font-size: 3.2rem;
    }

    .cta a {
        font-size: 2.4rem;
        padding: 25px 0;
        margin: 20px auto 30px;
    }

    .cta ul {
        margin: auto;
        display: block;
    }

    .cta ul li {
        font-size: 2.2rem;
        width: 130px;
        margin: 0 auto 20px;
        padding: 0;
    }

    .cta ul li::before {
        left: -20%;
        width: 20px;
        height: 20px;
    }

    .mv_cta {
        padding: 0 0 20px;
    }

    .issue {
        padding: 40px 0 0;
    }

    .issue ul {
        margin: 30px 0 0;
    }

    .issue ul li img {
        bottom: -20px;
    }

    .issue ul li {
        width: 48%;
        margin: 0 0 30px;
        padding: 20px 1% 0;
    }

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

    .issue:after {
        border-width: 25vw 50vw 0 50vw;
    }

    .issue_txt {
        font-size: 2rem;
        bottom: -8%;
    }

    .solution h2 {
        font-size: 1.35rem;
    }

    .solution h2::before {
        left: -53%;
    }

    .solution h2::after {
        right: -53%;
    }

    .issue_logo {
        max-width: 230px;
        margin: 20px auto 50px;
    }

    .solution ul li {
        width: 48%;
        padding: 30px 0 40px;
        margin: 0 0 40px;
        min-height: 200px;
    }

    .point {
        font-size: 1.4rem;
        top: -20px;
    }

    .point span {
        font-size: 1.8rem;
    }

    .solution ul li p {
        font-size: 1.8rem;
    }

    .solution ul li strong {
        font-size: 2.8rem;
    }

    .cont_ttl {
        font-size: 2.5rem;
    }

    .cont_ttl::before {
        bottom: -35px;
        width: 45px;
        height: 20px;
    }

    .solution {
        padding: 110px 0 40px;
    }

    .solution ul {
        margin: 0 0 30px;
    }

    .solution table {
        margin: 60px 0 0;
    }

    .solution table td {
        display: block;
        border-bottom: solid 2px #06CFAA;
        padding: 20px 0;
        width: 100%;
    }

    .solution table tr:nth-child(1) td:nth-child(1),
    .solution table tr:nth-child(1) td:nth-child(2),
    .solution table tr:nth-child(2) td:nth-child(1),
    .solution table tr:nth-child(2) td:nth-child(2) {
        padding: 20px 0;
    }

    .solution table tr:nth-child(1) td:nth-child(1),
    .solution table tr:nth-child(2) td:nth-child(2) {
        border-right: none;
        border-left: none;
        border-top: none;
    }

    .solution table tr:nth-child(2) td:nth-child(2) {
        border: none;
    }

    .solution table::before {
        display: none;
    }

    .feature_head h4 {
        font-size: 1.6rem;
        margin-left: 5%;
    }

    .feature_head img {
        max-width: 20%;
    }

    .feature_head h4 span {
        font-size: 2.2rem;
    }

    .cta p {
        display: none;
    }

    .cta .wrap::after,
    .cta .wrap::before {
        bottom: -80px;
        width: 80px;
        height: 140px;
    }

    #future {
        padding: 0 0 60px;
    }

    #future ul {
        top: 0;
    }

    #future ul li,
    #future ul li:nth-child(even) {
        flex-direction: column-reverse;
    }

    .future_r h3 {
        font-size: 2rem;
        margin: 0 0 20px;
    }

    .future_r p {
        font-size: 1.4rem;
    }

    .future_r {
        width: 100%;
        margin: 0 0 30px;
    }

    .future_l {
        width: 70%;
        margin: auto;
    }

    .future_txt {
        font-size: 1.7rem;
    }

    #step h2 {
        font-size: 2rem;
    }

    #step img {
        max-width: 110px;
    }

    #step h2 span {
        font-size: 2.8rem;
    }

    .step_txt {
        font-size: 1.6rem;
        margin: 15px auto 30px;
    }

    .step_r h3 {
        font-size: 1.6rem;
        margin: 0 0 10px;
    }

    .step_r p {
        font-size: 1.3rem;
        line-height: 1.6;
    }

    #step ul li {
        border: solid 3px #06CFAA;
        border-radius: 30px;
        padding: 20px 4% 50px;
        margin: 0 0 60px auto;
        width: 92%;
    }

    #step ul li h4 {
        font-size: 1.1rem;
        line-height: 1.4;
        width: 100%;
        padding: 10px 4%;
    }

    #step ul li h4 strong {
        font-size: 1.3rem;
        padding: 0;
        width: 55%;
    }

    #step ul li::before {
        height: 30%;
        left: -54%;
    }

    #step ul li .flex {
        align-items: center;
    }

    .step_l {
        width: 25%;
    }

    .step_r {
        width: 70%;
    }

    #step ul li:nth-child(4) {
        border: dashed 3px #EF82B4;
    }

    #step ul li:nth-child(4) h4 {
        font-size: 1.2rem;
        text-align: center;
        display: block;
    }

    #step ul li::after {
        bottom: -66%;
        left: -5%;
        width: 5px;
        height: 180px;
    }

    #step ul li:nth-child(4):before {
        height: 31%;
        left: -55%;
    }

    #voice ul li {
        width: 100%;
        margin: 0 0 30px;
        padding: 20px 3% 30px;
    }

    #step,
    #voice,
    #faq,
    #contact {
        padding: 50px 0;
    }

    #voice ul li h3 {
        font-size: 1.6rem;
        margin: 10px 0 5px;
    }

    #faq ul {
        margin: 70px 0 0;
    }

    #faq ul li {
        padding: 0 2%;
    }

    .title::before,
    .answer::before {
        width: 15px;
        height: 15px;
    }

    .answer::before {
        top: 23px;
    }

    .title::after {
        width: 20px;
        height: 20px;
    }

    .title {
        font-size: 1.6rem;
        padding: 15px 6%;
    }

    .answer p {
        font-size: 1.4rem;
        margin: 20px 0 0;
    }

    .cta.animate::after,
    .cta.animate::before {
        width: 85%;
    }

    .contact_page h2 {
        font-size: 2.3rem;
    }

    .form_box {
        margin: 40px auto 30px;
        padding: 30px 3% 40px;
    }

    .step0 h3 {
        font-size: 1.8rem;
    }

    .step0 ul li {
        width: 48%;
    }

    .c_btn,
    #step2-2 .c_btn {
        font-size: 1.4rem;
        min-height: 70px;
    }

    .contact_head h2 {
        font-size: 2rem;
    }

    .contact_head p {
        font-size: 1.6rem;
    }

    .r_btn {
        padding-left: 15%;
        font-size: 1.6rem;
    }

    .r_btn::after {
        width: 1.2rem;
        height: 1.2rem;
        left: 10%;
    }

    .r_btn::before {
        border: 2px solid #CCCCCC;
        width: 2.3rem;
        height: 2.3rem;
        left: 3%;
    }

    .step1 h3 {
        margin: 0 0 20px;
    }

    .step1 input[type="number"],
    .step4 input[type="number"] {
        font-size: 1.6rem;
        padding: 10px 2%;
        max-width: 250px;
        width: 60%;
        margin: 0 auto 10px;
    }

    .step4 input[type="text"],
    .step4 input[type="tel"],
    .step4 input[type="email"] {
        font-size: 1.6rem;
        padding: 10px 2%;
    }

    .step_btn {
        font-size: 1.6rem;
        width: 170px;
        padding: 1.4rem 0;
        border-radius: 50px;
    }

    .c_btn small {
        font-size: 1.4rem;
    }

    .step2 ul li {
        margin: 0 auto 20px;
        width: 70%;
    }

    .result_cell h3 {
        font-size: 1.8rem;
    }

    .result_profile span,
    .result_check span,
    .result_cover span {
        font-size: 1.4rem;
        margin: 0 1% 5px 0;
    }

    .result_cell {
        padding: 0 0 10px;
        margin: 0 0 20px;
    }

    .h_contents {
        width: 100%;
    }

    .h_contents h4 {
        font-size: 1.6rem;
    }

    .h_contents table th,
    .h_contents table td {
        font-size: 1.4rem;
        padding: 10px 0;
    }

    .h_contents h3 {
        padding: 0 0 0 10%;
        font-size: 1.6rem;
    }

    .h_contents_head::before {
        width: 2.2rem;
        height: 2.2rem;
    }

    .total_result {
        margin: 20px 0 30px;
        padding: 0;
        font-size: 1.7rem;
    }

    .total_result span {
        font-size: 3.8rem;
    }

    .tax_saving h3 {
        font-size: 2rem;
        margin: 0 0 20px;
    }

    .tax_saving p {
        font-size: 1.4rem;
    }

    p.tax_total span {
        font-size: 3rem;
    }

    .tax_saving {
        padding: 30px 3% 40px;
    }

    .tax_box {
        padding: 20px 3% 25px;
    }

    .tax_box h4 {
        font-size: 1.8rem;
    }

    .tax_l,
    .tax_r {
        width: 100%;
        margin: 0 0 20px;
    }

    .tax_box h5 {
        font-size: 1.6rem;
        padding: 10px 0;
    }

    .result_submit {
        display: block;
    }

    .result_submit .step_btn {
        width: 280px;
        margin: 0 auto 10px;
    }

    header h1 img {
        max-width: 320px;
    }

    .contact_page {
        padding: 100px 0 80px;
    }

    .reminder p {
        font-size: 1.6rem;
        line-height: 1.6;
    }

    .reminder p span {
        font-size: 2.8rem;
    }

    .reminder_attention {
        font-size: 1.4rem;
    }

    .reminder small {
        font-size: 1.2rem;
    }

    .form_radio label::before {
        border: 2px solid #CCCCCC;
        width: 2.3rem;
        height: 2.3rem;
        left: 2%;
    }

    .form_radio label::after {
        width: 1.2rem;
        height: 1.2rem;
        left: 10%;
    }

    .form_radio label {
        padding-left: 35%;
        font-size: 1.6rem;
    }

    .contact_form input.wpcf7-submit {
        width: 280px;
        margin: 10px auto;
        font-size: 1.6rem;
        padding: 1.4rem 0;
    }

    .thanks_cont h2 {
        font-size: 2rem;
    }

    .confirm_content h2 {
        font-size: 1.8rem;
        margin: 0 0 50px;
    }

    .confirm_table td,
    .confirm_table th {
        font-size: 1.4rem;
        display: block;
        width: 100%;
        padding: 10px 0;
    }

    .step5 .step_btn {
        width: 220px;
        margin: 0 auto 20px;
    }

    .step_list li {
        width: 85%;
        margin: 0 auto 40px;
        padding: 20px 5%;
    }

    .step_list li::after {
        top: auto;
        bottom: -15%;
        right: 0;
        left: 0;
        transform: rotate(90deg);
    }

    .step4 h3.step_ttl,
    .step4 h2 {
        font-size: 2.3rem;
        margin: 0px 0px 40px;
    }

    .contact_head div {
        margin: 0 auto;
    }

    .step4 .btn_area {
        display: block;
    }
}