.container{
    padding-bottom: 0;
}

/* sect_visual */
.sect_main-banner{
    position: relative;
}

/* main_banner */
.main_banner,
.main_banner .swiper,
.main_banner .swiper-slide a{
    height: 100%;
    max-width: 1920px;
    margin: 0 auto;
}
.main_banner_item{
    overflow: hidden;
}
.main_banner_item a[href="#none"]{
    user-select: none;
    pointer-events: none;
}
.main_banner_item.swiper-slide-active{
    z-index: 10;
}
.main_banner img{
    width: 100%;
}
.main_banner .pagination_wr{
    position: absolute;
    bottom: 20px;
    right: 20px;

    text-align: right;
}
.main_banner .swiper-pagination-fraction{
    display: inline-flex;
    position: relative;
    width: auto;
    left: auto;
    bottom: auto;
    right: auto;

    padding: 2px 6px;
    border-radius: 100px;
    background: rgba(51, 51, 51, 0.40);

    color: rgba(255, 255, 255, 0.60);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.1em;
}
.main_banner .swiper-pagination-fraction .swiper-pagination-current{
    color: var(--color-white);
}

/* belt_banner */
.belt_banner{
    position: absolute;
    top: 8px;
    left: 0;
    
    width: 100%;
    padding: 0 15px;
}
.belt_banner img{
    width: 100%;
}
.belt_banner .swiper{
    border-radius: 6px;
}
.belt_banner .swiper-pagination{
    display: flex;
    align-items: center;
    justify-content: center;

    top: 100%;
    bottom: auto;

    margin-top: 10px;
}
.belt_banner .swiper-pagination-bullet{
    opacity: 0.4;
    width: 6px;
    height: 6px;

    background: var(--color-gray-8);
}
.belt_banner .swiper-pagination-bullet-active{
    opacity: 1;
}
@media (min-width: 1025px){
    /* main_banner */
    .main_banner{
        height: 580px;
    }
    .main_banner img{
        width: auto;
        max-width: none;
        height: 100%;
    }
    .main_banner_item,
    .main_banner_item a{
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .main_banner .pagination_wr{
        left: 50%;
        width: 100%;
        max-width: 840px;
        margin-left: -420px;
    }
    .main_banner .swiper-pagination-fraction{
        padding: 3px 8px;
        font-size: 14px;
    }
    .main_banner .swiper-pagination-fraction .swiper-pagination-current{
        color: var(--color-white);
    }

    /* belt_banner */
    .belt_banner{
        top: 10px;
        left: 50%;
        margin-left: -420px;
        
        padding: 0;
        max-width: 840px;
    }
    .belt_banner .swiper-pagination{
        margin-top: 12px;
    }
    .belt_banner .swiper-pagination-bullet{
        width: 8px;
        height: 8px;
    }
}

/* page_common */
.page_sect{
    padding: 60px 0;
}
.page_sect .sect_header{
    margin-bottom: 40px;
    text-align: center;
}
.page_sect .sect_header .headline{
    display: block;
    margin-bottom: 8px;

    font-family: var(--font-2);
    color: var(--color-gray-8);
    font-size: 14px;
    line-height: 1.3;
    letter-spacing: -0.04em;
}
.page_sect .sect_header em.headline{
    display: block;
    color: var(--color-normal-4);
}
.page_sect .sect_header .headline.white,
.page_sect .sect_header em.headline.white{
    color: var(--color-white);
}
.page_sect .sect_header .headline.red,
.page_sect .sect_header em.headline.red{
    color: var(--color-normal-9);
}
.page_sect .sect_header .title{
    display: block;
    color: var(--color-gray-10);

    font-family: var(--font-2);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.25; 
    letter-spacing: -0.04em;
}
.page_sect .sect_header .title.white{
    color: var(--color-white);
}
.page_sect .sect_header .description{
    display: block;
    margin-top: 28px;

    color: var(--color-gray-7);

    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: -0.04em;
}
.page_sect .sect_body{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.page_sect .sect_footer{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    text-align: center;
    margin-top: 40px;
}

@media (min-width: 1025px) {
    .page_sect{
        padding: 80px 0;
    }

    .page_sect .sect_header{
        margin-bottom: 50px;
    }
    .page_sect .sect_header .headline{
        margin-bottom: 12px;
    
        font-size: 20px;
    }
    .page_sect .sect_header .title{
        font-size: 32px;
    }
    .page_sect .sect_header .description{
        margin-top: 32px;

        font-size: 18px;
    }
    .page_sect .sect_footer{
        margin-top: 50px;
    }
}

/* sect_proteacher */
#sect_proteacher .teacher_banner{
    position: relative;
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
}
#sect_proteacher .teacher_banner::before,
#sect_proteacher .teacher_banner::after{
    display: none;

    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: 100%;

    background: linear-gradient(90deg, #FFF 0%, rgba(255, 255, 255, 0.00) 100%);
    z-index: 10;
}
#sect_proteacher .teacher_banner::after{
    left: auto;
    right: 0;
    background: linear-gradient(-90deg, #FFF 0%, rgba(255, 255, 255, 0.00) 100%);
}
#sect_proteacher .teacher_banner .swiper-wrapper{
    transition-timing-function: linear;
}
#sect_proteacher .teacher_item{    
    display: flex;
    flex-direction: column;

    width: 180px;
    height: auto;
    padding: 22px 20px;
    margin: 0 6px;

    background: var(--color-gradient-3);
    border: 1px solid var(--color-normal-1);
    border-radius: 6px;
}
#sect_proteacher .teacher_item .thumb{
    position: relative;
    margin-bottom: 16px;
    border-radius: 50%;
    background: var(--color-white);
    height: 138px;
}
#sect_proteacher .teacher_item .thumb img{
    border-radius: 50%;
}
#sect_proteacher .teacher_item .thumb > a{
    display: block;
    width: 100%;
    height: 100%;
}
#sect_proteacher .teacher_item .thumb div.img{
    width: 100%;
    height: 100%;
    background-position: center;
    background-size: cover;
    border-radius: 50%;
}
#sect_proteacher .teacher_item .thumb .badge{
    position: absolute;
    top: 0;
    right: 0;
    width: 27px;
    height: 40px;

    background: url(../../../img/common/badge.png) no-repeat center / cover;
    z-index: 10;
}
#sect_proteacher .teacher_item .info{
    flex: 1;

    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
