@media (min-width: 769px) {
    .is-sp {
        display: none;
    }
}

@media (max-width: 768px) {
    .is-pc {
        display: none;
    }
}

.p-pattern01__list {
    --column-count: 2;

    @media screen and (max-width: 768px) {
        --column-count: 1;
    }
}

.page-aesthetic p.p-paragraph:not(:last-child) {
    margin-bottom: 1.5em;
}

.p-text--sub {
    font-size: 0.9em;
}

.p-indent1 {
    display     : inline-block;
    padding-left: 1em;
    text-indent : -1em;
}

/* margin-top */
.mt_10 {
    margin-top: 10px !important;
}

.mt_20 {
    margin-top: 20px !important;
}

.mt_30 {
    margin-top: 30px !important;
}

.mt_40 {
    margin-top: 40px !important;
}

.mt_50 {
    margin-top: 50px !important;
}

.mt_60 {
    margin-top: 60px !important;

    @media screen and (max-width: 768px) {
        margin-top: 30px !important;
    }
}

.mt_90 {
    margin-top: 90px !important;

    @media screen and (max-width: 768px) {
        margin-top: 45px !important;
    }
}

/* margin-bottom */
.mb_10 {
    margin-bottom: 10px !important;
}

.mb_20 {
    margin-bottom: 20px !important;
}

.mb_30 {
    margin-bottom: 30px !important;
}

.mb_40 {
    margin-bottom: 40px !important;
}

.mb_50 {
    margin-bottom: 50px !important;
}

.mb_60 {
    margin-bottom: 60px !important;

    @media screen and (max-width: 768px) {
        margin-bottom: 30px !important;
    }
}

.p-text-link {
    color          : #007bff;
    text-decoration: underline;
}

.p-center {
    width        : fit-content;
    margin-inline: auto;
}

.p-right {
    width      : fit-content;
    margin-left: auto;

    @media screen and (max-width: 768px) {
        margin-inline: auto;
    }
}

.p-left {
    width       : fit-content;
    margin-right: auto;

    @media screen and (max-width: 768px) {
        margin-inline: auto;
    }
}

.p-pattern08__list {
    --column-count: 2;

    @media screen and (max-width: 768px) {
        --column-count: 1;
    }
}

/* CTAボックス */
.p-ctabox {
    text-align      : center;
    width           : fit-content;
    margin-inline   : auto;
    border          : 1px solid #3c3c43;
    background-color: rgba(var(--color-bg-rgb), 85%);
    padding         : 1rem 2rem;
    margin-top      : 6rem;

    @media screen and (max-width: 768px) {
        margin-top: 3rem;
        width     : 100%;
        box-sizing: border-box;
    }
}

.p-ctabox__title {
    font-size    : 22px !important;
    font-weight  : bold;
    margin-bottom: 1rem;
    text-align   : center;

    @media screen and (max-width: 768px) {
        font-size: 5.5vw !important;
    }
}

.c-table th:first-child {
    width: 60%;
}

.c-table>tbody>tr>td {
    text-align    : center;
    min-width     : auto;
    vertical-align: middle;
}

.p-label {
    font-weight     : bold;
    background-color: #83cac7;
    color           : #ffffff;
    line-height     : 1.6;
    padding         : 0.2em 0.5em;
    border-radius   : 0.2em;
    margin-bottom   : 0.2em;
    display         : block;
    width           : fit-content;
}