/* ===================================================
   page-message.css — 私たちの想いと理念
   =================================================== */

/* ----- Section 1: 代表メッセージ ----- */
.p-message__ceo {
    position: relative;
    max-width: var(--content-narrow);
    margin: var(--space-5xl) auto 0;
    color: var(--color-text);
    scroll-margin-top: calc(var(--header-height) + 40px);
}
.p-message__ceo::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: 130%;
    background: url(../images/img/company/message_08.webp) center / cover no-repeat;
    pointer-events: none;
    z-index: -1;
}

/* 見出し */
.p-message__ceo > h2 {
    position: relative;
    margin: 0 0 var(--space-2xl);
    font-family: var(--font-heading);
    font-size: var(--fz-3xl);
    font-weight: 700;
    line-height: 1.5;
    color: var(--color-accent);
    text-align: center;
}
.p-message__ceo > h2::before {
    content: "";
    display: block;
    width: 23px;
    height: 18px;
    margin: 0 auto var(--space-sm);
    background: url('../images/icons/icon-ttl.svg') no-repeat center / contain;
}

/* 写真 + キャッチ + サイン */
.p-message__ceo > h2 + div {
    display: flex;
    align-items: center;
    gap: 71px;
    margin-bottom: var(--space-5xl);
}
.p-message__ceo > h2 + div > .p-image {
    flex-shrink: 0;
    width: 440px;
}
.p-message__ceo > h2 + div > .p-image img {
    display: block;
    width: 100%;
    height: auto;
}
.p-message__ceo > h2 + div > div {
    min-width: 0;
}
.p-message__ceo > h2 + div > div > p {
    margin: 0 0 var(--space-3xl);
    font-family: var(--font-heading);
    font-size: 3rem;
    font-weight: 400;
    line-height: 1.5;
}
.p-message__ceo > h2 + div > div > div {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}
.p-message__ceo > h2 + div > div > div > p {
    margin: 0;
    font-family: var(--font-base);
    font-size: var(--fz-base);
    line-height: 1.8;
}
.p-message__ceo > h2 + div > div > div > .p-image {
    flex-shrink: 0;
    width: 150px;
}
.p-message__ceo > h2 + div > div > div > .p-image img {
    display: block;
    width: 100%;
    height: auto;
}

/* 本文 */
.p-message__ceo > div:last-child {
    max-width: 717px;
    margin: 0 auto;
    text-align: center;
}
.p-message__ceo > div:last-child > p {
    margin: 0;
    font-family: var(--font-base);
    font-size: var(--fz-base);
    line-height: 1.8;
}
.p-message__ceo > div:last-child > p + p {
    margin-top: 1.8em;
}

/* ----- Section 2: Interview Movies ----- */
.p-message__movies {
    position: relative;
    max-width: var(--content-narrow);
    margin: var(--space-5xl) auto 0;
    padding: var(--space-5xl) 0;
    color: var(--color-text);
}
.p-message__movies::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: calc(100vw * 448 / 1440);
    background: url('../images/bg/arc-bg.svg') top center / 100% 100% no-repeat;
    pointer-events: none;
    z-index: -1;
}
.p-message__movies > h2 {
    margin: 0 0 var(--space-2xl);
    font-family: var(--font-heading);
    font-size: var(--fz-3xl);
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-accent);
    text-align: center;
}
.p-message__movies > div {
    display: flex;
    gap: var(--space-2xl);
    align-items: flex-start;
}
.p-message__movies > div > a,
.p-message__movies > div > button {
    flex: 1;
    min-width: 0;
    text-decoration: none;
    color: inherit;
    /* button reset */
    appearance: none;
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    text-align: inherit;
    cursor: pointer;
    display: block;
}
.p-message__movies > div > a > .p-image,
.p-message__movies > div > button > .p-image {
    position: relative;
    width: 100%;
    aspect-ratio: 333 / 189;
    overflow: hidden;
}
.p-message__movies > div > a > .p-image img,
.p-message__movies > div > button > .p-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.p-message__movies > div > a > .p-image::after,
.p-message__movies > div > button > .p-image::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 44px;
    height: 44px;
    background: url('../images/icons/icon_play_circle.svg') no-repeat center / contain;
    pointer-events: none;
}
.p-message__movies > div > a:last-child > .p-image::after {
    display: none;
}
.p-message__movies > div > a > p,
.p-message__movies > div > button > p {
    margin: var(--space-sm) 0 0;
    font-family: var(--font-base);
    font-size: var(--fz-base);
    line-height: 1.8;
}

/* ----- Section 3: 経営理念 ----- */
.p-message__philosophy {
    position: relative;
    max-width: var(--content-narrow);
    margin: 0 auto;
    padding: var(--space-5xl) 0;
    color: var(--color-text);
    text-align: center;
    scroll-margin-top: calc(var(--header-height) + 40px);
}
.p-message__philosophy::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: calc(100vw * 448 / 1440);
    background: url('../images/bg/arc-bg.svg') top center / 100% 100% no-repeat;
    pointer-events: none;
    z-index: -1;
}

/* 経営理念 見出し（二重ダイヤ deco） */
.p-message__philosophy > h2 {
    position: relative;
    margin: 0 0 var(--space-md);
    font-family: var(--font-heading);
    font-size: var(--fz-3xl);
    font-weight: 700;
    line-height: 1.5;
    color: var(--color-accent);
}
.p-message__philosophy > h2::before {
    content: "";
    display: block;
    width: 23px;
    height: 18px;
    margin: 0 auto var(--space-sm);
    background: url('../images/icons/icon-ttl.svg') no-repeat center / contain;
}

