@charset "utf-8";

/* ==================================================================

    message.css

=================================================================== */

main {
    overflow: hidden;
    background: url("../../images/common/page_head_bg.png") no-repeat top center / 100% auto;
}

@media screen and (max-width: 767px) {
    main {
        background-image: url("../../images/common/page_head_bg@sp.png");
    }
}

.contents .title._lv1 span.en {
    white-space: nowrap;
    color: #f2f2f2;
}

@media screen and (max-width: 767px) {
    .contents .title._lv1 {
        padding-bottom: 18px;
        line-height: 1.636;
    }

    .contents .title._lv1 span.en {
        top: -60px;
    }
}

.font-bold {
    font-weight: 700;
}

.inline-block {
    display: inline-block;
}

/* --------------------------------
■ ページタイトル
-------------------------------- */
.pageHead {
    position: relative;
    padding: 19.8% 0 7.4%;
}

.pageHead__title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.pageHead__en {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1.222;
    letter-spacing: 0.04em;
    color: #c5e7ee;
}

.pageHead__ja {
    margin-top: 4px;
    font-size: 4.2rem;
    font-weight: 700;
    line-height: 1.452;
    letter-spacing: 0.1em;
}

.pageHead__image {
    position: absolute;
    top: 144px;
    right: 4%;
    width: 34%;
    height: auto;
}

@media screen and (max-width: 767px) {
    .pageHead {
        padding: 57.7% 0 15.7%;
    }

    .pageHead__en {
        font-size: 1.2rem;
        line-height: 1.25;
    }

    .pageHead__ja {
        margin-top: 9px;
        font-size: 3.2rem;
        line-height: 1.4375;
    }

    .pageHead__image {
        top: 83.4px;
        right: 35px;
        width: 42.9%;
    }
}

/* --------------------------------
■ パンくず
-------------------------------- */
ol#breadcrumbs {
    gap: 0 36px;
    padding: 0;
}
ol#breadcrumbs li {
    font-size: 1.3rem;
    color: var(--text-color);
}

ol#breadcrumbs li a {
    position: relative;
    display: inline-block;
    color: #8e98ac;
}
ol#breadcrumbs li a:before {
    position: absolute;
    top: 6px;
    right: -18px;
    content: "";
    width: 1px;
    height: 11px;
    border: none;
    background-color: #8e98ac;
    transform: rotate(32deg);
}

@media screen and (max-width: 767px) {
    ol#breadcrumbs {
        display: none;
    }
}

/* --------------------------------
■ タブ
-------------------------------- */
.tabList {
    position: relative;
    z-index: 0;
    display: flex;
    column-gap: 40px;
    margin-top: 77px;
}

.tabList::after {
    content: "";
    position: absolute;
    bottom: 0.5px;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 1px;
    background-color: #d6d6d6;
}

.tabList__item {
    padding-bottom: 16.5px;
    font-size: 1.6rem;
    line-height: 1.5;
    letter-spacing: 0.04em;
}

a.tabList__item {
    transition: font-weight 0.2s;
}
a.tabList__item:hover {
    font-weight: 700;
    text-decoration: none;
}

.tabList__item.--current {
    border-bottom: 2px solid var(--text-color);
    font-weight: 700;
}

@media screen and (max-width: 767px) {
    .tabList {
        margin-top: 0;
    }

    .tabList__item {
        font-size: 1.4rem;
        padding-bottom: 12px;
    }
}

/* --------------------------------
■ Message
-------------------------------- */
section.message {
    margin-top: 57px;
}

.message__title {
    position: relative;
    z-index: 0;
    display: flex;
    align-items: center;
    height: 84px;
    padding: 31px 0 31px 25px;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.04em;
}

