/* common */
.cf::after{
    content: '';
    display: table;
    clear: both;
}
.eng{
    font-family: 'Open Sans', sans-serif;
}
.inner{
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 10px;
}
.header_dark + .sub_wrap .inner{
    padding: 0;
    position: relative;
}
.inner::after{
    content: '';
    display: table;
    clear: both;
}
.header{
    position: absolute;
    top: 0;
    z-index: 10;
    width: 100%;
    padding-top: 30px;
}
.header .logo{
    display: inline-block;
    padding-top: 30px;
}
.header .logo img{
    width: 168px;
}
.header .nav{
    display: inline-block;
    float: right;
    text-align: right;
}
.header nav li{
    display: inline-block;
}
.header nav a{
    display: block;
    font-size: 1.6rem;
    padding: 10px 25px;
    color: #fff;
    position: relative; 
}
.header .sub-menu li{
    display: block;
}

.header .member{
    text-align: right;
}
.header .member{
    margin-right: 15px;
    margin-bottom: 10px;

}
.header nav .eng>li{
    position: relative;
}
.header nav .eng>li>a:after{
    content: '';
    position: absolute;
    transition: 0.2s ease-out all;
    left: 50%;
    width: calc(0% - 50px);
    transform: translateX(-50%);
    height: 2px;
    background-color: #2bb7b3;
    bottom: 0;
    opacity: 0;
}
.header nav .eng>li>a:hover::after{
    width: calc(100% - 50px);
    transform: translateX(-50%);
    opacity: 1;
}
.footer{
    background-color: #333;
    padding-top: 70px;
    padding-bottom: 70px;
}
.footer .f_logo, .footer .f_text{
    float: left;
}
.footer .f_logo{
    width: 25%;
}
.footer .f_text{
    width: 75%;
    text-align: right;
}
.footer .f_text{
    color: #999;
    font-size: 1.4rem;
    line-height: 1.8;
}
@media (max-width:1800px) {
    .header{
        padding-top: 40px;
    }
}
@media (max-width:1200px) {
    .header{
        padding-top: 20px;
    }
    .header_dark + .sub_wrap .inner{
        padding: 0 20px;
    }   
}
@media (max-width: 991px) {
    .header{
        position: fixed;
        display: block;
        top: 0;
        padding-bottom: 20px;
        background-color: #fff;
        z-index: 100;
    }
    .header .inner{
        text-align: center;
    }
    .header .logo{
        padding-top: 0;
    }
    .header .logo img{
        width: 134px;
    }
    .header nav a{
        padding: 10px 15px;
    }
    .header nav a:after{
        width: calc(0% - 30px);
    }
    .header nav a:hover::after{
        width: calc(100% - 30px);
    }
    .footer {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .panel .menu_mobile ul .sub-menu{
        padding: 10px 0;
        background-color: rgba(0, 0, 0, 0.25);
    }
    .panel .menu_mobile ul .sub-menu a{
        font-size: 14px;
    }
}
@media (max-width: 768px) {
    .header {
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .header .logo img{
        width: 100px;
    }
    .footer {
        padding-top: 20px;
        padding-bottom: 20px;
    }
    .footer .f_logo{
        width: 100%;
    }
    .footer .f_logo img{
        height: 24px;
    }
    .footer .f_text{
        width: 100%;
        text-align: left;
        font-size: 1.2rem;
        margin-top: 10px;
    }
}
@media (min-width: 992px) {
    .sub-menu{
        position: absolute;
        min-width: 170px;
        padding: 10px 20px;
        background: rgba(0, 0, 0, 0.7);
        border-radius: 10px;
        box-shadow: 0 3px 11px 0 rgb(0 0 0 / 10%);
        transform-origin: 0 0 0;
        left: 0;
        font-size: 17px;
        right: auto;
        opacity: 0;
        visibility: hidden;
        transition: 0.5s;
        z-index: 99;
        top: 50px;
        text-align: left;
    }
    .header_dark .sub-menu{
        background: rgba(255, 255, 255, 0.95);
    }
    .menu_mobile > ul > li:hover .sub-menu {
        opacity: 1;
        top: 100%;
        visibility: visible;
    }
    .menu_mobile > ul > li:hover .sub-menu li{
        display: block;
        float: inherit;
    }
    .menu_mobile > ul > li .sub-menu li a{
        font-size: 14px;
        padding: 10px 0;
    }
    .menu_mobile > ul > li:hover .sub-menu li a{
        position: relative;
        transition: 0.2s padding-left   ease-out;
    }
    .menu_mobile > ul > li:hover .sub-menu li a:hover{
        padding-left: 10px;
    }
    .menu_mobile > ul > li:hover .sub-menu li a::after{
        content: '';
        width: 0;
        height: 0;
        transition: 0.4s all ease-out;
    }
    .menu_mobile > ul > li:hover .sub-menu li a:hover::after{
        content: '';
        width: 6px;
        height: 6px;
        display: block;
        border-radius: 50%;
        background-color: #2bb7b3;
        position: absolute;
        top: calc(50% - 3px);
        left: -3px;
    }
    .header_dark .header .eng a{
        color: #333;
    }
    .header .menu_mobile{
        text-align: right;
    }
    .header .member{
        padding: 0 10px;
        background-color: rgba(33, 184, 197, .85);
        display: inline-block;
        border-radius: 20px;
    }
    .header .member a{
        padding: 5px 10px;
        font-size: 14px;
        position: relative;
    }
    .header .member li+li a::before{
        content: '';
        width: 1px;
        height: 14px;
        position: absolute;
        left: 0;
        top: calc(50% - 7px);
        background-color: rgba(255, 255, 255, 0.2);
    }
}
/* 메인 */

.slider {   
    position: relative;
}
.swiper_img{
    text-align: center;
}
.swiper_img img{
    width: 100%;
    max-width: 1920px;
}
.swiper_text{
    color: #fff;
    position: absolute;
    left: 12.5%;
    top: 33%;
}
.swiper_text > *{
    display: block;
}
.swiper_text .swiper_tit .eng{
    font-size: 4rem;
    font-weight:700;
    display: inline-block;
    vertical-align: top;
}
.swiper_text .swiper_tit b{
    display: block;
    margin-top: 10px;
    font-size: 3.725rem;
}
.swiper_text strong{
    margin-top: 20px;
    font-weight: 700;
    font-size: 2rem;
    line-height: 1.6;
}
.swiper_text .swiper_btn{
    margin-top: 30px;
    font-size: 1.725rem;
    line-height: 1.5;
}
.swiper_text .swiper_btn a{
    border: 1px solid rgba(255, 255, 255, 0.5);
    padding: 10px 30px;
    display: inline-block;
    background-color: #fff;
    color: #2e4190;
    font-weight: 600;
}
.swiper_text .swiper_btn a+a{
    margin-left: 5px;
}
.swiper_text .swiper_btn a:hover{
    
}
.swiper-button-next, .swiper-button-prev{
    color: #fff;
}

.su_list>div{
    width: 25%;
    float: left;
    position: relative;
    background-position: center;
    background-size: cover;
}
.su_list a{
    position: relative;
    color: #fff;
    display: block;
}
.su_list .su_list_text{
    padding: 15% 6% 21%;
}
.su_list .su_list_text p{
    font-size: 1.6rem;
    line-height: 1.8;
    letter-spacing: -0.05rem;
    word-break: break-all;
    text-align: justify;
    height: 150px;
}
.su_list i{
    border-radius: 50%;
    width: 100px;
    height: 100px;
    display: block;
    margin: 0 auto;
    background-image: url(../img/main_icon.png);    
}
.su_list .google{
    background-image: url(../img/su_list_img_01.jpg);
}
.su_list .google i{
    background-color: #21b8c5;
    background-position: 0 0;
}
.su_list .software{
    background-image: url(../img/su_list_img_02.jpg);
}
.su_list .software i{
    background-color: #3c95bf;
    background-position: 0 -100px;
}
.su_list .flipped{
    background-image: url(../img/su_list_img_03.jpg);
}
.su_list .flipped i{
    background-color: #21c572;
    background-position: 0 -200px;
}
.su_list .education{
    background-image: url(../img/su_list_img_04.jpg);
}
.su_list .education i{
    background-color: #dd6b1c;
    background-position: 0 -300px;
}
.su_list .eng{
    text-align: center;
    font-size: 4rem;
    font-weight: 700;
    margin-top: 25px;
    margin-bottom: 25px;
    padding-bottom: 20px;
    position: relative;
}
.su_list li h4::after{
    content: '';
    display: block;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 18%;
    height: 1px;
    background-color: #fff;
}
.su_list li p{
    font-size: 1.6rem;
    word-break: break-all;
    text-align: justify;
    line-height: 1.7;
}
[class^="program_list_"] .inner{
    padding-top: 100px;
    padding-bottom: 80px;
}
[class^="program_list_"] .program_img, [class^="program_list_"] .program_text{
    float: left;
    width: 50%;
}
[class^="program_list_"] .program_img img{
    max-width: 710px;
    width: 100%;
    box-shadow: 0px 15px 20px 0px rgba(0, 0, 0, 0.2);
    display: block;
    position: relative;
    z-index: 1;

}
.program_list_01 .program_text, .program_list_03 .program_text{
    padding-left: 8.333%;
}
.program_list_02 .program_text{
    padding-right: 8.333%;
}
[class^="program_list_"] .program_text .title span{
    font-size: 2.2rem;
    display: inline-block;
    position: relative;
    line-height: 1.4;
    margin-bottom: 3.5rem;
    font-weight: 500;
} 
.program_list_01 .program_text .title span{
    color: #21c572;
}
.program_list_02 .program_text .title span{
    color: #ed6d14;
}
.program_list_03 .program_text .title span{
    color: #21b8c5;
}
[class^="program_list_"] .program_text .title span::after{
    content: '';
    position: absolute;
    width: 12px;
    height: 12px;
    top: -8px;
    right: -17px;
}
.program_list_01 .program_text .title span::after, .program_list_01 .program_img span{
    background-color: #21c572;;
}
.program_list_02 .program_text .title span::after, .program_list_02 .program_img span{
    background-color: #ed6d14;;
}
.program_list_03 .program_text .title span::after, .program_list_03 .program_img span{
    background-color: #21b8c5;;
}
.program_img span{
    position: absolute;
    display: inline-block;
}
[class^="program_list_"] .program_img{
    position: relative;
}
.program_list_01 .program_img span{
    padding-top: 59.25%;
    padding-left: 39.5%;
    top: -7%;
    right: -7%;
}
.program_list_02 .program_img span{
    padding-top: 39.5%;
    padding-left: 79.25%;
    bottom: -7%;
    left: -12%;
}
.program_list_03 .program_img span{
    padding-top: 51.25%;
    padding-left: 39.5%;
    bottom: -9.5%;
    right: -6%;
}
.program_list_03 .program_img span{
    
}
[class^="program_list_"] .program_text strong{
    font-size: 4.2rem;
    line-height: 1.4;
    margin-bottom: 2rem;
    font-weight: 600;
    display: block; 
    letter-spacing: -0.1rem;
}
.program_list_02.dark_list{
    background-color: #333333;
    color: #fff;
}
[class^="program_list_"] .program_text p{
    color: #666;
    font-size: 1.8rem;
    word-break:keep-all;
    line-height: 1.8;
    max-width: 570px;
}
.dark_list .program_text p{
    color: #fff;
}
[class^="program_list_"] .btn_read{
    border: 1px solid rgba(0, 0, 0, 0.5);
    padding: 10px 25px;
    display: inline-block;
    font-size: 1.4rem;
    color: #4c4c4c;
    margin-top: 50px;
}
.dark_list .btn_read{
    color: #fff;
    border-color: rgba(255, 255, 255, 0.5);
}
.swiper_pc{
    display: block;
}
.swiper_mobile{
    display: none;
}
.sub_wrap{
    overflow: hidden;
}


@media (max-width:1800px) {
    .swiper_text{
        width: 100%;
        max-width: 1440px;
        left: 50%;
        transform: translateX(-50%);
        padding: 0 10px;
    }
    .swiper_text .swiper_tit .eng{
        font-size: 3.5rem;
    }
    .swiper_text .swiper_tit b{
        font-size: 3.25rem;
    }
    .swiper_text strong{
        font-size: 2rem;
    }
    .su_list .eng span{
        display: block;
    }
    .swiper_text p{
        font-size: 1.5rem;
    }
}
@media (max-width:1200px) {
    .header nav a{
        padding: 10px 15px;
    }
    .su_list>div{
        width: 50%;
    }
    .su_list .eng span{
        display: inline-block;
    }
    .inner, .header_dark + .sub_wrap .inner{
        padding: 0 20px;
    }
    [class^="program_list_"] .program_text .title span{
        font-size: 1.8rem;
        margin-bottom: 2rem;
    }
    [class^="program_list_"] .program_text strong{
        font-size: 3.4rem;
    }
    [class^="program_list_"] .program_text p{
        font-size: 1.6rem;
    }
    [class^="program_list_"] .btn_read{
        margin-top: 25px;
    }
    .swiper_pc{
        display: none;
    }
    .swiper_mobile{
        display: block;
    }
    .swiper_text{
        padding-left: 80px;
    }
}
@media (max-width: 991px) {
    .su_list .eng{
        font-size: 3rem;
        margin-top: 15px;
        margin-bottom: 15px;
        padding-bottom: 10px;
    }
    .su_list .su_list_text p{
        font-size: 1.4rem;
    }
    [class^="program_list_"] .program_img{
        width: 40%;
    }
    [class^="program_list_"] .program_text{
        width: 60%;
    }
    .slider{
        margin-top: 60px;
    }
    .swiper_text{
        top: 50%;
        transform: translateY(-50%) translateX(-50%);
        padding: 20px;
    }
}
@media (max-width: 768px) {
    .su_list>div{
        width: 100%;
    }
    .su_list i{
        width: 50px;
        height: 50px;
        background-size: 50px;
    }
    .su_list .google i{
        background-position: 0 0;
    }
    .su_list .software i{
        background-color: #3c95bf;
        background-position: 0 -50px;
    }
    .su_list .flipped i{
        background-position: 0 -100px;
    }
    .su_list .education i{
        background-position: 0 -150px;
    }
    .su_list .su_list_text p, [class^="program_list_"] .program_text p{
        line-height: 1.6;
    }
    [class^="program_list_"] .program_text strong{
        line-height: 1.3;
    }
    .su_list .eng{
        font-size: 2.6rem;
        margin-top: 10px;
        margin-bottom: 10px;
        padding-bottom: 5px;
    }
    .su_list .su_list_text p{
        height: auto;
    }
    .su_list .su_list_text {
        padding: 7% 6% 10%;
    }
    .program_list_01 .program_img span, .program_list_03 .program_img span{
        right: -15px;
    }
    .program_list_01 .program_text, .program_list_03 .program_text{
        padding-left: 0;
        padding-top: 40px;
    }
    .program_list_02 .program_text{
        padding-bottom: 50px;
    }
    [class^="program_list_"] .program_img{
        width: 100%;
    }
    [class^="program_list_"] .program_text{
        width: 100%;
    }
    [class^="program_list_"] .program_text p{
        max-width: 800px;
        font-size: 1.4rem;
    }
    [class^="program_list_"] .inner{
        padding-top: 60px;
        padding-bottom: 60px;
    }
    [class^="program_list_"] .program_text strong{
        font-size: 2.8rem;
        margin-bottom: 1.5rem;
    }
    [class^="program_list_"] .program_text strong br{
        display: none;
    }
    [class^="program_list_"] .program_text .title span{
        font-size: 1.6rem;
        margin-bottom: 1.5rem;
    }
    [class^="program_list_"] .btn_read{
        font-size: 1.2rem;
        padding: 10px 15px;
    }
    .slider{
        margin-top: 40px;
    }
    .swiper_text .swiper_tit .eng{
        font-size: 1.75rem;
    }
    .swiper_text .swiper_tit b{
        font-size: 1.525rem;
        margin-top: 2px;
    }
    .swiper_text span .eng{
        margin-bottom: 0;
    }
    .swiper_text strong {
        font-size: 1.125rem;
        margin-top: 10px;
    }
    .swiper_text .swiper_btn {
        font-size: 1.125rem;
        margin-top: 15px;
    }
    .swiper-button-prev, .swiper-button-next{
        display: none;
    }
}


/* ----------------------------------
        구글 workspace 
----------------------------------*/
.sub_visual{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
}
.header_dark + .sub_wrap .sub_content{
    position: relative;
}
.header_dark + .sub_wrap .sub_content::before {
    content: "";
    display: block;
    width: calc(100% + 50%);
    height: 300px;
    background-color: #fff;
    position: absolute;
    left: 50%;
    bottom: calc(100% - 150px);
    transform: rotate(-3deg) translateX(-50%);
}
.header_dark + .sub_wrap .sub_visual .bg{
    background-color: transparent;
    margin-top: 130px;
    height: 200px;
}
.sub_visual .bg{
    background-color: rgba(0, 0, 0, 0.35);
    height: 380px;
    position: relative;
}
.sub_visual_txt{
    position: absolute;
    top: 62%;
    left: 50%;
    max-width: 1440px;
    width: 100%;
    transform: translateY(-50%) translateX(-50%);
    color: #fff;
    padding: 10px;
}
.header_dark + .sub_wrap .sub_visual_txt{
    top: 0;
    left: 0;
    transform: none;
    margin: 0 auto;
    position: relative;
}
.header_dark + .sub_wrap .sub_visual_txt::after{
    content: '';
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 30px;
    height: 70px;
    border-right: 1px solid #2bb7b3;
    border-bottom: 1px solid #2bb7b3;
}
.sub_visual_txt h3{
    font-size: 62px; 
    font-weight: 700;
    line-height: 1.4;
}
.sub_visual_txt h3 span{
    display: block;
    font-size: 18px;
    font-weight: 400;
    opacity: .5;
}
.header_dark + .sub_wrap .sub_visual_txt h3{
    font-size: 32px; 
    font-weight: 400;
    color: #fff;
    line-height: 1.6;
    margin-top: 20px;
    display: inline-block;
    position: relative;
    z-index: 10;
}
.header_dark + .sub_wrap .sub_visual_txt h3::after{
    content: '';
    width: 100%;
    height: 5px;
    background-color: #2bb7b3;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
}
.sub_visual_txt p, .sub_visual_txt_swiper{
    font-size: 18px;
    padding-top: 15px;
}
.google {
    background-color: #f0f0f0;
}
.big_list .big_list_item{
    width: 50%;
    float: left;
    margin-bottom: 40px;
    padding: 0 20px;
}
.big_list .big_list_item a{
    display: block;
    padding: 30px;
    background-color: #fff;
    border-radius: 20px;
    box-shadow: 2px 3px 9px rgba(0, 0, 0, 0.2);
    height: 200px;
    line-height: 1.6;
    transition: 0.2s all ease;
    position: relative;
    top: 0;
}
.big_list .big_list_item a:hover{
    top: -10px;
    box-shadow: 2px 10px 15px rgba(0, 0, 0, 0.2);
}
.big_list .big_list_item h4, .big_list .big_list_item p{
    float: left;
}
.big_list .big_list_item h4{
    width: 30%;
    font-size: 24px;
    text-align: center;
    font-family: 'Open Sans', sans-serif;
}
.big_list .big_list_item .icon{
    display: inline-block;
    width: 100px;
    height: 100px;
    background-image: url(../img/sub/google_icon.png);
    background-size: 100px auto;
}
.gmail .icon{
    background-position: 0 0;
}
.calendar .icon{
    background-position: 0 -100px;
}
.meet .icon{
    background-position: 0 -200px;
}
.drive .icon{
    background-position: 0 -300px;
}
.docs .icon{
    background-position: 0 -400px;  
}
.sheets .icon{
    background-position: 0 -500px;
}
.slides .icon{
    background-position: 0 -600px;
}
.keep .icon{
    background-position: 0 -700px;
}
.big_list .big_list_item span{
    display: block;
    margin-top: 10px;
}
.big_list .big_list_item p{
    width: calc(100% - 30%);
    padding-left: 5%;
    font-size: 16px;
    color: #666;
}
.sub_wrap .list{
    padding-bottom: 60px;
    padding-left: 10px;
    padding-right: 10px;
}
.sub_wrap .list .list_item{
    width: 25%;
    float: left;
    padding: 10px;
}

.sub_wrap .list .list_item a{
    display: block;
    padding: 30px;    
    transition: 0.2s all ease;
    position: relative;
    border-radius: 10px;
    top: 0;
    background-color: transparent;
}
.sub_wrap .list .list_item a:hover{
    top: -10px;
    background-color: #fff;
    box-shadow: 2px 10px 15px rgba(0, 0, 0, 0.2);
}
.sub_wrap .list .list_item .icon{
    display: inline-block;
    width: 100px;
    height: 100px;
    background-image: url(../img/sub/google_icon2.png);
    background-size: 100px auto;
}
.sub_wrap .list .list_item span{
    font-size: 24px;
}
.chat .icon{
    background-position: 0 0;
}
.forms .icon{
    background-position: 0 -100px;
}
.sites .icon{
    background-position: 0 -200px;
}
.currents .icon{
    background-position: 0 -300px;
}
.apps .icon{
    background-position: 0 -400px;
}
.cloud .icon{
    background-position: 0 -500px;
}
.jamboard .icon{
    background-position: 0 -600px;
}

/* about */
.about_list .about_tit, .google_tit{
    font-size: 42px;
    font-weight: 600;
}
.about_list .about_tit span, .google_tit span{
    color: #2bb7b3;
    display: block;
}
.about_list .about_tit strong, .google_tit strong{
    font-weight: 600;
    display: inline-block;
    position: relative;
    z-index: 1;
}
.about_list .about_tit strong::before, .google_tit strong::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 10px;
    background-color: rgba(43, 183, 179, 0.5);
    bottom:0;
    z-index: -1;
}
.about_list p{
    font-size: 16px;
    color: #333;
}
.about_item, .google_item{
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    margin-bottom: 100px;
}
.about_item .about_item_img img, .google_item .google_item_img img{
    width: 100%;
}
.about_item .about_item_txt , .about_item .about_item_img{
    flex: 1 1 40%;
}
.google_item .google_item_txt{
    flex: 1 1 65%;
}
.google_item .google_item_img{
    flex: 1 1 35%;
}
.google_item .google_item_img{
    margin-top: auto;
}
.about_item .about_item_txt + .about_item_img, .google_item .google_item_txt + .google_item_img{
    padding-left: 20px;
}
.about_item .about_item_img + .about_item_txt, .google_item .google_item_img + .google_item_txt{
    padding-left: 40px;
}
.about_item_txt p, .google_item_txt p{
    margin-top: 40px;
    font-size: 20px;
    line-height: 1.4;
}

.about_item_txt p strong, .google_item_txt p strong{
    font-weight: 600;
    font-size: 26px;
}
/* 구글 */
.google_item_txt ul{
    margin-top: 30px;
    font-size: 20px;
}
.google_item_txt ul li{
    position: relative;
    padding: 5px 10px;
    /* color: #666; */

}
.google_item_txt ul li::after{
    content: '';
    width: 3px;
    height: 10px;
    background-color: #21b8c5;
    position: absolute;
    left: 0;
    top: 11px;
}
.google_item_txt .txt_info{
    font-size: 20px;
    color: red;
    margin-top: 10px;
    display: block;
}
.google_item .btn_box{
    margin-top: 30px;
}
.google_item_img{
    position: relative;
}
.google_item_img img{
    z-index: 2;
    position: relative;
}
.google_item_img span{
    width: 50%;
    height: 50%;
    top: -20px;
    left: 0;
    display: block;
    position: absolute;
    background-color: #21b8c5;
}

@media (max-width:1200px) {
    .header_dark + .sub_wrap .sub_visual .bg{
        margin-top: 90px;
    }
    .sub_visual_txt, .header_dark + .sub_wrap .sub_visual_txt{
        padding: 10px 20px ;
    }
    .big_list .big_list_item a{
        padding: 25px;
        height: 225px;
    }
    .big_list .big_list_item h4{
        margin-top: 10px;
    }
    .big_list .big_list_item{
        padding: 0 15px;
        margin-bottom: 30px;
    }
    .sub_wrap .list .list_item .icon{
        display: block;
        margin: 0 auto;
    }
    .sub_wrap .list .list_item span{
        text-align: center;
        display: block;
    }

    .sub_wrap .list {
        padding-bottom: 40px;
    }
    .sub_wrap .list .list_item a{
        padding: 20px 20px 30px;
    }

    .about_item .about_item_img + .about_item_txt, .google_item .google_item_img + .google_item_txt{
        padding-right: 20px;
    }
    .about_list .about_tit, .google_tit{
        font-size: 36px;
    }
    .about_item_txt p, .google_item_txt p, .google_item_txt ul{
        font-size: 17px;
    }
    .about_item_txt p strong, .google_item_txt p strong{
        font-size: 22px;
    }
}
@media (max-width: 991px){
    .header_dark + .sub_wrap .sub_visual .bg{
        margin-top: 70px;
    }
    .big_list .big_list_item a{
        padding: 20px;
        height: 200px;
    }
    .big_list .big_list_item h4{
        width: 100%;
    }
    .big_list .big_list_item .icon{
        width: 40px;
        height: 40px;
        background-size: 40px auto;
    }
    .big_list .big_list_item span{
        display: inline-block;
        margin-top: 0;
    }
    .big_list .big_list_item p{
        width: 100%;
        padding-left: 0;
        margin-top: 10px;
        font-size: 14px;
    }
    .calendar .icon{
        background-position: 0 -40px;
    }
    .meet .icon{
        background-position: 0 -80px;
    }
    .drive .icon{
        background-position: 0 -120px;
    }
    .docs .icon{
        background-position: 0 -160px;  
    }
    .sheets .icon{
        background-position: 0 -200px;
    }
    .slides .icon{
        background-position: 0 -240px;
    }
    .keep .icon{
        background-position: 0 -280px;
    }
    .sub_wrap .list .list_item a{
        padding: 10px;
    }
    .sub_wrap .list .list_item .icon{
        width: 40px;
        height: 40px;
        background-size: 40px auto;
    }
    .forms .icon{
        background-position: 0 -40px;
    }
    .sites .icon{
        background-position: 0 -80px;
    }
    .currents .icon{
        background-position: 0 -120px;
    }
    .apps .icon{
        background-position: 0 -160px;
    }
    .cloud .icon{
        background-position: 0 -200px;
    }
    .jamboard .icon{
        background-position: 0 -240px;
    }
    .sub_wrap .list .list_item span {
        font-size: 20px;
    }
    .sub_wrap .list_item a>div{
        padding: 10px;
    }
}
@media (max-width: 768px) {
    .header_dark + .sub_wrap .sub_visual .bg{
        margin-top: 40px;
    }
    .header_dark + .sub_wrap .sub_visual_txt h3{
        font-size: 18px;
    }
    .header_dark + .sub_wrap .sub_visual_txt h3::after{
        height: 3px;
    }
    .sub_visual .bg{
        height: 240px;
    }
    .sub_visual_txt{
        top: 50%;
    }
    .sub_visual_txt h3{
        font-size: 40px;
        line-height: 1.2;
    }
    .sub_visual_txt h3 span{
        font-size: 15px;
    }
    .sub_visual_txt p, .sub_visual_txt_swiper{
        font-size: 15px;
        padding-top: 5px;
    }

    .big_list .big_list_item{
        width: 100%;
        padding: 0;
        margin-bottom: 20px;
    }
    .big_list .big_list_item a {
        height: auto;
        padding: 10px 20px 20px 20px;
        border-radius: 10px;
    }
    .sub_wrap .list{
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 20px;
    }
    .sub_wrap .list .list_item{
        padding: 0;
    }
    .sub_wrap .list .list_item a{
        padding: 10px 0;
    }
    .sub_wrap .list_item a>div{
        padding: 0 0 10px;
    }
    .sub_wrap .list .list_item span{
        font-size: 15px;
    }
    .big_list .big_list_item a:hover, .sub_wrap .list .list_item a:hover{
        top: -5px;
    }
    .about_item, .google_item{
        display: flex;
        flex-direction: column;
        justify-content: space-around;
        flex-wrap: wrap;
        margin-bottom: 50px;
    }
    .about_list .about_item:first-child .about_list .about_item_txt, .google_item:first-child .google_list .google_item_txt{
        margin-top: -50px;
    }
    .header_dark + .sub_wrap .sub_visual_txt::after{
        bottom: 20px;
    }
    .about_list .about_tit, .google_tit{
        font-size: 28px;
    }
    .about_list .about_tit span br, .google_tit span br{
        display: none;
    }
    .about_item .about_item_txt, .google_item .google_item_txt{
        padding: 0 !important;
    }
    .about_item_txt p, .google_item_txt p{
        font-size: 15px;
        margin-bottom: 30px;
        margin-top: 30px;
    }
    .google_item_txt ul{
        font-size: 15px;
    }
    .google_item_txt ul li::after{
        top: 9px;
    }
    .about_item_txt p strong, .google_item_txt p strong{
        font-size: 18px;
    }
    .about_item_img, .google_item_img{
        order: 2;
        padding-right: 0 !important;
        padding-left: 0 !important;
    }
    .about_item_img, .google_item_img img{
        padding: 0 20px;
    }
    .about_item:first-child .google_item_txt, .google_item:first-child .google_item_txt{
        margin-top: -80px;
    }
    /* .about_item .about_item_img + .about_item_txt{
        padding-left: 20px;
    } */
    .google_item_txt .txt_info{
        font-size: 15px;
    }
    .google_item .btn_box{
        margin-top: 20px;
        margin-bottom: 50px;
        text-align: center;
    }
    .google_item .btn_box a{
        width: 46%;
    }
}

/* qna */
.qna_list{
    font-size: 17px;
    margin-bottom: 60px;
}
.qna_q{
    padding: 30px 20px;
    font-size: 22px;
    line-height: 40px;
    border-bottom: 1px solid #ededed;
    cursor: pointer;
    position: relative;
}
.qna_q::after{
    content: '';
    background-image: url(../img/sub/chevron-up.svg);
    width: 30px;
    height: 40px;
    background-repeat: no-repeat;
    background-size: 30px auto;
    display: block;
    position: absolute;
    right: 20px;
    top: calc(50% - 20px);
    transform: rotate(180deg);
    opacity: 0.3;
    transition: 0.2s all ease;
}
.qna_items.active .qna_q::after{
    transform: rotate(0deg);
    opacity: 0.7;
}
.qna_q strong{
    color: #fff;
    background-color: #2bb7b3;
    border-radius: 1px;
    display: inline-block;
    width: 40px;
    height: 40px;
    text-align: center;
    margin-right: 10px;
}
.qna_q span{
    display: inline-block;
    padding-right: 50px;
}
.qna_a{
    display: none;
    background-color: #fafafa;
    border-bottom: 1px solid #999;
    padding: 30px 20px 30px 51px;
}
.active .qna_a{
    display: block;
}
.qna_a i{
    font-style: normal;
    float: left;
    color: #999;
    font-size: 12px;
    padding-top: 5px;
}
.qna_a span{
    display: block;
    margin-left: 25px;
    line-height: 1.6;
}
@media (max-width: 991px){
    .qna_list{
        font-size: 15px;
        word-break: break-all;
        transform: translateY(-80px);
        margin-bottom: 0;
    }
    .qna_q{
        padding: 20px 0;
        font-size: 18px;
        line-height: 30px;
    }
    .qna_q::after{
        width: 26px;
        height: 30px;
        background-size: 26px auto;
        right: 10px;
        top: calc(50% - 15px);
    }
    .qna_q strong{
        width: 30px;
        height: 30px;
        margin-right: 5px;
        float: left;
    }
    .qna_q span{
        margin-left: 40px;
        display: block;
    }
    .qna_a{
        padding: 20px 10px 20px 15px;
    }
}
@media (max-width: 768px) {
    .qna_list{
        font-size: 14px;
    }
    .qna_q{
        font-size: 17px;
    }
    .qna_q::after{
        width: 20px;
        height: 30px;
        background-size: 20px auto;
        right: 0;
        top: calc(50% - 15px);
    }
    .qna_q span{
        padding-right: 30px;
    }
}
/* 프로그램 */
.program_list_01{
    padding: 60px 0;
    line-height: 1.4;
    max-width: 1200px;
    margin: 0 auto;
}
.program_items{
    position: relative;
}
.program_items::after{
    content: '';
    width: 40px;
    height: 100px;
    border-right: 1px solid #2bb7b3;
    border-bottom: 1px solid #2bb7b3;
    display: block;
    position: absolute;
    right: 0;
    bottom: -4rem;
}
.program_tit{
    font-size: 52px;
    font-weight: 700;
    color: #2bb7b3;
    position: relative;
}
.program_tit::after{
    content: '';
    position: absolute;
    right: 80px;
    top: 40px;
    width: 80px;
    height: 80px;
    background-color: #2bb7b3;
    transform: rotate(45deg);
}
.program_tit::before{
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    width: 60px;
    height: 120px;
    border-right: 1px solid #2bb7b3;
    border-top: 1px solid #2bb7b3;
}
.program_tit + p{
    margin-top: 1rem;
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 2rem;
    color: #333;
    padding-right: 300px;
    position: relative;
}
.program_tab{
    margin-top: 12rem;
    margin-bottom: 6rem;
}
.program_tab ul{
    font-size: 18px;
}
.program_tab ul li{
    display: inline-block;
    padding: 10px 50px 10px 0;
    position: relative; 
    color: #999;
    font-weight: 600;
}
.program_tab ul .active{
    color: #333;
}
.program_tab ul a{
    display: inline-block;
    position: relative;
    padding: 5px 0;
}
.program_tab ul a:hover{
    color: #333;
}
.program_tab ul .active a::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #2bb7b3;
}
.tab_tit{
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 2rem;
    position: relative;
}
.tab_tit span{
    display: inline-block;
    padding-left: 50px;
}
.tab_tit::after, .tab_tit::before{
    content: '';
    width:40px;
    height:40px;
    display: block;
    border: 1px solid #2bb7b3;
    transform: rotateZ(45deg);
    position: relative;
    right: 0;
    z-index: -1;
}
.tab_tit::after{
    top: -30px;
} 
.tab_tit::before{
    top: 30px;
}
.tab_tit+p{
    font-size: 22px;
    font-weight: 500;
    margin-bottom: 3rem;
    padding-right: 40px;
}
.tab_tit+p strong{
    vertical-align: top;
    font-weight: 500;
    display: inline-block;
    position: relative;
}
.tab_tit+p strong::after{
    content: '';
    width: 100%;
    height: 7px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-color: #2bb7b3;
    z-index: -1;
    opacity: 0.5;
}
.tab_tit_2{
    font-size: 18px;
    font-weight: 600;
}
.tab_tit_2+p, .tab_img_box+p{
    margin-top: 1rem;
    font-size: 17px;
    color: #666;
    padding-right: 40px;
    line-height: 1.6;
}
.tab_tit_2+p+.tab_tit_2{
    margin-top: 4rem;
}
.program_items .btn_box{
    margin-top: 4rem;
    font-size: 18px;
    text-align: center;
}
.program_items .btn_box a, .google_item .btn_work{
    display: inline-block;
    padding: 20px;
    min-width: 200px;
    border: 1px solid #2bb7b3;
    transition: 0.3s all ease-in;
    font-weight: 500;
    font-size: 18px;
}
.program_items .btn_box a{
    width: 50%;
}
.program_items .btn_box a:hover, .google_item .btn_work:hover{
    background-color: #2bb7b3;
    color: #fff;
}
.tab_img_box{
    float: left;
    margin-right: 30px;
    margin-bottom: 30px;
}
#vr .tab_img_box{
    float: right;
    margin-left: 30px;
}
.tab_img_box img{
    width: 100%;
    display: inline-block;
    max-width: 600px;
}
.img_box  .tab_tit_2{
    font-size: 24px;
}
.program_bar{
    padding-top: 2rem;
    padding-bottom: 6rem;
}
.program_bar::before{
    content: '';
    display: inline-block;
    background-color: #2bb7b3;
    width: 70px;
    height: 4px;
}
.tab_img_box2{
    margin-top: 5rem;
    text-align: center;
}
.tab_img_box2 span{
    position: relative;
    display: inline-block;
    vertical-align: top;
    margin-right: 50px;
}
.tab_img_box2 span::after{
    content: '';
    display: block;
    width: 299px;
    height: 218px;
    position: absolute;
    background-color: #2bb7b3;
    top: 30px;
    left: 30px;
    z-index: -1;
}
.tab_img_box2 img{
    display: inline-block;
}
@media (max-width: 991px){
    .tab_img_box, #vr .tab_img_box{
        float: inherit;
        text-align: center;
        margin-left: 0;
        margin-right: 0;
    }
    .program_tit + p{
        padding-right: 170px;
    }
}
@media (max-width: 768px) {
    .program_tit{
        font-size: 36px;
        padding-right: 40px;
    }
    .program_tit::before{
        top: -10px;
        width: 40px;
        height: 80px;
    }
    .program_tit::after{
        right: 0;
        top: 10px;
        width: 30px;
        height: 30px;
    }
    .program_tit + p{
        font-size: 18px;
        padding-right: 0;
    }
    .program_tab {
        margin-top: 6rem;
        margin-bottom: 3rem;
    }
    .program_tab ul {
        font-size: 13px;
    }
    .program_tab ul li{
        padding: 10px 10px 10px 0;
    }
    .program_tab ul li:last-child{
        padding: 10px 0 10px 0;
    }
    .tab_tit{
        font-size: 28px;
        margin-bottom: 0;
    }
    .tab_tit::after, .tab_tit::before{
        width: 30px;
        height: 30px;
    }
    .tab_tit::before {
        top: 25px;
    }
    .tab_tit::after {
        top: -25px;
    }
    #vr .tab_tit::before{
        top: 40px;
    }
    #vr .tab_tit::after{
        top: -40px;
    }
    .tab_tit+p{
        font-size: 17px;
        padding-right: 0;
    }
    .tab_tit_2{
        font-size: 15px;
    }
    .tab_tit_2+p, .tab_img_box+p{
        font-size: 14px;
        padding-right: 10px;
    }
    .program_items::after {
        content: '';
        width: 50px;
        height: 75px;
        bottom: -2rem;
    }
    .program_items .btn_box a, .google_item .btn_work{
        font-size: 14px;
        padding: 15px 20px;
    }
    .img_box .tab_tit_2{
        font-size: 18px;
    }
    .program_bar{
        padding-top: 2rem;
        padding-bottom: 6rem;
    }
    .program_bar::before{
        content: '';
        display: inline-block;
        background-color: #2bb7b3;
        width: 50px;
        height: 3px;
    }
    .tab_img_box2 span{
        margin-bottom: 50px;
    }
}

