@charset "utf-8"; /* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

#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 } 

/* header */
#header { position: absolute; left: 0; top: 0; right: 0; z-index: 90; border-bottom: 1px solid rgba(255,255,255,0.3); } 
#header .contain { height:100px; display: flex; align-items: center; justify-content: space-between; max-width: 1780px; z-index: 2; } 
#header.on { background-color: #fff; } 
#header .shadow { position: relative; } 
#header .shadow::after { position: absolute; top: 0; left: 0; content: ""; width: 100%; height: 128px; background: rgb(0,0,0); background: linear-gradient(180deg, rgba(0,0,0) 0%, rgba(255,255,255,0) 100%); opacity: 30%; } 
#header.on .shadow { display: none; } 
#header .sitelogo > a .logo { position: absolute; top: 14px; left: 30px; width: 82px; height: 70px; background: url(../images/common/logo.png)no-repeat 100% /contain; } 
#header.on .sitelogo > a .logo { background: url(../images/common/logo-on.png) no-repeat 100% /contain; } 

#gnb>ul { display: flex; } 
#gnb>ul>li { position:relative; text-align:center; padding:0 45px; } 
#gnb>ul>li>a { position:relative; display:flex; align-items: center; justify-content: center; color:#fff; font-size:20px; line-height:1.3em; font-weight:500; height: 100px; } 
#header.on #gnb>ul>li>a { color: #242424; font-weight:600; } 
#gnb>ul>li:hover>a { color: #0055a9 !important; } 
#gnb .submenu { display:none; position:absolute; left:50%; transform:translateX(-50%); width:200px; z-index:102; background-color: #fff; padding:30px 0; } 
#gnb .submenu:before { content:''; width:100%; height:3px; background-color: #0055a9; position: absolute; left:0; top:-1px; z-index:1; } 
#gnb .submenu ul { display:block; } 
#gnb .submenu ul li { margin-bottom:15px; } 
#gnb .submenu ul li:last-child { margin-bottom:0; } 
#gnb .submenu ul li a { display:inline-block; font-size:17px; line-height:1.2em; position:relative; font-weight:500; transition:.3s; } 
#gnb .submenu ul li a:after { content:''; width:0; height:1px; background-color: #0055a9; position: absolute; left:50%; bottom:-3px; transition:.3s; opacity:0; } 
#gnb .submenu ul li a:hover { color: #0055a9; } 
#gnb .submenu ul li a:hover:after { width:100%; opacity:1; left:0; } 

.submenu-bg { background-color:rgba(0,0,0,0.6); } 

#header.on .btn-all-menu {background-image: url(../images/common/menu-on.png); } 


.contain { position:relative; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto; } 
#contArea { max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto; } 



