.usercontents {
    position: relative;
    --margin-between-items: 3rem;
}

/*SP????????????????*/
@media screen and (max-width: 768px) {
    .usercontents {
        position: relative;
    }
    .usercontents .form__changearea {
        position: absolute;
        top: 564px;
        left: 50%;
        transform: translateX(-50%);
    }
    .mypage .c-navigation {
        margin-bottom: 48px;
    }
}
.form__section:nth-of-type(n + 2) {
    margin-top: 10rem;
}
.form__section--container {
    width: 100%;
    display: grid;
    margin-top: 2rem;
}
@media screen and (min-width: 768px) {
    .form__section--container {
        gap: var(--margin-between-items, 3rem);
    }
}
@media screen and (min-width: 768px) {
    .form__section--container.column-2 {
        grid-template-columns: repeat(2, 1fr);
        gap: 2rem 1rem;
    }
    .form__section--container.column-2 .button__group li a {
        width: 100%;
        min-width: 0;
        padding-block: 0.625rem;
        padding-inline: 2.4rem;
        font-size: 1.2rem;
    }
}
.form__section--container > .form__section--item:first-child {
    margin-top: 0;
}
@media screen and (min-width: 768px) {
    .form__section--container > .form__section--item {
        margin-top: 0;
    }
}
.form__section--item {
    width: var(--inner-width);
    border: 1px solid var(--color-gray-300);
    border-radius: 0.4rem;
    box-sizing: border-box;
    margin-inline: auto;
    margin-top: var(--margin-between-items, 3rem);
    overflow: hidden;
}
@media screen and (min-width: 768px) {
    .form__section--item {
        --inner-width: 100%;
    }
}
.form__section--heading {
    background-color: var(--color-secondary);
    font-size: 1.6rem;
    font-weight: var(--fw-bold);
    letter-spacing: 0.08em;
    line-height: 1.2188;
    padding-block: 1.025rem;
    text-align: center;
}
.form__section--heading:has(.form__section--heading-subtext) {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}
.form__section--heading:has(.form__section--heading-subtext) .form__section--heading-subtext {
    margin-top: 1rem;
}
@media screen and (min-width: 768px) {
    .form__section--heading:has(.form__section--heading-subtext) {
        flex-direction: row;
    }
    .form__section--heading:has(.form__section--heading-subtext) .form__section--heading-subtext {
        margin-top: 0;
    }
}
.form__section--heading-subtext {
    font-size: 1.4rem;
    font-weight: var(--fw-regular);
}
.form__section--content {
    background-color: var(--color-white);
    padding: 2rem;
}
@media screen and (min-width: 768px) {
    .form__section--content {
        width: var(--form-inner-width);
        margin-inline: auto;
        padding: 3rem 0;
    }
    .form__section--content .lead {
        font-size: 1.4rem;
        font-weight: var(--fw-regular);
        letter-spacing: 0.05em;
        line-height: 1.8571;
        margin-bottom: 2.5rem;
        text-align: center;
    }
}

.agreement-box {
    width: 100%;
    height: 27.4rem;
    background-color: var(--color-gray-100);
    margin-inline: auto;
    margin-top: 2rem;
    padding: 3rem 2rem;
    font-size: 1.3rem;
}
.agreement-box__inner {
    height: 100%;
    overflow-y: auto;
}
.agreement-box h3 {
    margin-bottom: 2rem;
    text-align: center;
    font-size: 1.4rem;
}
.agreement-box h4 {
    margin: 2rem 0 0.5rem;
}
.agreement-box p,
.agreement-box li {
    letter-spacing: 0.05em;
    line-height: 1.7;
}

.form__login .c-form__item:first-of-type {
    margin-top: 2rem;
}
.form__login .c-form__item:nth-of-type(n + 2) {
    margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
    .form__login .form__login.form__login--lp .login__text--content-description {
        margin-bottom: 5rem;
    }
    .form__login .form__login .loginform__wrapper .c-button {
        width: 26rem;
        margin-inline: auto;
    }
}
.form__login .loginarea {
    margin-top: 3rem;
}
@media screen and (min-width: 768px) {
    .form__login .loginarea {
        width: 26rem;
        margin-top: 0;
    }
}
.form__login .loginarea__textlink {
    width: max-content;
    display: block;
    margin-inline: auto;
    margin-top: 1rem;
    text-align: center;
}
.form__login .loginarea .c-button {
    text-align: center;
}
.form__login.form__login--lp .login__text--content-description {
    margin-top: 0;
}
@media screen and (min-width: 768px) {
    .form__login.form__login--lp .login__text--content-description {
        margin-bottom: 5rem;
    }
}
@media screen and (max-width: 767px) {
    .form__login .loginform__wrapper .c-form__wrapper--column {
        grid-template-columns: repeat(1, 1fr);
    }
}
.form__login .loginform__wrapper .remember-check .c-form__input--check {
    justify-content: center;
}
.form__login .loginform__wrapper .c-social-login {
    margin-top: 3rem;
}
@media screen and (min-width: 768px) {
    .form__login .loginform__wrapper .c-button {
        width: 26rem;
        margin-inline: auto;
    }
    .form__login .loginform__wrapper .c-form__item {
        margin-top: 0;
    }
    .form__login .loginform__wrapper .c-form__item.full-width {
        grid-column: 1/3;
        justify-self: center;
    }
    .form__login .loginform__wrapper .c-form__item.remember-check {
        margin-top: 1.5rem;
    }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
    .form__login .loginform__wrapper .c-form__item.remember-check {
        margin-top: 3rem;
    }
}
@media screen and (min-width: 768px) {
    .form__login .loginform__wrapper .c-form__error {
        grid-column: 1/3;
    }
}
@media screen and (min-width: 768px) {
    .form__login .loginbutton {
        display: flex;
        justify-content: center;
        column-gap: 1rem;
        grid-column: 1/3;
        margin-top: 2rem;
    }
}