#sect_proteacher .teacher_item .info .title{
    color: var(--color-gray-8);
    
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: -0.04em;    
}
#sect_proteacher .teacher_item .info .title a{
    position: relative;
    padding-right: 11px; 
}
#sect_proteacher .teacher_item .info .title a::after{
    content: '';
    position: absolute;
    top: 50%;
    right: 0;
    width: 7px; 
    height: 12px;
    margin-top: -7px;
    background: url(../../../img/ico/ico_arw-teacher.png) no-repeat center / contain;
    vertical-align: top;
}
#sect_proteacher .teacher_item .info .name{
    color: var(--color-gray-10);
    font-weight: 700;
}
#sect_proteacher .teacher_item .info ul{
    flex: 1;
    margin: 10px 0;
}
#sect_proteacher .teacher_item .info li{
    position: relative;
    padding-left: 6px;

    color: var(--color-gray-7);
    line-height: 1.55;

    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
#sect_proteacher .teacher_item .info li + li{
    margin-top: 2px;
}
#sect_proteacher .teacher_item .info li::before{
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 2px;
    height: 2px;
    margin-top: -1px;
    background: var(--color-gray-7);
    border-radius: 50%;
}
#sect_proteacher .teacher_item .info .rate{
    position: relative;
    padding: 2px 4px 2px 18px;
    background: var(--color-normal-8);
    border-radius: 4px;
    
    color: var(--color-normal-9);
    font-size: 12px;
    font-weight: 500;
}
#sect_proteacher .teacher_item .info .rate::before{
    content: '';
    position: absolute;
    top: 50%;
    left: 4px;
    width: 12px;
    height: 12px;
    margin-top: -6px;

    background: url(../../../img/common/rate_star.png) no-repeat center / cover;
}

