@charset "utf-8";

/*====================
mainVisual
=====================*/
.mainVisual__wap {
    background: url(../images/mv_pc.jpg) no-repeat;
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
    background-size: cover;
    background-position: center;
    aspect-ratio: 9/5;
    text-align: center;
    position: relative;
}

.mainVisual__topics {
    font-size: 3.6rem;
    font-weight: 700;
    position: absolute;
    left: 52%;
    bottom: 32%;
    transform: translate(-50%, -25%);
    white-space: nowrap;
}

.mv_topics {
    font-size: 3.6rem;
    margin-left: 50px;
}

.logo-mv {
    width: 300px;
    height: auto;
    flex-shrink: 0;
    position: absolute;
    left: 50%;
    bottom: 5%;
    transform: translate(-50%, -5%);
}

/* mainVisual tb (600px～1023px) */
@media screen and (min-width: 600px) and (max-width: 1023px) {

    .mainVisual__topics {
        font-size: 3rem;
        position: absolute;
        left: 52%;
        bottom: 32%;
    }

    .mv_topics {
        font-size: 3rem;
        margin-left: 50px;
    }

    .logo-mv {
        width: 200px;

    }
}

/* tb */

/* mainVisual sp(599px以下） */
@media screen and (max-width: 599px) {
    .mainVisual__wap {
        background: url(../images/mv_sp.jpg) no-repeat;
        max-width: 100%;
        margin: 0 auto;
        width: 100%;
        background-size: cover;
        background-position: center;
        aspect-ratio: 3/4;
        text-align: center;
        position: relative;
    }

    .mainVisual__topics {
        font-size: 5vw;
        position: absolute;
        bottom: 28%;
    }

    .mv_topics {
        font-size: 5vw;
        margin-left: 20px;
    }

    .logo-mv {
        width: 120px;
        height: auto;
        flex-shrink: 0;
    }
}

/* sp 599px */

/*====================
top
=====================*/
.section--top {
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
    padding: 200px 10.4%;
    background: url(../images/top.jpg) no-repeat;
    background-size: cover;
    background-position: 70%;
    text-align: center;
    justify-content: center;
    align-items: center;
    z-index: 0;
}

.mainCaption {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 100px;
}

.mainCaption__title {
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 2.4;
}

/* .top-subTitle {
    font-family: "Zen Kaku Gothic New";
    font-size: 16px;
    font-weight: 400;
    line-height: 2.4;
} */

.mainCaption__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 50px;
}

/* top sp(599px以下） */
@media screen and (max-width: 599px) {
    .section--top {
        background: url(../images/top_sp.jpg) no-repeat;
        background-size: cover;
        background-position: 70%;
        padding: 100px 4.2%;
    }

    .mainCaption__title {
        font-size: 2rem;
    }

    /* .top-subTitle {
        font-size: 14px;
    } */
}

/* sp 599px */

/*====================
concept
=====================*/
.section--concept {
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
    padding: 200px 10.4%;
    background: url(../images/concept_background.jpg) no-repeat;
    background-size: cover;
    background-position-y: 10%;
    background-position-x: 80%;
    z-index: 0;

    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 140px;
}

/* セクションタイトル */
.section--title--concept {
    color: var(--primary-white);
    text-align: center;
    font-family: "Bonheur Royale";
    font-size: 15rem;
    font-weight: 400;
}

.section--title--concept::after {
    content: '';
    position: absolute;
    background: var(--primary-white);
    width: 300px;
    height: 1px;
    rotate: -45deg;
    display: inline-block;
    bottom: 130px;
    right: -10%;
}

/* サブタイトル */
.section--title--concept {
    position: relative;

    &::before {
        position: absolute;
        content: attr(data-sub);
        bottom: 10%;
        right: -45%;
        font-family: "Zen Old Mincho";
        font-size: 2.4rem;
    }
}

.concept--wrap {
    display: flex;
}