/* Curriculum */
.curr_01{
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.curr_tit {
    font-size: 42px;
    font-weight: 600;
}
.curr_tit span {
    color: #2bb7b3;
    display: block;
}
.curr_tit strong {
    font-weight: 600;
    display: inline-block;
    position: relative;
    z-index: 1;
}
.curr_tit strong::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 10px;
    background-color: rgba(43, 183, 179, 0.5);
    bottom: 0;
    z-index: -1;
}
.curr_txt p {
    margin-top: 40px;
    font-size: 19px;
    line-height: 1.4;
}
.curr_txt p strong{
    font-weight: 600;
    font-size: 26px;
}
.curr_01 {
    margin-bottom: 3rem;
}
.curr_01 .curr_txt, .curr_01 .curr_img {
    flex: 1 1 40%;
}
.curr_01 .curr_img{
    text-align: right;
    margin-bottom: 20px;
}
.curr_01 .curr_img img{
    width: 90%;
}
.curr_text{
    flex: 1 1 100%;
    background-color: #2bb7b3;
    padding: 30px 50px;
    margin-right: 20px;
    position: relative;
    margin-top: 20px;
}
.curr_text::after{
    content: '';
    position: absolute;
    right: -20px;
    bottom: -20px;
    width: 100px;
    height: 100px;
    border-right: 1px solid #2bb7b3;
    border-bottom: 1px solid #2bb7b3;
}
.curr_text strong{
    display: inline-block;
    color: #3068b3;
    font-size: 24px;
    margin-right: 50px;
    font-weight: 600;
    vertical-align: top;
    position: relative;
    padding-bottom: 5px;
}
.curr_text strong::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #3068b3;
}
.curr_text p{
    display: inline-block;
    width: calc(100% - 150px);
    font-weight: 500;
    font-size: 18px;
    line-height: 1.6;
    color: #fff;
}
.curr_02{
    margin-top: 12rem;
    position: relative;
}
.curr_02 .curr_tit::before{
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    width: 60px;
    height: 120px;
    border-right: 1px solid #2bb7b3;
    border-top: 1px solid #2bb7b3;
}
.curr_step{
    margin-top: 6rem;
}
.step_item {
    display: flex;
    justify-content: space-around;
    margin-bottom: 5rem;
}
.step_item_text{
    background-color: #2bb7b3;
    width: 25%;
    text-align: center;
    font-size: 16px;
    padding: 10px;
    margin-right: 5%;
}
.step_item_text span strong{
    text-decoration: underline;
}
.step_item_list {
    width: 70%;
}
.step_item_list ul{
    width: 100%;
    padding-top: 1rem;
    position: relative;
}
.item_list02 ul::before{
    content: '';
    width: 60%;
    height: 1px;
    background-color: #666;
    position: absolute;
    top: 0px;
    left: 10%;
}
.item_list03 ul::before{
    content: '';
    width: 75%;
    height: 1px;
    background-color: #666;
    position: absolute;
    top: 0px;
    left: 12.5%;
}
.step_item_text span{
    text-align: left;
    line-height: 1.4;
    width: 205px;
    font-weight: 500;
    color: #384249;
}
.step_item_text span strong{
    color: #fff;
    display: block;
    margin-top: 5px;
}
.step_item_text>strong{
    color: #fff;
    font-weight: 500;
    font-size: 18px;
    padding-right: 20px;
    width: 80px;
    text-align: left;
}