@media (min-width: 601px) {
    #sect_proteacher .teacher_banner::before,
    #sect_proteacher .teacher_banner::after{
        display: block;
    }
}

@media (min-width: 1025px) {
    #sect_proteacher .teacher_banner{
        max-width: 840px;
    }
    #sect_proteacher .teacher_item{    
        width: 236px;
        padding: 30px 28px;
        margin: 0 10px;

        border-radius: 8px;
    }
    #sect_proteacher .teacher_item .thumb{
        margin-bottom: 24px;
        height: 178px;
    }
    #sect_proteacher .teacher_item .thumb .badge{
        width: 30px;
        height: 44px;
    }
    #sect_proteacher .teacher_item .info .title{
        
        font-size: 20px;
    }
    #sect_proteacher .teacher_item .info .title a{
        padding-right: 15px;         
    }
    #sect_proteacher .teacher_item .info .title a::after{
        width: 11px; 
        height: 16px;
        margin-top: -8px;
    }    
    #sect_proteacher .teacher_item .info ul{
        margin: 16px 0;
    }
    #sect_proteacher .teacher_item .info li{
        padding-left: 8px;
    
        font-size: 16px;
        line-height: 1.5;
    }        
    #sect_proteacher .teacher_item .info .rate{
        padding: 4px 6px 4px 26px;

        font-size: 16px;
    }
    #sect_proteacher .teacher_item .info .rate::before{
        left: 6px;
        width: 16px;
        height: 16px;
        margin-top: -8px;
    }
}

/* sect_meetteacher */
#sect_meetteacher{
    background: linear-gradient(180deg, rgba(146, 128, 255, 0.00) 0%, rgba(187, 193, 254, 0.15) 62.43%, rgba(209, 227, 253, 0.50) 100%);
}
#sect_meetteacher .meet_chat{
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
}
#sect_meetteacher .meet_chat .chat_box{
    display: flex;
    align-items: center;    

    gap: 12px;
}
#sect_meetteacher .meet_chat .chat_box.reverse{
    flex-direction: row-reverse;
}
#sect_meetteacher .meet_chat .chat_box + .chat_box{
    margin-top: 16px;
}
#sect_meetteacher .meet_chat .chat_box .emoji{
    overflow: hidden;
    border-radius: 50%;
    background: var(--color-normal-3);
    box-shadow: 2px 2px 8px 0px rgba(65, 101, 134, 0.2);
}
#sect_meetteacher .meet_chat .chat_box .emoji img{
    width: 40px;
}
#sect_meetteacher .meet_chat .chat_box .chat{
    position: relative;
    padding: 12px 20px;
    border-radius: 100px;
    background: var(--color-white);
    box-shadow: 2px 4px 15px 0px rgba(64, 87, 128, 0.06);

    color: var(--color-gray-10);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: -0.04em;
}
#sect_meetteacher .meet_chat .chat_box .chat span{
    color: var(--color-normal-9);
}
#sect_meetteacher .meet_chat .chat_box .chat::after{
    content: '';
    position: absolute;
    top: 50%;
    right: 100%;
    margin-top: -7px;
    margin-right: -4px;

    width: 12px;
    height: 14px;

    background: url(../../../img/main/meetteacher/chat_heel.png) no-repeat center / cover;
}
#sect_meetteacher .meet_chat .chat_box.reverse .chat::after{
    left: 100%;
    margin-left: -4px;

    right: auto;
    margin-right: 0;

    transform: rotate(180deg);
}
#sect_meetteacher .sect_footer p{
    opacity: 0.6;

    color: var(--color-gray-10);

    font-size: 16px;
    line-height: 1.5;
    letter-spacing: -0.04em;
}