/* main */ 
.main-visual { position:relative; height:100vh; color:#fff; overflow:hidden; } 
.main-visual .item { position:relative; overflow:hidden; height:100vh; } 
.main-visual .item img { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; transition:5s; transform:scale(1.1); } 
.main-visual .caption { position:absolute; top:50%; left:50%; width:100%; transform: translate(-50%,-50%); text-align: center; text-transform: uppercase; } 
.main-visual .caption .t1 { font-size:35px; font-weight:500; line-height: 1.5em; letter-spacing:-.01em; opacity:0; transition:1.4s; transform:translateY(30px); } 
.main-visual .caption .t2 { font-family: 'Noto Serif', serif; font-size:60px; font-weight:700; line-height:1.166em; letter-spacing:-.01em; opacity:0; transition:1.4s; transform:translateY(30px); } 
.main-visual .caption .t3 { font-size: 28px; font-weight: 500; letter-spacing:0; padding-top: 30px; position: relative; opacity:0; transition:1.4s; transform:translateY(30px); } 
.main-visual .caption .t3.bar::before { content: ""; position: absolute; top: 15px; left: 50%; transform: translateX(-50%); width: 50px; height: 2px; background-color: #fff; opacity: 30%; } 
.main-visual .slick-arrow { position:absolute; top:50%; margin-top:-28px; width:29px; height:55px; border:0; font-size:0; line-height:0; text-indent:-9999em; overflow:hiddtab_conen; background-color:transparent; background-position:100%; background-repeat:no-repeat; z-index:50; } 
.main-visual .slick-prev { left:35px; background-image:url("../images/main/vis-prev.png"); } 
.main-visual .slick-next { right:35px; background-image:url("../images/main/vis-next.png"); } 
.main-visual .active .item img { transform:scale(1); } 
.main-visual .active .caption .t1 { opacity:1; transition-delay:.25s; transform:translateX(0); } 
.main-visual .active .caption .t2 { opacity:1; transition-delay:.5s; transform:translateX(0); } 
.main-visual .active .caption .t3 { opacity:1; transition-delay:.5s; transform:translateX(0); } 
.main-visual .scroll { position: absolute; bottom: 60px; left: 50%; margin-left: -50px; background: url(../images/main/btn-scroll.png) 100% no-repeat; animation: 1.5s scrollUpDown linear infinite; z-index: 50; width: 85px; height: 66px; } 
@keyframes scrollUpDown { 0%,100% { transform:translateY(-5px); } 
 50% { transform:translateY(10px); } 
 }
 .main-visual .caption.cap01 {


    margin-top: -100px;
}


.section .inner { padding: 100px 0; } 
.section .group-flex { display: flex; } 
.section .head { margin-bottom: 50px; } 
.section .head h2 { font-size: 35px; letter-spacing: -0.02em; color: #242424; margin-bottom: 16px; line-height: 1em; } 
.section .head p { font-size: 20px; font-weight: 600; } 
.section .btn-more { display:flex; align-items:center; padding: 0 30px; border-radius:30px; border: 1px solid rgba(255,255,255,0.3); width: 160px; height: 50px; position: relative; color: #fff; } 
.section .btn-more::after { content:''; width:8px; height:14px; background: url(../images/main/arrow-wht.png)no-repeat 50% 50%/contain; position: absolute; right: 30px; top:50%; transform:translateY(-50%); } 
.section .btn-more:hover { background-color: #0e91e4; color: #fff; border: 1px solid #0e91e4; } 

.sec1 { position: relative; width: 100%; overflow: hidden; max-height: 655px; height: 100%; } 
.sec1 .txt_area { position:relative; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
.sec1 .txt_area .tab-menu { width: 450px; } 
.sec1 .tab_con li { border-bottom: 1px solid #ddd; } 
.sec1 .tab_con li a { position: relative; display: block; font-size: 23px; color: #686868; height: 80px; padding: 0 30px; display: flex; align-items: center; } 
.sec1 .tab_con li a::after { content: ""; position: absolute; top: 30px; right: 30px; background: url(../images/main/btn-plus.png) 100% no-repeat; width: 16px; height: 16px; } 
.tab-menu.type2 ul.tabs>li.active a { background-color: #0055a9; font-weight: 700; color: #fff; } 
.tab-menu.type2 ul.tabs>li.active a::after { background: url(../images/main/btn-plus-on.png) 100% no-repeat; } 
.sec1 .img_area { position: absolute; left: 50%; top: 0; width: 100%; height: 655px; height: 100%; } 
.sec1 .img_area.show { opacity: 1; visibility: visible; transition: all 0.3s; } 
.sec1 .img_area.hide { opacity: 0; visibility: hidden; transition: all 0.3s; } 
.sec1 .img_area.one { background-image: url('../images/main/product1.jpg');}
.sec1 .img_area.two { background-image: url('../images/main/product2.jpg');}
.sec1 .img_area.three { background-image: url('../images/main/product3.jpg');}
.sec1 .img_area.four { background-image: url('../images/main/product4.jpg');}
.sec1 .img_area dl { padding: 440px 0 0 40px; } 
.sec1 .img_area dt { position: relative; font-size: 40px; color: #fff; font-weight: 500; letter-spacing: -0.02em; padding-bottom: 30px; } 

.sec2 .group-flex .box { flex:1; } 
.sec2 .group-flex a { display:block; position:relative; overflow:hidden; } 
.sec2 .group-flex .img img { width:100%; } 
.sec2 .group-flex .cnt { position:absolute; display:flex; align-items:center; justify-content:center; flex-direction:column; bottom:0; width:100%; height:80px; background-color: #183d55; opacity: 90%; transition:0.2s all ease; } 
.sec2 .group-flex .cnt .head { margin-bottom: 0; text-align: center; } 
.sec2 .group-flex .cnt .head h2 { text-align:center; font-size:24px; font-weight:600; line-height:1.428em; letter-spacing:-0.02em; transition:0.2s all ease; color: #fff; margin-bottom: 0; } 
.sec2 .group-flex .cnt .head p { display: none; color: #fff; font-weight: 500; } 
.sec2 .group-flex .cnt .btn-more { background-color: none; display:none; } 
.sec2 .group-flex a:hover .cnt { height:100%; background: rgb(24,61,85); background: linear-gradient(0deg, rgba(24,61,85,0.95) 0%, rgba(0,85,169,0.95) 100%); opacity: 100%; } 
.sec2 .group-flex a:hover .head { text-align: center; margin-bottom: 50px; } 
.sec2 .group-flex a:hover .head h2 { font-size: 45px; letter-spacing: -0.02em; margin-bottom: 16px; line-height: 1em; } 
.sec2 .group-flex a:hover .cnt .head p { display: block; } 
.sec2 .group-flex a:hover .btn-more { display: flex; } 
.sec2 .group-flex a:hover .btn-more:hover { color: #0367a6; background-color: #fff; border: 1px solid #fff; } 
.sec2 .group-flex a:hover .btn-more:hover::after { background: url(../images/main/arrow-blue.png)no-repeat 50% 50%/contain; } 

.sec3 { overflow: hidden; background: url(../images/main/about-bg.jpg) 50% 50% no-repeat;; background-size: cover; } 
.sec3 .row { display:flex; margin:0 -16px; } 
.sec3 .col { width:33.33333333%; padding:0 16px; } 
.sec3 .link { display:block; position:relative; width:100%; height:200px; color:#fff; overflow:hidden; transition:.4s; } 
.sec3 .link .bg { position:absolute; top:0; left:0; right:0; bottom:0; background-position:50% 50%; background-repeat:no-repeat; background-size:cover; } 
.sec3 .link .bg1 { background-image:url("../images/main/about1.jpg"); } 
.sec3 .link .bg2 { background-image:url("../images/main/about2.jpg"); } 
.sec3 .link .bg3 { background-image:url("../images/main/about3.jpg"); } 
.sec3 .link .inner { position:absolute; bottom: 0; left:0; padding: 0; transition:.4s; width: 250px; } 
.sec3 .link .tit { background-color: #0a59a8; opacity: 90%; position: relative; font-size: 18px; font-weight: 500; color: #fff; padding: 20px 30px; } 
.sec3 .link .tit::after { content: ""; position: absolute; top: 50%; transform: translateY(-50%); right: 30px; width:8px; height:14px; background: url(../images/main/arrow-wht.png)no-repeat 50% 50%/contain; } 
.sec3 .link .tit p { position: relative; } 
.sec3 .link:hover { transform:translateY(-22px); box-shadow: 0 0 30px rgba(0,0,0,.2); } 
.sec3 .link:hover::after { content:""; position:absolute; top:0; left:0; right:0; bottom:0; border:3px solid #0055a9; } 
.sec3 .link:hover .tit { opacity: 100%; } 


/* sub page */

.sub-visual { position:relative; height:410px; 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 { width:100%; position: absolute; left:0; top:50%; transform:translateY(-50%); z-index:1; color: #fff; text-align:center; padding-top: 90px; } 
 .sub-visual .tt-wrap .tit { font-size:35px; line-height:1.2em; font-weight:700; } 
 

#lnb { position:relative; border-bottom:1px solid #ddd; text-align:center; } 
#lnb .lnb { margin:0 auto; max-width:1200px; } 
#lnb .lnb .swiper-container { margin-bottom:-1px; padding-left:1px; } 
#lnb .lnb ul li { flex:1; width:auto; text-align:center; border-right:1px solid #ddd; } 
#lnb .lnb ul li:first-child { border-left:1px solid #ddd; } 
#lnb .lnb ul li a { display:flex; align-items:center; justify-content:center; width:100%; height:60px; padding:0 15px; color: #242424; font-size:19px; font-weight:500; line-height:1.4em; letter-spacing:-.02em; transition:none; position: relative; } 
#lnb .lnb ul li.active a { color:#0055a9; } 
#lnb .lnb ul li.active a:after { content: ''; width: 100%; height: 3px; background-color: #0055a9; position: absolute; left: 0; bottom: 0; } 


 
.real-cont { padding:0 0 100px; } 

.sub-title { text-align: center; margin: 80px 0; } 
.sub-title h2 { font-size: 35px; color: #242424; letter-spacing: -0.01em; line-height: 1em; } 

/* 전체메뉴 */
.btn-all-menu { display: block; width: 26px; height: 20px; background: url(../images/common/menu.png) no-repeat 100%/contain; } 


.all-menu.active { transform:translateY(0); } 
.all-menu { position:fixed; top:0; left:0; width:100%; height:100%; overflow:auto; background:#fff; z-index:102; transition:ease .3s; transform:translateY(-100%); } 
.all-menu .contain { position:relative; width:100%; max-width:1090px; height:100%; } 
.all-menu .wrap { position: relative; width: 100%; height: 100%; display: flex; justify-content: center; flex-direction: column; align-items: center; } 
.all-menu .gnb-logo { margin-bottom: 100px; } 
.all-menu .gnb-logo .img { width: 114px; height: 98px; } 
.all-menu .nav { position:relative; width: 100%; justify-content: center; display:flex; align-items:center; } 
.all-menu .nav > ul { display:flex; flex-wrap:wrap; width: calc(100% + 60px); margin: 0 -30px; } 
.all-menu .nav > ul > li { width:25%; padding: 0 30px; } 
.all-menu .nav > ul > li > a { display:block; font-size:24px; font-weight:600; letter-spacing:-.03em; position: relative; } 
.all-menu .nav > ul > li > a::after { content: ""; width: 100%; height: 1px; background-color: #d0d0cf; position: absolute; top: 45px; left: 0; } 
.all-menu .nav > ul > li:hover > a { color:#0055a9; } 
.all-menu .nav .submenu { padding-top:40px; } 
.all-menu .nav .submenu > ul > li { margin-bottom:20px; } 
.all-menu .nav .submenu > ul > li:last-child { margin-bottom:0; } 
.all-menu .nav .submenu > ul > li > a { display: inline-block; font-size:16px; font-weight:500; line-height: 1.3em; letter-spacing:-.02em; position: relative; } 
.all-menu .nav .submenu > ul > li > a::after { content:''; width:0; height:1px; background-color: #0055a9; position: absolute; left:50%; bottom:-3px; transition:.3s; opacity:0; } 
.all-menu .nav .submenu > ul > li > a:hover { color:#0055a9; } 
.all-menu .nav .submenu > ul > li > a:hover::after { width:100%; opacity:1; left:0; } 
.all-menu .close { position:absolute; top:40px; right:100px; width:20px; height:20px; text-indent:-9999em; overflow:hidden; background:url("../images/common/btn-close.png") 50% 50% no-repeat; background-size:contain; } 


/* footer */

#footer { background-color: #333333; padding: 50px 0; } 
#footer .contain { max-width:1780px; display:flex; justify-content:space-between; align-items: center; } 
#footer .foot-info { max-width: 630px; } 
#footer .foot-info .tit { color: #ffffff; font-size:17px; line-height:1.470em; margin-bottom:20px; } 
#footer .foot-info address { font-style:normal; display:flex; flex-wrap:wrap; margin:0 -8px; } 
#footer .foot-info address p { font-size: 15px; line-height: 1.666em; padding:0 8px; color: #9e9e9e; line-height:1.4em; } 
#footer .foot-info .copy { font-size:14px; color: #707070; line-height:1.2em; margin-top:13px; } 
#footer .foot-menu { display:flex; justify-content:flex-end; margin:0 -20px; padding-right: 100px; } 
#footer .foot-menu li { padding:0 20px; } 
#footer .foot-menu li a { position:relative; padding-left:21px; color: #ababab; font-size: 14px; line-height: 1.571em; font-weight: 500; } 
#footer .foot-menu li a:before { content:''; width:15px; height:15px; background:url('../images/common/btn-popup.png')no-repeat 50% 50%/contain; position: absolute; left:0; top:2px; } 
#footer .copy a:hover { text-decoration: underline; } 
.scroll-top { font-size: 0; border: none; border-radius: 50%; width: 50px; height: 50px; background: #0055a9 url(../images/common/top.png)no-repeat 50% 50%/19px; position: fixed; right: 100px; bottom: 65px; z-index: 100; } 

/* for mobile */
.only-mobile { display:none; } 
.btn-m-menu { display:none; position:absolute; top:50%; margin-top:-11px; right:30px; width:30px; height:22px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out; } 

.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-bottom:20px; padding-left:15px; } 
.mobile-navigation .home img { height:23px; } 
.mobile-navigation .nav-menu>ul { margin-top:30px; } 
.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:#0055a9 } 
.mobile-navigation .nav-menu>ul>li.active>a:after { transform:translateY(-35%) rotate(-135deg); border-color:#0055a9; } 
.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:#0055a9 } 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after { background:#0055a9 } 
.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; } 