.spr-contents {
    position: relative;
}

.spr-contents p {
    margin-bottom: 0;
}


.spr-contents.contents01-title {
    margin-top: 180px;
    margin-bottom: 100px;
}

.spr-contents.contents01-title::after {
    top: -80px;
    left: 0;
    bottom: -697px;
    width: 0%;
    height: auto;
}

.spr-contents.contents01-title.is-active::after {
    width: calc(100% - 200px);
}

@media screen and (max-width: 767px) {
    .spr-contents.contents01-title {
        margin-top: 80px;
        margin-bottom: 50px;
    }

    .spr-contents.contents01-title::after {
        top: -20px;
        bottom: -300px;
    }

    .spr-contents.contents01-title.is-active::after {
        width: calc(100% - 80px);
    }
}



.spr-contents.contents01-title .sub-title-wrapper {
    display: inline-block;
    padding-top: 50px;
    padding-bottom: 50px;
    padding-right: 112px;
    padding-left: calc((100vw - 1080px) / 2);
    background-color: #fff;
}

.spr-contents.contents01-title.is-active .sub-title-wrapper {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}

@media screen and (max-width: 1125px) {
    .spr-contents.contents01-title .sub-title-wrapper {
        padding-left: 2%;
    }
}


@media screen and (max-width: 767px) {

    .spr-contents.contents01-title .sub-title-wrapper {
        padding: 20px;
    }
}

.spr-contents.contents01-title .sub-title-wrapper .main {
    margin-bottom: 30px;
    font-family: 'Noto Serif JP';
    font-style: normal;
    font-weight: 700;
    font-size: 3.2rem;
    line-height: 4rem;
    letter-spacing: 0.05em;
    color: #0A74BB;
}

.spr-contents.contents01-title .sub-title-wrapper .sub {
    font-size: 2rem;
    line-height: 3rem;
    letter-spacing: 0.05em;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents01-title .sub-title-wrapper .main {
        margin-bottom: 15px;
        font-size: 2rem;
        line-height: 3rem;
    }

    .spr-contents.contents01-title .sub-title-wrapper .sub {
        font-size: 1.6rem;
        line-height: 2.2rem;
    }
}

/* @media screen and (max-width: 500px) {
    .spr-contents.contents01-title .sub-title-wrapper .main {
        margin-bottom: 15px;
        font-size: 20px;
        line-height: 30px;
    }

    .spr-contents.contents01-title .sub-title-wrapper .sub {
        font-size: 14px;
        line-height: 20px;
    }
} */



.spr-contents.contents01-contents {
    margin-bottom: 70px;
}

.spr-contents.contents01-contents::before {
    top: -60px;
    left: 200px;
    right: 0;
    bottom: 0;
    height: auto;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents01-contents {
        margin-bottom: 5rem;
    }

    .spr-contents.contents01-contents::before {
        top: -10px;
        left: 0;
        right: 0;
        bottom: 0;
        height: auto;
    }
}

.spr-contents.contents01-contents .img {
    margin-bottom: 30px;
    width: 100%;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents01-contents .img {
        margin: 0 auto 20px;
        max-width: 480px;
    }
}

.spr-contents.contents01-contents .img img {
    width: 100%;
}

.spr-contents.contents01-contents p {
    font-size: 1.8rem;
    line-height: 3rem;
    letter-spacing: 0.05em;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents01-contents p {
        font-size: 1.4rem;
        line-height: 2rem;
    }
}

.spr-contents.contents02-title {
    margin-bottom: 100px;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-title {
        margin-bottom: 5rem;
    }
}

.spr-contents.contents02-contents {
    margin-bottom: 250px;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents {
        margin-bottom: 9rem;
    }
}

.spr-contents.contents02-contents::after {
    top: -60px;
    right: 0;
    bottom: -110px;
    width: 0%;
    height: auto;
}

.spr-contents.contents02-contents.is-active::after {
    width: calc(100% - 200px);
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents::after {
        top: -20px;
        bottom: -40px;
    }

    .spr-contents.contents02-contents.is-active::after {
        width: 100%;
    }
}

.spr-contents.contents02-contents .flow-area {
    margin-bottom: 130px;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .flow-area {
        margin-bottom: 6rem;
    }

}

.spr-contents.contents02-contents .flow-area .card {
    position: relative;
    padding: 40px;
    background-color: #fff;
}

.spr-contents.contents02-contents .flow-area .card:not(:last-child) {
    margin-bottom: 74px;
}

