@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

body.cheer.examination #CntBox .ShopBox,
body.cheer.shop #CntBox .ShopBox,
body.cheer.club #CntBox .ShopBox {
    margin: 0;
    border-radius: 0;
}

body.cheer.examination #CntBox p.AdmissionBtn,
body.cheer.shop #CntBox p.AdmissionBtn,
body.cheer.club #CntBox p.AdmissionBtn {
    padding: 50px 0 80px;
    margin: 0;
    background-color: #fff;
}
@media screen and (min-width: 768px) {
    body.cheer.examination #CntBox p.AdmissionBtn,
    body.cheer.shop #CntBox p.AdmissionBtn,
    body.cheer.club #CntBox p.AdmissionBtn {
        padding: 60px 0 125px;
    }
}
body.cheer.examination #CheerMenuBox,
body.cheer.shop #CheerMenuBox,
body.cheer.club #CheerMenuBox {
    margin: 0;
}

body.cheer.examination #CntBox,
body.cheer.shop #CntBox,
body.cheer.club #CntBox {
    margin: 0 auto;
}
body.cheer.club #CntBox h2 {
    margin: 0;
}
@media screen and (min-width: 768px) {
    body.cheer.club #CntBox h2 {
        background-color: #fff;
    }
}
body.cheer.shop .ShopTobira {
    background-image: unset;
    padding: 34px 0px 0px;
}
.cheer_post * {
    box-sizing: border-box;
}

.cheer_sub_page .bg_white {
    background-color: #fff;
}
.cheer_sub_page.bg_students,
.cheer_sub_page .bg_students {
    background-color: #30bac5;
}
.cheer_sub_page #CheerMenuBox.bg_students {
    background: #30bac5;
}
.cheer_sub_page .Students .TitleLeft {
    background-color: #30bac5;
}

.cheer_sub_page.bg_teacher,
.cheer_sub_page .bg_teacher {
    background-color: #6eb92b;
}
.cheer_sub_page #CheerMenuBox.bg_teacher {
    background: #6eb92b;
}
.cheer_sub_page .Students.bg_teacher .TitleLeft {
    background-color: #6eb92b;
}

.cheer_teacher .StudentsTobira h1,
.cheer_teacher .Students .CatTitle {
    color: #6eb92b;
}

.cheer_sub_page.bg_money,
.cheer_sub_page .bg_money {
    background-color: #a97bb0;
}
.cheer_sub_page #CheerMenuBox.bg_money {
    background: #a97bb0;
}
.cheer_sub_page .Students.bg_money .TitleLeft {
    background-color: #a97bb0;
}

.cheer_money .StudentsTobira h1,
.cheer_money .Students .CatTitle {
    color: #a97bb0;
}

.cheer_sub_page.bg_graduate,
.cheer_sub_page .bg_graduate {
    background-color: #0ba95f;
}
.cheer_sub_page #CheerMenuBox.bg_graduate {
    background: #0ba95f;
}
.cheer_sub_page .Students.bg_graduate .TitleLeft {
    background-color: #0ba95f;
}

.cheer_graduate .StudentsTobira h1,
.cheer_graduate .Students .CatTitle {
    color: #0ba95f;
}

.cheer_sub_page #CheerMenuBox ul {
    background-color: #fff;
}
.cheer_sub_page #CntBox {
    margin: 0px auto;
}
.cheer_sub_page #TitleBox {
    height: auto;

    display: flex;
    flex-direction: column;
}
@media screen and (min-width: 768px) {
    .cheer_sub_page #TitleBox {
        flex-direction: row;
        min-height: 400px;
    }
}
.cheer_sub_page .TitleLeft {
    height: 100%;
}
.cheer_sub_page .TitleLeft,
.cheer_sub_page .TitleRight {
    float: none;
}
.cheer_sub_page .TitleRight {
    position: relative;
    background: #ccc;
}
.cheer_sub_page .txt_dummy {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    color: #808080;
}
.cheer_sub_page .TitleRight img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (min-width: 768px) {
    .cheer_sub_page #CntBox {
        padding: 0 0 50px;
    }
}
.cheer_sub_page #CntBox p.AdmissionBtn {
    margin: 0 auto;
    padding: 80px 0 0;
}

.cheer_sub_page #CheerMenuBox {
    margin: 0;
    padding: 100px 0 0;
}
.cheer_sub_page #Pankuzu,
.cheer_sub_page #Pankuzu span,
.cheer_sub_page #Pankuzu a {
    color: #fff;
}
.cheer_sub_page #Pankuzu.bg_white,
.cheer_sub_page #Pankuzu.bg_white span,
.cheer_sub_page #Pankuzu.bg_white a {
    background-color: #fff;
    color: #808080;
}
#CntBox .cheer_posts {
    padding: 10px 0 0;
}

