@charset "utf-8";
/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

.only-desktop {display:block;}
.only-tablet {display:none;}
.only-mobile {display:none;}
.only-desktop-tablet {display:block;}

#wrapper {position:relative; padding-top:var(--size100-60);}

#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}

.contain {position:relative; width:100%; max-width:1260px; padding-left:30px;padding-right:30px; margin:0 auto;}
.contain:after {content:" "; display:block; clear:both;}

/* header */
#header  {position:fixed; z-index:90; left:0; top:0; width:100%; transition:0.2s all ease; background:#fff;}
#header .contain {position:relative; max-width:1680px; padding-left:30px; padding-right:30px;}
#sub #header {border-bottom:1px solid #ddd;}
.sitelogo {position:absolute; left:30px; top:50%; margin-top:-13px; z-index:10;}
.sitelogo a {display:block;}

#gnb > ul {position:relative; display:flex; justify-content:flex-end;}
#gnb > ul > li {position:relative; text-align:center;}
#gnb > ul > li > a {position:relative; display:flex;  padding:0 var(--size45-20); font-size:var(--font20-16); font-weight:600; height:var(--size100-60); line-height:1.4em; letter-spacing:0; color:#242424; position:relative; align-items: center; justify-content: center;}
#gnb > ul > li > a:before {content:''; position:absolute; width:14px; height:10px; background:url('/images/common/header-icon.png') no-repeat 50% 50%/contain; left:50%; top:17px; margin-left:-7px; opacity:0; transform:translateY(10px); transition:0.2s all ease;}
#gnb > ul > li.active > a:before {opacity:1; transform:translateY(0);}

#gnb .submenu {position:absolute; display:none; left:50%; padding:0 10px; transform:translateX(-50%); top:var(--size100-60); text-align:center; z-index:21;}
#gnb .submenu > ul {position:relative; padding:25px 0; background:#991a26; min-width:190px;}
#gnb .submenu > ul > li {padding:5px 0; line-height:1.2em; transition:0.2s all ease;}
#gnb .submenu > ul > li > a {position:relative; font-size:var(--font18-14); font-weight:400; letter-spacing:-0.03em; color:#fff; line-height:1em; transition:0.2s all ease;}
#gnb .submenu > ul > li a:hover {text-decoration:underline;} 
#gnb .submenu > ul ul {margin-top:10px;}
#gnb .submenu > ul ul li {margin-bottom:5px;}
#gnb .submenu > ul ul li a {font-size:14px; color:#fff;}
#gnb .submenu > ul ul li:last-child {margin-bottom:0;}

.header-fixed #header {border-bottom:1px solid #ddd;}

/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; margin-top:-12px; right:30px; width:28px; height:26px; text-align:center; text-indent:-9999em; z-index:92; transition: all 0.5s ease-in-out;}
.btn-m-menu span {position:absolute; right:0; top:12px; height:2px; width:19px;background:var(--c-main);}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; right:0; width:28px; height:2px; background:#242424; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s;}
.btn-m-menu span:before {top:-12px; transition-property:top, transform;}
.btn-m-menu span:after {bottom:-12px; transition-property:bottom, transform;}