.spr-contents.contents02-contents .flow-area .card:not(:last-child)::after {
    content: "";
    display: block;
    position: absolute;
    bottom: -53px;
    left: calc(50% - 16px);
    width: 32px;
    height: 32px;
    background-image: url("../../common/img/parts/color-triangle.svg");
    background-size: 100% 100%;
    background-repeat: no-repeat;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .flow-area .card {
        padding: 20px;
    }

    .spr-contents.contents02-contents .flow-area .card:not(:last-child) {
        margin-bottom: 40px;
    }

    .spr-contents.contents02-contents .flow-area .card:not(:last-child)::after {
        bottom: -30px;
        left: calc(50% - 10px);
        width: 20px;
        height: 20px;
    }
}

.spr-contents.contents02-contents .flow-area .card .main {
    margin-bottom: 20px;
    font-family: 'Noto Serif JP';
    font-style: normal;
    font-weight: 700;
    font-size: 2.2rem;
    line-height: 2rem;
    letter-spacing: 0.1em;
}

.spr-contents.contents02-contents .flow-area .card .sub {
    font-size: 1.8rem;
    line-height: 3rem;
    letter-spacing: 0.05em;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .flow-area .card .main {
        margin-bottom: 12px;
        font-size: 1.6rem;
        line-height: 2rem;
    }

    .spr-contents.contents02-contents .flow-area .card .sub {
        font-size: 1.4rem;
        line-height: 2rem;
    }
}



.spr-contents.contents02-contents .sub-title-wrapper {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 4rem;
    margin-left: auto;
    margin-right: 0;
    padding: 50px;
    width: 83%;
    max-width: 1550px;
    background-color: #fff;
    box-sizing: border-box;
}

@media screen and (max-width: 1760px) {
    .spr-contents.contents02-contents .sub-title-wrapper {
        width: calc(1080px + 50px + ((100vw - 1080px) / 2));
    }
}

@media screen and (max-width: 1125px) {
    .spr-contents.contents02-contents .sub-title-wrapper {
        width: 98%;
    }
}

@media screen and (max-width: 900px) {
    .spr-contents.contents02-contents .sub-title-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .sub-title-wrapper {
        margin-left: auto;
        margin-right: 0;
        padding: 20px;
        width: 96%;
    }
}

.spr-contents.contents02-contents.is-active .sub-title-wrapper {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}

/* .spr-contents.contents02-contents .sub-title-wrapper .text-area-wrapper {
    flex-grow: 1;
} */

.spr-contents.contents02-contents .sub-title-wrapper .main {
    display: inline-block;
    margin-bottom: 20px;
    padding-bottom: 10px;
    font-family: 'Noto Serif JP';
    font-style: normal;
    font-weight: 700;
    font-size: 3.2rem;
    line-height: 3.8rem;
    letter-spacing: 0.05em;
    color: #0A74BB;
    border-bottom: solid 1px #0A74BB;
}

.spr-contents.contents02-contents .sub-title-wrapper ul li {
    font-size: 2rem;
    line-height: 3.2rem;
    letter-spacing: 0.05em;
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .sub-title-wrapper .main {
        margin-bottom: 12px;
        padding-bottom: 6px;
        font-size: 2.2rem;
        line-height: 3rem;
    }

    .spr-contents.contents02-contents .sub-title-wrapper ul li {
        font-size: 1.6rem;
        line-height: 2.4rem;
    }
}

.spr-contents.contents02-contents .sub-title-wrapper .img-area {
    flex-shrink: 0;
    width: 29.6rem;
}

@media screen and (max-width: 900px) {
    .spr-contents.contents02-contents .sub-title-wrapper .img-area {
        margin-left: auto;
        margin-right: auto;
        width: 38rem;
    }
}

@media screen and (max-width: 767px) {
    .spr-contents.contents02-contents .sub-title-wrapper .img-area {
        width: 29.6rem;
    }
}

.spr-contents.contents02-contents .sub-title-wrapper .img-area img {
    width: 100%;
}








.edit-area.spr-contents.archive-contents {
    padding: 50px 0;
    margin-bottom: 170px;
}

@media screen and (max-width: 767px) {
    .edit-area.spr-contents.archive-contents {
        padding: 30px 0;
        margin-bottom: 4rem;
    }
}

.edit-area.spr-contents.works.type02 .works-post-list thead tr th:nth-of-type(1),
.edit-area.spr-contents.works.type02 .works-post-list thead tr th:nth-of-type(3) {
    width: 24%;
}

.edit-area.spr-contents.works.type02 .works-post-list tr.no-single,
.edit-area.spr-contents.works.type02 .works-post-list tr.no-single a {
    pointer-events: none;
}