:root {
    --primary-color: #fd416e;
    --secondary-color: #f5f0e9;
    --background-color: #fff;
    --border-color: #a0a0a0;
    --box-shadow-color: #fd416e;
    --input-box: #FFE4E3;
    --chat-box: #efefee;
}

#formarea {
    background: url(../img/form-bg.webp) no-repeat top center / cover;
    padding: 5%;
}

#formarea * {
    font-size: 16px;
    line-height: 1.2em;
}

#formarea .flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
}

#formarea .form__box {
    width: 880px;
    max-width: 100%;
    margin: auto;
    border-radius: 16px;
    box-sizing: border-box;
}

#formarea .announce_bloc,
#formarea .answer {
    margin-bottom: 24px;
}

#formarea .liner {
    background: var(--background-color);
    padding: 2em;
}

#formarea .liner>form>*+* {
    margin-top: 1.5em;
}

#formarea .contact_bloc dl dd {
    margin: 0;
    flex: 1 0 0%;
    text-align: left;
    position: relative;
    box-sizing: border-box;
    padding: 0 0.5em;
}

#formarea .birthday {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
}

#formarea .contact_bloc dl dt {
    width: 100%;
    margin-bottom: 0.5em;
    box-sizing: border-box;
    position: relative;
    padding: 0 0.5em;
    font-weight: bold;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5em;
}

#formarea .fmctr {
    caret-color: #1e1e1e;
    border-radius: 0.3em;
}

#formarea .fmctr {
    font-size: 16px;
    width: 100%;
    padding: 10px 10px;
    box-sizing: border-box;
    border: solid 1px var(--border-color);
    background: var(--background-color);
    border-radius: 0;
}

#formarea .contact_bloc dl dt.required:after {
    content: "必須";
    display: inline-block;
    background: var(--primary-color);
    color: #fff;
    font-size: 12px;
    line-height: 1;
    padding: 4px;
    border-radius: 2px;
}

#formarea .announce,
#formarea .sub-announce {
    display: none;
    background: url(../images/load.gif) no-repeat left 115px center;
    background-size: 40px;
}

#formarea .announce_bloc {
    align-items: flex-start;
    justify-content: flex-start;
    gap: 2em;
}

#formarea .announce_bloc i {
    width: 100%;
    max-width: 70px;
}

#formarea .announce_bloc i img {
    width: 100%;
    max-width: 100%;
    height: auto;
}

#formarea .announce_bloc .message_bloc {
    flex: 1 0 0%;
    text-align: left;
}

#formarea .announce_bloc .message_bloc .box {
    display: inline-block;
    background: #fff;
    padding: 1em;
    border-radius: 0.5em;
    position: relative;
    display: none;
    width: 100%;
}

#formarea .announce_bloc .message_bloc .box:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 15px 10px 0;
    border-color: transparent #fff transparent transparent;
    position: absolute;
    top: 1em;
    left: -15px;
}



#formarea .announce_bloc .message_bloc .box p em {
    color: var(--primary-color);
}

#formarea .answer {
    background: var(--input-box);
    padding: 2em;
    border-radius: 0.5em;
    display: none;
}

#formarea .answer_bloc {
    margin-bottom: 1em;
}

#formarea .answer_btn {
    text-align: center;
}

#formarea .answer_btn span {
    display: inline-block;
    background: var(--background-color);
    color: var(--primary-color);
    font-size: 1em;
    line-height: 1em;
    font-weight: bold;
    max-width: 380px;
    width: 100%;
    padding: 1em 1em 1.1em;
    border-radius: 50px;
    border: solid 2px var(--primary-color);
    box-shadow: 0 4px 0 var(--primary-color);
    cursor: pointer;
    box-sizing: border-box;
}

#formarea .answer_btn span:hover {
    background: var(--primary-color);
    color: #fff;
}

#formarea .answer_btn span.disabled {
    background: var(--background-color);
    color: #ccc;
    border: solid 2px #ccc;
    box-shadow: 0 4px 0 #ccc;
}

#formarea .answer_btn span.disabled:hover {
    background: var(--background-color);
    color: #ccc;
    border: solid 2px #ccc;
    box-shadow: 0 4px 0 #ccc;
}

#formarea .question_item {
    gap: 5px 6px;
}

#formarea .question_item label {
    background: var(--background-color);
    width: calc(100% / 3 - 0.4em);
    display: block;
    border-radius: 0.5em;
    box-sizing: border-box;
    text-align: left;
    cursor: pointer;
}

#formarea .question_item label:hover {
    background: var(--primary-color);
    color: #fff;
}