.mobile-navigation {position:fixed; top:0; right:0; padding:20px 0; width:300px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#ffffff; z-index:101;}
.mobile-navigation .home {padding-bottom:20px; padding-left:15px;}
.mobile-navigation .home img {height:34px; width:auto;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #ddd;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:14px 15px; display:block; color:#242424; font-size:1.3em; font-weight:500; line-height:1.3em;}
.mobile-navigation .nav-menu>ul>li.active>a {color:var(--c-2) ;}
.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:after{transform: translateY(-35%) rotate(-135deg); border-color: var(--c-2) ;}
.mobile-navigation .nav-menu .submenu {display:none; position:static; transform: translateX(0); margin:-1px 0 0 0; width:100%;  padding:10px 0;background:var(--c-2) ; padding-bottom:10px;}
.mobile-navigation .nav-menu .submenu>ul {display:block; width:100%;}
.mobile-navigation .nav-menu .submenu>ul>li {text-align:left; padding:0;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; position:relative; padding:5px 0 5px 25px; color:var(--c-main); font-size:16px; font-weight:400; line-height:1.3em;}
.mobile-navigation .nav-menu .submenu>ul>li>a:after {content:"";position:absolute; top:14px; left:15px; width:4px; height:4px; border-radius:100%; background:var(--c-main); transition:.2s ease-in-out;}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover {color:var(--c-main)}
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after {background:var(--c-main)}
.mobile-navigation .close {position:absolute; top:20px; right:18px; 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:#242424;}
.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:.76; z-index:98;} 

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}

/* main */ 
.main-visual {margin-bottom:var(--size100-50); position:relative; width:100%; overflow:hidden;}
.main-visual .item {height:calc(100vh - var(--size100-60));}
.main-visual .cnt {position:absolute; width:100%; max-width:1460px; left:50%; top:50%; transform:translate(-50%,-50%); padding:0 var(--size30-15); z-index:1;}
.main-visual .cnt .txt-box {width:100%; max-width:790px; margin-left:auto;}
.main-visual .cnt .red-box {margin-bottom:var(--size30-15); padding:var(--size50-20) var(--size60-20); background:#a02e37;  opacity:0; transform:translateY(50px);}
.main-visual .cnt .red-box .tit {font-size:var(--font43-20); font-weight:600; line-height:1.2em; letter-spacing:-0.025em; color:#fff;}
.main-visual .cnt .tit strong {display:block; margin-bottom:0.4em; font-weight:900; font-size:1.12em;}
.main-visual .cnt .txt {margin-bottom:0.82em; padding-left:var(--size60-20); font-size:var(--font22-14); font-weight:500; line-height:1.5em; letter-spacing:-0.03em; color:#454545; opacity:0; transform:translateY(50px);}

.main-visual .cnt .inner .tit {font-size:var(--font80-30); font-weight:800; line-height:1.06em; letter-spacing:-0.025em; color:#fff; opacity:0; transform:translateY(50px);}
.main-visual .cnt .inner .more {margin-top:var(--size60-20); opacity:0; transform:translateY(50px);}
.main-visual .cnt .inner .more a {position:relative; display:inline-block; padding:1em 3.69em 1em 1.88em; font-weight:400; line-height:1; letter-spacing:-0.02em; color:#fff; border:1px solid #fff; border-radius:100vh;}
.main-visual .cnt .inner .more a:before {content:''; position:absolute; width:8px; height:13px; right:1.88em; top:50%; margin-top:-6.5px; background:url('/images/main/icon-more-w.png') no-repeat 50% 50%/contain;}
.main-visual .cnt .inner .more a:hover {border-color:#991a26; background:#991a26;}
.main-visual .cnt .inner .more a:hover:before {animation:move-arw 2s infinite linear; }


.main-visual .slick-arrow {position:absolute; top:50%; z-index:1; display:block; width:31px; height:60px; margin-top:-30px; border:0; text-indent:-999em; overflow:hidden; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; transition:0.2s all ease;}
.main-visual .slick-prev {background-image:url('../images/main/sld-prev.png'); left:var(--size100-15);}
.main-visual .slick-next {background-image:url('../images/main/sld-next.png'); right:var(--size100-15);}

.main-visual .slick-dots {position:absolute; left:50%; bottom:var(--size60-20); display:flex; transform:translateX(-50%); z-index:1;}
.main-visual .slick-dots li {position:relative; padding:0 10px;}
.main-visual .slick-dots li button {display:block; width:13px; height:13px; border-radius:100%; background:#fff; border:0; opacity:0.6; text-indent:-999em; overflow:hidden; border-radius:100%;}
.main-visual .slick-dots li.slick-active:before {content:''; position:absolute; width:30px; height:30px; left:1px; top:-9px; border:1px solid #fff; opacity:0.6; border-radius:100%;}
.main-visual .slick-dots li.slick-active button {opacity:1;}

.main-visual .slick-active .red-box {transform:translateY(0); opacity:1; transition:1s all 0.5s ease;}
.main-visual .slick-active .txt {transform:translateY(0); opacity:1; transition:1s all 0.7s ease;}
.main-visual .slick-active .inner .tit {transform:translateY(0); opacity:1; transition:1s all 0.5s ease;}
.main-visual .slick-active .inner .more {transform:translateY(0); opacity:1; transition:1s all 0.7s ease;}

.main-visual .mv {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 */ z-index:0;}
.main-visual .slick-active .mv {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 */ transition: all 3s ease-out 0s; transition-delay: 0.1s;}

.main-sec .contain {max-width:1460px;}
.main-tit {margin-bottom:0.95em; font-size:var(--font44-24); font-weight:700; line-height:1.2; letter-spacing:-0.02em; color:#242424;}

.main-app {padding-bottom:var(--size110-50);}
.main-app .bg {position:relative; padding-bottom:35.71%; overflow:hidden;}
.main-app .bg img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.main-app .bg a {display:flex; flex-direction:column; justify-content:center; align-items:center; position:absolute; left:0; top:0; width:100%; height:100%;}
.main-app .bg .in {position:relative;}
.main-app .bg .in .tit {padding:0.31em 0.56em; background:rgba(153,26,38,0.9); font-size:var(--font64-20); font-weight:600; line-height:1; letter-spacing:-0.035em; color:#fff; transition:0.2s all ease;}
.main-app .bg .in .more {position:absolute; bottom:0; left:50%; margin-left:-20px; opacity:0; width:40px; height:40px; background:#fff url('/images/main/icon-arw.png') no-repeat 50% 50%; border-radius:100%; text-indent:-999em; overflow:hidden; transition:0.2s all ease;}

.main-app .bg a:hover .tit {margin-bottom:var(--size70-50);}
.main-app .bg a:hover .more {opacity:1;}
.main-app .bg a:hover .in:hover .more {background-color:#991a26; background-image:url('/images/main/icon-arw-w.png');}

.main-business {margin-bottom:var(--size100-50);}
.main-business .wrap {display:flex; align-items:center; height:var(--size500-150);}
.main-business .left {position:relative; display:flex; align-items:center; justify-content:flex-end; width:32%; height:100%; background:#991a26; color:#fff; padding-left:var(--size30-15);}
.main-business .left:before {content:''; position:absolute; z-index:1; top:50%; margin-top:calc(0px - var(--size25-10)/2); right:calc(1px - var(--size30-15)); border-left:var(--size30-15) solid #991a26; border-top:var(--size25-10) solid transparent; border-bottom:var(--size25-10) solid transparent;}
.main-business .left .in {width:100%; max-width:480px;}
.main-business .left .tit {margin-bottom:var(--size15-10); font-size:var(--font62-22); font-weight:700; line-height:1.2; letter-spacing:-0.02em; color:#fff;}
.main-business .left a {font-size:var(--font28-18); font-weight:600; line-height:1.7; letter-spacing:0; color:#fff; text-decoration:underline; text-underline-offset:5px;}

.main-business .right {flex:1 1 auto; min-width:0; width:1%; height:100%;}
.main-business .right .img {position:relative; height:100%; width:100%; overflow:hidden;}
.main-business .right .img img {position:absolute; top:50%; left:0; transition:.4s ease-in-out; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}


.main-network {padding:var(--size100-50) 0; background:#f8f8f8;}
.main-network .wrap {display:flex; align-items:center;}
.main-network .left {flex:1 1 auto; min-width:0; width:1%; padding-right:var(--size90-10);}
.main-network .main-tit {margin-bottom:1.25em;}
.main-network .txt {margin-bottom:0.5em; font-size:var(--font20-14); font-weight:400; line-height:1.5; letter-spacing:-0.02em; color:#454545;}
.main-network .txt:last-child {margin-bottom:0;}
.main-network .more {margin-top:var(--size60-20); text-align:center;}
.main-network .more a {position:relative; display:inline-block; padding:1em 3.69em 1em 1.88em; font-weight:400; line-height:1; letter-spacing:-0.02em; color:#454545; border:1px solid #ddd; border-radius:100vh;}
.main-network .more a:before {content:''; position:absolute; width:8px; height:13px; right:1.88em; top:50%; margin-top:-6.5px; background:url('/images/main/icon-more.png') no-repeat 50% 50%/contain;}
.main-network .more a:hover {border-color:#991a26; background:#991a26; color:#fff;}
.main-network .more a:hover:before {background-image:url('/images/main/icon-more-w.png'); animation:move-arw 2s infinite linear; }

.main-supplier {padding:var(--size100-50) 0;}
.main-supplier .wrap {display:flex; align-items:center;}
.main-supplier .txt-wrap {flex:1 1 auto; min-width:0; width:1%; padding-left:var(--size90-10);}
.main-supplier .main-tit {margin-bottom:1.25em;}
.main-supplier .txt {margin-bottom:0.5em; font-size:var(--font20-14); font-weight:400; line-height:1.5; letter-spacing:-0.02em; color:#454545;}
.main-supplier .txt:last-child {margin-bottom:0;}
.main-supplier .more {margin-top:var(--size60-20); text-align:center;}
.main-supplier .more a {position:relative; display:inline-block; padding:1em 3.69em 1em 1.88em; font-weight:400; line-height:1; letter-spacing:-0.02em; color:#454545; border:1px solid #ddd; border-radius:100vh;}
.main-supplier .more a:before {content:''; position:absolute; width:8px; height:13px; right:1.88em; top:50%; margin-top:-6.5px; background:url('/images/main/icon-more.png') no-repeat 50% 50%/contain;}
.main-supplier .more a:hover {border-color:#991a26; background:#991a26; color:#fff;}
.main-supplier .more a:hover:before {background-image:url('/images/main/icon-more-w.png'); animation:move-arw 2s infinite linear; }


@keyframes move-arw {
	0%,100% {transform:translateX(0);}
	50% {transform:translateX(10px);}
}

/* sub */
.sub-visual {position:relative; background:#505050; width:100%; height:300px; display:flex; justify-content:center; align-items:center; text-align:center; overflow:hidden; background-repeat:no-repeat; background-position:50% 50%; background-size:cover;}
.sub-visual .content {position:relative; z-index:1; max-width:1260px; padding:0 30px; width:100%; margin:0 auto; color:#fff; text-shadow:3px 3px 5px rgba(0,0,0,0.4);}
.sub-visual .content h2 {font-size:var(--f50); font-weight:700; line-height:1.2em; letter-spacing:-0.03em; opacity:0; transform:translateY(20px); transition:0.8s all 0.3s ease;}
.sub-visual .content p {margin-top:1em; font-weight:500; line-height:1.4em; letter-spacing:-0.03em; opacity:0; transform:translateY(20px); transition:0.8s all 0.4s ease;}
.sub-visual.load .content h2 {opacity:1; transform:translateY(0);}
.sub-visual.load .content p {opacity:1; transform:translateY(0);}
 
.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-depth {width:100%; max-width:1260px; padding:0 var(--size30-15); margin:var(--size70-40) auto var(--size60-30) auto;}
.sub-depth span {position:relative; display:inline-block; padding-right:0.82em; font-size:var(--font17-14); font-weight:400; line-height:1; letter-spacing:0; color:#808080;}
.sub-depth span:before {content:''; position:absolute; width:8px; height:8px; border-right:1px solid #808080; border-top:1px solid #808080; right:2px; top:33%; transform:rotate(45deg);}
.sub-depth span:last-child {color:#991a26; font-weight:500;}
.sub-depth span:last-child:before {display:none;}

#lnb {position:relative; margin-bottom:var(--size40-20);}
.lnb {max-width:1260px; padding:0 var(--size30-15) !important; margin:0 auto; position:relative;}
.lnb ul {display:flex;}
.lnb ul li {width:auto; margin-right:var(--size40-10); position:relative;}
.lnb ul li a {position:relative; display:block; font-size:var(--font25-18); font-weight:600; color:#808080; line-height:1.2em; letter-spacing:-.02em;}
.lnb ul li.active a {color:var(--c-main); font-weight:700; border-bottom:2px solid var(--c-main);}


.sub-title {margin:var(--size100-40) auto var(--size60-40); padding:0 var(--size30-15); text-align:center;}
.sub-title h1 {position:relative; padding-bottom:27px; color:#242424; font-size:var(--font40-28); line-height:1.2em; font-weight:600; letter-spacing:-0.03em;}
.sub-title h1:before {content:''; position:absolute; width:60px; height:3px; background:#ff7900; left:50%; margin-left:-30px; bottom:0;}
.sub-title p {margin-top:15px; font-weight:400; line-height:1.4em; letter-spacing:-0.03em; color:#878787;}

#contArea {max-width:1260px; padding-left:var(--size30-15); padding-right:var(--size30-15); margin:0 auto;}
#contArea.wide {max-width:100%; padding-left:0; padding-right:0;}

.real-cont {padding-bottom:var(--size100-50);}
.real-cont.none {padding-bottom:0;}

/* footer */
#footer {position:relative; color:#505050; font-size:14px; font-weight:400; line-height:1.8em; letter-spacing:0; padding:var(--size50-20) 0; background:#fff; border-top:1px solid #ddd;}
#footer .contain {display:flex; max-width:1460px;}

#footer address {font-style:normal;}
#footer address > span {display:inline-block; margin-right:10px;}
#footer address .bar {display:inline-block; width:1px; height:10px; background:#888; margin-right:10px;}
#footer .copyright {display:block; margin-top:10px; margin-right:0;}
#footer .copyright a {color:#919191; font-size:12px;}

.f-cnt {display:flex; flex:1 1 auto; min-width:0; width:1%; flex-direction:column; justify-content:space-between; align-items:flex-end;}

.f-sns {padding-right:110px;}
.f-sns .tit {position:relative; display:inline-block; padding-bottom:0.38em; margin-bottom:1.15em; font-size:var(--font26-15); font-weight:700; line-height:1; letter-spacing:0; color:#333333;}
.f-sns .tit:before {content:''; position:absolute; width:100%; height:2px; background:#333; left:0; bottom:0;}
.f-sns ul {display:flex;}
.f-sns ul li {margin-right:10px;}
.f-sns ul li:last-child {margin-right:0;}
.f-sns ul li a {display:block;}

.scroll-top {position:absolute; right:-110px; top:50%; margin-top:calc(0px - var(--size60-40)/2); transform:translateY(20px); opacity:0; transition:0.2s all ease; z-index:99;}
.scroll-top img {height:var(--size60-40);}
.scroll-top.active {transform:translateY(0); opacity:1;}