.step_item_list  li{
    font-size: 12px;
    color: #666;
    width: 25%;
    text-align: center;
    position: relative;
    padding-top: 20px;
    float: left;
}
.step_item_list  li::before{
    content: '';
    position: absolute;
    width: 10px;
    height: 10px;
    top: 0;
    left: calc(50% - 5px);
    background-color: #2bb7b3;
    border-radius: 50%;
    z-index: 10;
}
.step_item_list  .no::before, .step_item_list  .no::after{
    display: none;
}
.item_list02 li::after, .item_list03 li::after{
    content: '';
    position: absolute;
    width: 1px;
    height: 10px;
    top: -10px;
    left: calc(50% - 0.5px);
    background-color: #666;
}
.step_item_list.item_list02 li{
    width: 20%;
}
.step_item_list .tit{
    color: #2bb7b3;
    font-size: 15px;
    padding: 10px;
    font-weight: 500;
}
.step_item_list li i{
    display: block;
    margin: 0 auto;
    width: 70px;
    height: 70px;
    background-repeat: no-repeat;
    background-position: 0 0;
    background-size: 70px auto;
}
.item_list02, .item_list03{
    border-top: 3px solid #2bb7b3;
}
.item_list02 li i{
    background-image: url(../img/sub/curriculum_icon1.gif);   
}
.item_list03 li i{
    background-image: url(../img/sub/curriculum_icon2.gif);   
}
.step_item_list li:nth-child(2) i{
    background-position-y: -70px;
}
.step_item_list li:nth-child(3) i{
    background-position-y: -140px;
}
.step_item_list li:nth-child(4) i{
    background-position-y: -210px;
}
.step_item_list li:nth-child(5) i{
    background-position-y: -280px;
}
.step_item{
    position: relative;
}
.step_item::after{
    content: '';
    background-image: url(../img/sub/chevron-up.svg);
    width: 30px;
    height: 30px;
    background-size: 30px auto;
    opacity: 0.6;
    position: absolute;
    top: -40px;
    left: calc(12.5% - 15px);
}
.step_item:first-child::after{
    display: none;
}
.step_item_text{
    display: flex;
    justify-content: center;
    align-items: center;
    
}
.curr_step_all{
    text-align: center;
}
.curr_step_all ul{
    display: flex;
    justify-content: center;
    position: relative;
    padding-top: 60px;
}
.curr_step_all ul::before{
    content: '';
    width: 70px;
    height: 70px;
    transform: rotate(90deg);
    background-position: 0 -280px;
    background-size: 70px auto;
    background-image: url(../img/sub/curriculum_icon2.gif);
    position: absolute;
    top: 0;
    left: calc(50% - 35px);
}
.curr_step_all li{
    width: 180px;
    height: 180px;
    background-color:rgba(43, 183, 179, 0.6);
    border-radius: 50%;
    color: #384249;
    text-align: left;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.4;
    margin-right: -10px;
    padding-left: 35px;
    padding-top: 40px;
}
.curr_step_all li:nth-child(2){
    background-color: rgba(48, 104, 179, 0.6);
    margin-right: 0;
    margin-left: -10px;
    padding-top: 50px;
}
.curr_03 {
    margin-top: 4rem;
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto;
}
.curr_tit_s{
    font-size: 24px;
    font-weight: 500;
}
.curr_tit_s span{
    position: relative;
    display: inline-block;
    padding-bottom: 5px;
    margin-bottom: 20px;
}
.curr_tit_s span::before{
    content: '';
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 1px;
    background-color: #666;
}
.curr_03 dl{
    display: table;
    margin-bottom: 3rem;
    line-height: 1.6;
}
.curr_03 dl>*{
    display: table-cell;
}
.curr_03 dt{
    width: 120px;
    background-color: #2bb7b3;
    color: #fff;
    text-align: center;
    padding: 10px 0;
    font-size: 18px;
    position: relative;
}
.curr_03 .pre dt, .curr_03 .pre dt::after{
    background-color: #3068b3;
}
.curr_03 dt::after{
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #2bb7b3;
    position: absolute;
    bottom: -20px;
    left: calc(50% - 5px);
}
.curr_03 dt::before{
    content: '';
    width: 1px;
    height: 40px;
    z-index: -1;
    position: absolute;
    bottom: -40px;
    left: calc(50% - 0.5px);
    background-color: #999;
}
.curr_03 .no::after, .curr_03 .no::before{ 
    content: '';
    display: none;
}
.curr_03 dl dd{
    width: calc(100% - 120px);
    padding-left: 30px;
    font-size: 16px;
}
.curr_list{
    margin-top: 6rem;
}
.curr_list:last-child{
    margin-bottom: 6rem;
}
.curr_list ul li{
    font-size: 16px;
    padding: 10px 0 10px 25px;
    position: relative;
}
.curr_list ul li::after{
    content: '';
    width: 16px;
    height: 16px;
    border: 4px solid rgb(194, 194, 194);
    display: block;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 12px;
}
.curr_list ol{
    display: flex;
    justify-content: space-between;
    font-size: 16px;
}
.curr_list ol li{
    width: 25%;
}
.curr_list ol strong{
    width: 25%;
    height: 300px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.6;
    display: table-cell;    
    margin: 0 auto;
    text-align: center;
    position: relative;
}
.curr_list ol li:nth-child(even) strong{
    color: #fff;
}
.curr_list ol strong::after{
    content: '';
    width: 200px;
    height: 200px;
    border: 1px solid #2bb7b3;
    position: absolute;
    left: calc(50% - 100px);
    top: calc(50% - 100px);
    transform: rotate(45deg);
    z-index: -1;
}
.curr_list ol li:nth-child(even) strong::after{
    background-color: #2bb7b3;
}
.curr_list ol span{
    padding: 20px;
    display: block;
    line-height: 1.6;
    border-left: 1px solid rgba(43, 183, 179, 0.5);
}
.curr_list ol li:first-child span{
    border-left: none;
}
.curr_list p{
    font-size: 16px;
}
.curr_list p strong{
    color: #2e4190;
    vertical-align: top;
    font-weight: 600;
}
.curr_list table{
    border-spacing: 0;
    border-collapse: collapse;
    width: 100%;
    font-size: 16px;
    text-align: center;
    margin-top: 2rem;;
    border-bottom: 2px solid #2bb7b3;
}
.curr_list table thead th{
    border-bottom: 1px solid #d9d9d9;
    background-color: #2bb7b3;
    color: #fff;
    border-left: 1px solid #d9d9d9;
}
.curr_list table th{
    text-align: center;
}
.curr_list table th, .curr_list table td{
    padding: 10px;
}
.curr_list table td  {
    border-left: 1px solid #d9d9d9;
    border-bottom: 1px solid #d9d9d9;
}
.curr_list table tbody th{
    border-bottom: 1px solid #d9d9d9;
    color: #2bb7b3;
    font-size: 22px;
    font-weight: 600;
}
.curr_list table .t_bar td, .curr_list table .t_bar th{
    border-top: 2px solid rgba(43, 183, 179, 0.65);
}
.curr_list table .t_info{
    color: #2e4190;
    background-color: rgba(48, 104, 179, 0.05);
}
/* kit */
#kit .img_box p{
    font-size: 23px;
    padding-top: 50px;
}
@media (max-width: 1200px){
    .curr_tit {
        font-size: 36px;
    }
    .curr_txt p, .curr_text p{
        font-size: 17px;
    }
    .curr_txt p strong{
        font-size: 24px;
    }
}
@media (max-width: 991px){
    .curr_list ol strong{
        height: 240px;
    }
    .curr_list ol strong::after{
        width: 160px;
        height: 160px;
        left: calc(50% - 80px);
        top: calc(50% - 80px);
    }
    #kit .img_box p{
        font-size: 19px;
        padding-top: 0;
    }
}
@media (max-width: 768px) {
    .curr_01 {
        flex-direction: column;
        justify-content: space-around;
        flex-wrap: wrap;
        margin-bottom: 100px;
    }
    .curr_txt, .about_item_txt{
        margin-top: -80px;
    }
    .curr_text{
        padding: 20px;
    }
    .curr_tit {
        font-size: 28px;
    }
    .curr_txt p, .curr_text p{
        font-size: 15px;
    }
    .curr_txt p strong{
        font-size: 18px;
    }
    .curr_text strong{
        display: block;
        margin-right: 0;
        font-size: 18px;
        margin-bottom: 10px;
    }
    .curr_text p{
        width: 100%;
    }
    .curr_01 .curr_img{
        text-align: left;
        margin-top: 20px;
    }
    .curr_01 .curr_img img {
        width: 100%;
    }
    .curr_tit_s{
        font-size: 18px;
    }
    .curr_03 dt{
        font-size: 16px;
    }
    .curr_03 dl dd{
        font-size: 14px;
    }
    .curr_03 dt{
        width: 90px;
    }
    .curr_03 dl dd{
        width: calc(100% - 100px);
        padding-left: 20px;
    }
    .step_item{
        flex-direction: column;
    }
    .step_item:last-child{
        margin-bottom: 2rem;
    }
    .step_item_text{
        margin-bottom: 10px;
    }
    .step_item_text, .step_item_list{
        width: 100%;
    }
    .step_item::after {
        left: calc(50% - 15px);
    }
    .step_item_list li{
        font-size: 10px;
    }
    .step_item_list li i {
        width: 50px;
        height: 50px;
        background-size: 50px auto;
    }
    .step_item_list li:nth-child(2) i {
        background-position-y: -50px;
    }
    .step_item_list li:nth-child(3) i {
        background-position-y: -100px;
    }
    .step_item_list li:nth-child(4) i {
        background-position-y: -150px;
    }
    .step_item_list li:nth-child(5) i {
        background-position-y: -200px;
    }
    .step_item_text{
        padding: 5px;
    }
    .step_item_text>strong{
        font-size: 16px;
    }
    .step_item_text span{
        font-size: 14px;
    }
    .step_item_text span strong{
        margin-top: 0;
    }
    .curr_step_all ul::before{
        content: '';
        width: 50px;
        height: 50px;
        background-position: 0 -200px;
        background-size: 50px auto;
        left: calc(50% - 25px);
    }
    .curr_step_all ul{
        padding-top: 50px;
    }
    .curr_step_all li{
        width: 130px;
        height: 130px;
        font-size: 15px;
        padding-left: 25px;
        padding-top: 20px;
    }
    .curr_step_all li:nth-child(2) {
        padding-top: 30px;
    }
    .curr_step{
        margin-top: 3rem;
    }
    .curr_list ol{
        flex-wrap: wrap;
    }
    .curr_list ol li{
        width: 50%;
        margin-bottom: 20px;
    }
    .curr_list ol strong{
        height: 150px;
        font-size: 15px;
        line-height: 1.4;
    }
    .curr_list ol strong::after{
        width: 100px;
        height: 100px;
        left: calc(50% - 50px);
        top: calc(50% - 50px);
    }
    .curr_list ol span{
        padding: 10px;
        font-size: 14px;
    }
    .curr_list ul li{
        font-size: 14px;
        padding: 5px 0 5px 20px;
    }
    .curr_list ul li::after {
        content: '';
        width: 12px;
        height: 12px;
        border: 3px solid rgb(194, 194, 194);
        display: block;
        border-radius: 50%;
        position: absolute;
        left: 0;
        top: 8px;
    }
    .curr_list ol li:nth-child(odd) span{
        border-left: none;
    }
    .curr_list p {
        font-size: 14px;
    }
    .curr_list table {
        font-size: 14px;
    }
    .curr_list table th, .curr_list table td {
        padding: 5px;
    }
    .curr_list table tbody th{
        font-size: 18px;
    }
    #kit .img_box p{
        font-size: 15px;
    }
}

/* 로그인 */
.logo_box{
    padding: 50px 10px 150px;
}
#sns_login{
    border: 1px solid #eee;
    padding-bottom: 60px;
    max-width: 500px;
    margin: 0 auto;

}
#sns_login h3{
    text-align: center;
    padding: 20px;
    font-size: 20px;
    font-weight: normal;
    color: #666;
}

@media (max-width: 768px) {
    #sns_login{
        border: none;
        border-radius: 20px;
        padding-bottom: 60px;
        max-width: 500px;
        margin: 0 auto;
    }
    .logo_box{
        padding: 0 15px 150px;
    }
    #mb_login{
        width: 100% !important;
        padding: 0 !important;
    }
    #sns_login h3{
        font-size: 16px;
        margin-top: -80px;
    }
}