@charset "utf-8";

.article__header {
    margin-top: 80rem;
    padding: 55rem 0 0 30rem;
}
@media screen and (min-width: 769px) {
    .article__header {
        margin-top: 100rem;
        padding: 90rem 100rem 0 0;
        display: flex;
        justify-content: flex-end;
        position: relative;
    }

    .article__header::after {
        display: block;
        content: '';
        width: 800rem;
        height: 2rem;
        transform: rotate(-45deg);
        transform-origin: center left;
        background-color: var(--primary-black);
        filter: drop-shadow(0 10rem 10rem rgba(0, 0, 0, 0.25));
        position: absolute;
        bottom: 120rem;
        left: 200rem;
    }
}

.section {
    color: var(--primary-black);
    font-family: "Cormorant Garamond";
    font-size: 48rem;
    font-weight: 700;   
}
@media screen and (min-width: 769px) {
    .section {
        font-size: 96rem;
        margin-top: 90rem;
        margin-right: 62rem;
    }
}

.article__header img {
    width: 100%;
    height: 255rem;
    margin-top: 40rem;
}
@media screen and (min-width: 769px) {
    .article__header img {
        width: 853rem;
        height: 631rem;
        margin-top: 0;
    }
}

.concept {
    padding: 80rem 30rem 100rem;
}
@media screen and (min-width: 769px) {
    .concept {
        padding: 200rem;
    }
}

.concept__topic {
    color: var(--primary-blackblack, #222);
    font-family: "Noto Serif JP";
    font-size: 16rem;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.64rem;
}
@media screen and (min-width: 769px) {
    .concept__topic {
        font-size: 28rem;
        line-height: 2.5;
        letter-spacing: 1.12rem;
        text-align: center;
    }
}

.concept__content {
    margin-top: 80rem;
    position: relative;
}
@media screen and (min-width: 769px) {
    .concept__content {
        margin-top: 200rem;
    }
}

.concept__content::after {
    display: block;
    content: '';
    width: 170rem;
    height: 170rem;
    border-radius: 50%;
    background-color: var(--primary-orange);
    filter: blur(90rem);
    position: absolute;
    top: 120rem;
    left: 170rem;
    z-index: -1;
}
@media screen and (min-width: 769px) {
    .concept__content::after {
        width: 300rem;
        height: 300rem;
        filter: blur(150rem);
        top: 160rem;
        left: 600rem;
    }
}

.concept__content--healing::after {
    width: 150rem;
    height: 150rem;
    background-color: var(--primary-pink);
    filter: blur(100rem);
}
@media screen and (min-width: 769px) {
    .concept__content--healing::after {
        width: 250rem;
        height: 250rem;
        top: -90rem;
        left: 210rem;
        filter: blur(200rem);
    }
}

.concept__title h3 {
    color: var(--primary-blackblack, #222);
    font-family: "Noto Serif JP";
    font-size: 24rem;
    font-weight: 600;
    letter-spacing: 0.72rem;
    transform: skewX(-5deg);
    margin-left: 12rem;
}
@media screen and (min-width: 769px) {
    .concept__title h3 {
        font-size: 40rem;
        letter-spacing: 1.2rem;
        margin-left: 24rem;
    }
}

.concept__title {
    display: flex;
    align-items: flex-end;
}

.concept__title::before {
    display: block;
    content: '';
    width: 4rem;
    height: 23rem;
    background: #FFD188;
}
@media screen and (min-width: 769px) {
    .concept__title::before {
        width: 7rem;
        height: 38rem;
    }
}

.concept__title--healing::before {
    background: #FFC7C7;
}

.concept__txt {
    color: var(--primary-blackblack, #222);
    font-family: "Noto Serif JP";
    font-size: 16rem;
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.48rem;
    margin-top: 30rem;
}
@media screen and (min-width: 769px) {
    .concept__txt {
        font-size: 24rem;
        line-height: 2;
        letter-spacing: 0.72rem;
        margin-top: 50rem;
    }

    .concept__txt span {
        display: block;
    }
}

.concept__imgGroupSp {
    margin-top: 80rem;
}
@media screen and (min-width: 769px) {
    .concept__imgGroupSp {
        display: none;
    }
}

.concept__imgGroupPc {
    display: none;
}
@media screen and (min-width: 769px) {
    .concept__imgGroupPc {
        display: block;
        margin-top: 150rem;
    }
}

.concept__imgBottomPc {
    display: none;
}
@media screen and (min-width: 769px) {
    .concept__imgBottomSp {
        display: none;
    }

    .concept__imgBottomPc {
        display: block;
    }
}



