@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}

.contain {width:100%; max-width:1460px; padding-left:30px; padding-right:30px; margin:0 auto;}
.contain:after {content:""; display:block; clear:both;}
#sub .contain {max-width:1260px;}

.only-desktop {display:block;}
.only-desktop-tablet {display:block;}
td.only-desktop-tablet {display:table-cell;}
.only-tablet-mobile {display:none;}
.only-tablet {display:none;}
.only-mobile {display:none;}

/* header */
#header {position:relative; width:100%; z-index:100; background:#fff;}
#header .contain {position:relative; max-width:1460px; height:100px; padding-left:30px; padding-right:30px;}

.sitelogo {position:absolute; top:50%; left:30px; margin-top:-32.5px; z-index:5;}

.gnb-wrap {border-bottom:1px solid #ddd; border-top:1px solid #ddd; height:60px; margin-bottom:30px;}
#gnb {position:relative; height:60px; width:100%; z-index:2; display:flex; justify-content:space-around;}
#gnb > ul {display:inline-block;}
#gnb > ul:after {content:" "; display:block; clear:both;}
#gnb > ul > li {position:relative; float:left; padding-right:50px; padding-left:50px; height:100px; z-index:1;}
#gnb > ul > li:last-child {padding-right:0;}
#gnb > ul > li > a {display:block; height:60px; line-height:60px; position:relative; font-size:20px; font-weight:500; color:#333; z-index:5; letter-spacing:-0.03em;}
#gnb > ul > li.active > a,
#gnb > ul > li:hover > a {font-weight:500; color:#3f48cc;}

#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a {font-weight:500;}

#gnb .submenu {display:none; position:absolute; z-index:1; padding:0 5px; padding-top:20px; padding-bottom:20px; width:100%; left:0; background:rgba(21, 57, 145, 0.8);}
#gnb .submenu ul:after {content:" "; display:block; clear:both;}
#gnb .submenu ul li {text-align:center;}
#gnb .submenu ul li a {font-size:18px; display:inline-block; text-decoration:none; color:#fff; font-weight:400; line-height:40px; position:relative;} 
#gnb .submenu ul li.active a,
#gnb .submenu ul li:hover a:after {position:absolute; content:''; bottom:0; left:0; width:100%; height:1px; background-color:#fff;}

#gnb .m2 .submenu:before {left:50px;}
.submenu-bg {display:none; position:absolute; top:100px; left:0; width:100%; background:rgba(255, 255, 255, 0.8);}

.main-link {position: absolute; top:50%; margin-top:-25px; right:20px; z-index:500;}
.main-link ul {display:flex; align-items:center;}
.main-link ul li {padding:0 5px;}
.main-link ul .links {padding-right:30px;}

 /* main */ 
.main-visual {position:relative; overflow:hidden;}
.main-visual .caption {position:absolute; top:43%; left:100px; transform:translateY(-50%); width:100%; color:#333; z-index:40;}
.main-visual .caption h2 {font-weight:500; font-size:55px; line-height:1.273em; letter-spacing:-.03em; margin-top:20px;}
.main-visual .caption h2 span {color:#3f48cc;}
.main-visual .caption p {font-size:26px; letter-spacing:-.03em;	line-height:1.3em;}
.main-visual .caption .bold {font-weight:500;}
.main-visual .slick-dots {position:absolute; bottom:150px; left:140px; width:100%; z-index:50; line-height:0;}
.main-visual .slick-dots li {display:inline-block; margin-right:25px;}
.main-visual .slick-dots li button {display:block; width:5px; height:5px; background:transparent; color:#333; background:#000; border-radius:50%; overflow:hidden; text-indent:-9999px;}
.main-visual .slick-dots li.slick-active button {margin-right:-10px; margin-left:-10px; background:url("../images/main/dot-active.png")50% 50% no-repeat; width:29px; height:29px; padding-top:12px; border:1px solid #666;}
.main-visual .slick-arrow {position:absolute; bottom:0; width:9px; height:16px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:500; background-size:contain;}
.main-visual .control button {position:relative; display:block; width:20px; height:15px; border:0; background:transparent; z-index:500;}
.main-visual .control {position:absolute; display:flex; left:230px; bottom:160px; z-index:50;}
.main-visual .control .slick-arrow {text-indent:-999em; overflow:hidden;}
.main-visual .control .slick-prev {background:url("../images/main/slide_prev.png") no-repeat 50% 50%;}
.main-visual .control .slick-next {background:url("../images/main/slide_next.png") no-repeat 50% 50%;}
.main-visual .control .stop:before {content:""; position:absolute; width:7px; height:12px; border-right:2px solid rgba(51, 51, 51, 0.7); border-left:2px solid rgba(51, 51, 51, 0.7); left:50%; top:50%; margin:-6px 0 0 -2px;}
.main-visual .control .play:before {content:""; position:absolute; border-left: 8px solid #454545; border-top: 8px solid transparent; border-bottom: 8px solid transparent; left:50%; top:50%; transform:translate(-50%,-50%);}
.main-visual .control .play {display:none;}
.main-visual .item .img img {width:100%; max-width:1400px; margin:0 auto;}

.main_group ul {display:flex; justify-content:center; background-color: rgba(0, 0, 0, 0.6); color:#fff;}
.main_group ul li:hover {background:linear-gradient(to bottom right, #e67223, #f3a977);}
.main_group ul li:hover:after {display:none;}
.main_group ul li {position:relative; text-align:center; padding:35px 0; width:16.6666%; height:200px;}
.main_group ul li:after {content:""; display:inline-block; width:1px; height:145px; background:#24282d; position:absolute; top:25px; right:0;}
.main_group ul li:last-child:after {display:none;}
.main_group ul li .img {display:block; margin:0 auto 10px; width:32%;}

.main-cnt {padding:100px 0;}
.main_estimate .txt-box {width:28.6%;}
.main_estimate .txt-box h3 {font-size:40px; font-weight:500; letter-spacing:-.03em; line-height:1.0em; margin-bottom:55px;}
.main_estimate .txt-box .txt-flex li {display:flex; justify-content:space-between; position:relative; font-size:32px; font-weight:500; letter-spacing:-.03em; line-height:1.0em; border-bottom:1px solid #ddd;}
.main_estimate .txt-box .txt-flex li:last-child {border-bottom:none;}
.main_estimate .txt-box .txt-flex li:after {position:absolute; content:""; top:50%; margin-top:-5px; right:0; width:6px; height:10px; background:url("../images/main/main-next.png")50% 50% no-repeat;}
.main_estimate .txt-box .txt-flex li a {justify-content:space-between; align-items:center; padding:35px 0;}
.main_estimate .txt-box .txt-flex li a:hover {color:#3f48cc;}
.main_estimate .txt-box .txt-flex li a:hover span {color:#3f48cc;}
.main_estimate .txt-box .txt-flex li:hover:after {background-image:url("../images/main/main-next-hover.png");}
.main_estimate .txt-box .txt-flex li span {font-size:16px; color:#555; font-weight:500; letter-spacing:-.03em; padding-right:20px;}
.main_estimate .txt-box .txt-flex li .taps-hover {width:20%;}
.main_estimate .txt-box .txt-flex li .font {width:80%; font-size:16px; font-weight:500; padding-right:20px; text-align:right;}
.main_estimate .txt-box .txt-bg {width:100%; height:225px; background:#3f48cc; margin-top:70px; color:#fff; text-align:center; padding:20px;}
.main_estimate .txt-box .txt-bg .txt-border {border:1px solid rgba(160, 160, 160, 0.4); padding:35px 10px 40px 10px;}
.main_estimate .txt-box .txt-bg .txt-border .tit {font-size:24px; font-weight:500; letter-spacing:-.03em; line-height:1.3em;}
.main_estimate .txt-box .txt-bg .txt-border .lg-txt {font-size:30px; font-weight:700; letter-spacing:-.03em; line-height:1.3em;} 
.main_estimate .estimate-list {width:71.4%; padding-left:70px;}
.main_estimate .estimate-list ul {display:flex; flex-wrap:wrap; margin:-10px;}
.main_estimate .estimate-list ul li {width:50%; padding:10px;}
.main_estimate .estimate-list ul li img {position:relative; border:1px solid #ddd;}
.main_estimate .estimate-list ul li img:hover:before {position:absolute; content:""; top:0; left:0; width:100%; height:100%; background:rgba(0, 0, 0, 0.3);}

.produce {background:url("../images/main/produce-bg.jpg")50% 50% no-repeat; background-size:cover;}
.produce-list ul {display:flex; flex-wrap:wrap;}
.produce-list ul li {width:25%; position:relative;}
.produce-list ul li .tit-box {width:100%; position:absolute; bottom:0; color:#fff; padding:30px;}
.produce-list ul li:hover .tit-box {background:#3f48cc;}
.produce-list ul li .tit {display:flex; align-items:center; justify-content:space-between; font-size:22px; font-weight:700; letter-spacing:-.03em; line-height:1.364em; margin-bottom:5px;}
.produce-list ul li .tit-box .txt {font-size:18px;}

.main-case .title {font-size:40px; font-weight:500; letter-spacing:-.03em; line-height:1.0em; text-align:center; margin-bottom:55px;}
.main-case .slick-slide .thumb {position:relative; margin:0 auto; padding-bottom:73%; margin-bottom:12px; overflow:hidden;}
.main-case .slick-slide .thumb 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-case .slick-arrow {position:absolute; top:50%; margin-top:-53.5px; width:20px; height:37px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.main-case .slick-prev {left:-50px; background-image:url("../images/main/main-prev.png");}
.main-case .slick-next {right:-50px; background-image:url("../images/main/main-nexts.png");}

.subSliderinner .item {padding:0 5px;}
.subSliderinner .slick-arrow {position:absolute; top:50%; margin-top:-37.5px; width:20px; height:37px; border:none; overflow:hidden; text-indent:-999em; background-color:transparent; background-position:50% 50%; background-repeat:no-repeat; z-index:50; background-size:contain;}
.subSliderinner .txt {font-size:18px; margin-top:15px; font-weight:500; text-align:center;}

/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; right:30px; margin-top:-12px; width:24px; height:24px; text-indent:-9999em; z-index:50;}
.btn-m-menu span {position:absolute; left:0; right:0; top:11px; height:2px; background:#603913;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; right:0; height:2px; background:#603913;}
.btn-m-menu span:before {top:-9px;}
.btn-m-menu span:after {bottom:-9px;}

.mobile-navigation {display:none; position:fixed; top:0; right:0; width:280px; height:100%; overflow:auto; transition:.2s linear; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:102;}
.mobile-navigation .home {padding:21px 20px;}
.mobile-navigation .home a {display:block;}
.mobile-navigation .home img {height:38px;}
.mobile-navigation .nav-menu>ul {border-top:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li {border-bottom:1px solid #dfdfdf;}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:13px 20px; display:block; color:#242424; font-size:18px; font-weight:700; line-height:1.5em;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:12px; height:12px; border-right:2px solid #242424; border-bottom:2px solid #242424;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#3f48cc;}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg);}
.mobile-navigation .nav-menu .submenu {display:none; padding:10px 20px; background:#3f48cc; color:#fff; font-size:16px; line-height:1.5em;}
.mobile-navigation .nav-menu .submenu > ul >  li > a {display:block; padding:6px 0;}
.mobile-navigation .close {position:absolute; top:16px; right:10px; width:24px; height:24px; text-indent:-9999em; overflow:hidden;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:11px; left:0; width:100%; height:2px; background:#242424; border-radius:3px;}
.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:101;}

html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}

/* sub */
.sub-visual {position:relative; display:table; table-layout:fixed; width:100%; height:360px; background-color:#fff; background-position:50% 50%; background-repeat:no-repeat; background-size:cover;}
.sub-visual .cell {display:table-cell; vertical-align:middle; width:100%; height:100%;}
.sub-visual .in {text-align:center;}
.sub-visual h3 {position:relative; font-size:40px; line-height:1.0em; color:#fff; letter-spacing:-.03em; font-weight:500;}
.sub-visual p {font-size:14px; line-height:1.3em; color:#fff; letter-spacing:0.8em;}
.sub-visual.bg1 {background-image:url("../images/common/sv1.jpg");}
.sub-visual.bg2 {background-image:url("../images/common/sv2.jpg");}
.sub-visual.bg3 {background-image:url("../images/common/sv3.jpg");}
.sub-visual.bg4 {background-image:url("../images/common/sv4.jpg");}
.sub-visual.bg5 {background-image:url("../images/common/sv5.jpg");}
.sub-visual.bg6 {background-image:url("../images/common/sv6.png");}

/* .performance-list {display:flex; justify-content:center; margin:0 -10px; margin-bottom:60px;}
.performance-list li {padding:0 10px;}
.performance-list li.active a {background-color:#1ca1e4; color:#fff;}
.performance-list li a {display:block; text-align:center; font-size:20px; font-weight:500; color:#1ca1e4; letter-spacing:-.03em; width:200px; height:60px; line-height:60px; border-radius:30px; border:1px solid #1ca1e4;}
 */
#contArea {max-width:1260px; padding-left:30px; padding-right:30px; margin:0 auto;}
#contArea.wide {max-width:none;} 


.sub-title {text-align:center; padding:80px 0;}
.sub-title.pb {padding-bottom:0;}
.sub-title h2 {position:relative; color:#333; font-size:32px; font-weight:500; line-height:1.3em; letter-spacing:-.03em; padding-bottom:15px;}
.sub-title h2:before {position:absolute; content:""; bottom:0; left:50%; margin-left:-24px; width:48px; height:3px; background:#3f48cc;}

.real-cont {padding-bottom:100px;}

/* lnb */
.lnb-wrap {position:relative; border-bottom:1px solid #ddd; color:#333;}	
.lnb {max-width:1920px; margin:0 auto; text-align:center; background:#fff; border-bottom:1px solid #ddd;}
.lnb ul {display:flex; margin:0 auto;}
.lnb ul li {flex:1; position:relative; width:auto; margin-left:-1px; border-bottom:none;}
.lnb ul li:first-child::before {display:none;}
.lnb ul li a {position:relative; display:inline-block; width:100%; line-height:60px; font-size:18px; letter-spacing:-.03em; transition:none; color:#333; font-weight:500; border-right:1px solid #ddd;}
.lnb ul li:first-child a {border-left:1px solid #ddd;}
.lnb ul li:last-child:after {display:none;}
.lnb ul li.active a {color:#fff; font-weight:500; background:#3f48cc;}
.lnb ul li.active + li:before {display:none;}
.lnb .swiper-container {overflow:visible ;}

/* footer */
#footer {padding:25px 0 30px 0; position:relative; line-height:28px; border-top:1px solid #ddd;}
#footer .contain {max-width:1460px; color:#cccbcb; font-size:15px; letter-spacing:-.03em; line-height:1.600em; align-items:center;}
#footer address {font-style:normal; line-height:1.714em;}
#footer .foot_logo {font-size:18px; padding-bottom:15px; color:#666;}
.link-wrap {border-bottom:1px solid #666666;}
.foot-logo {order:1; margin-right:65px; padding-left:20px;}
.foot-info .foot-link {display:inline-block; font-weight:400;}
.foot-info {font-size:15px; color:#666; order:2; flex:1;}
.foot-info .foot-links {margin:0 auto; margin-bottom:10px;}
.foot-info .foot-link a {display:block; font-size:14px; color:#878787;}
.foot-info span {position:relative; display:inline-block; padding-right:30px; margin-bottom:5px;}
.foot-info span:after {position:absolute; content:""; top:50%; right:13px; width:1px; height:11px; margin-top:-5.5px; background:#ddd;}
.foot-info span:nth-child(5):after {display:none;}
.foot-info span:last-child:after {display:none;}
.foot-info .foot-after {padding-right:25px; font-size:15px; letter-spacing:-.03em; line-height:1.600em;}
.foot-links ul {display:flex; margin-right:30px; margin-bottom:10px;}
.foot-links ul li {position:relative; padding-left:6px; color:#666; font-weight:500;}
.foot-links ul li a {position:relative; padding-left:20px;}
.foot-links ul li a:after {content: ""; display:inline-block; position:absolute; top:3px; left:0; width:16px; height:15px; background-image: url("/images/main/foot_links.png"); background-position:50% 50%; background-repeat:no-repeat;}
.foot-links ul li:first-child {padding-left:0; padding-right:20px;}
.foot-links ul li:first-child::before {display:none;}
.foot-links .name {font-size:17px; font-weight:500; padding-right:33px;}
.go-top {position:absolute; right:100px; bottom:160px; z-index:1;}

/* quick */
#sub .quick {top:520px;}
.quick {position:absolute; top:150px; right:0; width:130px; text-align:center; z-index:90;}
.quick .bg1 {background:#603913;}
.quick .bg2 {background:#c69c6d;}
.quick ul li a {display:block; padding:26px 0 23px; font-size:18px; font-weight:500; color:#fff; line-height:1.3em; letter-spacing:-.03em;}
.quick ul li img {display:block; margin:0 auto 15px;}
.catalogue {position:fixed; right:100px; top:700px;}