@charset "utf-8";
@import url("./font.css");
/* layout */
body, table, th, td, button, select, input, textarea {
  font-family: 'Pretendard', "돋움", Dotum, Arial, sans-serif;
  font-size: 18px;
  color: #666;
  -webkit-text-size-adjust: none;
}
body {
  background-color: #fff;
}
#wrap {
  overflow: hidden;
  width: 100%;
  min-width: 320px;
  position: relative;
}
#bo_v_share {
  display: none
}
/* ****************** 공통클래스 ********************** */
.area {
  max-width: 1500px;
  position: relative;
  margin: 0px auto;
}
.area-1320 {
  max-width: 1320px;
  position: relative;
  margin: 0px auto;
}
.clearfix {
  *zoom: 1;
}
.clearfix:after {
  clear: both;
  display: block;
  content: "";
}
.table-layout {
  display: table;
  width: 100%;
  height: 100%;
}
.table-cell-layout {
  display: table-cell;
  width: 100%;
  height: 100%;
  vertical-align: middle;
}
.blind {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 1px;
  font-size: 0;
  line-height: 0
}
.text-ellipsis {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* ****************** HEADER ********************** */
#header {
  height: 96px;
  width: 100%;
  z-index: 99999;
  position: fixed;
  left: 0%;
  top: 0px;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
#headerInnerWrap {
  position: relative;
  width: 100%;
  z-index: 99999;
}
#headerInner {
  position: relative;
  margin: 0px auto;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: padding 0.3s;
  -moz-transition: padding 0.3s;
  -o-transition: padding 0.3s;
  -ms-transition: padding 0.3s;
  transition: padding 0.3s;
  padding: 0 2%;
}
#header .logo {
  position: relative;
  z-index: 100;
  padding: 30px 0;
  display: inline-block;
  vertical-align: middle;
}
#header .logo a {
  display: block;
  padding: 0px 0;
  background: url(../images/logo.png);
  width: 198px;
  height: 37px;
  text-indent: -999999px;
}
.header-util-box {
  position: absolute;
  top: 0%;
  right: 2%;
  z-index: 100;
  vertical-align: middle;
  display: flex;
  height: 100%;
}
.header-util-box a {
  display: block;
  vertical-align: middle;
  color: #fff;
  width: 57px;
  text-align: center;
  font-size: 1.2em;
  line-height: 96px;
}
#header.fixed {
  background: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
}
#header.fixed .logo a,
#header.open .logo a {
  background: url(../images/logo_b.png);
}
#header.fixed .header-util-box a ,
#header.open .header-util-box a  {
  color: #000;
}
/* -------- Header :: GNB(PC) -------- */
.gnb-overlay-bg {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0);
  z-index: 9997;
}
#gnb {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 99;
  transition: all 0.4s;
  text-align: center;
}
#gnb .area > ul {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
#gnb .area > ul > li {
  position: relative;
  float: left;
  word-break: keep-all;
  width: 140px
}
#gnb .area > ul > li > a {
  position: relative;
  z-index: 100;
  display: block;
  height: 96px;
  line-height: 96px;
  text-align: center;
  color: #fff;
  font-size: 23px;
  padding: 0 10px;
  letter-spacing: -0.25px;
  font-weight: 400;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