@media (min-width: 1025px) {
    #sect_meetteacher{
        background: linear-gradient(180deg, rgba(146, 128, 255, 0.00) 0%, rgba(187, 193, 254, 0.15) 62.43%, rgba(209, 227, 253, 0.50) 100%);
    }
    #sect_meetteacher .meet_chat{
        max-width: 620px;
    }
    #sect_meetteacher .meet_chat .chat_box{
        gap: 18px;
    }
    #sect_meetteacher .meet_chat .chat_box + .chat_box{
        margin-top: 30px;
    }
    #sect_meetteacher .meet_chat .chat_box .emoji img{
        width: 64px;
    }
    #sect_meetteacher .meet_chat .chat_box .chat{
        padding: 18px 34px;

        font-size: 20px;
    }
    #sect_meetteacher .meet_chat .chat_box .chat::after{
        margin-top: -12px;
        margin-right: -9px;
    
        width: 21px;
        height: 24px;
    }
    #sect_meetteacher .meet_chat .chat_box.reverse .chat::after{
        left: 100%;
        margin-left: -9px;
    }
    #sect_meetteacher .sect_footer p{
        font-size: 18px;
        letter-spacing: -0.02em;
    }
}

/* sect_edusystem - system */
#sect_edusystem{
    background: var(--color-gradient-3-reverse);
}
#sect_edusystem .system .sect_body{
    padding: 0 10px;
}
#sect_edusystem .system .grade_wrap{
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
}
#sect_edusystem .system .grade + .grade{
    margin-top: 20px;
} 
#sect_edusystem .system .grade_title{
    padding-bottom: 12px;
    margin-bottom: 12px;
    border-bottom: 1px solid #eee;
    font-weight: 600;
} 
#sect_edusystem .system .item_box{
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.85) 0%, rgba(255, 255, 255, 0.85) 100%), #638FDB;
    border-radius: 100px;
    display: flex;
    align-items: center;
    gap: 13px;
} 
#sect_edusystem .system .item_box + .item_box{
    margin-top: 6px;
} 
#sect_edusystem .system .item_box em{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 66px;
    height: 36px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 50px;
    
    font-size: 12px;
    color: var(--color-normal-4);
    font-weight: 600;
    line-height: 1;
    text-align: center;
    letter-spacing: -0.04em;
} 
#sect_edusystem .system .item_box .item{
    display: flex;
}
#sect_edusystem .system .item_box .item span{
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
} 
#sect_edusystem .system .item_box .item span + span{
    position: relative;
    padding-left: 7px;
    margin-left: 7px;
} 
#sect_edusystem .system .item_box .item span + span::before{
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 8px;
    background: rgba(51,51,51,0.3);
}

#sect_edusystem .system .grade_middle .item_box:nth-of-type(2){
    margin-right: 10px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.90) 0%, rgba(255, 255, 255, 0.90) 100%), #638FDB;
}

#sect_edusystem .system .grade_elem em{
    color: var(--color-normal-6);
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(1){
    margin-right: 20px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.70) 0%, rgba(255, 255, 255, 0.70) 100%), #9280FF;
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(2){
    margin-right: 30px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.74) 0%, rgba(255, 255, 255, 0.74) 100%), #9280FF;
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(3){
    margin-right: 40px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.78) 0%, rgba(255, 255, 255, 0.78) 100%), #9280FF;
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(4){
    margin-right: 50px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.82) 0%, rgba(255, 255, 255, 0.82) 100%), #9280FF;
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(5){
    margin-right: 60px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.86) 0%, rgba(255, 255, 255, 0.86) 100%), #9280FF;
}
#sect_edusystem .system .grade_elem .item_box:nth-of-type(6){
    margin-right: 70px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.90) 0%, rgba(255, 255, 255, 0.90) 100%), #9280FF;
}

#sect_edusystem .system .grade_preelem em{
    color: var(--color-normal-9);
}
#sect_edusystem .system .grade_preelem .item_box:nth-of-type(1){
    margin-right: 80px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.85) 0%, rgba(255, 255, 255, 0.85) 100%), #EB595F;
}
#sect_edusystem .system .grade_preelem .item_box:nth-of-type(2){
    margin-right: 90px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.90) 0%, rgba(255, 255, 255, 0.90) 100%), #EB595F;
}

