@charset "utf-8";
/* *******************************************************
 * filename : layout.css
 * description : 전체 레이아웃 CSS
 * date : 2021-06-14
******************************************************** */

/* fallback */
@font-face {
  font-family: 'Material Icons';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/Material-Icons.woff2") format('woff2');
}

.material-icons {
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased;
}

/* ****************** LAYOUT ********************** */
::selection {
    background: #555;   
    color: #fff;
}
::-moz-selection {
    background: #555;    
    color: #fff;
}
body, table, th, td, button, select, input, textarea {
	font-family: 'Lato', 'Noto Sans KR', "나눔고딕", NanumGothic, "Nanum Gothic","돋움", Dotum, Arial, sans-serif;
	font-size:13px;
	color:#666;
	-webkit-text-size-adjust:none;
	word-break:keep-all;
}
body { background-color:#fff; }
table, th, td{word-break:break-word;}
#wrap {overflow:hidden; width:100%; min-width:320px; position:relative; }
.area{ max-width:1300px; margin:0px auto;} /* width 홈페이지 컨텐츠 가로값에 맞게 변경 */
.area-box{ padding: 0 8%; margin:0px auto; }
.font-noto{font-family: 'Noto Sans KR', "나눔고딕", NanumGothic, "Nanum Gothic","돋움", Dotum, Arial, sans-serif;}

/* Fullpage Layout */
.fullpage-html{overflow:hidden; height:100%;}
.fullpage-html #wrap{position:static;}

/* ****************** HEADER ********************** */
#header{
	position:absolute; height:110px; top:0; left:0; width:100%; z-index:9999; 
}
.fullpage-html #header{
	position:fixed;
}
#headerInnerWrap{
	position:absolute; top:0px; left:0px; width:100%; height:100%; z-index:9999; 
	-webkit-transition:background-color 0.3s;
	transition:background-color 0.3s
}
#headerInner{position:relative; height:100%; margin:0px auto;}
#header .logo{position:relative; z-index:100; float:left; padding-top:37px;}
#header .logo a{display:block; width: 205px; height: 36px; background: url("../images/common/logo.png") center/cover no-repeat; -webkit-transition: background 0.3s; transition: background 0.3s;}


/* -------- Header :: UTIL BOX -------- */
.header-util-box{position:absolute; top:50%; right:8%; margin-top:-15px; z-index:100;}

