/* visual sub 공통 start */
.sub_visual{
    width:100%;
    min-width:1400px;
    position: relative;
    overflow: hidden;
}
.sub_visual::after{
    content: '';
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color: rgba(0, 0, 0, 0.4);
}
.sub_visual > img{
    width:100%;
    object-fit: cover;
    height:450px;
    transition: all 1.5s ease-in-out;
    transform:scale(1.5);
}
.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:1;
    transform:translate(0,100%);
    transition:all 1s ease-in-out;
}

.sub_visual .sub_typo span:first-child{
    font-size:36px;
    font-weight: 800;
    transition-delay:0s;
    font-family: 'Noto Serif KR', serif;
}
.sub_visual .sub_typo span:nth-child(2){
    font-size:18px;
    font-weight: 600;
    transition-delay:0.5s;
}
/* visual sub 공통 end */

/* sub 타이틀 공통 */
.contents_title{
    padding:30px 0;
    position: relative;
    width:100%;
    min-width:1224px;
    overflow: hidden;
}
.contents_title h2{
    font-size:40px;
    padding:30px;
    color:#333;
    font-weight: 600;
    text-align: left;
    position: relative;
}
.contents_title h2::before{
    content: '';
    position: absolute;
    top:20px;
    left:0;
    width:25px;
    height:25px;
    border-top:2px solid #dd4926;
    border-left:2px solid #dd4926;
    animation: bounceInLeft 1.5s .3s both;
}
.contents_title h2::after{
    content: '';
    position: absolute;
    bottom:0;
    left:0;
    width:100%;
    height:1px;
    background-color: #dd4926;
    animation: bounceInLeft 1.5s .3s both;
}

.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 .about .greetings{padding-bottom:60px;}
.sub01_01 .about .greetings ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap:40px;
}
.sub01_01 .about .greetings ul li{width:50%;}
.sub01_01 .about .greetings ul li h3{
    font-size:24px;
    color:#000;
    text-align: left;
    font-weight: 600;
}
.sub01_01 .about .greetings .tit{margin-top:10px;}
.sub01_01 .about .greetings .tit p{
    font-size:18px;
    color:#333;
    text-align: left;
    line-height:32px;
    padding:10px 0;
}
.sub01_01 .about .greetings .img img{border-radius: 0 30px 0 30px;}


.sub01_01 .about .map{
    padding:60px 0;
    background-color: #f7f7f7;
    margin-bottom:-30px;
}
.sub01_01 .about .map .section_address{display: none;}
.sub01_01 .about .map .chart{
    width:100%;
    margin-top:30px;
    border-top:3px solid #dd4926;
}
.sub01_01 .about .map .chart tr th,
.sub01_01 .about .map .chart tr td{
    font-size:16px;
    padding:20px;
    border:1px solid #ccc;
}
.sub01_01 .about .map .chart tr th{
    text-align: center;
    background-color: #dddada;
}
/* sub01_01 */




/* sub02_01 */
.sub02_01 .business{padding-bottom:160px; position: relative;}
.sub02_01 .business::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 0;
    background: url(../img/sub/sub02/sub02_01_bg.png) no-repeat;
    background-size: auto;
    background-position: left 200px top -1000px;
}

.sub02_01 .business .tit h3{
    font-size:32px;
    color:#000;
    text-align: center;
}
.sub02_01 .business .tit p{
    font-size:18px;
    color:#333;
    text-align: center;
    margin-top:10px;
}

.sub02_01 .business .symbol{position: relative; margin-top:120px;}
.sub02_01 .business .symbol::before{
    content: '';
    position: absolute;
    top:-85px;
    left:50%;
    transform: translateX(-50%);
    width:3px;
    height:60px;
    background-color: #dd4926;
}
.sub02_01 .business .symbol .img{
    width:180px;
    height:180px;
    border-radius: 50%;
    padding:40px;
    background-color: #f9f6f6;
    margin:0 auto;
}

.sub02_01 .business ul{
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap:20px;
}
.sub02_01 .business ul li{width:33.333%;}
.sub02_01 .business ul li .img{overflow: hidden; background-color: #000;}
.sub02_01 .business ul li .img img{transition: all .3s ease-in-out;}
.sub02_01 .business ul li:nth-of-type(1) {transform: translateY(30px);}
.sub02_01 .business ul li:nth-of-type(1) .img{border-radius: 30px 0 0 0;}
.sub02_01 .business ul li:nth-of-type(2){transform: translateY(120px);}
.sub02_01 .business ul li:nth-of-type(3){transform: translateY(80px);}
.sub02_01 .business ul li:nth-of-type(3) .img{border-radius: 0 0 30px 0;}
.sub02_01 .business ul li .img:hover img{transform: scale(1.1); opacity: .8;}


.sub02_01 .business ul li .txt{margin-top:10px;}
.sub02_01 .business ul li .txt h4{
    font-size:24px;
    font-weight: 800;
    color:#dd4926;
    text-align: center;
    margin-bottom:10px;
}
.sub02_01 .business ul li .txt p{
    font-size:18px;
    color:#333;
    text-align: center;
    line-height:32px;
}
/* sub02_01 */




/* sub03_01 */
.sub03_01 .portfolio .category_pd{
    position: sticky;
    top:100px;
    left:0;
    z-index: 99;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
}
.sub03_01 .portfolio .category_pd .cat_bar{display: none;}
.sub03_01 .portfolio .category_pd a{
    display: block;
    font-size:18px;
    width:25%;
    text-align: center;
    border-right:0;
    transition: all .3s ease-in-out;
    color:#000;
    background-color: #fff;
}
.sub03_01 .portfolio .category_pd a b{color:#dd4926;}
.sub03_01 .portfolio .category_pd a:hover{color:#dd4926;}
.sub03_01 .portfolio .photo_bbs{margin-top:30px;}
.sub03_01 .portfolio .photo_bbs .tit a{text-align: center;}
.sub03_01 .portfolio .photo_bbs .date{display: none;}
.sub03_01 .portfolio .bbs_paging tr td b{color:#dd4926;}
/* sub03_01 */




/* sub04_01 */
.sub04_01 .contact .top10{margin-top:0; margin-bottom:10px;}
/* sub04_01 */
/* ------------------------------------------- sub -------------------------------------------------------- */