.couponbox__bg {
    width: 100vw;
    width: 100dvw;
    height: 100vh;
    height: 100dvh;
    background-color: rgba(0, 0, 0, 0.4);
    display: grid;
    place-content: center;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
}
.couponbox__modal {
    width: 92vw;
    max-height: 75vh;
    max-height: 75dvh;
    background-color: var(--color-white);
    border-radius: 0.4rem;
    justify-self: center;
    overflow: hidden;
    position: relative;
}
@media screen and (min-width: 768px) {
    .couponbox__modal {
        width: 108rem;
    }
}
.couponbox__heading {
    background-color: var(--color-primary);
    color: var(--color-white);
    font-size: 1.6rem;
    font-weight: var(--fw-bold);
    letter-spacing: 0.08em;
    line-height: 1.2188;
    padding-block: 1.025rem;
    text-align: center;
}
@media screen and (min-width: 768px) {
    .couponbox__heading {
        font-size: 1.8rem;
        padding-block: 1.404rem;
    }
}
.couponbox__content {
    height: calc(100% - 4rem);
    padding: 2rem 2rem 7rem;
    overflow-y: auto;
}
@media screen and (min-width: 768px) {
    .couponbox__content {
        height: calc(100% - 5rem);
        padding: 2rem 2rem 11rem;
    }
}
.couponbox__fieldlist {
    display: grid;
    grid-template-columns: 15% 25% 11% 6% 1fr;
    column-gap: 3rem;
    margin-bottom: 1rem;
}
.couponbox__fieldlist--item {
    align-self: center;
    color: var(--color-gray-500);
    font-weight: var(--fw-regular);
}
.couponbox__fieldlist--item:first-of-type {
    text-align: center;
}
.couponbox__coupon:nth-of-type(n + 2) {
    margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
    .couponbox__coupon:nth-of-type(n + 2) {
        margin-top: 1rem;
    }
}
.couponbox__coupon--inner {
    background-color: var(--color-gray-100);
    border-radius: 0.4rem;
    padding: 2rem 1.5rem;
}
@media screen and (min-width: 768px) {
    .couponbox__coupon--inner {
        display: grid;
        grid-template-columns: 15% 1fr 11% 6% 17.4% 10%;
        column-gap: 3rem;
        padding: 2rem;
    }
}
.couponbox__coupon--column {
    display: grid;
    grid-template-columns: 34.54% 1fr;
    column-gap: 2rem;
}
.couponbox__coupon--column:nth-of-type(n + 2) {
    margin-top: 1rem;
}
@media screen and (min-width: 768px) {
    .couponbox__coupon--column {
        align-self: center;
        display: block;
    }
    .couponbox__coupon--column:nth-of-type(n + 2) {
        margin-top: 0;
    }
}
.couponbox__coupon--heading {
    color: var(--color-gray-500);
    font-size: 1.3rem;
    line-height: 1.6923;
    word-break: keep-all;
}
.couponbox__coupon .c-button {
    width: 100%;
    min-width: 100%;
    padding-block: 0.65rem;
    margin-top: 1rem;
    text-align: center;
}
@media screen and (min-width: 768px) {
    .couponbox__coupon .c-button {
        display: grid;
        place-content: center;
        margin-top: 0;
        padding: 0.65rem 0;
    }
}
.couponbox__bottomarea {
    width: 100%;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
}
.couponbox__bottomarea .c-button__secondary {
    width: 88.4%;
    text-align: center;
    margin: 1rem auto;
}
@media screen and (min-width: 768px) {
    .couponbox__bottomarea .c-button__secondary {
        width: 20rem;
        margin: 2rem auto 4rem;
    }
}

.form__view {
    border-bottom: 1px dashed var(--color-gray-300);
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 1rem;
    align-items: center;
    padding-block: 2rem;
}
@media screen and (min-width: 768px) {
    .form__view {
        grid-template-columns: 29.72% 1fr;
        grid-template-rows: auto;
    }
}
.form__view--text {
    font-size: 1.3rem;
    font-weight: var(--fw-regular);
    letter-spacing: 0.05em;
    line-height: 2;
    margin-block: 2rem;
}
.form__view > dt {
    font-weight: var(--fw-bold);
    align-self: baseline;
}
.form__view > dd {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 0;
    line-height: 1.5;
}
@media screen and (min-width: 768px) {
    .form__view > dd {
        align-items: center;
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-rows: auto;
    }
}
.form__view > dd .c-button {
    width: 100%;
    min-width: auto;
    padding-block: 0.6rem;
}
@media screen and (min-width: 768px) {
    .form__view > dd .c-button {
        width: 15rem;
        padding-inline: 0;
        align-self: flex-start;
    }
}
@media screen and (max-width: 767px) {
    .item-vertical .form__view {
        grid-template-columns: 35% 1fr;
        grid-template-rows: auto;
    }
}