#gnb.open .area > ul > li > a {
  color: #000;
}
#gnb .gnb-inner {
  display: block;
}
#header.fixed #gnb .area > ul > li > a {
  color: #000;
}
#gnb .area > ul > li > a:hover, #gnb .area > ul > li.on > a {
  color: #009dbc !important;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s;
}
/* GNB :: 2차 전체메뉴 */
#gnbBg {
  overflow: hidden;
  position: absolute;
  left: 0%;
  top: 0;
  width: 100%;
  height: 0;
  background: #fff;
  z-index: 98;
  -webkit-transition: height 0.3s ease-in-out;
  transition: height 0.3s ease-in-out
}
#gnb .area > ul > li .gnb-2dep {
  position: absolute;
  top: 96px;
  left: 0px;
  z-index: 99;
  width: 100%;
  text-align: center;
  opacity: 0;
  filter: Alpha(opacity=0);
  height: 0;
  -webkit-transition: all 0.3s 0s;
  transition: all 0.3s 0s;
  visibility: hidden;
}
#gnb .area > ul > li .gnb-2dep ul {
  padding: 13px 0px;
}
#gnb .area > ul > li .gnb-2dep ul li {
  position: relative;
}
#gnb .area > ul > li .gnb-2dep ul li a {
  display: block;
  padding: 10px 0px;
  color: #666;
  font-size: 15px;
  letter-spacing: -0.5px;
  font-weight: 300;
  line-height: 1.3;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s
}
#gnb .area > ul > li:hover .gnb-2dep ul li a {
  color: #000;
  font-weight: 500;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s
}
#gnb .area > ul > li:hover .gnb-2dep ul li a:hover {
  color: #009dbc;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s
}
#gnb .area > ul > li .gnb-2dep ul li a span {
  display: inline-block;
  position: relative;
}
#gnb .area > ul > li .gnb-2dep ul li a span:before {
  position: absolute;
  bottom: -4px;
  left: 50%;
  display: block;
  content: '';
  width: 0;
  height: 1px;
  background-color: #009dbc;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
#gnb .area > ul > li .gnb-2dep ul li a:hover span:before {
  width: 100%;
  margin-left: -50%;
}
#gnb.open #gnbBg {
  height: 250px
}
#gnb.open .area > ul > li .gnb-2dep {
  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;
  -moz-transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
  -ms-transition: height 0.5s ease-in-out, opacity 0.5s ease-in-out 0.2s;
  -o-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;
}
#gnb.open .area > ul > li .gnb-2dep {
  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;
}
#gnb .area > ul > li .gnb-2dep:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 0;
  filter: Alpha(opacity=0);
  z-index: -1;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
#gnb .area > ul > li:hover .gnb-2dep:after {
  opacity: 1;
  filter: Alpha(opacity=100);
}
#gnb .area > ul > li .gnb-2dep:before {
  content: "";
  position: absolute;
  top: 0px;
  width: 0;
  left: 50%;
  height: 3px;
  background-color: #009dbc;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
  z-index: 10;
}
#gnb .area > ul > li:hover .gnb-2dep:before {
  width: 105px;
  margin-left: -52.5px;
}
/* over했을때 */
#gnb > ul > li .gnb-2dep.open ul li {
  opacity: 1.0;
  filter: Alpha(opacity=100);
  -webkit-transition: all 0.8s;
  -moz-transition: all 0.8s;
  -o-transition: all 0.8s;
  -ms-transition: all 0.8s;
  transition: all 0.8s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(1) {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(2) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(3) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
/* -------- Header :: GNB(Mobile) -------- */
.nav-open-btn {
  display: none;
}
#gnbM {
  display: none
}
/* ****************** FOOTER ********************** */
#footer {
  background-color: #FFF;
  border-top: 1px solid #dedede;
}
#footerInner {
  position: relative;
}
/* -------- FOOTER :: 하단 -------- */
#footerBottom {
  padding: 40px 2%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