@media (min-width: 1025px) {
    #sect_edusystem .system .sect_body{
        padding: 0;
    }
    #sect_edusystem .system .grade_wrap{
        max-width: 620px;
    }
    #sect_edusystem .system .grade + .grade{
        margin-top: 24px;
    } 
    #sect_edusystem .system .grade_title{
        padding-bottom: 14px;
        margin-bottom: 14px;

        font-size: 16px;
    } 
    #sect_edusystem .system .item_box{
        gap: 20px;
    } 
    #sect_edusystem .system .item_box + .item_box{
        margin-top: 8px;
    } 
    #sect_edusystem .system .item_box em{
        width: 100px;
        height: 50px;
        font-size: 16px;
    } 
    #sect_edusystem .system .item_box .item span{
        font-size: 16px;
    } 
    #sect_edusystem .system .item_box .item span + span{
        position: relative;
        padding-left: 17px;
        margin-left: 17px;
    } 
    #sect_edusystem .system .item_box .item span + span::before{
        width: 1px;
        height: 12px;
    }
    #sect_edusystem .system .grade_middle .item_box:nth-of-type(2){
        margin-right: 25px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(1){
        margin-right: 50px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(2){
        margin-right: 75px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(3){
        margin-right: 100px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(4){
        margin-right: 125px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(5){
        margin-right: 150px;
    }
    #sect_edusystem .system .grade_elem .item_box:nth-of-type(6){
        margin-right: 175px;
    }
    #sect_edusystem .system .grade_preelem .item_box:nth-of-type(1){
        margin-right: 200px;
    }
    #sect_edusystem .system .grade_preelem .item_box:nth-of-type(2){
        margin-right: 225px;
    }
}

/* sect_edusystem - situation | smart */
#sect_edusystem .situation{
    margin-top: 80px;
}
#sect_edusystem .smart{
    margin-top: 80px;
}

#sect_edusystem .situation .pic{
    max-width: 276px;
}

#sect_edusystem .smart .pic{
    max-width: 205px;
}

#sect_edusystem .edusystem_list{
    width: 100%;
    max-width: 480px;
    margin: 40px auto 0;
    padding: 20px;
    border: 1px solid var(--color-normal-1);
    background: var(--color-white);
    border-radius: 6px;
}
#sect_edusystem .edusystem_item + .edusystem_item{
    padding-top: 16px;
    margin-top: 16px;
    border-top: 1px solid var(--color-normal-1);
}
#sect_edusystem .edusystem_item .title{
    display: block;
    margin-bottom: 6px;
    color: var(--color-normal-5);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
}
#sect_edusystem .edusystem_item [class*=ico]{
    padding-left: 24px;
    background-repeat: no-repeat;
    background-position: center left;
    background-size: 20px auto;
}
#sect_edusystem .edusystem_item .ico_student{
    background-image: url(../../../img/ico/ico_student.png);
}
#sect_edusystem .edusystem_item .ico_teacher{
    background-image: url(../../../img/ico/ico_teacher.png);
}
#sect_edusystem .edusystem_item .ico_parents{
    background-image: url(../../../img/ico/ico_parents.png);
}
#sect_edusystem .edusystem_item .ico_diagnosis{
    background-image: url(../../../img/ico/ico_diagnosis.png);
}
#sect_edusystem .edusystem_item .ico_prescription{
    background-image: url(../../../img/ico/ico_prescription.png);
}
#sect_edusystem .edusystem_item .ico_training{
    background-image: url(../../../img/ico/ico_training.png);
}
#sect_edusystem .edusystem_item .description{
    color: var(--color-gray-8);
    line-height: 1.55;
}

@media (min-width: 1025px) {
    /* sect_edusystem - situation | smart */
    #sect_edusystem .situation{
        margin-top: 100px;
    }
    #sect_edusystem .smart{
        margin-top: 100px;
    }

    #sect_edusystem .situation .pic{
        max-width: 396px;
    }

    #sect_edusystem .smart .pic{
        max-width: 250px;
    }

    #sect_edusystem .edusystem_list{
        display: flex;        
        width: 100%;
        max-width: 100%;
        margin-top: 50px;
        padding: 30px;
    }
    #sect_edusystem .edusystem_item{
        flex: 1;
    }
    #sect_edusystem .edusystem_item + .edusystem_item{
        padding-top: 0;
        margin-top: 0;
        padding-left: 24px;
        margin-left: 24px;
        border-top: none;
        border-left: 1px solid var(--color-normal-1);
    }
    #sect_edusystem .edusystem_item .title{
        margin-bottom: 8px;
        font-size: 20px;
    }
    #sect_edusystem .edusystem_item [class*=ico]{
        padding-left: 30px;
        background-size: 24px auto;
    }
    #sect_edusystem .edusystem_item .description{
        font-size: 16px;
        line-height: 1.5;
    }
}