.message__title::after {
    content: "";
    position: absolute;
    top: 0;
    left: -40px;
    z-index: -1;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background-image: linear-gradient(90deg, #a696fb, #60ffdf);
}

.message__wrapper {
    position: relative;
    z-index: 0;
    margin-top: 8px;
    padding-bottom: 103px;
}

.message__wrapper::before {
    content: "";
    position: absolute;
    top: 56px;
    right: 105px;
    right: 8.56%;
    bottom: 0;
    left: calc(50% - 50vw);
    z-index: -1;
    border-radius: 0 28px 28px 0;
    background: url("../../images/message/message_bg.jpg") no-repeat center / cover;
}

.message__container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.message__info {
    width: 57.2%;
}

.message__heading {
    font-size: 3.6rem;
    line-height: 1.556;
    letter-spacing: 0.06em;
}

.message__text {
    text-align: left;
    font-size: 1.6rem;
    line-height: 2;
    letter-spacing: 0.04em;
}

.message__figure {
    width: 34.2%;
    margin-top: -5.86%;
}

.message__image {
    width: 100%;
    height: auto;
    border-radius: 16px;
}

.message__caption {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 32px;
    line-height: 1.833;
    letter-spacing: 0.04em;
}

.message__captionTop {
    font-size: 1.6rem;
}

.message__captionBottom {
    font-size: 1.8rem;
    font-weight: 700;
}

@media screen and (max-width: 1320px) {
    .message__title {
        height: 64px;
        padding: 0 0 0 40px;
        font-size: 1.6rem;
    }

    .message__title::after {
        left: -8px;
        width: 64px;
        height: 64px;
    }
}

@media screen and (max-width: 767px) {
    .message__wrapper {
        margin-top: 36px;
        padding-bottom: 40px;
    }

    .message__wrapper::before {
        right: calc(50% - 50vw);
        border-radius: 0;
    }

    .message__container {
        flex-direction: column-reverse;
        row-gap: 24px;
        padding-right: 15px;
    }

    .message__figure {
        width: 65%;
        margin-top: 0;
        margin: 0 auto;
    }

    .message__caption {
        margin-top: 6px;
    }

    .message__captionTop {
        font-size: 1.4rem;
    }

    .message__captionBottom {
        font-size: 1.6rem;
    }

    .message__info {
        width: 100%;
    }

    .message__heading {
        font-size: 2.2rem;
    }

    .message__text {
        font-size: 1.4rem;
    }
}

.history {
    margin-top: 64px;
}

.history__title {
    display: flex;
    align-items: center;
    column-gap: 17px;
    margin-bottom: 36px;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.history__title::after {
    content: "";
    width: calc(100% - 99px);
    height: 1px;
    background-color: #8e98ac;
}

.history__list {
    position: relative;
    z-index: 0;
}

.history__list::after {
    content: "";
    position: absolute;
    top: 16px;
    left: 107px;
    z-index: -1;
    width: 2px;
    height: calc(100% - 32px);
    background-color: #dedede;
}

.history__item {
    position: relative;
    display: flex;
    column-gap: 100px;
    font-size: 1.6rem;
    line-height: 2;
    letter-spacing: 0.04em;
}

.history__item:not(:first-of-type) {
    margin-top: 26px;
}

.history__item::after {
    content: "";
    position: absolute;
    top: 10px;
    left: 102px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: var(--text-color);
}

.history__item dt {
    text-align: right;
    min-width: 56px;
    font-weight: 700;
}

@media screen and (max-width: 767px) {
    .history {
        margin-top: 32px;
        padding-right: 15px;
    }

    .history__title {
        margin-bottom: 16px;
        font-size: 1.6rem;
    }

    .history__list::after {
        top: 12px;
        left: 84px;
        height: calc(100% - 25px);
    }

    .history__item {
        column-gap: 60px;
        font-size: 1.4rem;
    }

    .history__item::after {
        top: 8px;
        left: 79px;
    }
}

@media screen and (max-width: 455px) {
    .history__list::after {
        height: calc(100% - 54px);
    }
}

/* --------------------------------
■ ロゴに込めた想い
-------------------------------- */
.companyLogo {
    margin: 132px 0 111px;
}

.companyLogo__container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 1126px;
    margin: 76px auto 0;
    padding: 0 20px;
}

.companyLogo__logo {
    width: 22.56%;
    height: auto;
}

.companyLogo__info {
    width: 67.68%;
}

.companyLogo__heading {
    position: relative;
    margin-bottom: 30px;
    padding-left: 21px;
    text-align: left;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.04em;
}

.companyLogo__heading::before {
    content: "";
    position: absolute;
    top: 0.7em;
    left: 0;
    width: 12px;
    height: 3px;
    background-color: var(--text-color);
}

.companyLogo__text {
    text-align: left;
    font-size: 1.6rem;
    line-height: 2;
    letter-spacing: 0.04em;
}

.companyLogo__list {
    display: flex;
    column-gap: 10px;
    margin-top: 37px;
    margin-bottom: 33px;
}

.companyLogo__item {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: calc((100% - 40px) / 5);
    aspect-ratio: 139 / 115;
    border-radius: 6px;
    background-color: #eff6f8;
}

.companyLogo__item__name {
    margin-bottom: 6px;
    font-size: 3.7rem;
    font-weight: 600;
    line-height: 1.216;
}

.companyLogo__item__value {
    margin-bottom: 0;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 0.04em;
    opacity: 0.46;
}

@media screen and (max-width: 1080px) {
    .companyLogo__list {
        flex-wrap: wrap;
        justify-content: center;
        row-gap: 10px;
        column-gap: 8px;
    }

    .companyLogo__item {
        width: calc((100% - 16px) / 3);
    }
}

@media screen and (max-width: 767px) {
    .companyLogo {
        margin: 100px 0;
    }

    .companyLogo__container {
        flex-direction: column;
        row-gap: 32px;
        margin: 0;
        padding: 0;
    }

    .companyLogo__logo {
        width: 100%;
        max-width: 180px;
        margin: 0 auto;
    }

    .companyLogo__info {
        width: 100%;
    }

    .companyLogo__heading {
        margin-bottom: 16px;
        font-size: 1.6rem;
    }

    .companyLogo__text {
        font-size: 1.4rem;
    }

    .companyLogo__list {
        margin-top: 24px;
        margin-bottom: 24px;
    }

    .companyLogo__item__name {
        margin-bottom: 8px;
        font-size: 2.8rem;
    }
}
