/* pagesMV */
.contact .heading--primary.imgBg {
    background-image: url(../../contact/img/mv_contact.webp);
    line-height: 1.44;
    margin-bottom: 90rem;
}


.info__lists {
    display: flex;
    justify-content: space-between;
    margin-bottom: 80rem;
}

.info__list {
    display: revert;
    width: 277rem;
    line-height: 1.5;
    padding-top: 10rem;
}

.info__list:hover {
    color: var(--color-green);
    background-color: revert;
}

.info__list:hover::after {
    border-color: var(--color-green);
}

.info__list.btn--arrow::after {
    right: -58rem;
    top: 38%;
    height: 15rem;
    width: 15rem;
}

.info__list.current {
    background-color: var(--color-green);
    color: var(--color-white);
}

.info__list.btn--arrow:last-child::after {
    display: none;
}

.info__lists.btns4 .btn {
    width: 200rem;
}

.btns4 .info__list.btn--arrow::after {
    right: -40rem;
}

.annotation {
    font-size: 14rem;
    margin: 3rem 0 34rem;
}

.btn--more p {
    color: var(--color-green);
    letter-spacing: .1em;
}

@media screen and (max-width: 767.9px) {
    .contact .heading--primary.imgBg {
        background-image: url(../../contact/img/mv_contact.webp);
        margin-bottom: 51rem;
    }

    .info__lists {
        flex-direction: column;
        align-items: center;
        gap: 49rem;
        margin-bottom: 43rem;
    }

    .info__lists.btns4 .btn {
        width: 277rem;
    }

    .info__list.btn--arrow::after {
        right: 130rem;
        top: unset;
        bottom: -31rem;
        transform: rotate(45deg);
    }

    .btns4 .info__list.btn--arrow::after {
        right: 130rem;
    }

    .annotation {
        margin: 4rem 0 14rem;
    }
}

/* contact/other */
.other {
    .info__list {
        line-height: 1.3;
        padding-top: 5rem;

        .en {
            font-size: 13rem;
        }
    }
}

/* form */
.form {
    padding: 39rem 0 51rem;
}

.contact select,
.contact input,
.contact textarea {
    background-color: var(--color-white);
    border: 1px solid var(--color-gray);
    border-radius: 4rem;
    padding: 12rem 14rem;
    width: 100%;
    font-size: 16rem;
}

.contact select {
    cursor: pointer;
}

::placeholder {
    color: var(--color-gray-light);
    font-size: 16rem;
}

.contact .input--checkbox {
    position: relative;
    width: 25rem;
    height: 25rem;
    appearance: none;
    background: #FFFFFF;
    border: 1px solid #707070;
    border-radius: 4rem;
    padding: 0;
}

.input--checkbox:checked::after {
    position: absolute;
    content: "";
    width: 18rem;
    height: 10rem;
    top: 5rem;
    left: 3rem;
    border-left: 3rem solid var(--color-green);
    border-bottom: 3rem solid var(--color-green);
    transform: rotate(-45deg);
}

.contact .input--radio {
    position: relative;
    width: 25rem;
    height: 25rem;
    appearance: none;
    background: #FFFFFF;
    padding: 0;
    border-radius: 50%;
}

.input--radio:checked::after {
    position: absolute;
    content: "";
    top: 4rem;
    left: 4rem;
    width: 15rem;
    height: 15rem;
    border-radius: 50%;
    background-color: var(--color-green);
}

.form__lists {
    border-top: 1px solid var(--color-gray-lighter);
}

.form__list {
    border-bottom: 1px solid var(--color-gray-lighter);
    display: flex;
}

.select__box {
    position: relative;
}

.select__box::after {
    position: absolute;
    content: "";
    width: 8rem;
    height: 8rem;
    top: 43%;
    right: 16rem;
    background: none;
    transform: rotate(45deg);
    border-bottom: 1px solid var(--color-gray);
    border-right: 1px solid var(--color-gray);
}

.select__box.box::after {
    top: 35%;
}

fieldset {
    display: contents;
}

label {
    display: block;
}

.form__title {
    align-self: flex-start;
    width: 424rem;
    font-weight: 600;
    letter-spacing: .1em;
    margin-top: 11rem;
}

.form__title.required {
    position: relative;
}

.form__title.required::after {
    position: absolute;
    content: "必須";
    color: var(--color-white);
    background-color: var(--color-red);
    width: 51rem;
    height: 24rem;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14rem;
    font-weight: 600;
    bottom: -1.7em;
    left: 0;
    letter-spacing: .1em;
}
.form__value {
    width: 600rem;
}
.contact .form__input {
    width: 600rem;
    margin: 20rem 0;
}

.corporation .form__input {
    margin-bottom: 13rem;
}

.form__input .text {
    font-size: 14rem;
    margin-top: 4rem;
}

.form__input.address__wrapper {
    margin: 11rem 0 8rem;
}