/* sect_award */
#sect_award{
    padding-bottom: 0;
}
#sect_award .sect_header .desc{
    margin-top: 16px;
}
#sect_award .sect_header .desc span{
    display: inline-block;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 600;
    color: #68614f;
    border-radius: 100px;
    background: linear-gradient(91deg, rgba(229, 190, 90, 0.80) 0.34%, rgba(247, 235, 172, 0.80) 35.22%, rgba(194, 154, 94, 0.80) 95.22%), #FFF;
}
#sect_award .award_list{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
}
#sect_award .award_list img{
    width: 104px;
}
#sect_award .award p{
    margin-top: 24px;

    color: var(--color-gray-5);
    text-align: center;
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: -0.04em;
}
#sect_award .sect_footer{
    overflow: hidden;
}
#sect_award .sect_footer img{
    height: 212px;
    max-width: 1044px;
    margin-left: 20px;
}

@media (min-width: 1025px) {
    #sect_award .sect_header .desc{
        margin-top: 30px;
    }
    #sect_award .sect_header .desc span{
        padding: 6px 16px;
        font-size: 16px;
    }
    #sect_award .award_list{
        gap: 40px;
    }
    #sect_award .award_list img{
        width: 170px;
    }
    #sect_award .award p{
        margin-top: 30px;

        font-size: 14px;
    }
    #sect_award .sect_footer img{
        height: auto;
        margin-left: 0;
    }
}

/* sect_review */
#sect_review{
    background: var(--color-gradient-5);
}

#sect_review .review_banner{
    position: relative;
    width: 100%;
    max-width: 804px;
    margin: 0 auto;
}
#sect_review .review_item{
    overflow: hidden;

    display: flex;
    flex-direction: column;

    width: 260px;
    height: auto;
    margin: 0 6px;

    background: var(--color-white);
    border-radius: 6px;
}
#sect_review .review_item .article{
    flex: 1;
    padding: 24px;
}
#sect_review .review_item .article .title{
    display: block;

    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.04em;
}
#sect_review .review_item .article .description{
    min-height: 192px;
    margin-top: 10px;

    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 8;
    -webkit-box-orient: vertical;

    color: var(--color-gray-8);
    word-break: break-all;
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: -0.04em;
}
#sect_review .review_item .info{
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 50px;
    padding: 0 16px;
    background: var(--color-normal-2);
}
#sect_review .review_item .info .emoji{
    overflow: hidden;

    width: 32px;
    height: 32px;
    background: var(--color-white);
    border-radius: 50%;
}
#sect_review .review_item .info .user{
    margin-right: 4px;

    color: var(--color-normal-3);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: -0.04em;
}
#sect_review .review_item .info .user_id{
    color: var(--color-normal-5);
}
#sect_review .review_banner .swiper-pagination{
    display: flex;
    justify-content: center;
    position: relative;
    bottom: 0;

    margin-top: 20px;
}
#sect_review .review_banner .swiper-pagination-bullet{
    opacity: 0.4;
    width: 6px;
    height: 6px;
    margin: 0 3px;
    background: var(--color-white);
}
#sect_review .review_banner .swiper-pagination-bullet-active{
    opacity: 1;
}
#sect_review .review_banner .swiper-button-prev,
#sect_review .review_banner .swiper-button-next{
    opacity: 0;
    visibility: hidden;

    width: 40px;
    height: 41px;
    border-radius: 50%;

    background: url(../../../img/ico/ico_arw-reivew.png) no-repeat center / cover;
}
#sect_review .review_banner .swiper-button-prev{
    left: 0;
    transform: rotate(180deg);
}
#sect_review .review_banner .swiper-button-prev::after,
#sect_review .review_banner .swiper-button-next::after{
    display: none;
}
#sect_review .review_banner .swiper-button-next{
    right: 0;
}