#formarea .radio-input {
    display: none;
}

#formarea .radio-parts {
    display: block;
    padding-left: 42px;
    position: relative;
    line-height: 1.2em;
    font-size: 1em;
    font-weight: 700;
    padding: 1em 1em 1em 3em;
    border-radius: 0.5em;
    border: 1px solid #FF2E42;


}

#formarea .radio-parts::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 1em;
    margin-top: -12px;
    width: 24px;
    height: 24px;
    border: 1px solid #999;
    border-radius: 50%;
    background: var(--background-color);
}

#formarea .radio-input:checked+.radio-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: calc(1em + 4px);
    width: 16px;
    height: 16px;
    margin-top: -8px;
    background: var(--primary-color);
    border-radius: 50%;
}

#formarea .radio-input:checked+.radio-parts {
    background: var(--primary-color);
    color: #fff;
}

#formarea .fmctr {
    caret-color: #1e1e1e;
    border-radius: 0.5em;
    border: solid 1px #FF2E42;
    padding: 1em 1em;
}

.tel-text {
    margin-top: 13px;
    color: #1A1A1A;
    font-feature-settings: 'palt'on;
    font-family: "Noto Sans JP";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 160%;
    /* 25.6px */
}

.text-center {
    text-align: center;
    font-weight: 500;
}

#formarea select.fmctr {
    padding: 1em 4em 1em 1em;
    width: 100%;
}

#formarea .selectbox+.selectbox {
    margin-top: 1em;
}

#formarea .contact_bloc dl {
    border-top: none;
    padding: 0;
}

#formarea .contact_bloc dl:nth-child(odd) {
    background: none;
}

#formarea .contact_bloc dl:last-child {
    border-bottom: none;
}

#formarea .contact_bloc dl+dl {
    margin-top: 0.5em;
}

#formarea .contact_bloc dl dt.required:after {
    background: var(--primary-color);
}

#formarea .contact_bloc dl dt {
    width: 100%;
    margin-bottom: 0.5em;
    font-weight: bold;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5em;
}

#formarea .btn_text {
    margin-bottom: 1em;
}

#formarea .btn_text p {
    font-size: 16px;
    line-height: 1.4em;
}

#formarea .btn_text p a {
    color: #1e1e1e;
    font-weight: bold;
}

#formarea .btn_text p a:hover {}

#formarea .btn_bloc button {
    display: inline-block;
    color: #FFF;
    text-align: center;
    font-feature-settings: 'palt'on;
    text-shadow: 0 0 8px #006839;
    font-family: "Noto Sans JP";
    font-size: 2.4rem;
    font-style: normal;
    font-weight: 700;
    line-height: 120%;
    /* 28.8px */
    letter-spacing: 1.2px;

    max-width: 451px;
    width: 80%;
    aspect-ratio: 451 / 96;
    width: 100%;
    border-radius: 50px;
    border-radius: 80px;
    background: linear-gradient(90deg, #04C66F 0%, #03BE7F 38.94%, #01B28F 100%);
    box-shadow: 0 8px 8px 0 rgba(2, 151, 84, 0.30);
    cursor: pointer;
}

#formarea .btn_bloc button span {
    color: #FFF;
    font-feature-settings: 'palt'on;
    font-family: "Noto Sans JP";
    font-size: 3.2rem;
    font-style: normal;
    font-weight: 700;
    line-height: 120%;
    letter-spacing: 1.6px;
}

#formarea .btn_bloc button:hover {
    opacity: 0.7;
}

#formarea .btn_bloc button:disabled {
    background: #ccc;
    border: solid 2px #ccc;
    box-shadow: 0 4px 0 #ccc;
    text-shadow: unset;
}

#formarea .btn_bloc button:disabled:hover {
    background: #ccc;
    border: solid 2px #ccc;
    box-shadow: 0 4px 0 #ccc;
}

#formarea .btn_bloc,
#formarea .btn_text {
    text-align: center;
}

.question_item-lead {
    margin-top: 16px;

}

.question_item-lead p {
    color: #1A1A1A;
    font-feature-settings: 'palt'on;
    font-family: "Noto Sans JP";
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 160%;
    /* 25.6px */
}

.question_item-lead p span {
    color: #FF2E42;
    font-weight: 700;

}

.mt-29 {
    margin-top: 29px;
}

@media screen and (max-width: 768px) {
    #formarea {
        padding: 15vw 4% 15vw;
    }

    #formarea .question_item {
        flex-direction: column;
    }

    #formarea .question_item label {
        width: 100%;
        box-sizing: border-box;
    }

    .custom-select {
        width: 100%;
    }
}