/* 可能性に真剣であれ */
.p-message__philosophy > h2 + p {
    margin: 0 0 var(--space-md);
    font-family: var(--font-heading);
    font-size: var(--fz-6xl);
    font-weight: 700;
    line-height: 1.2;
}

/* 本文（視覚改行は<br>、単一p） */
.p-message__philosophy > h2 + p + p {
    margin: 0 0 var(--space-5xl);
    font-family: var(--font-base);
    font-size: var(--fz-base);
    line-height: 1.8;
}

/* VISION / MISSION */
.p-message__philosophy > div:first-of-type {
    margin: 0 0 var(--space-5xl);
}
.p-message__philosophy > div:first-of-type > p {
    margin: 0;
    font-family: var(--font-heading);
    font-size: var(--fz-5xl);
    font-weight: 700;
    line-height: 1.4;
}
.p-message__philosophy > div:first-of-type > p + p {
    margin-top: var(--space-5xl);
}
.p-message__philosophy > div:first-of-type > p > span {
    display: block;
    margin-bottom: var(--space-md);
    font-size: var(--fz-2xl);
    color: var(--color-accent);
}

/* 4カード（ACTION/SLOGAN/CORE VALUE/TAGLINE） */
.p-message__philosophy > div:last-of-type {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2xl);
}
.p-message__philosophy > div:last-of-type > div {
    flex: 0 0 calc(50% - var(--space-2xl) / 2);
    min-width: 0;
    box-sizing: border-box;
    background-color: var(--color-bg-card);
    padding: var(--space-2xl);
}
.p-message__philosophy > div:last-of-type > div > p:first-child {
    margin: 0 0 var(--space-lg);
    font-family: var(--font-heading);
    font-size: var(--fz-xl);
    font-weight: 700;
    line-height: 1.5;
    color: var(--color-accent);
}
.p-message__philosophy > div:last-of-type > div > p:last-child {
    margin: 0;
    font-family: var(--font-heading);
    font-size: var(--fz-2xl);
    font-weight: 700;
    line-height: 1.5;
}


/* ===================================================
   Responsive
   =================================================== */

/* ----- Tablet: 601–1024px ----- */
@media screen and (max-width: 1024px) {
    .p-message__ceo {
        margin-top: var(--space-4xl);
    }
    .p-message__ceo::before {
        height: 110%;
    }
    .p-message__ceo > h2 {
        margin-bottom: var(--space-xl);
    }
    .p-message__ceo > h2 + div {
        gap: var(--space-2xl);
        margin-bottom: var(--space-4xl);
    }
    .p-message__ceo > h2 + div > .p-image {
        width: 340px;
    }
    .p-message__ceo > h2 + div > div > p {
        font-size: var(--fz-3xl);
        margin-bottom: var(--space-2xl);
    }

    .p-message__movies {
        margin-top: var(--space-4xl);
        padding: var(--space-4xl) var(--space-md);
    }
    .p-message__movies > div {
        gap: var(--space-lg);
    }

    .p-message__philosophy {
        padding: var(--space-4xl) var(--space-md);
    }
    .p-message__philosophy > h2 + p {
        font-size: var(--fz-5xl);
    }
    .p-message__philosophy > div:first-of-type > p {
        font-size: var(--fz-4xl);
    }
    .p-message__philosophy > div:last-of-type > div {
        padding: var(--space-xl);
    }

}

/* ----- SP: ≤600px ----- */
@media screen and (max-width: 600px) {
    .p-message__ceo {
        margin-top: var(--space-2xl);
    }
    .p-message__ceo > h2 {
        margin-bottom: var(--space-lg);
        font-size: var(--fz-2xl);
    }
    .p-message__ceo > h2 + div {
        flex-direction: column;
        gap: var(--space-lg);
        margin-bottom: var(--space-3xl);
    }
    .p-message__ceo > h2 + div > .p-image {
        width: 100%;
    }
    .p-message__ceo > h2 + div > div > p {
        font-size: 20px;
        margin-bottom: var(--space-lg);
        text-align: center;
    }
    .p-message__ceo > h2 + div > div > div {
        justify-content: center;
    }
    .p-message__ceo > div:last-child {
        text-align: left;
    }
    .p-message__ceo > div:last-child > p + p {
        margin-top: 1.5em;
    }
    .p-message__ceo > div:last-child > p br {
        display: none;
    }

    .p-message__movies {
        margin-top: var(--space-3xl);
        padding: var(--space-3xl) var(--space-md);
    }
    .p-message__movies > h2 {
        font-size: var(--fz-2xl);
        margin-bottom: var(--space-xl);
    }
    .p-message__movies > div {
        flex-direction: column;
        gap: var(--space-xl);
    }

    .p-message__philosophy {
        padding: var(--space-3xl) 0;
    }
    .p-message__philosophy > h2 {
        font-size: var(--fz-2xl);
    }
    .p-message__philosophy > h2 + p {
        font-size: var(--fz-4xl);
    }
    .p-message__philosophy > h2 + p + p {
        margin-bottom: var(--space-3xl);
    }
    .p-message__philosophy > div:first-of-type {
        margin-bottom: var(--space-3xl);
    }
    .p-message__philosophy > div:first-of-type > p + p {
        margin-top: var(--space-3xl);
    }
    .p-message__philosophy > div:first-of-type > p {
        font-size: var(--fz-2xl);
    }
    .p-message__philosophy > div:first-of-type > p > span {
        font-size: var(--fz-xl);
    }
    .p-message__philosophy > div:last-of-type {
        gap: var(--space-lg);
    }
    .p-message__philosophy > div:last-of-type > div {
        flex: 0 0 100%;
        padding: var(--space-xl);
    }
    .p-message__philosophy > div:last-of-type > div > p:last-child {
        font-size: var(--fz-xl);
    }

}
