/*================================================
  about
================================================*/

.page-mainvisual {
    background-image: url(../../image/about/page-mainvisual.jpg);
}

/*================================================
  message
================================================*/

.message-content {
    margin-top: calc(var(--layout-gap) / 2);
    margin-bottom: var(--layout-gap);
}

.message-pic img {
    height: 350px;
    object-fit: contain;
    object-position: center top;
    margin-bottom: calc(var(--layout-gap) / 4);
}

.message-post {
    font-size: 1.7rem;
    font-weight: bold;
    letter-spacing: 0.1em;
    margin-right: calc(var(--layout-gap) / 4);
}

.message-name {
    font-size: 2.4rem;
    font-weight: bold;
    letter-spacing: 0.1em;
    line-height: 1;
    white-space: nowrap;
}

.message-lead {
    font-size: 2.4rem;
    font-weight: 900;
    letter-spacing: 0.015em;
    line-height: 1.6;
    margin-bottom: calc(var(--layout-gap) / 4);
}

.message-text {
    margin-top: var(--layout-gap);
}

.message-text p {
    font-size: 1.6rem;
    letter-spacing: 0.015em;
    line-height: 2.3;
}

@media print,
screen and (min-width: 769px) {
    .message-content {
        display: flex;
        margin-top: var(--layout-gap);
        margin-bottom: calc(var(--layout-gap) * 2);
    }

    .message-pic {
        width: 30%;
        margin-left: calc(var(--layout-gap) / 4);
    }

    .message-text {
        width: 70%;
    }

    .message-pic img {
        height: 377px;
        object-fit: cover;
    }

    .message-name {
        font-size: 3.2rem;
    }

    .message-text {
        margin-left: calc(var(--layout-gap) * 1.5);
        margin-top: 0;
    }

    .message-lead {
        font-size: 3.2rem;
    }

    .message-text p {
        font-size: 1.8rem;
    }

}

/*================================================
  corporate-profile
================================================*/

.corporate-profile {
    padding-block: var(--layout-gap);
}

.corporate-profile-list {
    display: flex;
    flex-wrap: wrap;
    border: 1px solid var(--color-gray);
    margin-top: calc(var(--layout-gap) / 2);
}

.corporate-profile-title {
    font-size: 1.4rem;
    line-height: 1.7;
    font-weight: bold;
    text-align: center;
    width: 30%;
    padding-block: calc(var(--layout-gap) / 2.5);
    padding-inline: calc(var(--layout-gap) / 4);
    background-color: var(--color-bg-primary);
    border-bottom: 1px solid var(--color-gray);
    border-right: 1px solid var(--color-gray);
}

.corporate-profile-text {
    font-size: 1.4rem;
    width: 70%;
    padding-block: calc(var(--layout-gap) / 2.5);
    padding-inline: calc(var(--layout-gap) / 2);
    background-color: var(--color-white);
    border-bottom: 1px solid var(--color-gray);
}

.lh-tight {
    line-height: 1.7;
}

@media print,
screen and (min-width: 1200px) {
    .corporate-profile {
        padding-block: calc(var(--layout-gap) * 1.5);
    }

    .corporate-profile-title {
        font-size: 1.6rem;
        padding-block: calc(var(--layout-gap) / 2);
    }

    .corporate-profile-text {
        font-size: 1.6rem;
        padding-block: calc(var(--layout-gap) / 2);
        padding-inline: var(--layout-gap);
    }
}

/*================================================
  our-history
================================================*/

.our-history {
    padding-block: var(--layout-gap);
    background-image: url(../../image/about/back_image.jpg);
    background-size: cover;
    background-position: center;
}

.our-history-list {
    margin-top: calc(var(--layout-gap) * 1.5);
    margin-left: var(--layout-gap);
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    font-size: 1.6rem;
}

.our-history-year {
    width: 100px;
    white-space: nowrap;
    font-weight: bold;
    position: relative;
    margin-bottom: calc(var(--layout-gap) / 2);
}

.our-history-description {
    width: calc(100% - 100px);
    position: relative;
    margin-bottom: calc(var(--layout-gap) / 2);
}

.our-history-year::before {
    content: '';
    position: absolute;
    top: 50%;
    left: -35px;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    background-color: var(--color-primary);
    border-radius: 50%;
}

.our-history-description::after {
    content: '';
    position: absolute;
    top: 5px;
    left: -122px;
    width: 2px;
    height: calc(100% + calc(var(--layout-gap) / 2));
    background-color: var(--color-primary);
}

.our-history-description:last-of-type::after {
    content: none;
}

@media print,
screen and (min-width: 1200px) {
    .our-history {
        padding-block: calc(var(--layout-gap) * 1.5);
    }

    .our-history-year {
        width: 120px;
    }

    .our-history-description {
        width: calc(100% - 120px);
    }

    .our-history-description::after {
        left: -142px;
    }
}

/*================================================
  access
================================================*/

.access {
    padding-block: var(--layout-gap);
}

.access-content {
    margin-top: var(--layout-gap);
}

.access-text {
    padding-inline: calc(var(--layout-gap) / 1.5);
    margin-top: calc(var(--layout-gap) / 2);
    margin-bottom: calc(var(--layout-gap) / 2);
}

iframe {
    width: 100%;
    height: 200px;
}

.access-img {
    margin-bottom: calc(var(--layout-gap) / 2);
}

@media print,
screen and (min-width: 769px) {
    .access-content {
        display: flex;
    }
    .access-text {
        padding-right: 0;
        font-size: clamp(1rem, 0.5991rem + 0.8341vw, 1.6rem);
    }
    .access-item-left {
        width: 55%;
        margin-right: calc(var(--layout-gap) / 2);
    }

    .access-item-right {
        width: 45%;
    }

    iframe {
        height: 100%;
    }

    .access-img {
        margin-bottom: 0;
    }
}

@media print,
screen and (min-width: 1200px) {
    .access {
        padding-block: calc(var(--layout-gap) * 1.5);
    }

    .access-content {
        margin-top: calc(var(--layout-gap) * 1.5);
    }

    .content-title {
        font-size: 1.8rem;
        padding-block: calc(var(--layout-gap) / 2);
        padding-left: var(--layout-gap);
    }

    .access-text {
        /* padding-inline: calc(var(--layout-gap) * 1.25); */
        padding-left: calc(var(--layout-gap) * 1.25);
        /* margin-top: calc(var(--layout-gap) / 0.8); */
        line-height: 2.5;
    }
    .access-item-left {
        width: 50%;
        margin-right: var(--layout-gap);
    }

    .access-item-right {
        width: 50%;
    }
}