#footerBottom h1 {
  width: 14%;
}
#footerBottom h1 img {
  max-width: 100%;
}
.footer-address {
  width: 60%
}
.footer-link a {
  color: #000;
  font-size: 1.1em;
  display: inline-block;
  padding: 0 8px;
}
.footer-address p {
  color: #575757;
  font-size: 0.9em;
  line-height: 1.5em;
  padding-bottom: 15px;
}
.footer-address p.link-area {
  background: #dcdcdc;
  padding: 7px 7px;
  display: inline-block;
  margin-bottom: 15px;
}
.footer-address span {
  display: inline-block;
  margin: 0 14px
}
.footer-address strong {
  font-weight: 500;
  color: #333;
}
.footer-address .link {
  display: none;
}
.footer-copyright {
  font-size: 0.9em;
  margin: 0 8px;
  color: #969696;
}
.footer-link {
  width: 25%;
  color: #000;
}
.footer-link p {
  text-align: right;
}
.to-top-btn {
  position: fixed;
  bottom: -100px;
  right: 1%;
  display: block;
  width: 74px;
  height: 74px;
  background-color: #404348;
  text-align: center;
  line-height: 74px;
  color: #fff;
  z-index: 99;
  opacity: 0;
  -webkit-border-radius: 50px;
  -moz-border-radius: 50px;
  -o-border-radius: 50px;
  border-radius: 50px;
  filter: Alpha(opacity=0);
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -ms-transition: all 0.4s;
  transition: all 0.4s;
}
.to-top-btn i {
  display: inline-block;
}
.to-top-btn.fixed {
  bottom: 15px;
  opacity: 1.0;
  filter: Alpha(opacity=100);
}
.to-top-btn:hover {
  color: #fff;
}
/* ****************** SUB LAYOUT ********************** */
/*  SUB LAYOUT :: 비주얼 */
#visual {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 550px;
  z-index: 1;
}
#visual .visual-img-con {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-size: cover !important;
  -ms-transform: scale(1.1, 1.1);
  -o-transform: scale(1.1, 1.1);
  -moz-transform: scale(1.1, 1.1);
  -webkit-transform: scale(1.1, 1.1);
  transform: scale(1.1, 1.1);
  -webkit-transition: transform 5000ms ease-in-out;
  -moz-transition: transform 5000ms ease-in-out;
  -o-transition: transform 5000ms ease-in-out;
  -ms-transition: transform 5000ms ease-in-out;
  transition: transform 5000ms ease-in-out;
  text-align: center;
}
#visual.sub-visual-company .visual-img-con {
  background: #fff url(../images/sub_visual01.png) no-repeat center center;
}
#visual.sub-visual-business .visual-img-con {
  background: #fff url(../images/sub_visual02.png) no-repeat center center;
}
#visual.sub-visual-product .visual-img-con {
  background: #fff url(../images/sub_visual03.png) no-repeat center center;
}
#visual.sub-visual-result .visual-img-con {
  background: #fff url(../images/sub_visual04.png) no-repeat center center;
}
#visual.sub-visual-data .visual-img-con {
  background: #fff url(../images/sub_visual05.png) no-repeat center center;
}
#visual.sub-visual-cs .visual-img-con {
  background: #fff url(../images/sub_visual06.png) no-repeat center center;
}
#visual .visual-txt-con {
  position: relative;
  z-index: 1;
  display: table;
  width: 100%;
  height: 100%;
  letter-spacing: -0.5px;
  color: #fff;
  text-align: center;
}
#visual .visual-tit, #visual .visual-sub-txt {
  opacity: 0;
  filter: Alpha(opacity=0);
  -ms-transform: translateY(30px);
  -o-transform: translateY(30px);
  -moz-transform: translateY(30px);
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  -webkit-transition: opacity 1.0s, transform 1.0s;
  -moz-transition: opacity 1.0s, transform 1.0s;
  -o-transition: opacity 1.0s, transform 1.0s;
  -ms-transition: opacity 1.0s, transform 1.0s;
  transition: opacity 1.0s, transform 1.0s;
}
#visual .visual-tit {
  font-weight: 400;
  font-size: 80px;
  -webkit-transition-delay: 0.3s;
  -moz-transition-delay: 0.3s;
  -o-transition-delay: 0.3s;
  -ms-transition-delay: 0.3s;
  transition-delay: 0.3s;
  font-family: 'GongGothicLight';
}
#visual .visual-sub-txt {
  color: #fff;
  font-size: 0.9em;
  margin-top: 20px;
  font-weight: 300;
}
#visual.active .visual-img-con {
  -ms-transform: scale(1.0, 1.0) rotate(0.002deg);
  -o-transform: scale(1.0, 1.0) rotate(0.002deg);
  -moz-transform: scale(1.0, 1.0) rotate(0.002deg);
  -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);
  -ms-transform: translateY(0px);
  -o-transform: translateY(0px);
  -moz-transform: translateY(0px);
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}
#visual.active .visual-sub-txt {
  opacity: 1.0;
  filter: Alpha(opacity=100);
  -ms-transform: translateY(0px);
  -o-transform: translateY(0px);
  -moz-transform: translateY(0px);
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}
/* SUB LAYOUT :: 서브메뉴 Fixed (공통) */
#middleArea {
  position: relative;
  z-index: 10;
  padding: 0px 0 150px 0
}
.content-tit {
  font-size: 60px;
  color: #000;
  text-align: center;
  position: relative;
  padding: 0 0px;
  margin: 0 auto 70px;
    font-family: 'GongGothicLight';
	font-weight:400;
}
#topMenu01 {
 position: absolute;
    bottom: 45px;
	right:2%;
	left:2%;
	    z-index: 10;
}
#topMenu01 .side-menu-inner {
  width: 100%;background: rgba(255, 255, 255, 0.5);   
	display: flex;
    justify-content: space-between;
}
#topMenu01 .side-menu-inner p.nav {
	align-self: center;
	color:#fff;
	display:flex;
	align-items: center;
	gap:5px;
	padding-left:2%;
}
#topMenu01 .side-menu-inner p.nav i {font-size:0.8em;}
#topMenu01 .side-menu-inner ul {
  display: flex;
  align-items: center;
  border-left: none;
  justify-content: center;
}
#topMenu01 .side-menu-inner ul li {
  padding: 0;
  text-align: center;
}
#topMenu01 .side-menu-inner ul li > a {
  display: block;
  display: table;
  position: relative;
  width: 100%;
  padding: 25px 50px;
  line-height: 1.2;
  font-size: 25px;
  letter-spacing: -0.5px;
  font-weight: 200;
  color: #fff;
  word-break: keep-all;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
