@charset "utf-8";


/* =================
main
==================== */
/* =================
section concept
==================== */

.section.section--concept {
    padding: var(--contentPadding);
}

.topic {
    margin-top: 120px;
}

.topic__subTitle {
    text-align: center;
}

.conceptDetail {
    margin-top: 50px;
}

.conceptDetail__imgPC {
    display: none;
}

.conceptGroup {
    padding: 30px 20px 30px;
    background: rgba(228, 233, 231, 0.80);
}

.conceptGroup.conceptGroup--second {
    background: rgba(233, 228, 222, 0.80);
}


.conceptGroup__title {
    text-align: center;
    font-size: 2rem;
    font-weight: 500;
}

.conceptGroup__txt {
    margin-top: 20px;
    line-height: 150%;
}

.conceptDetail.conceptDetail--second {
    margin-top: 4px;
}

.concept__slider {
    margin-top: 50px;

}

.concept__slider__SP {
    max-width: 335px;
}


/* 自己紹介 */
.introduction {
    margin-top: 50px;
    background: rgba(228, 233, 231, 0.80);
}

.introductionGroup {
    padding: 30px 20px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

.introductionGroup__title {
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.5;
}

.introductionGroup__txt {
    line-height: 1.5;
    margin-top: 20px;
}

.about {
    margin-top: 20px;
}

.about__title {
    padding: 5px;
    background: var(--primary-white);
    font-size: 1.4rem;
    line-height: 1.5;
    width: 185px;
}

.about__txt {
    padding: 10px;
    background: var(--primary-white);
    font-size: 1.4rem;
    line-height: 1.5;
    margin-top: 5px;
}


/*=========================
 tab concept 769px 
 ==========================*/
@media screen and (min-width: 769px) {
    .conceptDetail {
        margin-top: 100px;
    }

    .concept__vis {
        display: block;
    }

    .concept__vis__PC {
        width: 22.5%;
    }

    .conceptDetail__imgPC {
        display: block;
    }

    .conceptDetail__imgSP {
        display: none;
    }

    .conceptDetail {
        position: relative;
    }

    .conceptGroup {
        width: 36.5%;
        position: absolute;
        top: 0;
        right: 0;
    }

    .conceptDetail.conceptDetail--second {
        margin-top: 50px;
        position: relative;
    }

    .conceptGroup.conceptGroup--second {
        width: 36.5%;
        position: absolute;
        top: 0;
        left: 0;
    }

    .concept__slider {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-top: 100px;
    }

    .concept__slider__SP {
        width: 22.5%;
    }


    .introduction {
        display: flex;
        margin-top: 100px;
        margin-bottom: 100px;
    }

    .introduction__img {
        width: 32.4%;
        height: 43.9%;
    }

}

/* tab 769px */

/*=========================
 PC concept 1280px 
 ==========================*/
@media screen and (min-width: 1280px) {
    .conceptGroup {
        padding: 50px 20px;
    }

    .conceptGroup__txt {
        margin-top: 24px;
    }


    .introductionGroup {
        padding: 50px 20px;
    }

    .introductionGroup__txt {
        margin-top: 24px;
    }
}

/* pc 1280px */


















.detail {
    text-align: center;
    margin-top: 30px;
}

.plan__item {
    padding: 20px 20px;
    background: var(--primary-beige);
    margin-top: 30px;
    justify-content: center;
}

.planDetail__title {
    display: flex;
    flex-direction: column;
    align-items: left;
    margin-top: 20px;
}

.planDetail__title__name {
    color: var(--primary-brown);
    font-family: Sacramento;
    font-size: 3.2rem;
    line-height: 1.2;
}

.planDetail__title__txt {
    font-size: 2.4rem;
}

.planDetail__txt {
    margin-top: 20px;
}

.btn.btn--plan {
    width: 250px;
}

.plan__item--second {
    background: var(--primary-green);
    margin-top: 30px;
    padding: 20px 20px;
    justify-content: center;
}

/* pc plan */
@media screen and (min-width: 769px) {
    .topic {
        padding: var(--contentPaddingPC);
        margin-top: 210px;
    }

    .detail {
        margin-top: 50px;
    }

    .plan__item,
    .plan__item--second {
        margin-top: 50px;
        padding: 30px 30px;
        display: flex;
    }

    .planTitle {
        display: block;
    }

    .plan__img {
        width: 37%;
        height: 85%;
    }

    .plan__item--second {
        margin-top: 50px;
    }

    .planDetail {
        margin-left: 30px;
        gap: 20px;
    }


    .planBtn {
        display: flex;
        flex-wrap: wrap;
        gap: 10px 20px;
        margin-top: 20px;
    }

    .btn.btn--plan,
    .btn.btn--plan753 {
        margin: 0;
    }
}

/* pc 769px */