/* Header :: 언어선택 */
.header-lang {position:relative; float:left; width: 110px; height:30px; z-index:100;}
.header-lang .lang-open-btn {overflow:hidden; position:relative; display:block; width:100%; text-align:left; height:100%; font-size:11px; line-height: 30px; color:#fff; -webkit-transition: color 0.3s; transition: color 0.3s;}
.header-lang .lang-open-btn i {display:inline-block; margin-right: 6px; vertical-align: middle; font-size:20px; margin-top:-2px;}
.header-lang .lang-open-btn .arrow{position:absolute; top:0px; right:-8px;}
.header-lang .lang-open-btn .arrow i{font-size:18px;}
.header-lang > ul {display:none; position:absolute; top:30px; left:-1px; z-index:10; width:100%; border:1px solid #5c5c5c; background-color:#fff;}
.header-lang > ul > li > a{display:block; padding:0 10px; font-size:11px; line-height: 30px; color:#333;}
.header-lang > ul > li > a:hover{background-color:#f2f2f2; }
.header-lang.open .lang-open-btn .arrow i{transform:rotate(180deg); margin-top:-3px;}


/* -------- Header :: GNB(PC) -------- */
.gnb-overlay-bg{position:fixed; top:0; left:0; width:100%; height:100%; visibility:hidden; opacity:0;filter:Alpha(opacity=0); background:rgba(0,0,0,0.5); z-index:9997;  -webkit-transition:all 0.3s; transition:all 0.3s; }	/* gnb overlay BG */
.gnb-overlay-bg.open{visibility:visible; opacity:1.0;filter:Alpha(opacity=100);}
#gnb{position:absolute; text-align:center; top:0; left:0px; width:100%; z-index:99;}
#gnb > ul{width: 100%; display:inline-block; text-align: right; *display:inline;*zoom:1; -webkit-box-sizing: border-box; box-sizing: border-box;}
#gnb > ul > li{position:relative; display: inline-block; word-break:keep-all;}
#gnb > ul > li > a{
	position:relative; z-index:100; display:block; line-height:110px; padding:0 35px; text-align:center; color:#fff; font-size:18px; letter-spacing:-0.5px; font-weight:500; -webkit-transition:all 0.3s; transition:all 0.3s;
}
#gnb > ul > li > a:hover,
#gnb > ul > li > a:focus{color:#0053a0;}

/* GNB :: 2차 전체메뉴 */
#gnbBg{
	overflow:hidden; position:absolute; left:0; top:0px; width:100%; height:0; background:#fff; z-index:98;
	opacity:0;filter:Alpha(opacity=0);
	-webkit-transition:height 0.3s ease-in-out, opacity 0.2s ease-in-out;
	transition:height 0.3s ease-in-out, opacity 0.2s ease-in-out;
}
#gnbBg:after{position:absolute; top:110px; width:100%; left:0; height:1px; background-color:#ddd; content:"";}
#gnb.total-menu > ul > li .gnb-2dep{
	position:absolute; 
	top:110px; 
	left:0px; 
	z-index:99;
	width:100%; 
	text-align:left; 
	opacity:0;filter:Alpha(opacity=0);
	height:0;
	-webkit-transition: all 0.2s 0s;
    transition: all 0.2s 0s;
	visibility:hidden;
}
#gnb.total-menu > ul > li .gnb-2dep:before {
	content:""; position:absolute; left:0; top:-1.5px; width:0; left:50%; height:3px; background-color:#0053a0; 
	-webkit-transition:all 0.3s; transition:all 0.3s; z-index:10;
}
#gnb.total-menu > ul > li:hover .gnb-2dep:before {width:100%; left:0;}
#gnb.total-menu > ul > li .gnb-2dep ul{padding-top: 30px;}
#gnb.total-menu > ul > li .gnb-2dep ul li{position:relative;}
#gnb.total-menu > ul > li .gnb-2dep ul li a{ display:block; padding:10px 15px; color:#545454; font-size:16px; letter-spacing:-0.5px; font-weight:400; line-height:1.3; -webkit-transition:all 0.2s; transition:all 0.2s; text-align: center;}
#gnb.total-menu > ul > li .gnb-2dep ul li a:hover{color:#0053a0; font-weight: 700;}

/* GNB :: 2차메뉴 Over (높이변경) */
#gnb.open #gnbBg{height:380px; opacity:1.0;filter:Alpha(opacity=100);}
#gnb.open > ul > li .gnb-2dep{
	height:250px; opacity:1.0;filter:Alpha(opacity=100);
	visibility:visible;
	-webkit-transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
    transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
}

