@charset "utf-8";

.sp {
        display: none;
}

.ceo-title-box {
        max-width: calc(calc(1200px + 6%) + 6%);
        padding-left: 3%;
        padding-right: 3%;
        margin: 5rem auto 0;
        display: flex;
        justify-content: center;
}

.ceo-title {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 2.2rem;
        font-weight: normal;
        text-align: center;
}

.ceo-title::before,
.ceo-title::after {
        content: '';
        width: 70px;
        height: 2px;
        background-color: #e5001b;
}

.ceo-title::before {
        margin-right: 20px;
}

.ceo-title::after {
        margin-left: 20px;
}

.ceo-photo-box {
        position: relative;
        margin-top: 5rem;
}

.ceo-photo,
.ceo-name-img,
.ceo-message-img {
        width: 100%;
}

.ceo-message-box {
        width: 38%;
        position: absolute;
        top: 50%;
        left: 6%;
        transform: translateY(-65%);
}

.ceo-name-box {
        position: absolute;
        bottom: 10rem;
        right: 10rem;
        width: 20%;
}

.ceo-m {
        margin-top: 5rem;
}

.title-box {
        max-width: calc(1200px + 6%);
        padding-left: 3%;
        padding-right: 3%;
        margin: 0 auto;
}

.title-name {
        position: relative;
        padding-top: 40px;
        padding-left: 30px;
        font-weight: normal;
        font-size: 3.5rem;
}

.title-name span {
        position: relative;
        z-index: 2;
}

.title-name::before {
        content: attr(data-en);
        position: absolute;
        transform: rotate(-5deg);
        top: -20px;
        left: 0;
        color: rgba(229, 0, 27, 0.3);
        font-size: 80px;
        font-weight: 400;
        font-family: luxus-brut, cursive;
        font-style: italic;
}

.title-number {
        position: relative;
        width: fit-content;
        font-size: 8rem;
        color: rgba(229, 0, 27, 0.3);
        font-family: luxus-brut, cursive;
        font-weight: 400;
        font-style: normal;
}

.title-number::before {
        content: "";
        position: absolute;
        width: 30rem;
        height: 1px;
        top: 35%;
        left: 150%;
        transform: translateY(-50%);
        background-color: rgba(229, 0, 27, 0.3);
}

.title-style {
        font-size: 1.8rem;
}

.message-bgc01 {
        position: relative;
        padding: 8rem 0 8rem;
        margin: 10rem auto 3rem;
}

.message-bgc01::after {
        content: "";
        position: absolute;
        display: block;
        background-color: #f7f7f7;
        width: 70%;
        height: 100%;
        top: 0;
        z-index: -1;
}

.content-box {
        max-width: calc(1200px + 6%);
        padding-left: 3%;
        padding-right: 3%;
        margin: 0 auto;
}

.content-topmessage {
        display: flex;
        align-items: center;
        justify-content: space-between;
}

.content-title {
        width: 45%;
        display: flex;
        align-items: center;
        justify-content: center;
}

.title-wrap {
        position: relative;
        font-size: 3rem;
        padding-bottom: 3rem;
        letter-spacing: 0.16em;
}

.title-wrap::after {
        content: "";
        position: absolute;
        display: block;
        width: 95px;
        height: 10px;
        background-color: #e5001b;
        bottom: 0;
        left: 0;
        z-index: 1;
}

.message-top {
        width: 50%;
}

.message-top-text {
        line-height: 1.9;
        letter-spacing: 0.16em;
        text-align: justify;
}

.topmessage02 {
        padding: 7rem 0;
        float: right;
}

.content-title02 {
        display: flex;
        align-items: center;
}

.title-wrap01 {
        text-align: left;
}

.title-wrap02 {
        width: 50%;
        margin-right: 5%;
        padding-left: 3%;
        max-width: 820px;
}

.title-item02 {
        margin-bottom: 5rem;
}

.ceo-img-box {
        width: 45%;
        max-width: 750px;
        margin-right: 0;
}

.ceo-photo-img {
        max-width: 100%;
}

.message-bgc02 {
        position: relative;
        padding: 8rem 0 8rem;
        clear: both;
        margin: 10rem auto;
}

.message-bgc02::after {
        content: "";
        position: absolute;
        display: block;
        background-color: #f7f7f7;
        width: 70%;
        height: 100%;
        top: 0;
        right: 0;
        z-index: -1;
}

.topmessage04 {
        margin: 10rem auto 20rem;
}


.title-wrap02-02 {
        width: 35%;
        margin-right: 5%;
        padding-left: 3%;
        max-width: 820px;
}

.corporate-identity {
        margin-top: 5rem;
}

.triangle-img {
        max-width: 820px;
        margin: 4rem auto 10rem;
        border: 2px solid #e5001b;
        padding: 4rem;
}

.corporate-identity-img {
        width: 100%;
}



@media screen and (max-width:767px) {
        .sp {
                display: block;
        }

        .pc {
                display: none;
        }

        .content-box {
                flex-direction: column;
        }

        .ceo-photo-box {
                position: static;
                margin-top: 0;
        }

        .ceo-title-box {
                margin: 1rem auto;
        }

        .ceo-title {
                font-size: 1.7rem;
        }

        .ceo-message-box {
                width: 94%;
                margin: 1rem auto;
                position: static;
                transform: none;
                font-size: 2rem;
                font-weight: bold;
                font-family: "游ゴシック",
                        YuGothic,
                        "Hiragino Sans",
                        "Hiragino Kaku Gothic Pro";
                color: #1c1c1c;
        }

        .ceo-name-box {
                width: 60%;
                margin: 0 3% 0 auto;
                position: static;
        }

        .content-title {
                width: 100%;
                order: 1;
                margin: 0 auto;
                justify-content: flex-start;
        }

        .title-wrap {
                padding-bottom: 2rem;
                margin-bottom: 2rem;
                font-size: 1.8rem;
                letter-spacing: 0.15em;
        }

        .message-top {
                width: 100%;
                order: 2;
        }

        .message-bgc01 {
                clear: both;
                margin: 1rem auto 0;
                padding: 1rem 0;
        }

        .message-top-text {
                letter-spacing: 0.01em;
        }

        .topmessage02 {
                padding: 1rem 0;
        }

        .content-title02 {
                display: block;
        }

        .title-wrap02 {
                width: 100%;
                margin: 0 auto 1rem;
                padding-right: 3%;
        }

        .message-bgc02 {
                padding: 4rem 0;
                margin: 1rem auto;
        }

        .ceo-img-box {
                width: 100%;
        }

        .content-topmessage {
                align-items: flex-start;
        }

        .topmessage04 {
                margin: 1rem auto;
        }

        .title-name {
                padding-top: 10px;
                padding-left: 10px;
                font-size: 2rem;
        }

        .title-style {
                font-size: 1.3rem;
        }

        .title-name::before {
                font-size: 4.5rem;
        }

        .title-number {
                font-size: 4rem;
        }

        .title-number::before {
                width: 6rem;
        }

        .title-wrap02-02 {
                width: 100%;
                padding-right: 3%;
        }

        .triangle-img {
                padding: 1rem;
                margin: 1rem auto 5rem;
        }



}