@charset "UTF-8";

.kv__words {
    margin: 8rem 0 0;
}

.kv__title .inner {
    font-size: 2.4rem;
}

.kv__text p {
    font-size: 1.4rem;
}

/*================================================================
# intro
================================================================ */
.intro {
    width: 100%;
    padding: 0;
    background: url(../img/intro.png) no-repeat center top / cover;
    aspect-ratio: auto;
}

.intro .inner {
    padding: 6.4rem 0 32rem;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 1.5rem;
}

.intro .heading05 {
    font-size: 2.42rem;
    font-weight: 500;
    text-shadow: none;
    text-align: center;
}

.intro .heading05 .icon {
    width: 12rem;
    height: auto;
    mix-blend-mode: color-burn;
    position: absolute;
    top: auto;
    right: -2.4rem;
    bottom: -2.4rem;
    display: block;
}

.intro .text03 {
    margin: 2.4rem 0 0;
    font-size: 1.4rem;
    font-weight: 500;
    text-shadow: none;
    text-align: center;
}

/*================================================================
# section02
================================================================ */
.section02_img01 {
    width: 88%;
    margin: 6.4rem 0 0;
}

.section02 .row {
    width: calc(100% - 8rem);
    margin: auto;
}

.section02 .row .left {
    margin: -2.4rem -4rem 0 0;
}

.section02 .row .right {
    margin: 2.4rem 0 0;
}

/*================================================================
# section03
================================================================ */
.p-item__list {
    width: 72%;
    margin: 8rem auto 0;
    padding: 0 6vw;
    display: grid;
    gap: 4rem;
}

.p-item__list li {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}

.p-item__list li .img {
    width: 88%;
    margin: 0 auto;
    position: relative;
}

.p-item__list li .img:before {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: linear-gradient(-90deg, rgba(12, 20, 44, 0.8) 0, rgba(12, 20, 44, 0) 60%);
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    z-index: 1;
}

.p-item__list li .img img {
    max-width: 100%;
    height: auto;
    border-radius: 50%;
}

.p-item__list li .img span {
    padding: 0 0 0 0.1429rem;
    border-left: 1px solid var(--gold);
    position: absolute;
    top: 0;
    right: -0.2857rem;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.5556;
    white-space: nowrap;
    letter-spacing: 0.2em;
    writing-mode: vertical-rl;
    z-index: 1;
}

.p-item__list li .text {
    margin: 1.4286rem 0 0;
    flex-grow: 1;
    font-size: 1.3rem;
    line-height: 2;
}

/*================================================================
# section04
================================================================ */
.section04 {
    padding: 0;
}

/*================================================================
# section05
================================================================ */
.section05_img01 {
    width: 88%;
    margin: 6.4rem 0 0;
}

.section05 .row {
    width: 100%;
    margin: -2.4rem 0 0;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.section05 .row .left {
    width: calc(40% - 0.2rem);
    margin: 0 0 0 0.2rem;
}

.section05 .row .right {
    width: calc(50% - 0.2rem);
    margin: 0.2rem 0 0 0.2rem;
}

/*================================================================
# section06
================================================================ */

.section06_img01 {
    width: 72%;
    margin: 6.4rem 0 0 auto;
}

.section06 .img-wrap {
    position: relative;
}

.section06 .illust01 {
    width: calc(40rem / 2);
    position: absolute;
    bottom: -8rem;
    left: -4rem;
    z-index: 1;
    transition-delay: .4s;
}

.section06 .row {
    width: 88%;
    margin: -2.4rem auto 0;
    position: relative;
    z-index: 2;
}

.section06 .row .right {
    margin: 6.4rem 0 0;
}

.section06 .c-tbl {
    width: 100%;
    margin: 2.4rem auto 0;
}

.section06 .c-tbl tr {
    width: 100%;
    display: flex;
}

.section06 .c-tbl tr th,
.section06 .c-tbl tr td {
    padding: 1.6rem .8rem;
    font-size: 1.4rem;
    line-height: 1.4;
    letter-spacing: 0.04em;
}

.section06 .c-tbl tr th {
    border-bottom: 1px solid var(--border);
    flex: 1 1 auto;
    font-weight: 500;
    text-align: left;
    vertical-align: middle;
}

.section06 .c-tbl tr td {
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex: 0 0 40%;
    text-align: right;
    white-space: nowrap;
}

.section06 .c-tbl tr td span {
    margin: 0 0 0 1.6rem;
}

/*================================================================
# section07
================================================================ */
.section07 {
    margin: 4rem 0 0;
    padding: 16rem 0 0;
    position: relative;
}

.section07 .texture02 {
    width: calc(683px / 4);
    height: calc(1920px / 4);
    mix-blend-mode: lighten;
    background: url(../../common/img/texture02.png) no-repeat center top / contain;
    position: absolute;
    content: "";
    top: -2rem;
    left: calc(50% - 4rem);
    z-index: -1;
}

.p-thoughts .illust01 {
    width: calc(40rem / 2);
    position: absolute;
    left: -8rem;
    top: 4rem;
    z-index: 2;
}

.p-thoughts .p-thoughts__container {
    padding: 0 6vw;
}

.p-thoughts .p-thoughts__container__contents {
    position: relative;
    z-index: 1;
}

.p-thoughts .inner {
    margin: 4rem 0 0;
    display: flex;
    justify-content: center;
    gap: 2.86rem;
}

.p-thoughts .inner .heading05 {
    order: 2;
}

.p-thoughts .inner .text03 {
    order: 1;
}

.p-thoughts .p-thoughts__container__img {
    list-style: none;
    position: relative;
    display: flex;
    flex-direction: row-reverse;
    z-index: 1;
}

.p-thoughts .p-thoughts__container__img img {
    width: 100%;
    height: auto;
}

.p-thoughts .p-thoughts__container__img li:nth-child(1) {
    margin: -4rem 0 0 -1.6rem;
    position: relative;
    z-index: 1;
}

.p-thoughts .p-thoughts__container__img li:nth-child(2) {
    position: relative;
    z-index: 0;
}