﻿@charset "UTF-8";

/* common
---------------------------------------------------*/
#wrapper {
    background-color: #F7FAFD;
}
.footerGlobal {
    z-index: 10;
}

/* articles
---------------------------------------------------*/
#articles {
    position: relative;
    z-index: 1;
}
#articles:has(.articles-list) {
    overflow: hidden;
}
#articles::before {
    content: '';
    position: absolute;
    top: min(1235px, calc(1235 / var(--pc-size) * 100vw));
    left: 0;
    width: 100%;
    height: 1000vh;
    background-color: #DFEDFE;
    z-index: -1;
}
#articles .articles-inner {
    position: relative;
    padding: 2.5rem 0 5.0rem;
}
#articles .articles-inner:has(.articles-list) {
    padding-bottom: 11.0rem;
}

/* page-title */
#articles .page-title {
    text-align: center;
    margin-bottom: 7.0rem;
}
#articles .page-title-wrap {
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
}
#articles .page-title-wrap::before,
#articles .page-title-wrap::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 1.8rem;
    height: 3.0rem;
    border-left: 2px solid var(--key-color);
    border-right: 2px solid var(--key-color);
    pointer-events: none;
}
#articles .page-title-wrap::before {
    left: -5.0rem;
    transform: skewX(38deg);
}
#articles .page-title-wrap::after {
    right: -5.0rem;
    transform: skewX(-38deg);
}
#articles .page-title .number {
    position: relative;
    text-align: center;
    line-height: 1.2;
    color: var(--key-color);
    font-size: 2.8rem;
    font-weight: 700;
    margin-right: 4.9rem;
    padding: 0 1.8rem;
    z-index: 1;
}
#articles .page-title .number::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 100%;
    aspect-ratio: 1 / 1;
    background-color: var(--white-color);
    border: 2px solid var(--key-color);
    border-radius: 50%;
    z-index: -1;
}
#articles .page-title .number sub {
    font-size: 2.8rem;
    font-weight: 600;
    bottom: 0;
}
#articles .page-title .number span {
    font-size: 4.4rem;
    font-weight: 600;
    bottom: 0;
}
#articles .page-title .title {
    line-height: 1.5;
    color: var(--key-color);
    font-size: 6.0rem;
    font-weight: 700;
}

/* healing-wrap */
#articles .healing-wrap {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    margin-bottom: min(168px, calc(168 / var(--pc-size) * 100vw));
}
#articles .contents-index {
    width: min(406px, calc(406 / var(--pc-size) * 100vw));
}
#articles .contents-index .title {
    text-align: right;
    line-height: 1.2;
    color: var(--key-color);
    font-size: 2.2rem;
    font-weight: 600;
}

/* contents-index01 */
#articles .contents-index-list li.contents-index01 {
    margin-bottom: 2.0rem;
}
/* contents-index02 */
#articles .contents-index-list li.contents-index02 {
    margin-bottom: 1.0rem;
}