@media screen and (min-width: 768px) {
    #CntBox .cheer_posts {
        padding: 20px 0 0;
    }
}
#CntBox .cheer_post {
    width: 100%;
    margin: 75px auto 0;
    padding: 0 10px;
    box-sizing: border-box;
}
@media screen and (min-width: 768px) {
    #CntBox .cheer_post {
        padding: 0 40px;
    }
}
#CntBox .cheer_post:first-child {
    margin: 0 auto;
}
#CntBox .cheer_post_link {
    width: 100%;
    display: flex;
    flex-direction: column;

    background: linear-gradient(
            0deg,
            rgba(255, 255, 255, 0.3) 75%,
            transparent 0%
        )
        no-repeat;
    text-decoration: none !important;
    text-underline-offset: 0 !important;
    color: #fff;
}
@media screen and (min-width: 768px) {
    #CntBox .cheer_post_link {
        flex-direction: row;
        background: rgba(255, 255, 255, 0.3);
    }
    #CntBox .cheer_post_link:hover {
        transition: all 0.5s;
        opacity: 1;
        background: rgba(255, 255, 255, 0.5);
    }
}

@media screen and (min-width: 768px) {
    #CntBox .cheer_post:nth-child(even) .cheer_post_link {
        flex-direction: row-reverse;
    }
}
#CntBox .cheer_post .cheer_post_img {
    margin: 0;
    width: 220px;
    position: relative;
    background: #ccc;
    overflow: hidden;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
}
@media screen and (min-width: 768px) {
    #CntBox .cheer_post .cheer_post_img {
        margin: 0;
    }
}
#CntBox .cheer_post .cheer_post_img img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}
#CntBox .cheer_post_info {
    width: 100%;
    margin: 0;
    padding: 30px 23px;
}

@media screen and (min-width: 768px) {
    #CntBox .cheer_post_info {
        width: calc(100% - 220px);
    }
}
@media screen and (min-width: 1025px) {
    #CntBox .cheer_post_info {
        padding: 39px 49px 45px;
    }
}
#CntBox .cheer_post_info_quote,
#CntBox .cheer_post_info_department,
#CntBox .cheer_post_info_name,
#CntBox .cheer_post_info_txt_slant_mark {
    margin: 0;
    display: inline-block;
    color: #fff;
}
#CntBox .cheer_post_info_quote {
    font-family: 'Noto Serif JP', serif;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: calc(35 / 18);
}

@media screen and (min-width: 1025px) {
    #CntBox .cheer_post_info_quote {
        font-size: 23px;
        line-height: calc(45 / 23);
    }
}
#CntBox .cheer_post_info_quote br {
    display: none;
}
@media screen and (min-width: 768px) {
    #CntBox .cheer_post_info_quote br {
        display: block;
    }
}

#CntBox .cheer_post_info_department,
#CntBox .cheer_post_info_name,
#CntBox .cheer_post_info_txt_slant_mark {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: bold;
    letter-spacing: 0.1em;
    font-size: 14px;
    margin-top: 15px;
    line-height: calc(25 / 14);
}

@media screen and (min-width: 1025px) {
    #CntBox .cheer_post_info_department,
    #CntBox .cheer_post_info_name,
    #CntBox .cheer_post_info_txt_slant_mark {
        font-size: 18px;
        line-height: 1.5em;
    }
}

#CntBox .cheer_post.no_quote .cheer_post_info_department,
#CntBox .cheer_post.no_quote .cheer_post_info_name,
#CntBox .cheer_post.no_quote .cheer_post_info_txt_slant_mark {
    margin-top: 0;
}

#CntBox .cheer_students_single_description img {
    max-width: 820px;
    width: 100%;
    margin: 20px auto;
}

.cheer_teacher .TeacherText {
    text-align: center;
}
.cheer_teacher_single_bnr,
.cheer_graduate_single_bnr {
    box-sizing: border-box;
    margin: 60px auto 0;
    width: 100%;
    padding: 0 10px;
    text-align: center;
}
@media screen and (min-width: 768px) {
    .cheer_teacher_single_bnr,
    .cheer_graduate_single_bnr {
        padding: 0 40px;
    }
}
.cheer_money #CntBox {
    padding-top: 20px;
}

#CntBox p.cheer_money_single_desc01 {
    text-align: center;
    margin: 0 10px 20px;
}
@media screen and (min-width: 768px) {
    #CntBox p.cheer_money_single_desc01 {
        margin: 0 40px 20px;
    }
}

.cheer_money_single_desc02 img {
    max-width: 820px;
    width: 100%;
    margin: 20px auto;
}

.cheer_money_single_img_chart {
    text-align: center;
}
.cheer_money_single_img_chart img {
    margin: 10px;
}
.cheer_graduate #CntBox {
    padding-top: 20px;
}
.cheer_graduate #CntBox p.GraduateText {
    margin: 0 10px 20px;
}
@media screen and (min-width: 768px) {
    .cheer_graduate #CntBox p.GraduateText {
        margin: 0 40px 20px;
    }
}
.cheer #CntBox .ShopBox.txt_head p {
    text-align: left;
}
@media screen and (min-width: 768px) {
    .cheer #CntBox .ShopBox.txt_head p {
        margin: 0;
        text-align: center;
    }
}
.cheer.examination #CntBox {
    background-color: #fff;
}
body.cheer.examination #CntBox h3:first-child {
    margin-top: 0;
}
body.cheer.examination #CntBox h2 {
    margin-left: 0;
    margin-right: 0;
}
body.cheer.examination #CntBox {
    padding-top: 30px;
}
.cheer_sub_page #CntBox h2 {
    margin-left: 0;
    margin-right: 0;
}