.concept--item {
    display: flex;
    flex-direction: column;
    text-align: left;
    align-items: flex-start;
    gap: 40px;
}

.concept__photo {
    width: 452px;
    height: auto;
}

.strong {
    font-weight: 700;
}

.logo {
    display: flex;
    padding: 0px 4px;
    align-items: center;
}

.concept__logo {
    width: 228px;
    height: auto;
}

.logo__txt {
    color: #FFFEFE;
    text-align: center;
    font-family: "Cormorant Garamond";
    font-size: 3.6rem;
    font-weight: 700;
    align-items: center;
    padding: 0 40px 20px;

}

.plus {
    font-size: 2.4rem;
    margin: 0 5px;
    align-items: center;
}

.strong {
    font-weight: 700;
}

/* concept tb (768px～1023px) */
@media screen and (min-width: 768px) and (max-width: 1023px) {
    .section--title--concept {
        font-size: 12rem;
    }

    .section--title--concept::after {
        content: '';
        position: absolute;
        background: var(--primary-white);
        width: 220px;
        height: 1px;
        rotate: -45deg;
        display: inline-block;
        bottom: 90px;
        right: -10%;
    }

    .section--title--concept {
        position: relative;

        &::before {
            position: absolute;
            content: attr(data-sub);
            bottom: 0%;
            right: -20%;
            font-size: 1.8rem;
        }
    }


}

/* tb */

/* concept sp(767px以下） */
@media screen and (max-width: 767px) {
    .section--concept {
        background: url(../images/concept_background_sp.jpg) no-repeat;
        background-size: cover;
        background-position-y: 60%;
        display: flex;
        padding: 120px 4.2%;
        flex-direction: column;
        align-items: center;
        gap: 100px;
        align-self: stretch;
    }

    .section--title--concept {
        color: var(--primary-white);
        text-align: center;
        font-size: 10rem;
    }

    .section--title--concept::after {
        content: '';
        position: absolute;
        background: var(--primary-white);
        width: 190px;
        height: 1px;
        rotate: -45deg;
        display: inline-block;
        bottom: 90px;
        right: -10%;
    }

    /* サブタイトル */
    .section--title--concept {
        position: relative;

        &::before {
            position: absolute;
            content: attr(data-sub);
            bottom: 0%;
            right: -20%;
            font-size: 1.6rem;
        }
    }

    .concept--wrap {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 40px;
    }

    .concept--item {
        order: 1;
        padding: 0 4.2%;
    }

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

    .concept__logo {
        width: 156px;
        height: auto;
    }

    .logo__txt {
        font-size: 2.4rem;
        padding: 0;
    }

    .plus {
        font-size: 1.6rem;
    }

    .concept__photo {
        width: 100vw;
        height: auto;
    }

    .concept__img {
        width: 375px;
    }
}

/* sp 767px */

/*====================
botton-arrow
=====================*/
.button-arrow-about {
    width: 200px;
}

.button-arrow-about a {
    font-family: "Cormorant Garamond";
    font-size: 4rem;
    color: var(--primary-black);
    font-weight: 500;
    display: block;
    position: relative;
    box-sizing: border-box;
    max-width: 200px;
    text-align: center;
    padding: 4px 16px 4px 0;
    margin: 24px;
    margin-inline: auto;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.3s;
}

.button-arrow-about a::before {
    content: "";
    display: block;
    position: absolute;
    width: 200px;
    height: 1px;
    background: var(--primary-black);
    bottom: 0;
    transition: all 0.3s;
}

.button-arrow-about a::after {
    content: "";
    display: block;
    position: absolute;
    width: 30px;
    height: 1px;
    background: var(--primary-black);
    rotate: 40deg;
    right: -3px;
    bottom: 10px;
    transition: all 0.3s;
}

.button-arrow-about a:hover::after,
.button-arrow-about a:hover::before {
    translate: 20px 0;
    transition: all 0.3s;
}