/* article */
#articles .article {}
#articles .article-inner {
    position: relative;
}
#articles .article .figure-wrap {
    position: relative;
    width: min(800px, calc(800 / var(--pc-size) * 100vw));
    z-index: 1;
}
#articles .article .figure-wrap .figure {
    position: relative;
    width: 100%;
}
#articles .article .figure-wrap .figure::after {
    content: '';
    position: absolute;
    top: 1.0rem;
    left: 1.0rem;
    width: min(440px, calc(440 / var(--pc-size) * 100vw));
    aspect-ratio: 440 / 350;
    border-top: 2px solid #238BC2;
    border-left: 2px solid #238BC2;
    pointer-events: none;
}
#articles .article .figure-wrap .figure img {
    width: 100%;
    border-radius: 1.0rem 30.0rem 1.0rem 1.0rem;
    filter: drop-shadow(1.0rem 1.0rem 2.0rem rgba(17, 86, 125, 0.16));
}
#articles .article .figure-wrap .tag-list {
    position: absolute;
    bottom: 1.0rem;
    right: 1.0rem;
    display: flex;
    gap: 1em;
}
#articles .article .figure-wrap .tag-list li {
    line-height: 1.5;
    color: #238BC2;
    font-size: 1.6rem;
    font-weight: 500;
    background-color: var(--white-color);
    border: 1px solid #238BC2;
    border-radius: 1.1rem;
    padding: 0.2em 1em;
}
#articles .article .text-wrap {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
}
#articles .article .text-wrap .number {
    margin-bottom: 7.0rem;
}
#articles .article .text-wrap .number p {
    position: relative;
    display: inline-block;
    color: var(--key-color);
    font-size: 3.2rem;
    font-weight: 700;
}
#articles .article .text-wrap .number p::before,
#articles .article .text-wrap .number p::after {
    content: '';
    position: absolute;
    left: 0;
    height: 2px;
    background-color: var(--key-color);
}
#articles .article .text-wrap .number p::before {
    bottom: 0;
    width: 100%;
}
#articles .article .text-wrap .number p::after {
    bottom: -0.8rem;
    width: 45%;
}
#articles .article .text-wrap .number .num {
    font-size: 5.0rem;
    font-weight: 600;
    vertical-align: text-bottom;
    margin-left: 0.8rem;
}
#articles .article .text-wrap .title-wrap {
    margin-bottom: 2.0rem;
}
#articles .article .text-wrap .figure {
    width: min(180px, calc(180 / var(--pc-size) * 100vw));
    aspect-ratio: 1 / 1;
    background-color: var(--white-color);
    border: 2px solid #238BC2;
    border-radius: 50%;
    padding: 0.8rem;
    margin-left: 3.0rem;
    margin-bottom: -2.0rem;
    overflow: hidden;
}
#articles .article .text-wrap .figure img {
    width: 100%;
}
#articles .article .text-wrap .title span {
    display: inline-block;
    line-height: 1.6;
    color: var(--praimary-color);
    font-size: 3.2rem;
    font-weight: 500;
    background-color: var(--white-color);
    border: 1px solid var(--key-color);
    border-radius: 0.5rem;
    padding: 0.1em 1em;
}
#articles .article .text-wrap .title span.-np {
    padding: 0.1em 0;
}
#articles .article .text-wrap .title span:not(:last-of-type) {
    margin-bottom: 1.0rem;
}
#articles .article .text-wrap .title span small {
    font-size: 2.8rem;
}
#articles .article .text-wrap .btn-link {
}
#articles .article .text-wrap .btn-link a,
#articles .article .text-wrap .btn-link > span {
    width: min(200px, calc(200 / var(--pc-size) * 100vw));
    height: min(60px, calc(60 / var(--pc-size) * 100vw));
    font-size: 2.0rem;
    text-indent: -1em;
    font-weight: 700;
}
/* .healing-wrap .article */
#articles .healing-wrap .article {
    width: min(820px, calc(820 / var(--pc-size) * 100vw));
}
#articles .healing-wrap .article-inner {
    padding-bottom: 8.0rem;
}
#articles .healing-wrap .article .figure-wrap {
    padding-top: 3.0rem;
    margin: 0 0 0 auto;
}
#articles .healing-wrap .article .figure-wrap .figure::after {
    top: 1.0rem;
    left: auto;
    right: 1.0rem;
    border-top: 2px solid #238BC2;
    border-left: 0;
    border-right: 2px solid #238BC2;
}
#articles .healing-wrap .article .figure-wrap .figure img {
    border-radius: 30.0rem 1.0rem 1.0rem 1.0rem;
}
#articles .healing-wrap .article .text-wrap {
    top: 0;
    left: 0;
    right: auto;
    width: 100%;
    height: 100%;
}
#articles .healing-wrap .article .text-wrap .number {
    position: absolute;
    top: 0;
    left: 0;
    margin-bottom: 0;
}
#articles .healing-wrap .article .text-wrap .title-wrap {
    position: absolute;
    bottom: 0;
    left: 0;
    margin-bottom: 0;
}
#articles .healing-wrap .article .text-wrap .btn-link {
    position: absolute;
    bottom: 0;
    right: 0;
}

/* articles-list */
#articles .articles-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10.0rem 5.0rem;
    margin-top: 18.0rem;
}
#articles .articles-list li {
    width: min(600px, calc(600 / var(--pc-size) * 100vw));
}
#articles .articles-list li img {
    width: 100% ;
    border-radius: 0.5rem;
    filter: drop-shadow(1.0rem 1.0rem 2.0rem rgba(17, 86, 125, 0.16));
}