#sect_review .btn-type-round-2{
    background: transparent;

    color: var(--color-white);
}

@media (min-width: 1025px) {
    #sect_review .review_banner{
        max-width: 978px;
        padding: 0 70px;
    }
    #sect_review .review_item{
        width: 266px;
        margin: 0 10px;
        border-radius: 8px;
    }
    #sect_review .review_item .article{
        padding: 30px;
    }
    #sect_review .review_item .article .title{
        font-size: 20px;
    }
    #sect_review .review_item .article .description{
        margin-top: 12px;
        letter-spacing: -0.02em;
    }
    #sect_review .review_item .info{
        height: 60px;
    }
    #sect_review .review_item .info .emoji{
        width: 38px;
        height: 38px;
    }
    #sect_review .review_item .info .user{
        font-size: 14px;
    }

    #sect_review .review_banner .swiper-pagination-bullet{
        width: 8px;
        height: 8px;
        margin: 0 4px;
    }

    #sect_review .review_banner .swiper-button-prev,
    #sect_review .review_banner .swiper-button-next{
        opacity: 1;
        visibility: visible;    
    }
}

/* sect_product */
#sect_product .product_list{
    overflow: hidden;

    width: 100%;
    max-width: 480px;
    margin: 0 auto;
}
#sect_product .product_item{
    overflow: hidden;

    display: flex;
    justify-content: space-between;
    min-height: 64px;

    border-radius: 6px;
    border: 1px solid var(--color-gray-3);
}
#sect_product .product_item + .product_item{
    margin-top: 12px;
}
#sect_product .product_item em{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;

    width: 80px;
    height: auto;
    background: var(--color-normal-1);

    color: var(--color-normal-5);
    font-weight: 500;
    letter-spacing: -0.04em;
    text-align: center;
}
#sect_product .product_item em[class*="ico_"]::before{
    display: block;
    content: '';
    width: 17px;
    height: 16px;
    margin: 0 auto 2px;

    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
#sect_product .product_item em.ico_price::before{
    background-image: url(../../../img/ico/ico_price-prd.png);
}
#sect_product .product_item em.ico_student::before{
    background-image: url(../../../img/ico/ico_student-prd.png);
}
#sect_product .product_item em.ico_teacher::before{
    background-image: url(../../../img/ico/ico_teacher-prd.png);
}
#sect_product .product_item em.ico_book::before{
    background-image: url(../../../img/ico/ico_book-prd.png);
}
#sect_product .product_item em.ico_class::before{
    background-image: url(../../../img/ico/ico_class-prd.png);
}
#sect_product .product_item em.ico_study::before{
    background-image: url(../../../img/ico/ico_study-prd.png);
}
#sect_product .product_item p{
    flex: 1;
    padding: 20px 10px;

    color: var(--color-gray-6);
    text-align: center;

    font-size: 14px;
    line-height: 1.55;
    word-break: keep-all;
}
#sect_product .product_item p strong{
    color: var(--color-gray-9);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -0.04em;
}
@media (min-width: 1025px) {
    #sect_product .product_list{
        max-width: 620px;
    }
    #sect_product .product_item{
        min-height: 74px;
        border-radius: 8px;
    }
    #sect_product .product_item + .product_item{
        margin-top: 16px;
    }
    #sect_product .product_item em{
        width: 120px;
        font-size: 16px;
    }
    #sect_product .product_item em[class*="ico_"]::before{
        width: 25px;
        height: 24px;
        margin-bottom: 4px;
    }
    #sect_product .product_item p{
        padding: 22px;
        
        font-size: 16px;
        line-height: 1.5;
    }
    #sect_product .product_item p strong{
        font-size: 20px;
    }
}

