@charset "utf-8";/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

.fancybox-close {background-color:#242424 !important;}

#skipToContent a { z-index:100000; position:absolute; top:0; left:0; width:1px; height:1px; font-size:0; line-height:0; overflow:hidden } 
#skipToContent a:focus, 
#skipToContent a:active { width:200px; height:50px; background:#21272e; color:#fff; font-size:14px; font-weight:bold; text-align:center; text-decoration:none; line-height:50px } 

.only-desktop-tablet { display:block; } 
.only-desktop { display:block; } 
.only-tablet { display:none; } 
.only-mobile { display:none; } 

.company-header {padding-top: var(--header-height);}

.company-header #header .header-bg {background: #fff; border-bottom: 1px solid #ddd;}
.company-header #header .sitelogo a {background-image:url(../images/common/logo-c.png); }
.company-header #header #gnb>ul>li>a {color:#242424;}
.company-header #header .btn-m-menu span {background:#242424;}
.company-header #header .btn-m-menu span:before, 
.company-header #header .btn-m-menu span:after {background:#242424;}


/* header */
#header {position:fixed; top:0; left:0; width:100%; z-index:90; } 
#header .contain {display:flex; align-items:center; justify-content:space-between; position:relative; height:var(--header-height); max-width:1460px !important;z-index:10;} 
#header .sitelogo a {display:block; width:clamp(110px, calc( 182 / var(--inner) * 100vw ), 182px); height:var(--header-height); text-indent:-999em; background-image:url(../images/common/logo-w.png); background-size:contain; background-repeat:no-repeat; background-position: 0 50%;} 

#header.active .header-bg {background: #fff; box-shadow:rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;}
#header.active .sitelogo a {background-image:url(../images/common/logo-c.png); }
#header.active #gnb>ul>li>a {color:#242424;}
#header.active .btn-m-menu span {background:#242424;}
#header.active .btn-m-menu span:before, 
#header.active .btn-m-menu span:after {background:#242424;}

#header:hover .header-bg {background: #fff;}
#header:hover .sitelogo a {background-image:url(../images/common/logo-c.png); }
#header:hover #gnb>ul>li>a {color:#242424;}
#header:hover .btn-m-menu span {background:#242424;}
#header:hover .btn-m-menu span:before, 
#header:hover .btn-m-menu span:after {background:#242424;}

#gnb {text-align:center; flex:1 1 auto; min-width:0; width:1%;}
#gnb>ul {display:flex; justify-content:flex-end;} 
#gnb>ul>li {position:relative; padding:0 clamp(30px, calc( 45 / var(--inner) * 100vw ), 45px);}
#gnb>ul>li.active > a{ color: var(--color-primary) !important;}
#gnb>ul>li>a {display:flex; align-items:center; flex-direction: column; justify-content:center; height:var(--header-height); color:#fff; font-size:clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px); font-weight:600; letter-spacing:-.03em; line-height:1.3em;}
#gnb>ul>li:last-child .submenu {left:auto; right:0; transform:none;}
/*#gnb>ul>li:nth-child(4) .submenu {left:auto ; right:0; transform:none;}*/
/*#gnb>ul>li:nth-child(5) .submenu {left:auto ; right:0; transform:none;}*/
#gnb .submenu {display:none; position:absolute; left:50%; top:100%; margin-top:10px; text-align:center; transform:translateX(-50%); z-index:100;}
#gnb .submenu>ul {display:flex; padding: 0 clamp(20px, calc( 30 / var(--inner) * 100vw ), 30px); background: #121212 ; border-radius: 12px;}
#gnb .submenu>ul>li>a {display:block; padding:15px clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px); color:#fff; font-size:clamp(14px, calc( 16 / var(--inner) * 100vw ), 16px); line-height:1.33em; white-space:nowrap;}
#gnb .submenu>ul>li.active>a  {font-weight: bold;}
#gnb .submenu>ul>li.active>a ,
#gnb .submenu>ul>li:hover>a {color:var(--color-secondary);}

#gnb .submenu>ul>li a .eng {display: none;}
#gnb .submenu>ul>li a .kor {display: inline-block;}
#gnb .submenu>ul>li a:hover .eng {display: inline-block;}
#gnb .submenu>ul>li a:hover .kor {display: none;}
/*#gnb .submenu>ul>li a span {width:210px;text-align: center;}*/



/* 공통  */
.section {overflow:hidden;}
.flxWrap {display:flex; flex-wrap:wrap;}
.sec-pd {padding: clamp(60px, calc( 160 / var(--inner) * 100vw ), 160px) 0;}
.text-center {text-align:center;}
.align-items-center {align-items:center !important;}
.justify-content-center {justify-content:center !important;}
.main-color {color:var(--color-primary) !important;}
.sub-color {color:var(--color-secondary) !important;}
.color-dark {color: var(--color-dark) !important;}
.red {color:#e32020;}
.pt-0 {padding-top:0 !important;} 
.pb-0 {padding-bottom:0 !important;}
.mb-0 {margin-bottom:0 !important;}
.mt-0 {margin-top:0 !important;}
.font-light {font-weight:300 !important;}
.font-medium {font-weight:500 !important;}
.font-semi {font-weight:600 !important;}
.font-extra {font-weight:800 !important;}
.font-normal {font-weight:400 !important;}
.text-center {text-align:center !important;}
.text-left {text-align:left !important;}
.text-right {text-align:right !important;}
.max-wid {max-width:1460px; width:100%; margin:0 auto; padding-left:var(--container-space); padding-right:var(--container-space);}
.sec-titbox {margin-bottom: clamp(30px, calc( 75 / var(--inner) * 100vw ), 75px); line-height:1.1;}
.sec-titbox .section-tit {font-size:clamp(24px, calc( 44 / var(--inner) * 100vw ), 44px); font-weight:bold; color:#242424;text-transform: uppercase; }
.sec-titbox .section-dec { font-size:clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px); color:var(--color-primary); line-height:1.44;font-weight: bold; text-transform: uppercase;}
.sec-titbox .section-dec + .section-tit {padding-top: clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px);}
.bg-gray {background:#fafafa;}

/* main */
[data-aos=fade-up] { transform: translate3d(0,100px,0); } 
.main-visual { position:relative; overflow:hidden; color:#fff; } 
.main-visual .item {position:relative; overflow:hidden;}
.main-visual .image {position:relative; padding-bottom:50.52%; overflow:hidden;}
.main-visual .image img {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%;object-fit : cover;}
.main-visual .vjs-controls-disabled {position:relative; padding-bottom:50.52%; overflow:hidden;}
.main-visual .vjs-controls-disabled video {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%;object-fit : cover;}
.main_visual_vod_0-dimensions {height: 100% !important; width: 100% !important;}
.main_visual_vod_1-dimensions {height: 100% !important; width: 100% !important;}

.main-visual .text-box {padding-left:var(--container-space); padding-right:var(--container-space); position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); max-width:1460px; width:100%; line-height:1.3;}
.main-visual .text-box p {transition:1.2s; transform:translate(50px,0); opacity:0; }
.main-visual .text-box .txt1 {font-size: clamp(24px, calc( 60 / var(--inner) * 100vw ), 60px);font-weight: bold; line-height: 1.16;}
.main-visual .text-box .txt2 {padding-top: clamp(15px, calc( 35 / var(--inner) * 100vw ), 35px); font-size: clamp(16px, calc( 38 / var(--inner) * 100vw ), 38px);font-style: italic;font-family: var(--font-serif);}

.main-visual .controls {display:flex; align-items:center; padding-left:var(--container-space); padding-right:var(--container-space); position:absolute; bottom:28%; left:50%; transform:translatex(-50%); max-width:1460px; width:100%; color:#fff; z-index:40;}
.main-visual .pager {display:flex; align-items:center; gap:clamp(4px, calc( 8 / var(--inner) * 100vw ), 8px); font-size:clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px);}
.main-visual .pager span {position:relative; width: clamp(50px, calc( 70 / var(--inner) * 100vw ), 70px); font-size: 15px; color:rgba(255, 255, 255, 0.5); transition:color 0.3s;}
.main-visual .pager span::after {content:''; position:absolute; bottom:-8px; left:0; width:100%; height:clamp(2px, calc( 4 / var(--inner) * 100vw ), 4px); background:rgba(255, 255, 255, 0.5); transition:height 0.3s, background 0.3s;}
.main-visual .pager span.current {color:#fff;}
.main-visual .pager span.current::after { background:#fff;}
.main-visual .active .text-box p {transform:translate(0,0); opacity:1;}
.main-visual .active .text-box .txt1 {transition-delay:.5s;}
.main-visual .active .text-box .txt2 {transition-delay:.7s;}


/* section */
.performance-grid {display: flex; gap: clamp(5px, calc( 30 / var(--inner) * 100vw ), 30px); }
.performance-item {position: relative; height: clamp(40px, calc( 545 / var(--inner) * 100vw ), 545px); overflow: hidden; display: block; text-decoration: none; transition: flex 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94); flex: 1; min-width: 0;border-radius: 24px;}
.performance-item:hover,
.performance-item.active {flex: 2.85; z-index: 10;}
.performance-image {position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden;}
.performance-image img ,
.performance-image video {width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; transform-origin: center center;}
.performance-overlay {display: flex; align-items: flex-end; justify-content: center; padding: clamp(20px, calc( 55 / var(--inner) * 100vw ), 55px) 20px; position: absolute; bottom: 0; left: 0; width: 100%; height: 100%; color: #fff;letter-spacing: -0.6px;}
.performance-overlay .title {font-size: clamp(18px, calc( 30 / var(--inner) * 100vw ), 30px); font-weight: bold; line-height: 1.2; margin: 0; white-space: nowrap;text-align: center;}
.performance-overlay .titbx {display: flex;flex-direction: column;}
.performance-overlay .sub {padding-top:clamp(12px, calc( 23 / var(--inner) * 100vw ), 23px); font-size: clamp(16px, calc( 23 / var(--inner) * 100vw ), 23px);max-height: 0;opacity: 0;overflow: hidden;transition: opacity 0.4s ease, max-height 0.4s ease, padding 0.4s ease;padding-top: 0;}
.performance-overlay .arrow {display: flex;align-items: center;justify-content: center; width: clamp(40px, calc( 70 / var(--inner) * 100vw ), 70px); height: clamp(40px, calc( 70 / var(--inner) * 100vw ), 70px);background: rgba(255, 255, 255, 0.30); border-radius: 50%;font-weight: 400; display: none;}
.performance-overlay .arrow svg {width: clamp(16px, calc( 40 / var(--inner) * 100vw ), 40px); height: clamp(16px, calc( 40 / var(--inner) * 100vw ), 40px);}
.performance-item.active .performance-overlay {justify-content: space-between;padding: clamp(20px, calc( 55 / var(--inner) * 100vw ), 55px) clamp(20px, calc( 55 / var(--inner) * 100vw ), 55px);}
.performance-item.active .performance-overlay .sub {opacity: 1;max-height: 100px;padding-top: clamp(12px, calc( 25 / var(--inner) * 100vw ), 25px);}
.performance-item.active .performance-overlay .arrow {display: flex;} 
.performance-item.active .performance-image img {transform: scale(1.05);}
.performance-item.active .performance-overlay {background: transparent;}
.performance-item.active .performance-overlay .title {font-size: clamp(22px, calc( 40 / var(--inner) * 100vw ), 40px);text-align: left;}

.sec2 { background: url(../images/main/sec2-bg.jpg) no-repeat 50% 50% /cover;}
.sec2 .videobx {position:relative; padding-bottom:56.25%; overflow:hidden; border-radius: 24px;}
.sec2 .videobx video ,
.sec2 .videobx iframe {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%;object-fit : cover;}

.sec3 {padding: clamp(50px, calc( 100 / var(--inner) * 100vw ), 100px) 0; position: relative;}
.commflxWrap + .commflxWrap {padding-top: clamp(50px, calc( 160 / var(--inner) * 100vw ), 160px);}
.commflxWrap {display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, calc( 250 / var(--inner) * 100vw ), 250px); align-items: center;}
.commflxWrap .textbx {display: flex; flex-direction: column;justify-content: center; text-align: left;}
.commflxWrap .video {position:relative; aspect-ratio: 560 / 350; overflow:hidden; border-radius: 20px; max-width: 560px; width: 100%;}
.commflxWrap .video video ,
.commflxWrap .video iframe {width:100%; height:100%; object-fit:cover;}
.commflxWrap .section-tit {font-size: clamp(20px, calc( 38 / var(--inner) * 100vw ), 38px);}
.commflxWrap .desc {padding-top: clamp(20px, calc( 35 / var(--inner) * 100vw ), 35px); font-size: clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); line-height: 1.5; color: var(--color-body);}
.commflxWrap .desc2 {display: flex; align-items: center;  padding-top: clamp(15px, calc( 25 / var(--inner) * 100vw ), 25px); flex-wrap: wrap;}
.commflxWrap .desc2 .icn {display: flex; align-items: center;}
.commflxWrap .desc2 .txt {padding: 0 13px; font-size: clamp(13px, calc( 15 / var(--inner) * 100vw ), 15px); position: relative; color: #A7A7A7;}
.commflxWrap .desc2 .txt:not(:last-child)::after {position: absolute; content: '|'; right: 0;  top: 50%; transform: translateY(-50%); color: #ddd;}
.commflxWrap .morebx {padding-top: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px);}
.moving { left: 50%;   margin-top: -100px;  transform: translateX(-50%); position: absolute;  width: 2px; height: 100%;}
.moving__bg { position: relative;  width: 2px;  height: 1360px;  max-height: 100%; background: linear-gradient(#aaa 20%, #aaa 40%, #aaa 80%, #aaa 100%);   background-size: 100% 2px;  overflow: hidden;}
.moving__line { position: absolute;   bottom: 0; width: 100%; height: 200px;  background: linear-gradient(to bottom, transparent 0%, var(--color-primary) 100%, transparent 0%); animation: moveDown 4s linear infinite;}
.moving__bg:before { top: 0; background: linear-gradient(to bottom, rgba(255, 255, 255, 0.8), #aaa, transparent);}
.moving__bg:after {  bottom: 0;  background: linear-gradient(to top, rgba(255, 255, 255, 0.8), #aaa, transparent);}
.moving__bg:before ,
.moving__bg:after { content: "";  display: block;  position: absolute; left: 0; width: 100%; height: 300px;}
@keyframes moveDown {
    0% {
        top: -100px;
    }
    100% {
        top: 1340px;
    }
}

/* 버튼공통 */
.btn-more {display: inline-flex;align-items: center;justify-content: center; gap: 10px; padding:0 clamp(10px, calc( 30 / var(--inner) * 100vw ), 30px); height:clamp(40px, calc( 52 / var(--inner) * 100vw ), 52px); border-radius: 30px; border: 1px solid var(--color-primary); color: var(--color-primary); font-size: clamp(14px, calc( 18 / var(--inner) * 100vw ), 18px); font-weight: 600; transition: all 0.3s;}
.btn-more:hover {background: var(--color-primary); color: #fff;}
.btn-more:hover path {stroke: #fff;}

/* 제품,뉴스 레이아웃 공통 */
.commwidposition {display: flex; flex-wrap: wrap; position:relative; left:calc(50% - 700px);}
.commwidposition .commtabwrap {flex: 1 0 clamp(250px, calc( 400 / var(--inner) * 100vw ), 400px); max-width: clamp(250px, calc( 400 / var(--inner) * 100vw ), 400px);}
.commwidposition .slideWrap {flex: 1 0 auto; width: 1%;}
.commwidposition .slideWrap .slick-list {width: 100% !important;}
.commwidposition .slideWrap .slick-track {margin-left: 0 !important;}

.tab-slidebx .tab {position: relative;}
.tab-slidebx .tab ul {max-width: clamp(200px, calc( 290 / var(--inner) * 100vw ), 290px);width: 100%;}
.tab-slidebx .tab ul li a {display:inline-flex; align-items:center; padding: 5px clamp(20px, calc( 30 / var(--inner) * 100vw ), 30px); width: 100%; height:clamp(45px, calc( 75 / var(--inner) * 100vw ), 75px);  font-size: clamp(16px, calc( 24 / var(--inner) * 100vw ), 24px); font-weight: 600; letter-spacing: -0.5px;color: #848484;border-radius: 10px;}
.tab-slidebx .tab ul li a .dot {position: relative;}
.tab-slidebx .tab ul li.active a {background:#F6F6F6;}
.tab-slidebx .tab ul li.active .dot:after {position: absolute;content: ''; right: -12px; top: -2px; width:clamp(4px, calc( 6 / var(--inner) * 100vw ), 6px); height: clamp(4px, calc( 6 / var(--inner) * 100vw ), 6px); border-radius: 50%; background: var(--color-primary);}


.sec4 .sec-titbox {margin-bottom: clamp(30px, calc( 150 / var(--inner) * 100vw ), 150px);}
.tab-sliderprd .tab-nav {position: absolute; left: clamp(10px, calc( 30 / var(--inner) * 100vw ), 30px); border: 0;background: transparent;width: clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px); height: clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px);}
.tab-sliderprd .tab-nav svg {width: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); height: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); color: #B3B3B3;}
.tab-sliderprd .tab-prev {top: -50px;}
.tab-sliderprd .tab-next {bottom: -50px;}
.slidecont {position:relative; text-align:center;}
.slidecont .items {display:flex; margin:0 -15px;}
.slidecont .item {padding:0 15px;}
.slidecont .ginner {display:block;padding: clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px) clamp(15px, calc( 20 / var(--inner) * 100vw ), 20px); position: relative; background: #F5F5F5;border-radius: 24px; text-align: center;}
.slidecont .ginner:after {content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:0px solid var(--color-primary); border-radius: 24px;}
.slidecont .ginner .imgbx {width: clamp(150px, calc( 214 / var(--inner) * 100vw ), 214px); margin: 0 auto;}
.slidecont .ginner .image {aspect-ratio: 1 / 1;border-radius: 50%;background: #fff;}
.slidecont .ginner .image img {width:100%; height:100%; object-fit:cover;}
.slidecont .ginner .title {margin-bottom: clamp(12px, calc( 20 / var(--inner) * 100vw ), 20px); font-size:clamp(16px, calc( 28 / var(--inner) * 100vw ), 28px); font-weight:700; display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp:1;}
.slidecont .ginner .morebx {padding-top: clamp(20px, calc( 50 / var(--inner) * 100vw ), 50px);}
.slidecont .ginner:hover {background: #DCEDFD;}
.slidecont .ginner:hover:after {border-width: 2px;}
.slidecont .ginner:hover .morebx .btn-more {background: var(--color-primary); color: #fff;}
.introfilebx {display: flex; flex-wrap: wrap;  border-radius:24px;overflow: hidden;}
.introfilebx .filebx {flex: 1 0 50%; max-width: 50%; padding:clamp(30px, calc( 65 / var(--inner) * 100vw ), 65px) 20px; text-align: center;}
.introfilebx .filebx .title {font-size:clamp(22px, calc( 40 / var(--inner) * 100vw ), 40px); font-weight: bold; line-height: 1.25;}
.introfilebx .filebx .desc {padding-top: clamp(12px, calc( 20 / var(--inner) * 100vw ), 20px); font-size:clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); font-weight: 500; line-height: 1.5; color: var(--color-body);}
.introfilebx .filebx .morebx {padding-top: clamp(25px, calc( 54 / var(--inner) * 100vw ), 54px);}
.introfilebx .filebx:nth-child(1) {background: #F5F5F5;}
.introfilebx .filebx:nth-child(2) {background: #E9E9E9;}

.sec5 {background: url(../images/main/sec5-bg.jpg) no-repeat center bottom /cover; height: clamp(400px, calc( 700 / var(--inner) * 100vw ), 700px);}
.sec5 .textbx {color: #fff;}
.sec5 .textbx .title {font-size:clamp(20px, calc( 38 / var(--inner) * 100vw ), 38px); font-weight: bold;}
.sec5 .textbx .dec {padding-top: clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); font-size: clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); line-height: 1.5;}

.sec6 .sec-titbox {margin-bottom:clamp(30px, calc( 130 / var(--inner) * 100vw ), 130px);}
.galleryitem {position:relative;}
.galleryitem .inner {display: block; padding:clamp(25px, calc( 50 / var(--inner) * 100vw ), 50px) clamp(18px, calc( 50 / var(--inner) * 100vw ), 50px); background: #F5F5F5; border-radius: 24px;}
.galleryitem .title {font-size:clamp(18px, calc( 24 / var(--inner) * 100vw ), 24px); font-weight:600; min-height: clamp(55px, calc( 70 / var(--inner) * 100vw ), 70px); line-height: 1.41; display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp:2;}
.galleryitem .text {margin-top:clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px); color: var(--color-body); font-size: clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); min-height: clamp(70px, calc( 85 / var(--inner) * 100vw ), 85px); line-height: 1.4;display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp:3;}
.galleryitem .morebx {padding-top: 25px;}
.controlpaging {display:flex; align-items:center; padding-top:clamp(25px, calc( 50 / var(--inner) * 100vw ), 50px); max-width: 1000px;width: 100%;}
.controlpaging .swiper-pagination {position:initial; height:clamp(3px, calc( 7 / var(--inner) * 100vw ), 7px); border-radius:3px;background: #EBEBEB ;}
.controlpaging .swiper-pagination-progressbar-fill {background:#B8B8B8; border-radius:3px;}


/* slide btn 공통 */
.btn-arrow {margin-top:0; top:40%; width:clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px); height:clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px); border-radius:50%;  border:1px solid #ddd; transition: all 0.3s;}
.btn-arrow::after {display: none;}
.btncontrol {display:flex; align-items:center; padding-right:clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px);}
.btncontrol .btn-arrow {margin-right:clamp(10px, calc( 16 / var(--inner) * 100vw ), 16px); position:initial;}
.btncontrol .btn-arrow:last-child {margin-right:0;}
.btn-arrow svg {color: #ddd; width:clamp(20px, calc( 28 / var(--inner) * 100vw ), 28px);}
.btn-arrow:hover {background:var(--color-primary); border-color:var(--color-primary);}
.btn-arrow:hover svg {color: #fff;}


/* sub page */
.contain { max-width:1460px; margin:0 auto; padding-left:var(--container-space); padding-right:var(--container-space); width:100%;} 
#contArea { max-width:1460px; padding-left:var(--container-space); padding-right:var(--container-space); margin:0 auto;} 
#sub .contain {max-width:1460px; }
#contArea.wide { max-width:100% !important; padding-left:0 !important; padding-right:0 !important;} 
.sub-title {margin-bottom:clamp(25px, calc( 40 / var(--inner) * 100vw ), 40px);}
.sub-title .maintit { font-size:clamp(24px, calc( 42 / var(--inner) * 100vw ), 42px); line-height:1.14; } 
.subttflx {display: flex;align-items: center; margin: 0 -20px;}
.subttflx .txt {padding: 0 20px; position: relative; font-size: clamp(24px, calc( 42 / var(--inner) * 100vw ), 42px); color: var(--color-body); line-height: 1.14;}
.subttflx .txt:not(:last-child):after {position: absolute; content: ''; right: 0 ; top: 50%; transform: translateY(-50%); width: 1px; height:clamp(15px, calc( 32 / var(--inner) * 100vw ), 32px); background: #A2A2A2;} 

.sub-box { display:flex; align-items:center; justify-content:center; width:300px; height:300px; border-radius:var(--border-radius-30); background-color:var(--color-warning); font-size:var(--font-size-20); color:var(--color-white); text-align:center; } 

.real-cont {padding:40px  0 clamp(60px, calc( 150 / var(--inner) * 100vw ), 150px);} 

.sub-visual { position:relative; height:500px; z-index:10; overflow:hidden; } 
.sub-visual .background {position:absolute;top:0;left:0;width:100%; height:100%;background-position:50% 50%;background-repeat:no-repeat;background-size:cover;transform:scale(1.09); -ms-transform:scale(1.09); /* IE 9 */
 -moz-transform:scale(1.09); /* Firefox */
 -webkit-transform:scale(1.09); /* Safari and Chrome */
 -o-transform:scale(1.09); /* Opera */
transition: all 2s ease-out 0s;transition-delay: 0.1s;z-index:0; } 
.sub-visual.load .background {transform:scale(1); -ms-transform:scale(1); /* IE 9 */
 -moz-transform:scale(1); /* Firefox */
 -webkit-transform:scale(1); /* Safari and Chrome */
 -o-transform:scale(1); /* Opera */}
.sub-visual .tt-wrap {padding-right:var(--container-space); padding-left:var(--container-space); max-width:1260px; width: 100%; position: absolute; left: 50%; top: 55%; transform: translate(-50%,-50%); z-index: 1; color: #fff; text-align: center; } 
.sub-visual .tt-wrap .tit {font-size: clamp(26px, calc( 60 / var(--inner) * 100vw ), 60px); line-height: 1.2em; font-weight: 600; }
.sub-visual .tt-wrap .eng {display: block; padding-top: clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px); font-size:clamp(16px, calc( 24 / var(--inner) * 100vw ), 24px); font-weight: 400;}

.lnb-wrap {padding-bottom: clamp(40px, calc( 95 / var(--inner) * 100vw ), 95px);}
/* .lnb .swiper {padding-bottom: 35px;} */
.lnb ul {display:flex;  margin:0 auto; max-width:1400px; width:100%;}
.lnb ul li {width:auto; text-align:center;}
.lnb ul li:not(:last-child) {padding-right:clamp(5px, calc( 12 / var(--inner) * 100vw ), 12px);} 
.lnb ul li.active a {color:#fff;background:var(--color-primary);border-color: var(--color-primary);}
.lnb ul li a {display:inline-flex; align-items:center; justify-content:center; padding:0 15px; position: relative; min-width: clamp(170px, calc( 270 / var(--inner) * 100vw ), 270px); height:var(--nav-height); line-height:1.2em; font-size:clamp(14px, calc( 18 / var(--inner) * 100vw ), 18px); color:#666; border: 1px solid #ddd; border-radius: 8px;}
.lnb ul li a .eng {display: none;}
.lnb ul li a .kor {display: inline;}
.lnb ul li a:hover .eng {display: inline;}
.lnb ul li a:hover .kor {display: none;}

.lnb2 ul {display:flex;  margin:0 auto; max-width:1400px; width:100%;}
.lnb2 ul li {width:auto; text-align:center;}
.lnb2 ul li:not(:last-child) {padding-right:clamp(5px, calc( 12 / var(--inner) * 100vw ), 12px);} 
.lnb2 ul li.active a {color:#fff;background:var(--color-primary);border-color: var(--color-primary);}
.lnb2 ul li a {display:inline-flex; align-items:center; justify-content:center; padding:0 20px; min-width: clamp(120px, calc( 210 / var(--inner) * 100vw ), 210px); height:var(--nav-height); line-height:1.2em; font-size:clamp(14 px, calc( 18 / var(--inner) * 100vw ), 18px); color:#666; border: 1px solid #ddd; border-radius: 8px;}

.path-wrap {padding-bottom: clamp(30px, calc( 75 / var(--inner) * 100vw ), 75px);}
.path-wrap .wrap {margin-right: -16px;}
.path-wrap .inner {display:flex;align-items: center; } 
.path-wrap .home {display:flex; align-items:center; padding-right:12px; color: #a8a8a8;}
.path-wrap .home a { background:url("../images/common/home.png") no-repeat center center /contain; text-indent: -999em; width: clamp(14px, calc( 16 / var(--inner) * 100vw ), 16px); height: clamp(14px, calc( 16 / var(--inner) * 100vw ), 16px);}
.path-wrap .part {display:flex; align-items:center; padding:0 16px; cursor:default; position: relative; font-size:clamp(13px, calc( 15 / var(--inner) * 100vw ), 15px); line-height: 1; color: #787878; letter-spacing: -0.5px;}
.path-wrap .part:last-child {color: var(--color-body);}
.path-wrap .part:after {position: absolute; content: ''; left: -2px; top: 50%; transform: translateY(-50%); width:7px; height: 12px; background:url(../images/common/path-arrow.png) no-repeat  50% 50% / contain;}

/* footer */
#footer {padding:clamp(50px, calc( 100 / var(--inner) * 100vw ), 100px) 0; position: relative; background-color:#F5F5F5;} 
 
#footer .contain {max-width:1480px !important;  letter-spacing: -0.5px;}
#footer .flxWrap {flex-wrap: nowrap; justify-content: center; margin: 0 -100px; font-size:clamp(13px, calc( 16 / var(--inner) * 100vw ), 16px);}
#footer .flx {flex: 0 1 auto; position: relative; padding: 0 100px;}
#footer .flx:not(:last-child):after {position: absolute; content: ''; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height:clamp(110px, calc( 220 / var(--inner) * 100vw ), 220px); background: #BFBFBF ;}
#footer .foot-links {white-space: nowrap;}
#footer .foot-links .txt {display: block; font-size:clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); font-weight: 600;} 
#footer .foot-links .num {font-size:clamp(18px, calc( 28 / var(--inner) * 100vw ), 28px); font-weight: 600;}
#footer .daylist {padding-top: 10px;}
#footer .dayitem + .dayitem {margin-top:8px;}
#footer .dayitem {display: flex; align-items: center; color: var(--color-body);}
#footer .dayitem .name { position: relative; margin-right: 10px; padding-right: 10px; font-weight: 600; color: #242424;}
#footer .dayitem .name:after {position: absolute; content: ''; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 10px; background: #BFBFBF; }
#footer .f-menu  {padding-top: clamp(12px, calc( 18 / var(--inner) * 100vw ), 18px);}
#footer .f-menu li:not(:first-child) {margin-top:7px;}
#footer .f-menu li a {display:inline-block; padding-left:clamp(18px, calc( 24 / var(--inner) * 100vw ), 24px);  font-weight:600; font-size:16px; background:url(../images/common/f-icn.png) no-repeat left center; background-size:clamp(12px, calc( 16 / var(--inner) * 100vw ), 16px) auto;}


#footer .foot-addr {color: var(--color-body); letter-spacing:0; } 
#footer address + address {margin-top: clamp(15px, calc( 22 / var(--inner) * 100vw ), 22px);}
#footer address { font-style:normal; display:block; width: max-content;} 
#footer address .inflx {display: flex;}
#footer .address-txt {display:flex; line-height: 1.714em; } 
#footer .address-txt .tt {margin-right:9px; color: #242424; font-weight: 600;}
#footer .address-txt .dec {margin-right:5px; }
#footer .address-txt.wid-50 {display: inline-flex; margin: -9px;}
#footer .address-txt .inflx {padding: 9px; position: relative;}
#footer .address-txt .inflx:not(:last-child):after {position: absolute; content: ''; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 10px; background: #BFBFBF;}
#footer .foot-logo {padding-top: clamp(15px, calc( 20 / var(--inner) * 100vw ), 20px);}
#footer .foot-logo img {width:clamp(150px, calc( 259 / var(--inner) * 100vw ), 259px);  } 

#footer .copy {font-size:14px; color:#666666; line-height: 1.714em;} 

.btn-top {display:flex; flex-direction:column; justify-content:center; align-items:center; position: absolute; right:clamp(16px, calc( 120 / var(--inner) * 100vw ), 120px); top: -70px;width:clamp(35px, calc( 70 / var(--inner) * 100vw ), 70px); height:clamp(35px, calc( 70 / var(--inner) * 100vw ), 70px); background:var(--color-primary);}
.btn-top img {width: clamp(18px, calc( 30 / var(--inner) * 100vw ), 30px);}

/* all menu */
html.menu-all-opened {overflow:hidden;}
html.menu-all-opened .all-navigation {-ms-transform:translateX(0); transform:translateX(0); }
html.menu-all-opened .all-navigation .only-all-menu {display:block;}
html.menu-all-opened .mobile-overlay {display:block;}

.btn-all-menu {position:relative; top:0; right:0; width:24px; height:15px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out; } 
.btn-all-menu span{ position:absolute; right:0; top:0; height:2px; width:24px; background:#fff; } 
.btn-all-menu span:before,
.btn-all-menu span:after { content:" "; position:absolute; right:0; height:2px; background:#fff; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s; } 
.btn-all-menu span:before {top:7.5px; width:24px; transition-property:top, transform; } 
.btn-all-menu span:after { bottom:-15px; width:24px; transition-property:bottom, transform; } 

.all-navigation {position:fixed; top:0; right:0; padding:20px 0; width:100%; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202; } 
.all-navigation .contain {padding-top:200px; max-width:1460px !important;}
.all-navigation .home {display:none;}
.all-navigation .sitelogo {display:block; margin-bottom:20px; padding-left:15px; } 
.all-navigation .sitelogo img { height:23px; } 
.all-navigation .all-nav-menu>ul>li {display:flex; align-items:center; padding:50px 0; border-bottom:1px solid #dfdfdf; } 
.all-navigation .all-nav-menu>ul>li>a {flex:1 0 410px; max-width:410px; position:relative; font-size:36px; font-weight:bold; line-height:1.3em; color:#2c2c2c;}
.all-navigation .all-nav-menu>ul>li>a:hover {color:var(--color-primary);}
.all-navigation .all-nav-menu .submenu {flex:1; display:block;} 
.all-navigation .all-nav-menu .submenu>ul {display:flex;}
.all-navigation .all-nav-menu .submenu>ul>li {flex:1 0 25%; max-width:25%; padding-right:15px;}
.all-navigation .all-nav-menu .submenu>ul:after { content:""; display:block; clear:both; } 
.all-navigation .all-nav-menu .submenu>ul>li>a {display:block; position:relative; color:#898989; font-size:18px; font-weight:500; line-height:1.3em; } 
.all-navigation .all-nav-menu .submenu>ul>li>a:hover {color:var(--color-secondary); text-decoration: underline;}
.all-navigation .close { position:absolute; top:20px; right:100px; width:24px; height:24px; text-indent:-9999em; overflow:hidden; } 
.all-navigation .close:before,
.all-navigation .close:after { content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#2c2c2c; } 
.all-navigation .close:before { transform:rotate(45deg); } 
.all-navigation .close:after { transform:rotate(-45deg); } 


/* for mobile */
.only-mobile { display:none; } 
.btn-m-menu {display: none; position:relative; top:0; right:0; width:20px; height:16px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out; } 
.btn-m-menu span { position:absolute; right:0; top:0; height:2px; width:20px; background:#fff; } 
.btn-m-menu span:before,
.btn-m-menu span:after { content:" "; position:absolute; right:0; height:2px; background:#fff; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s; } 
.btn-m-menu span:before {top:8px; width:20px; transition-property:top, transform; } 
.btn-m-menu span:after { bottom:-16px; width:20px; transition-property:bottom, transform; } 
.mobile-navigation { position:fixed; top:0; right:0; padding:20px 0; width:400px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202; } 
.mobile-navigation .home {margin-left:15px; width:120px;}
.mobile-navigation .sitelogo {display:block; margin-bottom:20px; padding-left:15px; } 
.mobile-navigation .sitelogo img { height:23px; } 
.mobile-navigation .nav-menu>ul {margin-top:20px;}
.mobile-navigation .nav-menu>ul>li { border-bottom:1px solid #dfdfdf; } 
.mobile-navigation .nav-menu>ul>li>a { position:relative; padding:12px 15px; display:block; color:#454545; font-size:18px; font-weight:500; line-height:1.3em; } 
.mobile-navigation .nav-menu>ul>li a:after { content:""; position:absolute; top:50%; right:15px; transform:translateY(-75%) rotate(45deg); width:10px; height:10px; border-right:2px solid #2c2c2c; border-bottom:2px solid #2c2c2c; } 
.mobile-navigation .nav-menu>ul>li.active>a { color:#305e92 } 
.mobile-navigation .nav-menu>ul>li.active>a:after { transform:translateY(-35%) rotate(-135deg); border-color:#305e92; } 
.mobile-navigation .nav-menu .submenu { display:none; margin:-1px 0 0 0; padding:0 15px 15px; } 
.mobile-navigation .nav-menu .submenu>ul:after { content:""; display:block; clear:both; } 
.mobile-navigation .nav-menu .submenu>ul>li>a { display:block; position:relative; padding:5px 15px; color:#454545; font-size:16px; font-weight:400; line-height:1.3em; } 
.mobile-navigation .nav-menu .submenu>ul>li>a:after { display:block; content:""; position:absolute; top:14px; left:5px; width:4px; height:4px; background:#dfdfdf; border-radius:50%; transition:.3s ease-in-out; } 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover { color:#305e92 } 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after { background:#305e92 } 
.mobile-navigation .close { position:absolute; top:20px; right:15px; width:24px; height:24px; text-indent:-9999em; overflow:hidden; } 
.mobile-navigation .close:before,
.mobile-navigation .close:after { content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#2c2c2c; } 
.mobile-navigation .close:before { transform:rotate(45deg); } 
.mobile-navigation .close:after { transform:rotate(-45deg); } 

.mobile-overlay { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:201; } 

html.menu-opened { overflow:hidden; } 
html.menu-opened .mobile-navigation { -ms-transform:translateX(0); transform:translateX(0); } 
html.menu-opened .mobile-overlay { display:block; } 