@import url(https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@200;300;400;500;600&family=Noto+Sans+JP:wght@100;300;400;500;700&family=Roboto:wght@300;400&family=Noto+Sans+SC:wght@300;500&display=swap);

.p-philosophy-page__article-heading__sub-heading {
    display: block;
    margin-bottom: 80px;
    font-weight: normal;
    font-size: 16px;
    /* font-family: Barlow Condensed, sans-serif; */
    font-family: "Noto Sans JP", sans-serif;
    letter-spacing: 0.1em;

}

.p-philosophy-page__article-heading__sub-heading img {
    width: 100%;
    max-width: 800px;
}

@media screen and (max-width: 640px) {
    .p-philosophy-page__article-heading__sub-heading {
        margin-bottom: 25px;
    }
}

.p-philosophy-page__article-heading__sub-heading:before {
    content: "";
    display: block;
    width: 28px;
    height: 2px;
    margin-bottom: 13px;
    background-color: #6857a3;
}

.p-philosophy-list-page__article-heading {
    font-size: 36px;
}

@media screen and (max-width: 640px) {
    .p-philosophy-list-page__article-heading {
        margin-bottom: 1rem;
    }

    .p-philosophy-list-page__article-heading {
        font-size: 24px;
    }
}

.t-general__main-content__inner {
    padding-bottom: 50px;
}

.t-general__main-content__inner p {
    line-height: 3;
}

.t-general__main-content__inner figure {
    height: 400px;
    width: 100%;
    margin-top: 50px;
    overflow: hidden;
    display: flex;
    align-items: center;
}


@media screen and (max-width: 640px) {
    .t-general__main-content__inner figure {
        height: 150px;
        margin-top: 30px;
    }
}

.t-general__main-content__inner figure img {
    width: 100%;
}

.p-philosophy-page__article-heading__main {
    display: block;
    font-weight: 500;
    font-size: 44px;
    line-height: 1.63;
    letter-spacing: 0.08em;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    margin-bottom: 34px;
}

h1,
span {
    text-transform: uppercase;
}

.philosophy_subtitle {
    padding: 0;
}



html[lang=en] *,
html[lang=cn] {

    letter-spacing: 0.08em;
    line-height: 2;
}

.valu-title-under {
    margin-top: 6rem;
}

@media screen and (max-width: 640px) {
    .valu-title-under {
        margin-top: 4rem;
    }
}

.philosophy__last-contents .m-article p {
    font-size: 20px;
    text-align: center;
}

.philosophy__last-contents h2 {
    text-align: center;
    margin: 0 auto;
    font-size: 36px;
    margin-bottom: 2rem;

}

@media screen and (max-width: 640px) {
    .philosophy__last-contents .m-article p {
        font-size: 16px;
        text-align: center;
    }

    .philosophy__last-contents h2 {
        text-align: center;
        margin: 0 auto;
        font-size: 32px;
        margin-bottom: 2rem;
    }
}




/* swiper */
.swiper-wrap {
    padding-top: 0;
    padding-bottom: 100px;
}

.swiper {
    width: 100%;
    max-width: 100%;
    height: 500px;
    margin: 0 auto;
    overflow: hidden;
}

@media screen and (max-width: 640px) {
    .swiper-wrap {
        padding: 0;
    }

    .swiper {
        height: 250px;
    }
}

.swiper-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}


/* フェイドイン */

/* 初期は非表示・少しズラす */
.reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 1600ms ease, transform 1600ms ease;
    will-change: opacity, transform;
}

/* 表示状態 */
.reveal.show {
    opacity: 1;
    transform: none;
    transition-delay: var(--delay, 0ms);
}

/* バリエーション（任意） */
.reveal.left {
    transform: translateX(-16px);
}

.reveal.right {
    transform: translateX(16px);
}

.reveal.zoom {
    transform: scale(.98);
}

/* モーション軽減ユーザーには即表示 */
@media (prefers-reduced-motion: reduce) {

    .reveal,
    .reveal.show {
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
    }
}

.card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, .04);
    margin: 24px 0;
}

.philosophy__header-second {
    width: 100%;
}

.philosophy__header-second+.m-about-page-hero {
    display: block;
}

.one-colum .m-about-page-hero {
    display: block;
}

.one-colum .m-about-page-hero__header {
    width: 100%;
    max-width: 860px;
}