/* sect_freetrial */
#sect_freetrial{
    background: var(--color-gray-2);
}
#sect_freetrial .sect_header{
    margin-bottom: 30px;
}
#sect_freetrial .freetrial .pic{
    width: 160px;
    margin: 0 auto 30px;
}
#sect_freetrial .freetrial .freetrial_list{
    counter-reset: num;
}
#sect_freetrial .freetrial .freetrial_item{
    display: flex;

    padding: 16px;
    background: var(--color-white);
    border: 1px solid var(--color-gray-3);
    border-radius: 6px;

    counter-increment: num;
}
#sect_freetrial .freetrial .freetrial_item + .freetrial_item{
    margin-top: 12px;
}
#sect_freetrial .freetrial .freetrial_item::before{
    content: counter(num);
    width: 24px;
    height: 24px;
    margin-right: 10px;
    background: var(--color-gray-2);
    border-radius: 50%;

    color: var(--color-normal-9);
    font-size: 13px;
    line-height: 24px;
    font-weight: 600;
    text-align: center;
    letter-spacing: -0.04em;
}
#sect_freetrial .freetrial .freetrial_item p{
    flex: 1;

    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    word-break: keep-all;
    letter-spacing: -0.04em;
}
#sect_freetrial .freetrial .freetrial_item p em{
    color: var(--color-normal-9);
    font-weight: 700;
}
@media (min-width: 1025px) {
    #sect_freetrial .sect_header{
        margin-bottom: 50px;
    }
    #sect_freetrial .freetrial .pic{
        width: 211px;
        margin-bottom: 40px;
    }
    #sect_freetrial .freetrial .freetrial_item{
        padding: 20px;
        border-radius: 8px;
    }
    #sect_freetrial .freetrial .freetrial_item + .freetrial_item{
        margin-top: 16px;
    }
    #sect_freetrial .freetrial .freetrial_item::before{
        width: 28px;
        height: 28px;
        margin-right: 12px;
    
        font-size: 16px;
        line-height: 28px;
    }
    #sect_freetrial .freetrial .freetrial_item p{
        font-size: 18px;
        letter-spacing: -0.02em;
    }
}

/* sect_apply */
#sect_apply .sect_header{
    margin-bottom: 30px;
}
#sect_apply .sect_header .logo{
    width: 82px;
    height: 14px;
    margin: 0 auto 30px;
}
#sect_apply .sect_header .logo::before{
    content: '';
    display: block;
    width: 100%;
    height: 100%;

    background: url(../../../img/logo/gnbhd_logo.svg) no-repeat center / cover;
}
#sect_apply .sect_header .description{
    display: inline-block;
    position: relative;
    padding: 4px 10px 4px 30px;
    margin-top: 12px;
    background: var(--color-gray-2);
    border-radius: 50px;

    color: var(--color-gray-6);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: -0.04em;
}
#sect_apply .sect_header .description::before{
    content: '';
    position: absolute;
    top: 50%;
    left: 10px;

    width: 16px;
    height: 16px;
    margin-top: -8px;

    background: url(../../../img/ico/ico_tel.png) no-repeat center / cover;
}
#sect_apply .sect_header .description em{
    color: var(--color-normal-4);
}
#sect_apply .pic{
    width: 145px;
    margin: 0 auto 30px;
}
#sect_apply .apply{
    width: 100%;
    max-width: 400px;
    margin: 0 auto; 
}
#sect_apply label, 
#sect_apply .label{
    color: var(--color-gray-7);
}
#sect_apply label.ico_required::before, 
#sect_apply .label.ico_required::before{
    color: var(--color-gray-7);
}
#sect_apply .check_box + a{
    color: var(--color-gray-4);
}



@media (min-width: 1025px) {
    #sect_apply .sect_header{
        margin-bottom: 40px;
    }
    #sect_apply .sect_header .logo{
        display: none;
    }
    #sect_apply .sect_header .description{
        display: inline-block;
        position: relative;
        padding: 8px 18px 8px 42px;
        margin-top: 24px;
    
        font-size: 16px;
    }
    #sect_apply .sect_header .description::before{
        left: 18px;
    
        width: 20px;
        height: 20px;
        margin-top: -10px;
    }
    #sect_apply .pic{
        width: 190px;
        margin-bottom: 40px;
    }
}