/* visual sub 공통 start */
.sub_visual{
    width:100%;
    min-width:1300px;
    position: relative;
    overflow: hidden;
    margin-top:100px;
}
.sub_visual::before{
    position: absolute;
    content: '';
    width:100%;
    height:100%;
    background-color: rgba(0, 0, 0, .2);
    z-index: 1;
}
.sub_visual > img{
    width:100%;
    height:450px;
    object-fit: cover;
    transition: all 3s ease-in-out;
    transform:scale(1.2);
}
.sub_visual > img.zoom{transform:scale(1);}
.sub_visual .sub_typo{
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width:100%;
    z-index: 99;
}
.sub_visual .sub_typo > span.up{opacity:1; transform:translate(0,0);}
.sub_visual .sub_typo span{
    color:#fff;
    display:block;
    opacity:0;
    transform:translate(0,100%);
    transition:all 1s ease-in-out;
    font-family:'GmarketSansMedium';
}
.sub_visual .sub_typo span:first-child{
    font-size:42px;
    transition-delay:0s;
}
.sub_visual .sub_typo span:nth-child(2){
    font-size:18px;
    transition-delay:0.5s;
    font-family:'GmarketSansLight';
}
/* visual sub 공통 end */

/* tab 메뉴 공통 */
/* .contents{padding:30px 0;} */
.sub_tabmenu{
    position: sticky;
    z-index: 99;
    top:160px;
    transform: translateY(-60px);
    background: rgba(0,0,0,0.6);
    height:60px;
    line-height: 60px;
}
.sub_tabmenu ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
}
.sub_tabmenu li a{
    display: block;
    font-size:18px;
    text-align: center;
    color:#fff;
    transition: all .3s ease-in-out;
}
.tabmenu01 li{width:20%;}
.sub_tabmenu li a:hover{background-color: #ea1f54; color:#fff; transition: all .3s ease-in-out;}

.sub01_01 .sub_tabmenu li:nth-child(1) a{background-color: #ea1f54; color:#fff;}
.sub01_02 .sub_tabmenu li:nth-child(2) a{background-color: #ea1f54; color:#fff;}
.sub01_03 .sub_tabmenu li:nth-child(3) a{background-color: #ea1f54; color:#fff;}
.sub01_04 .sub_tabmenu li:nth-child(4) a{background-color: #ea1f54; color:#fff;}
.sub01_05 .sub_tabmenu li:nth-child(5) a{background-color: #ea1f54; color:#fff;}    
/* tab 메뉴 공통 */

/* sub 타이틀 공통 */
.contents_title{
    padding:30px 0;
    position: relative;
    width:100%;
    min-width:1224px;
    overflow: hidden;
}
.contents_title h2{
    padding:30px 0 30px 20px;;
    font-size:40px;
    color:#333;
    font-weight: 400;
    text-align: left;
    position: relative;
}
.contents_title h2::before{
    position: absolute;
    content: '';
    top:40px;
    left:0;
    width:3px;
    height:40px;
    background-color: #ea1f54;
}
.contents_title h2::after{
    content: '';
    position: absolute;
    bottom:10px;
    left:0;
    width:100%;
    height:1px;
    background-color: #ccc;
    animation:bounceInRight 1s .2s both;
}
.contents_title h2 span{
    font-size:40px;
    font-weight:800;
    display: block;
}

.contents_detail{padding:30px 0;}
/* sub 타이틀 공통 */

/* image_show_wrap 공통 */
.contents_detail .image_show_wrap,
.contents_detail .image_show_wrap2{
    position: relative;
    top: 0px;
    left: 0%;
    width: 100%;
}
.contents_detail .image_show_wrap{overflow: hidden; animation-duration: 1.4s;}
.contents_detail .image_show_wrap2{animation-duration: 1.4s;}

.contents_detail .show_img01{animation-name: show_img01;}
@keyframes show_img01{
    0%{opacity: 0; transform: translate3d(-100%, 0, 0);}
}
.contents_detail .show_img02{animation-name: show_img02;}
@keyframes show_img02{
    0%{opacity: 0; transform: translate3d(100%, 0, 0);}
}
.contents_detail .show_img03{animation-name: show_img03;}
@keyframes show_img03{
    0%{opacity: 0; transform: translate3d(100%, 0, 0);}
}
.contents_detail .show_img04{animation-name: show_img04;}
@keyframes show_img04{
    0%{opacity: 0; transform: translate3d(-100%, 0, 0);}
}
.contents_detail .show_img05{animation-name: show_img05;}
@keyframes show_img05{
    0%{opacity: 0; transform: translate3d(0, 100%, 0);}
}
.contents_detail .show_img06{animation-name: show_img06;}
@keyframes show_img06{
    0%{opacity: 0; transform: translate3d(0, -100%, 0);}
}
/* image_show_wrap 공통 */


/* image 확대 공통 */
.clip-animation {
    clip-path: polygon(50% 50%, 50% 50%, 50% 50%, 50% 50%);
    animation: clipExpand 1s cubic-bezier(0.770, 0.000, 0.175, 1.000) forwards;
}
    @keyframes clipExpand {
    from {
        clip-path: polygon(50% 50%, 50% 50%, 50% 50%, 50% 50%);
    }
    to {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    }
}
/* image 확대 공통 */

/* ------------------------------------------- sub -------------------------------------------------------- */
/* sub01_01 */
.sub01_01 .greetings ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap:40px;
}
.sub01_01 .greetings ul li{width:50%;}
.sub01_01 .greetings ul li .img{position: relative; border-radius: 30px 0 30px 0; overflow: hidden;}
.sub01_01 .greetings ul li .img::before{
    content: '';
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color: #ea1f54;
    animation: bounceInRight 2s both;;
}
.sub01_01 .greetings ul li p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
    padding:10px 0;
}
.sub01_01 .greetings ul li p:nth-of-type(6),
.sub01_01 .greetings ul li p:nth-of-type(7){text-align: right;}
.sub01_01 .greetings ul li p strong{
    font-size:24px;
    color:#000;
}
/* sub01_01 */



/* sub01_02 */
.sub01_02 .purpose .title h3{
    font-size:28px;
    color:#000;
    text-align: left;
}
.sub01_02 .purpose .title p{
    font-size:24px;
    color:#333;
    text-align: left;
    line-height:40px;
    margin-top:10px;
}
.sub01_02 .purpose ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap:40px;
    margin-top:60px;
}
.sub01_02 .purpose ul li{width:50%;}
.sub01_02 .purpose ul li .img{position: relative; border-radius: 30px 0 30px 0; overflow: hidden;}
.sub01_02 .purpose ul li .img::before{
    content: '';
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color: #ea1f54;
    animation: bounceInRight 2s both;;
}
.sub01_02 .purpose ul li h3{
    font-size:28px;
    color:#000;
    text-align: left;
    margin-bottom:10px;
}
.sub01_02 .purpose ul li span{
    display: block;
    font-size:20px;
    color:#000;
    text-align: left;
    margin-bottom:30px;
    line-height:40px;
}
.sub01_02 .purpose ul li p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
    padding:10px 0;
}
/* sub01_02 */



/* sub01_03 */
.sub01_03 .org .line{margin-bottom:60px;} 
.sub01_03 .org .line1 ul{
    display: flex;
    justify-content: center;
}
.sub01_03 .org .line1 ul li{position: relative;}
.sub01_03 .org .line1 ul li::before{
    content: '';
    position: absolute;
    bottom:-90px;
    left:50%;
    transform: translateY(-50%);
    background-color: #ccc;
    width:1px;
    height:60px;
}
.sub01_03 .org .line1 ul li h3{
    font-size:24px;
    color:#fff;
    padding:10px 30px;
    background-color: #EA1F54;
}



.sub01_03 .org .line2{position: relative;}
.sub01_03 .org .line2 ul{
    display: flex;
    justify-content: center;
}
.sub01_03 .org .line2 ul li{position: relative;}
.sub01_03 .org .line2 ul li::before{
    content: '';
    position: absolute;
    bottom:-90px;
    left:50%;
    transform: translateY(-50%);
    background-color: #ccc;
    width:1px;
    height:60px;
}
.sub01_03 .org .line2 ul li h3{
    font-size:24px;
    color:#fff;
    padding:10px 30px;
    background-color: #fbae70;
}
.sub01_03 .org .line2 p{
    position: absolute;
    top:49%;
    left:65%;
    transform: translate(-50%, -50%);
    font-size:20px;
    color:#fff;
    padding:10px 30px;
    background-color: #F72DDC;
}
.sub01_03 .org .line2 p::before{
    content: '';
    position: absolute;
    top:50%;
    transform: translateY(-50%);
    left:-85px;
    width:85px;
    height:1px;
    background-color: #ccc;
}



.sub01_03 .org .line3 ul{
    display: flex;
    justify-content: center;
    position: relative;
}
.sub01_03 .org .line3 ul::before{
    content: '';
    position: absolute;
    bottom:-30px;
    left:50%;
    transform: translateX(-50%);
    width:1075px;
    height:1px;
    background-color: #ccc;
}
.sub01_03 .org .line3 ul li{position: relative;}
.sub01_03 .org .line3 ul li::before{
    content: '';
    position: absolute;
    bottom:-45px;
    left:50%;
    transform: translateY(-50%);
    background-color: #ccc;
    width:1px;
    height:30px;
}
.sub01_03 .org .line3 ul li h3{
    font-size:24px;
    color:#fff;
    padding:10px 30px;
    background-color: #f97a6c;
}



.sub01_03 .org .line4 ul{
    display: flex;
    justify-content: space-between;
    gap:40px;
}
.sub01_03 .org .line4 ul li{position: relative; width:20%;}
.sub01_03 .org .line4 ul li::before{
    content: '';
    position: absolute;
    top:-15px;
    left:50%;
    transform: translateY(-50%);
    background-color: #ccc;
    width:1px;
    height:30px;
}
.sub01_03 .org .line4 ul li h3{
    font-size:20px;
    color:#fff;
    padding:30px 40px;
    background-color: #796765;
    text-align: center;
}
/* sub01_03 */




/* sub01_04 */
/* 연혁 */
.sub01_04 .history{margin-top:30px;}
.sub01_04 .history .history_list {position:relative; padding-left:50%; overflow: hidden;}
.sub01_04 .history .history_list .years_tit {
    position:absolute;
    top:0;
    left:0;
    width:50%;
    height:100vh;
    max-height:calc(var(--vh, 1vh) * 100);
    background:url('../img/sub/sub01/sub01_04_img1.jpg') no-repeat 50% 50% / cover;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
}
.sub01_04 .history .history_list .years_tit .tit {
    font-size:72px;
    font-weight: 800;
    color:#fff;
    /* font-weight:300;
    line-height:1.2;
    margin-bottom:40px; */
    text-align:center;
}
.sub01_04 .history .history_list .years_tit ul {display:flex; flex-direction:column; gap:20px;}
.sub01_04 .history .history_list .years_tit li {font-size:60px; color:rgba(255,255,255,0); font-weight:700; line-height:84px; -webkit-text-stroke:1px rgba(255,255,255,.3)}
.sub01_04 .history .history_list .years_tit li.on {color:#fff; -webkit-text-stroke:0;}
.sub01_04 .history .history_list .years_tit li a {display:block; color:inherit;}
.sub01_04 .history .history_list .years_con {padding:80px 0 100px 80px;}
.sub01_04 .history .history_list .years_con dl {margin-bottom:60px;}
.sub01_04 .history .history_list .years_con dl:last-child {margin-bottom:0;}
.sub01_04 .history .history_list .years_con dt {position:relative; font-size:40px; color:#000; font-weight:700; line-height:1.2;}
.sub01_04 .history .history_list .years_con dt .ypoint {position:absolute; top:-50vh;}
.sub01_04 .history .history_list .years_con dd {padding-top:30px; display:flex; flex-direction:column; gap:15px;}
.sub01_04 .history .history_list .years_con dd p {position:relative; color:#333; line-height:30px; padding-left:115px;}
.sub01_04 .history .history_list .years_con dd p strong {position:absolute; top:0; left:0; color:#015aae; font-weight:700;}
.sub01_04 .history .history_list .hispoint {position:absolute; top:0;}
.sub01_04 .history .history_list .setpoint {position:absolute; top:-40px;}
.sub01_04 .history .upset .history_list .setpoint {top:-100px;}
.sub01_04 .history .history_list .his_end {top:calc(100% - 100vh);}
.sub01_04 .history .history_list.start .years_tit {position:fixed; top:160px;}
.sub01_04 .history .history_list.end .years_tit {position:absolute; bottom:-166px; top:auto;}
/* sub01_04 */




/* sub01_05 */
.sub01_05 .map_wrap .map .cont{display: none;}

.sub01_05 .map_wrap .map .chart{
    width:100%;
    border-top:3px solid #ea1f54;
    margin-top:30px;
}
.sub01_05 .map_wrap .map .chart tr th,
.sub01_05 .map_wrap .map .chart tr td{
    font-size:18px;
    color:#333;
    padding:20px;
    border:1px solid #ccc;
}
.sub01_05 .map_wrap .map .chart tr th{background-color: #f7f7f7;}
.sub01_05 .map_wrap .map .chart .tit{margin-top:10px;}
.sub01_05 .map_wrap .map .chart .tit p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
}
.sub01_05 .map_wrap .map .chart .tit ul{
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap:20px;
    margin-top:20px;
}
.sub01_05 .map_wrap .map .chart .tit ul a{
    display: block;
    padding:10px 40px;
    border-radius: 100px;
    transition: all .3s ease-in-out;
    background-color: #03c158;
    font-size:18px;
    color:#fff;
    text-align: center;
}
.sub01_05 .map_wrap .map .chart .tit ul li:nth-of-type(1) a{background-color: #f1db00; color: #371d1f;}
.sub01_05 .map_wrap .map .chart .tit ul li:nth-of-type(2) a{background-color: #03c158;}

.sub01_05 .map_wrap .map .chart .tit ul a span{
    font-size:18px;
    vertical-align: middle;
    padding-bottom: 3px;
}



/* sub01_05 */



/* sub02_01 */
.sub02_01 .business ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap:20px;
}
.sub02_01 .business ul li{
    width:32.3%;
    border:1px solid #ccc;
    padding:30px;
}
.sub02_01 .business ul li h3{
    font-size:24px;
    color:#000;
    text-align: center;
}
.sub02_01 .business ul li .img{
    margin:30px 0;
    width:200px;
    height:200px;
    border-radius: 50%;
    margin:30px auto;
    padding:40px;
    box-shadow:2px 2px 5px rgba(0,0,0,0.3);
}
.sub02_01 .business ul li .tit p{
    font-size:18px;
    color:#333;
    text-align: center;
    line-height:32px;
    padding:5px 0;
    position: relative;
}
.sub02_01 .business ul li .tit p::before{
    content: '';
    position: absolute;
    top:50%;
    transform: translateY(-50%);
    left:60px;
    background-color: #333;
    width:8px;
    height:8px;
    border-radius: 50%;
}
/* sub02_01 */



/* sub03_01 */
.sub03_01 .boost ul{
    display: flex;
    justify-content: space-between;
    gap:40px;
}
.sub03_01 .boost ul li{width:50%;}
.sub03_01 .boost ul li .img{position: relative; border-radius: 30px 0 30px 0; overflow: hidden;}
.sub03_01 .boost ul li .img::before{
    content: '';
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color: #ea1f54;
    animation: bounceInRight 2s both;
}
.sub03_01 .boost ul li .tit h4{
    font-size:24px;
    color:#000;
    text-align: left;
    margin-bottom:10px;
}
.sub03_01 .boost ul li .tit p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
}
.sub03_01 .boost ul li .icon{
    padding:20px 0;
    display: flex;
    align-items: center;
    justify-content: start;
    gap:20px;
}
.sub03_01 .boost ul li .icon span{
    display: inline-block;
    padding:10px;
    width:80px;
    height:80px;
    border-radius: 50%;
    position: relative;
    background-color: #ea1f54;
    vertical-align: middle;
    margin-right:10px;
}
.sub03_01 .boost ul li .icon h4{
    font-size:24px;
    color:#000;
    text-align: left;
}
.sub03_01 .boost ul li .icon p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
}

.sub03_01 .boost .boost_box{margin-top:30px;}
.sub03_01 .boost .boost_box ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap:40px;
}
.sub03_01 .boost .boost_box ul li{
    width:50%;
    padding:35px;
    border:1px solid #ccc;
}
.sub03_01 .boost .boost_box h3{
    font-size:32px;
    color:#000;
    text-align: center;
    margin-bottom:20px;
}
.sub03_01 .boost .boost_box p{
    font-size:24px;
    color:#333;
    text-align: left;
    line-height:48px;
    
}
.sub03_01 .boost .boost_box p strong{
    font-size:24px;
    color:#ea1f54;
}
/* sub03_01 */



/* sub04_01 */
.sub04_01 .sub_gallery .board .photo_bbs .thumb{padding-top:100%;}
.sub04_01 .sub_gallery .board .photo_bbs .tit a{text-align: center;}
.sub04_01 .sub_gallery .board .photo_bbs .date{display: none;}
.sub04_01 .sub_gallery .board .bbs_paging tr td b{background-color: #ea1f54;}
/* sub04_01 */



/* sub05_01 */
.sub05_01 .notice .board .AW_bbs_table{border-top:0;}
.sub05_01 .notice .board .bbs_paging tr td b{background-color: #ea1f54;}
/* sub05_01 */
/* ------------------------------------------- sub -------------------------------------------------------- */