/*====================
strengths
=====================*/
.section--strengths {
    display: flex;
    background: url(../images/strengths_background.jpg) no-repeat;
    background-size: cover;
    background-position-x: 10%;
    background-position-y: bottom;
    padding: 200px 10.4% 300px;
    flex-direction: column;
    gap: 100px;
    max-width: 100%;
    margin: 0 auto;
    align-items: center;
    z-index: 0;
}

.strengths--list {
    display: flex;
    align-items: start;
    justify-content: space-around;
    gap: 2.7%;
}

.strengths--item {
    border-radius: 45px 0px;
    background: rgba(255, 255, 255, 0.60);
    display: flex;
    width: 100%;
    padding: 100px 2% 40px;
    flex-direction: column;
    align-items: flex-start;
}

.digit {
    color: #FFFEFE;
    /* No. */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
    font-family: "Bonheur Royale";
    font-size: 14rem;
    line-height: 28.571%;
    margin-top: -130px;
    margin-bottom: 54px;
    margin-left: -30px;
}

.list--item--box {
    display: flex;
    padding: 0px 10px 20px;
    align-self: stretch;
    border-bottom: 1px solid var(--primary-blue);
    margin-bottom: 60px;
}

.list--itemTitle {
    font-size: 2rem;
}

.strengths--txt {
    font-family: "Zen Kaku Gothic New";
    font-size: 1.6rem;
    font-weight: 400px;
    line-height: 1.8;
    margin-bottom: 40px;
}

.strengths--item:nth-child(2) {
    margin-top: 240px;
}

.strengths--item:nth-child(3) {
    margin-top: 520px;
}

/* common sp&tb(1023px以下） */
@media screen and (max-width: 1023px) {
    .section--strengths {
        background: url(../images/strengths_background_sp.jpg) no-repeat;
        background-size: cover;
        background-position: bottom;
        display: flex;
        padding: 120px 4.2% 100%;
        flex-direction: column;
        align-items: center;
        gap: 120px;
        align-self: stretch;
    }

    .strengths--list {
        display: flex;
        flex-direction: column;
        gap: 40px;
    }

    .strengths--item {
        width: 100%;
        padding: 100px 30px 40px;
    }

    .strengths--item:nth-child(2) {
        margin-top: 120px;
    }

    .strengths--item:nth-child(3) {
        margin-top: 120px;
    }

    .digit {
        font-size: 12rem;
        line-height: 28.571%;
        margin-top: -124px;
        margin-bottom: 54px;
        margin-left: -30px;
    }
}

/* sp&tb 1023px */