.formview__elem--align-start {
    align-self: start;
}
.formview__elem--align-center {
    align-self: center;
}
.formview__elem--align-baseline {
    align-self: baseline;
}
.formview__elem--align-end {
    align-self: end;
}
.formview__grid--container {
    display: grid;
    gap: 0.6rem;
}

.form__edit {
    width: 100%;
    border-bottom: 1px dashed var(--color-gray-300);
    padding-block: 2rem;
}
@media screen and (min-width: 768px) {
    .form__edit {
        padding-block: 2.5rem;
    }
}
@media screen and (min-width: 768px) {
    .form__edit--inner {
        padding-left: calc(29.72% + 1rem);
    }
}
.form__edit--buttons {
    display: flex;
    column-gap: 0.6rem;
}
@media screen and (max-width: 767px) {
    .form__edit--buttons {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (min-width: 768px) {
    .form__edit--buttons {
        justify-content: end;
    }
}
.form__edit--buttons .c-button {
    min-width: 0;
    height: 3.6rem;
    display: grid;
    place-content: center;
    padding: 0;
    margin-top: 2rem;
}
@media screen and (min-width: 768px) {
    .form__edit--buttons .c-button {
        width: 15rem;
    }
}

.form__text--gray {
    color: var(--color-gray-500);
}

.form__changearea {
    margin-top: 2rem;
}
@media screen and (min-width: 768px) {
    .form__changearea {
        margin-top: 3rem;
    }
}
@media screen and (max-width: 767px) {
    .form__changearea .c-button {
        padding-block: 0.65rem;
    }
}
@media screen and (min-width: 768px) {
    .form__changearea .c-button {
        width: 20rem;
        margin-inline: auto;
        padding-inline: 0;
    }
}
.form__changearea:empty {
    display: none;
}

.form__totalpricearea {
    width: var(--inner-width);
    background-color: var(--color-gray-100);
    border: 1px solid var(--color-gray-300);
    border-radius: 0.4rem;
    margin-inline: auto;
    margin-block: 1rem;
}
@media screen and (min-width: 768px) {
    .form__totalpricearea {
        width: 100%;
        margin-block: 0;
    }
}
.form__totalpricearea .total {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto;
    align-items: baseline;
    padding: 1rem 2rem;
}
@media screen and (min-width: 768px) {
    .form__totalpricearea .total {
        padding: 2rem 4rem;
    }
}
.form__totalpricearea .total dt {
    font-size: 1.8rem;
    font-weight: var(--fw-bold);
}
.form__totalpricearea .total dd {
    display: block;
    font-size: 2.8rem;
    font-weight: var(--fw-bold);
}
.form__totalpricearea--pointinfo {
    font-size: 1.3rem;
    padding: 1.5rem 2rem;
    text-align: right;
}
@media screen and (min-width: 768px) {
    .form__totalpricearea--pointinfo {
        padding: 2rem 4rem;
    }
}

.form__submitarea {
    width: 81.3333%;
    display: grid;
    grid-template-rows: repeat(2, max-content);
    row-gap: 1rem;
    margin-inline: auto;
    margin-top: 4rem;
}
@media screen and (min-width: 768px) {
    .form__submitarea {
        width: 38rem;
        margin-top: 0;
    }
}
.form__submitarea .c-button__primary {
    font-size: 1.6rem;
    padding-block: 1.7rem;
}

.table__view {
    --grid-columns: 30% 1fr;
    --grid-column-gap: 1rem;
    border-radius: 0.5rem;
    font-size: 1.4rem;
    margin-top: 2rem;
    overflow: hidden;
}
@media screen and (min-width: 768px) {
    .table__view {
        --grid-columns: 20% 1fr;
    }
}
.table__view--column {
    background-color: var(--color-white);
    display: grid;
    grid-template-columns: var(--grid-columns);
    column-gap: var(--grid-column-gap);
    padding: 1.5rem;
}
@media screen and (max-width: 767px) {
    .table__view--column[data-mobile-view="row"] {
        grid-template-columns: 1fr;
        grid-template-rows: repeat(2, auto);
        row-gap: var(--grid-column-gap);
    }
}
.table__view--column-head {
    background-color: var(--color-secondary);
}
.table__view--column:not(.table__view--column-head):not(:last-of-type) {
    border-bottom: 1px dashed var(--color-gray-300);
}
.table__view--content-overflow {
    overflow-x: auto;
}
.table__view--content-overflow * {
    width: max-content;
}

/*# sourceMappingURL=common_form.css.map */