#topMenu01 .side-menu-inner ul li > a > span {
  display: table-cell;
  vertical-align: middle;
	position:relative;
}
#topMenu01 .side-menu-inner ul li > a:hover, #topMenu01 .side-menu-inner ul li.on > a {
  font-weight: 500;
}
#topMenu01 .side-menu-inner ul li.on > a span {font-weight:500;}
#topMenu01 .side-menu-inner ul li.on > a span:after { 
	position:absolute;
	bottom:-10px;
	left:0;
	right:0;
	height:4px;
	display:block;
	content:"";
	background:#009dbd;
}

#topMenuM01, #topMenuM02 {
  display: none;
}
#topMenu01 .cs {
    background: #009dbd url(../images/main_cs_ico.png) no-repeat calc(100% - 20px) center;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0px 70px 0px 30px;
    font-size: 23px;
}
/*  SUB LAYOUT :: 컨텐츠 레이아웃 */
#content {
  padding-top: 80px
}
ul.dot {
  text-align: left;
}
ul.dot li {
  position: relative;
  padding: 2px 0 2px 10px;
  line-height: 1.4em;
  color: #666666;
  word-break: keep-all;
}
ul.dot li:before {
  display: block;
  content: "·";
  position: absolute;
  left: 0;
  top: 3px;
}
ul.dot-bold li {
  position: relative;
  padding: 10px 0 10px 15px;
  line-height: 1.5em;
  color: #666666;
  font-weight: 300;
  word-break: keep-all;
}
ul.dot-bold li:before {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 20px;
  width: 5px;
  height: 5px;
  background: #0083cb;
  border-radius: 50%;
}
/* ****************** MODAL LAYERPOPUP ********************** */
.popup-wrap {
  background-color: rgba(0, 0, 0, .8);
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: none;
  padding: 15px;
  z-index: 99999;
}
.popup {
  width: 100%;
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  border-radius: 0px;
  overflow: hidden;
  background: #363b3e;
}
.popup-head {
  background: #009dbd;
  padding: 20px 35px;
  color: #fff;
  font-size: 1.2em;
  font-weight: 600;
}
.popup-body {
  background: #fff;
  padding: 20px;
}
.body-content.scroll {
  width: 100%;
  word-break: break-word;
  overflow-x: auto;
  min-height: 100px;
  max-height: 550px;
  padding: 20px;
  line-height: 1.4em;
}
.popup-foot {
  position: absolute;
  top: 20px;
  right: 20px;
  color: #fff;
}
.pop-btn {
  color: #ffffff;
  cursor: pointer;
}
.pop-btn i {
  color: #fff;
}