/* Header open ver. */
.gnb-open #gnb > ul > li > a{color: #545454;}
.gnb-open #gnb > ul > li.on > a{color:#0053a0;}
.gnb-open#header .logo a{background: url("../images/common/logo_c.png") center/cover no-repeat;}
.gnb-open .header-lang .lang-open-btn{color: #545454;}


/* -------- Header :: GNB(Mobile) -------- */
.nav-open-btn{display:none;}
#gnbM{display:none}

/* ****************** FOOTER ********************** */
/* -------- FOOTER :: 레이아웃 -------- */
#footer{background-color:#fff;}
#footerInner{position:relative; }

/* -------- FOOTER :: 상단 -------- */
#footerTop{padding:55px 0 50px; background-color: #f5f5f5;}

/* Footer :: 사이트맵 */
.footer-sitemap-list-con > ul > li{float:left; width: 16.66%; padding-right: 20px; -webkit-box-sizing: border-box; box-sizing: border-box;}
.footer-sitemap-list-con > ul > li h3{margin-bottom:20px; color:#3a3a3a; font-size:18px; line-height: 1.3; font-weight:500; letter-spacing:-0.55px;}
.footer-sitemap-list-con > ul > li .sitemap-2dep li{margin-bottom:15px;}
.footer-sitemap-list-con > ul > li .sitemap-2dep li:last-child{margin-bottom:0}
.footer-sitemap-list-con > ul > li .sitemap-2dep li a{display:block; font-size:15px; line-height: 1.3; letter-spacing:-0.55px; color:#797979; transition:all 0.3s;}
.footer-sitemap-list-con > ul > li .sitemap-2dep li a:hover{color:#0053a0;}

/* -------- FOOTER :: 하단 -------- */
#footerBottom{padding:50px 0;}
#footerBottom .area-box{position: relative;}

.footer-left-con{float:left; width: calc(100% - 290px);}
/* Footer :: 푸터로고 */
.foot-logo{margin-top: 20px; width: 205px; padding-right: 5.6%; float: left; display:block;}
.foot-logo img{height: 36px;}

.foot-info-group{width: calc(94.4% - 205px); float: left;}

/* Footer :: 푸터메뉴 */
.foot-menu{}
.foot-menu li{float:left; position:relative; padding-left:25px;}
.foot-menu li:first-child{padding-left: 0;}
.foot-menu li a{font-size:15px; letter-spacing:-0.55px; font-weight: 700; color: #3a3a3a;}

/* Footer :: 정보 */
.footer-address{margin-top:15px; letter-spacing:-0.5px;}
.footer-address .footer-address-txt{font-size:15px; line-height:1.5; margin:0 -8px; color:#3a3a3a;}
.footer-address p{display:inline-block; vertical-align:middle; position:relative; margin:0 8px;}
.footer-address a{color:inherit}

/* Footer :: Copyright */
.footer-copyright{margin-top: 15px; font-size:15px; color:#3a3a3a;}

.footer-right-con{position: absolute; top: 50%; margin-top: -30px; right: 8%;}
/* Footer :: 패밀리사이트 */
.family-site-box{margin-right: 10px; float: left; position:relative; width:200px; text-align:left; letter-spacing:-0.5px;}
.family-site-box .family-site-open-btn{display:block; width:100%; height:60px; line-height:60px; padding:0 50px 0 35px; text-align:left; font-size:14px; border:1px solid #cacaca; background-color:#fff; color:#3a3a3a; box-sizing:border-box; -webkit-border-radius: 60px; border-radius: 60px; -webkit-transition: all 0.6s; transition: all 0.6s;}
.family-site-box .family-site-open-btn:after{position:absolute; right:30px; top:50%; transform:translateY(-50%); font-size:16px; font-family: 'xeicon'; content:"\e945";}
.family-site-box.open .family-site-open-btn:after{content:"\e942";}
.family-site-box.open .family-site-open-btn{border-top-color:#fff; -webkit-border-radius: 0 0 20px 20px; border-radius: 0 0 20px 20px; -webkit-transition: all 0s; transition: all 0s;}
.family-site-list{position:absolute; bottom:100%; left:0px; width:100%; padding:10px 0 0; background-color:#fff; border:1px solid #cacaca; border-bottom: 0; z-index:11; display:none; box-sizing:border-box; -webkit-border-radius: 20px 20px 0 0; border-radius: 20px 20px 0 0;}
.family-site-list a{display:block; padding:10px 20px; color:#3a3a3a; font-size:14px;}
.family-site-list a:hover{color:#000; text-decoration:underline;}

/* Footer :: TOP버튼 */
.to-top-btn{
	float: left; display:block; width:60px; height:60px; background-color:#3a3a3a; font-size: 12px; color:#fff; z-index:99;
	-webkit-transition:all 0.6s; transition:all 0.6s;
	-webkit-border-radius:50%;-moz-border-radius:50%;-o-border-radius:50%;border-radius:50%;
}
@media all and ( min-width: 801px ){		
	.to-top-btn:hover{animation: circleHover 0.7s both;}
}
@keyframes circleHover {
	0% {
		transform:scale(1); 
	}
	50% {
		transform:scale(1.3); 
	}
	100% {
		transform:scale(1); 
	}
}

/* ****************** SUB LAYOUT ********************** */
/*  SUB LAYOUT :: 비주얼 */
#visual{position:relative; overflow:hidden; width:100%; height:615px;}
#visual .visual-img-con{
	position:absolute; 
	top:0px; 
	left:0px; 
	width:100%;
	height:100%;
	background-size:cover !important;
    -webkit-transform: scale(1.1,1.1); 
     transform: scale(1.1,1.1);
	-webkit-transition:transform 5000ms  ease-in-out ;
    transition:transform 5000ms ease-in-out ;	
}
#visual .visual-txt-con{position:relative; z-index:1; text-align:center; display:table; width:100%; height:100%; letter-spacing:-0.5px; color:#fff;}
#visual .visual-txt-container{padding-top: 55px; position:relative; width:100%; }
#visual .visual-tit{
	opacity:0;filter:Alpha(opacity=0);
    -webkit-transform: translateY(30px); 
     transform: translateY(30px);
	-webkit-transition:opacity 1.0s, transform 1.0s;
	transition:opacity 1.0s, transform 1.0s;
}
#visual .visual-tit{
	font-weight:700; 
	font-size:60px; 
	-webkit-transition-delay:0.3s;
	transition-delay:0.3s;
}

/* SUB LAYOUT :: 상단효과 active */
#visual.active .visual-img-con{
    -webkit-transform: scale(1.0,1.0) rotate(0.002deg);
     transform: scale(1.0,1.0) rotate(0.002deg);
}
#visual.active .visual-tit{
	opacity:1.0;filter:Alpha(opacity=100);
    -webkit-transform: translateY(0px); 
     transform: translateY(0px);
}

/*  SUB LAYOUT :: 서브메뉴(스타일1) */
#topMenu01{position:relative; width:100%;height:75px; }
#topMenu01 .side-menu-inner{text-align:center; width:100%; height:74px; border-bottom:1px solid #e2e2e2; background-color: #fff;}
#topMenu01 .side-menu-inner ul{display:flex; align-items:center; justify-content:center;}
#topMenu01 .side-menu-inner ul li{margin: 0 45px; float:left; max-width:200px;} /* max-width 자유롭게 수정 */
#topMenu01 .side-menu-inner ul li > a{
	display:block; 
	display:table; 
	position:relative;
	width:100%;
	height:74px; 
	line-height:1.2; 
	color:#525252; 
	font-size:19px; 
	letter-spacing:-0.55px; 
	font-weight:400; 
	word-break:keep-all;
	-webkit-transition:all 0.3s;
	transition:all 0.3s;
}
#topMenu01 .side-menu-inner ul li > a:before{
	position:absolute;
	bottom:-1.5px;
	left:50%;
	width:0;
	height:3px;
	background-color:#0053a0;
	content:"";
	-webkit-transition:all 0.3s;
	transition:all 0.3s;
}
#topMenu01 .side-menu-inner ul li > a > span{display:table-cell; vertical-align:middle;}
#topMenu01 .side-menu-inner ul li > a:hover, 
#topMenu01 .side-menu-inner ul li.on > a{color:#0053a0;}
#topMenu01 .side-menu-inner ul li > a:hover:before, 
#topMenu01 .side-menu-inner ul li.on > a:before{width:100%; margin-left:-50%;}

/* SUB LAYOUT :: 서브메뉴 Fixed (공통) */
@media all and (min-width:1025px){
	.fixed-sub-menu.top-fixed .side-menu-inner{position:fixed; top:0px; left:0px; z-index:9999;}
}

/* SUB LAYOUT :: 모바일메뉴(공통)  */
#topMenuM01,
#topMenuM02{display:none;}

/*  SUB LAYOUT :: 컨텐츠 레이아웃 */
#content:not(.wide){padding:100px 0 150px}
#content.wide{padding:100px 0 155px}

/*  SUB LAYOUT :: 상단정보 (공통) */
#contentInfoCon{position:relative; margin:0 auto 40px; text-align:center;}
#contentInfoCon .content-tit{font-size:48px; font-weight:700; letter-spacing:-0.5px; color:#2e2e2e; }
#contentInfoCon.surface_treatment_medicine-con{margin:0 auto;}
#contentInfoCon.surface_treatment_medicine-con, #contentInfoCon.automatic_plating_equipment-con{display: none;}

/* ****************** MODAL LAYERPOPUP ********************** */
/* modal layer */
.modal-fixed-pop-wrapper{display:none; overflow-y:scroll; overflow-x:hidden;  position:fixed; top:0px; left:0px; width:100%; height:100%; z-index:9999; background:#000; background:rgba(0,0,0,0.8);}
.modal-fixed-pop-inner{position:absolute; display:table; width:100%; height:100%; text-align:center;}
.modal-inner-box{ position:relative; display:table-cell; vertical-align:middle;}
.modal-loading{position:absolute; top:50%; left:50%; margin:-25px 0 0 -25px; z-index:10000;}
.modal-inner-content{text-align:left;}
.loading {
  display: inline-block;
  width: 50px;
  height: 50px;
  border: 8px solid rgba(255,255,255,.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 1s ease-in-out infinite;
  -webkit-animation: spin 1s ease-in-out infinite;
}
@keyframes spin {
  to { -webkit-transform: rotate(360deg); transform: rotate(360deg); }
}
@-webkit-keyframes spin {
  to { -webkit-transform: rotate(360deg); transform: rotate(360deg);  }
}
/* modal layer content */
.footer-modal-content{position:relative; width:96%; max-width:1000px; margin:20px auto; }
.footer-modal-content h1{font-size:24px; font-weight:600; letter-spacing:-0.5px; text-align:center; padding:0 50px 20px; color:#fff;}
.modal-close-btn{position:absolute; top:-6px; right:-6px; color:#fff; }
.modal-close-btn i{font-size:38px;}
.modal-close-btn i:hover {color:#fff}
.footer-inner-box{padding:30px; background-color:#fff; }
.footer-inner{padding:20px; height:400px; overflow-y:auto; overflow-x:hidden; border:1px solid #ddd; }

/* ****************** 사이트맵 ********************** */
/* -------- 사이트맵 01 -------- */
/* 사이트맵 01 */
.sitemap-wrapper{padding:30px; background-color:#fff;}
.sitemap-wrapper > ul{display:table; width:100%; table-layout:fixed;}
.sitemap-wrapper > ul > li{display:table-cell; vertical-align:top; text-align:center;}
.sitemap-wrapper > ul > li > h2{color:#191919; margin:0 2% 20px 2%; padding:15px; font-size:18px; background-color:#f2f2f2;  letter-spacing:-1.0px; margin-bottom:20px; font-weight:500;}
.sitemap-wrapper > ul > li .sitemap-2dep {padding:0 5% 20px;}
.sitemap-wrapper > ul > li .sitemap-2dep a{display:block; padding:10px 0; color:#666; font-size:14px; font-weight:400; line-height:1.2em;}
.sitemap-wrapper > ul > li .sitemap-2dep a:hover{color:#000; }

/* -------- 사이트맵 02 -------- */
/* 사이트맵 02 :: Layout */
#sitemapContent{	
	position:fixed; 
	top:0; left:0; right:0; bottom:0; 
	opacity:0;filter:Alpha(opacity=0); 
	visibility:hidden;   
	z-index:-1;
	-webkit-transition:all 0.3s  0.5s;
	transition:all 0.3s  0.5s;
}
#sitemapInnerCon{position:absolute; top:0; left:0; bottom:0; right:100px; border-right:1px solid #ddd; }
#sitemapContent .sitemap-bg-box{position:absolute; top:0px; left:0px; width:100%; height:100%;}
#sitemapContent .visual-intro-item{float:left; position:relative; height:100%;}
#sitemapContent .visual-intro-item:before{
	position:absolute;  left:0; top:0px; width:1px; height:0; content:""; background-color:#ddd; z-index:1; 
}
#sitemapContent .visual-intro-item:first-child:before{display:none}
#sitemapContent .visual-intro-item:after{	
	content:""; 
	position:absolute; right:0; top:0px; 
	width:100%; height:100%; 
	background: #333; 
	-webkit-transition: width .6s cubic-bezier(0.47, 0, 0.31, 1.04) 0.2s;
	transition: width .6s cubic-bezier(0.47, 0, 0.31, 1.04) 0.2s ;
}
#sitemapContent .sitemap-close-btn{position:absolute; top:40px; right:40px;}
#sitemapContent .sitemap-close-btn i{font-size:20px; color:#222;}

/* 사이트맵 02 :: 메뉴리스트 */
.sitemap-wrapper-style02{height:100%; }
.sitemap-wrapper-style02 > ul{overflow:hidden; position:relative; z-index:1; top:50%; transform:translateY(-50%);}
.sitemap-wrapper-style02 > ul > li{overflow:hidden; float:left; width:20%;height:100%;}
.sitemap-wrapper-style02 > ul > li > h2{overflow:hidden; color:#191919; font-size:18px; letter-spacing:-1.0px; margin:0% 15% 40px; font-weight:600; }
.sitemap-wrapper-style02 > ul > li:hover > h2{color:#f57f20;}
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a{
	overflow:hidden; position:relative; display:block;  padding:20px 15%; color:#777; font-size:15px; letter-spacing:-0.15px; font-weight:400; line-height:1.2;
	-webkit-transition:all 0.3s;-moz-transition:all 0.3s;-o-transition:all 0.3s;-ms-transition:all 0.3s;transition:all 0.3s
}
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a:after{
	position:absolute; top:0; left:0; width:0; content:""; height:100%; background:#f57f20;
	-webkit-transition:all 0.3s;-moz-transition:all 0.3s;-o-transition:all 0.3s;-ms-transition:all 0.3s;transition:all 0.3s
}
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a span{position:relative; z-index:1;}
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a .gnb-icon{display:none;}
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a:hover{color:#fff; }
.sitemap-wrapper-style02 > ul > li .sitemap-2dep a:hover:after{width:100%; }
.sitemap-wrapper-style02 ul li span{
	display:block; opacity:0;filter:Alpha(opacity=50);
	-webkit-transform:translateX(-5%);
	transform:translateX(-50%);
	transition: transform .8s cubic-bezier(0.47, 0, 0.31, 1.04) 0s, opacity .8s cubic-bezier(0.47, 0, 0.31, 1.04) 0s; 
}
/* 사이트맵 open */
#sitemapContent.open{
	opacity:1.0;filter:Alpha(opacity=100); 
	visibility:visible; 
	z-index:99999; 
	background-color:#fff;
	-webkit-transition:all 0.3s  0s; 
	transition:all 0.3s 0s;
}
#sitemapContent.open .visual-intro-item:before{height:100%;}
#sitemapContent.open .visual-intro-item:after {width:0;}
#sitemapContent.open .visual-intro-item {
	-webkit-transform: scaleX(1);
	transform: scaleX(1); 
	transform-origin:right top; 
	transition-property: transform;
}
#sitemapContent.open .sitemap-wrapper-style02 ul li span{
	opacity:1.0;filter:Alpha(opacity=100);
	-webkit-transform:translateX(0);
	transform:translateX(0);
	transition: transform .8s cubic-bezier(0.47, 0, 0.31, 1.04), opacity .8s cubic-bezier(0.47, 0, 0.31, 1.04); 
}