/*====================
service
=====================*/
.section--service {
    background: var(--beige_gradation, linear-gradient(305deg, #F7F2EC 5.39%, #F7F0E8 34.87%, #EEE3D6 75.63%));
    display: flex;
    width: 100%;
    padding: 200px 10.4%;
    flex-direction: column;
    align-items: center;
    gap: 100px;
}

.service--list,
.service--sub-list {
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 2.7%;
}

/* PC版：コンサルティングを大きく表示 */
.service--list {
    margin-bottom: 2.7%;
}

.service--item-consulting {
    width: 100%;
    max-width: 100%;
}

/* PC版：プレゼンとデザインを横並びに */
.service--sub-list {
    flex-wrap: nowrap;
}

.service--item-presentation,
.service--item-design {
    width: 48%;
}

.service--item {
    border-radius: 8px;
    background: #FFFEFE;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    padding: 80px 40px 80px;
}

.service--title {
    font-family: "Cormorant Garamond";
    font-size: 4vw; /* PC版ではビューポート幅に合わせて調整 */
    line-height: 1;
}

.service--tit_ja {
    font-size: 1.8vw; /* PC版ではビューポート幅に合わせて調整 */
    line-height: 1;
}

.service--txt {
    font-family: "Zen Kaku Gothic New";
    font-size: 1.6rem;
    line-height: 1.8;
}

.service--img {
    width: 100%;
}

/* sp(767px以下） */
@media screen and (max-width: 767px) {
    .service--list,
    .service--sub-list {
        flex-direction: column;
        gap: 40px;
    }

    .service--item {
        width: 100%;
    }

    .service--item-presentation,
    .service--item-design {
        width: 100%; /* スマホ版で幅を100%に */
    }

    .service--title {
        font-size: 8vw; /* スマホ版では大きく表示 */
    }

    .service--tit_ja {
        font-size: 2vw; /* スマホ版では大きく表示 */
    }
}
/*====================
botton-arrow
=====================*/
.button-arrow-view {
    width: 280px;
}

.button-arrow-view a {
    font-family: "Cormorant Garamond";
    font-size: 4rem;
    color: var(--primary-black);
    font-weight: 500;
    display: block;
    position: relative;
    box-sizing: border-box;
    max-width: 260px;
    text-align: center;
    padding: 4px 16px 4px 0;
    margin: 24px;
    margin-inline: auto;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.3s;
}

.button-arrow-view a::before {
    content: "";
    display: block;
    position: absolute;
    width: 260px;
    height: 1px;
    background: var(--primary-black);
    bottom: 0;
    transition: all 0.3s;
}

.button-arrow-view a::after {
    content: "";
    display: block;
    position: absolute;
    width: 30px;
    height: 1px;
    background: var(--primary-black);
    rotate: 40deg;
    right: -2px;
    bottom: 10px;
    transition: all 0.3s;
}

.button-arrow-view a:hover::after,
.button-arrow-view a:hover::before {
    translate: 20px 0;
    transition: all 0.3s;
}

/* common sp(599px以下） */
@media screen and (max-width: 599px) {
    .section--service {
        background: var(--beige_gradation, linear-gradient(305deg, #F7F2EC 5.39%, #F7F0E8 34.87%, #EEE3D6 75.63%));
        display: flex;
        padding: 120px 4.2%;
        flex-direction: column;
        align-items: center;
        gap: 80px;
        align-self: stretch;
    }

    .service--list {
        display: flex;
        flex-direction: column;
        gap: 80px;
    }

    .service--title {
        font-family: "Cormorant Garamond";
        font-size: 4.8rem;
        line-height: 1;
    }

    .service--tit_ja {
        font-size: 2rem;
        line-height: 1;
    }
}

/* sp 599px */

/* トップページ内のサービスセクションのレイアウトを修正 */
.service--sub-list {
    flex-wrap: wrap; /* 要素を折り返す */
}

.service--item-presentation,
.service--item-design {
    width: 100%; /* 幅を100%にして縦に並べる */
}

/*====================
topページ専用のserviceセクション
=====================*/
.section--service {
    background: var(--beige_gradation, linear-gradient(305deg, #F7F2EC 5.39%, #F7F0E8 34.87%, #EEE3D6 75.63%));
    display: flex;
    width: 100%;
    padding: 200px 10.4%;
    flex-direction: column;
    align-items: center;
    gap: 100px;
}

.service--list,
.service--sub-list {
    display: flex;
    justify-content: space-between;
    width: 100%;
    gap: 2.7%;
}

.service--list {
    margin-bottom: 2.7%;
}

.service--item-consulting {
    width: 100%;
    max-width: 100%;
}

.service--sub-list {
    flex-wrap: nowrap;
}

.service--item-presentation,
.service--item-design {
    width: 48%;
}

.service--item {
    border-radius: 8px;
    background: #FFFEFE;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    padding: 80px 40px 80px;
}

/* スマホ表示の修正 */
@media screen and (max-width: 599px) {
    .section--service {
        padding: 100px 4.2%;
        gap: 50px;
    }

    .service--sub-list {
        flex-direction: column;
    }

    .service--item-presentation,
    .service--item-design {
        width: 100%;
        margin-bottom: 2.7%;
    }
}