@charset "UTF-8";

.kv__words {
    margin: 8rem 0 0;
}

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

.intro .inner {
    padding: 10rem 0 20rem;
    display: flex;
    justify-content: center;
    flex-direction: row-reverse;
    gap: 2.86rem;
}

.intro .heading05 {
    font-size: 4rem;
    font-weight: 500;
    line-height: 1.4;
    text-shadow: 0 0 1.6rem rgba(0, 0, 0, 0.5);
}

.intro .heading05 .icon {
    mix-blend-mode: color-burn;
    top: auto;
    right: -4rem;
    bottom: 8rem;
}

.intro .text03 {
    font-size: 1.6rem;
    font-weight: 500;
    text-shadow: 0 0 1.6rem rgba(0, 0, 0, 0.5);
}

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

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

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

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

/*================================================================
# section03
================================================================ */
.p-item__list {
    margin: 8rem 0 0;
    padding: 0 6vw;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    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.4rem;
    line-height: 2;
}

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

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

.section05 .row {
    width: 100%;
    margin: -10rem 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: 10rem 0 0 auto;
}

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

.section06 .illust01 {
    width: 40rem;
    position: absolute;
    bottom: -8rem;
    left: 10%;
    z-index: 1;
    transition-delay: .4s;
}

.section06 .row {
    width: 88%;
    margin: -10rem auto 0;
    position: relative;
    display: grid;
    z-index: 2;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
}

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

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

.section06 .c-tbl tr th {
    border-bottom: 1px solid var(--border);
    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: flex-end;
    text-align: right;
}

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

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

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

.p-thoughts .illust01 {
    width: 40rem;
    position: absolute;
    right: -8%;
    bottom: -16rem;
    z-index: 0;
}

.p-thoughts .p-thoughts__container {
    padding: 0 6vw;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.p-thoughts .p-thoughts__container__contents {
    width: 40%;
}

.p-thoughts .inner {
    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 {
    width: 60%;
    list-style: none;
    position: relative;
    z-index: 1;
}

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

.p-thoughts .p-thoughts__container__img li:nth-child(1) {
    width: 50%;
    position: absolute;
    right: 2.4rem;
    bottom: -10rem;
    z-index: 1;
}

.p-thoughts .p-thoughts__container__img li:nth-child(2) {
    width: 50%;
}