/* 820 */
@media screen and (min-width:1px) and (max-width: 820px) {
    #articles::before {
        top: calc(1770 / var(--sp-size) * 100vw);
    }
    #articles .articles-inner {
        position: relative;
        padding: 0 0 1.0rem;
    }
    #articles .articles-inner:has(.articles-list) {
        padding-bottom: 8.0rem;
    }

    /* page-title */
    #articles .page-title {
        margin-bottom: 3.5rem;
    }
    #articles .page-title-wrap {
        position: relative;
        display: inline-flex;
        justify-content: center;
        align-items: center;
        padding-top: 3.4rem;
    }
    #articles .page-title-wrap::before,
    #articles .page-title-wrap::after {
        top: auto;
        bottom: 0.8rem;
        width: 1.8rem;
        height: 2.0rem;
    }
    #articles .page-title-wrap::before {
        left: -3.0rem;
    }
    #articles .page-title-wrap::after {
        right: -3.0rem;
    }
    #articles .page-title .number {
        position: absolute;
        top: 2.0rem;
        left: 0;
        text-align: center;
        line-height: 1.2;
        color: var(--key-color);
        font-size: 1.5rem;
        margin-right: 0;
        padding: 0 1.4rem;
    }
    #articles .page-title .number sub {
        font-size: 1.5rem;
    }
    #articles .page-title .number span {
        font-size: 2.3rem;
    }
    #articles .page-title .title {
        font-size: 3.2rem;
    }

    /* healing-wrap */
    #articles .healing-wrap {
        display: block;
        margin-bottom: calc(78 / var(--sp-size) * 100vw);
    }
    #articles .contents-index {
        width: 100%;
    }

    /* article */
    #articles .article-inner {
        padding-bottom: 8.5rem;
    }
    #articles .article .figure-wrap {
        width: 100%;
        padding-top: calc(72 / var(--sp-size) * 100vw);
    }
    #articles .article .figure-wrap .figure::after {
        width: calc(182 / var(--sp-size) * 100vw);
        aspect-ratio: 182 / 118;
    }
    #articles .article .figure-wrap .figure img {
        border-radius: 0.5rem 14.0rem 0.5rem 0.5rem;
        filter: drop-shadow(0.5rem 0.5rem 1.0rem rgba(17, 86, 125, 0.16));
    }
    #articles .article .figure-wrap .tag-list {
        top: 1.8rem;
        bottom: auto;
        right: 0;
    }
    #articles .article .figure-wrap .tag-list li {
        font-size: 1.0rem;
        border: 1px solid #238BC2;
        border-radius: 0.6rem;
        padding: 0.2em 0.5em;
    }
    #articles .article .text-wrap {
        top: 0;
        left: 0;
        right: auto;
        width: 100%;
        height: 100%;
    }
    #articles .article .text-wrap .number {
        position: absolute;
        top: 0;
        left: 0;
        margin-bottom: 0;
    }
    #articles .article .text-wrap .number p {
        font-size: 2.0rem;
    }
    #articles .article .text-wrap .number .num {
        font-size: 4.0rem;
        margin-left: 0.6rem;
    }
    #articles .article .text-wrap .title-wrap {
        position: absolute;
        bottom: 4.8rem;
        left: 0;
        margin-bottom: 0;
    }
    #articles .article .text-wrap .figure {
        width: calc(140 / var(--sp-size) * 100vw);
        margin-left: 1.0rem;
        margin-bottom: -1.0rem;
    }
    #articles .article .text-wrap .title span {
        font-size: 2.0rem;
        border-radius: 0.4rem;
    }
    #articles .article .text-wrap .title span:not(:last-of-type) {
        margin-bottom: 0.3rem;
    }
    #articles .article .text-wrap .title span small {
        font-size: 1.6rem;
    }
    #articles .article .text-wrap .btn-link {
        position: absolute;
        bottom: 0;
        right: 0;
    }
    #articles .article .text-wrap .btn-link a,
    #articles .article .text-wrap .btn-link > span {
        width: calc(160 / var(--sp-size) * 100vw);
        height: calc(40 / var(--sp-size) * 100vw);
        font-size: 1.6rem;
    }
    /* .healing-wrap .article */
    #articles .healing-wrap .article {
        width: 100%;
        margin-bottom: 6.0rem;
    }
    #articles .healing-wrap .article-inner {
        padding-bottom: 11.5rem;
    }
    #articles .healing-wrap .article .figure-wrap {
        padding-top: 5.0rem;
        margin: 0 auto;
    }
    #articles .healing-wrap .article .figure-wrap .figure::after {
    }
    #articles .healing-wrap .article .figure-wrap .figure img {
        border-radius: 14.0rem 0.5rem 0.5rem 0.5rem;
    }
    #articles .healing-wrap .article .text-wrap .title-wrap {
        position: absolute;
        bottom: 4.8rem;
        left: 0;
        margin-bottom: 0;
    }

    /* articles-list */
    #articles .articles-list {
        flex-direction: column;
        gap: 4.0rem 0;
        margin-top: 8.0rem;
    }
    #articles .articles-list li {
        width: 100%;
    }
    #articles .articles-list li img {
        border-radius: 0.5rem;
        filter: drop-shadow(0.5rem 0.5rem 1.0rem rgba(17, 86, 125, 0.16));
    }
}