.input__wrapper {
    display: flex;
    gap: 20rem;
    margin-bottom: 13rem;
}

.input__wrapper.align {
    align-items: center;
}

.input__wrapper.align.check {
    margin: 4rem 0 10rem;
    gap: 15rem;
}

.address__wrapper .input__wrapper .box {
    line-height: 1;
}

.address__wrapper .select__box {
    margin: 2rem 0 13rem;
}

.contact .mb {
    margin-bottom: 20rem;
}

.contact .box {
    width: 200rem;
    height: unset;
}

.contact .box.btn {
    letter-spacing: 0;
    background-color: var(--color-gray);
    border-radius: 4rem;
    cursor: pointer;
    padding: 12rem 14rem;
    line-height: 1.2;
    height: 44rem;
    font-size: 16rem;
}

.contact .box.btn:hover {
    background-color: var(--color-white);
}

.contact .address {
    margin: 2rem 0 0;
    padding: 10rem 14rem 4rem;
}

.optional .form__title {
    align-self: center;
    margin-top: 0;
}

.optional.gender .form__input {
    margin: 26rem 0;
    gap: 16rem;
}

.optional.gender .form__input input:last-child {
    margin-left: 13rem;
}

.form__input.details {
    padding: 8rem 14rem 5rem;
}

.error {
    /* display: none; */
    color: var(--color-red);
    margin: -15rem 0 10rem 0;
}

.address__wrapper .error {
    margin-top: -8rem;
}

#re_email + .error {
    margin: 5rem 0 0;
}

.details + .error {
    margin-top: -25rem;
}

.corporation .error {
    margin-top: 3rem;
}

.contact .btn--prev::after {
    transform: rotate(135deg);
    left: 28rem;
    right: unset;
}


.btns__wrapper {
    display: flex;
    gap: 20rem;
    justify-content: center;
    margin-top: 119rem;
}

.btns__wrapper .btn {
    font-size: 16rem;
}

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

    .form {
        padding: 19rem 0 66rem;
    }

    .contact select,
    .contact input,
    .contact textarea {
        padding: 13rem 14rem 12rem;
    }

    .select__box.age::after {
        top: 17rem;
    }

    .form__list {
        flex-direction: column;
        gap: 23rem;
    }

    .form__list.site {
        gap: 0;
    }

        .form__value,
    .contact .form__title,
    .contact .form__input {
        width: 100%;
    }

    .contact .age,
    .contact .age .box {
        width: 200rem;
    }


    .corporation {
        gap: 0;
    }

    .corporation .form__input {
        margin: 13rem 0 12rem;
    }

    .input__wrapper {
        flex-direction: column;
    }

    .input__wrapper.align {
        flex-direction: row;
    }

    .optional.gender {
        gap: 8rem;
    }

    .optional.gender .form__input {
        margin: 0 0 18rem;
    }

    .form__input.address__wrapper {
        margin: 11rem 0;
    }

    .form__list.site .form__input.address__wrapper {
        margin: 6rem 0 11rem;
    }

    .input__wrapper.align.check {
        margin: 4rem 0 4rem;
        align-items: flex-start;
    }

    .contact .input--checkbox {
        margin-top: 3rem;
    }

    .input__wrapper.align.check .checkbox {
        width: 295rem;
    }

    .contact .address {
        padding: 5rem 14rem 9rem;
    }

    .address::placeholder {
        line-height: 2;
    }

    .contact .box.btn {
        padding: 13rem 14rem 12rem;
    }

    .contact .mb {
        margin-bottom: 19rem;
    }

    .optional {
        gap: 11rem;
    }

    .optional .form__title {
        margin-top: 12rem;
    }

    .optional .form__input {
        margin: 0 0 20rem;
    }

    .btns__wrapper {
        flex-direction: column-reverse;
        align-items: center;
        margin-top: 42rem;
    }
}


/* confirmation page */
.confirm .text {
margin-bottom: 34rem;
}
.confirm .form__title {
    width: 331rem;
    margin: 11rem 0 13rem;
}

.confirm .form__input {
    width: 693rem;
    margin: 11rem 0 13rem;
    letter-spacing: .08em;
}

@media screen and (max-width: 767.9px) {
    .confirm .form__list {
        gap: 0;
    }

    .confirm .form__title {
        width: 100%;
        margin-bottom: 0;
    }

    .confirm .form__input {
        width: 100%;
        margin: 4rem 0 13rem;
    }

    .confirm .btns__wrapper {
        margin-top: 121rem;
    }
}

/* complete page */
.contact.complete .btn--prev {
    margin: 112rem auto 50rem;
    font-size: 16rem;
}

.contact.complete .btn--prev::after {
    transform: rotate(-45deg);
    right: 28rem;
    left: unset;
}

@media screen and (max-width: 767.9px) {
    .contact.complete .btn--prev {
        margin: 137rem auto 65rem;
    }
}