@charset "utf-8";
@import url("../css/font.css");
@import url("../css/main.css");
@import url("../css/content.css?t=1");
@import url("../css/board.css");
/* layout */
#wrap {
  overflow: hidden;
  width: 100%;
  min-width: 320px;
  position: relative;
}
/* ****************** 공통클래스 ********************** */
.area {
  max-width: 1100px;
  margin: 0px auto;
  position: relative;
}
.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;
}
/* ****************** HEADER ********************** */
#header {
  height: 90px;
  width: 100%;
  z-index: 99;
  position: relative;
}
#header.fixed {
  position: fixed;
  background: var(--bs-white);
  border-bottom: 1px solid #dddddd;
}
#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: 12px 0;
  display: inline-block;
  vertical-align: middle;
}
#header .logo a {
  display: block;
  padding: 0px 0;
  background: url(../images/logo.png);
  width: 128px;
  height: 66px;
  text-indent: -999999px;
}
.header-util-box {
  position: absolute;
  top: 50%;
  right: 2%;
  z-index: 100;
  vertical-align: middle;
  display: flex;
  transform: translateY(-50%);
  gap: 16px;
}
.header-util-box button {
  display: block;
  vertical-align: middle;
  width: 30px;
  height: 30px;
  text-indent: -999999px;
}
.header-util-box button.header-home-btn {
  background: url("../images/header_ico_home.png");
}
.header-util-box button.header-location-btn {
  background: url("../images/header_ico_location.png");
}
.header-util-box button.header-allmenu-open-btn {
  background: url("../images/header_ico_menu.png");
}
/* -------- Header :: GNB(PC) -------- */
#gnb {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 99;
  transition: all 0.4s;
  text-align: center;
}
#gnb .area {
  max-width: 90%
}
#gnb .area > ul {
  display: flex;
  justify-content: center;
}
#gnb .area > ul > li {
  position: relative;
  word-break: keep-all;
  width: 250px
}
#gnb .area > ul > li > a {
  position: relative;
  z-index: 100;
  display: block;
  height: 90px;
  line-height: 90px;
  text-align: center;
  color: var(--bs-gray-200);
  font-size: 19px;
  padding: 0;
  letter-spacing: -0.25px;
  font-weight: 700;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
#gnb .gnb-inner {
  display: block;
}
#gnb .area > ul > li > a:hover {
  color: var(--bs-primary) !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: 0px;
  width: 100%;
  height: 0;
  background: #fff;
  z-index: 98;
  -webkit-transition: height 0.3s ease-in-out;
  transition: height 0.3s ease-in-out;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
}
#gnbBg:after {
  position: absolute;
  top: 90px;
  width: 100%;
  left: 0;
  height: 1px;
  background-color: #e9e9e9;
  content: "";
  z-index: 1;
}
#gnb .area > ul > li .gnb-2dep {
  position: absolute;
  top: 90px;
  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;
  letter-spacing: -0.5px;
  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 {
  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: var(--bs-primary);
  -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: -3px;
  left: 50%;
  display: block;
  content: '';
  width: 0;
  height: 1px;
  background-color: var(--bs-primary);
  -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, #gnb .area > ul > li .gnb-2dep ul li.on a span:before {
  width: 100%;
  margin-left: -50%;
}
#gnb .area > ul > li.on > a {
  color: var(--bs-primary);
}
#gnb .area > ul > li .gnb-2dep ul li.on a {
  color: var(--bs-primary);
  font-weight: 500;
}
#gnb.open #gnbBg {
  height: 280px
}
#gnb.open .area > ul > li .gnb-2dep {
  height: 190px;
  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.open .area > ul > li:last-child .gnb-2dep {
  border-right: 1px solid #e9e9e9;
}
#gnb .area > ul > li .gnb-2dep:after {
  content: "";
  position: absolute;
  width: 1px;
  height: 100%;
  left: 0;
  top: 0;
  background: #e9e9e9;
  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 .gnb-2dep:before {
  content: "";
  position: absolute;
  top: 0px;
  width: 0;
  left: 50%;
  height: 3px;
  background-color: var(--bs-primary);
  -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: 100%;
  margin-left: -50%;
}
/* 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;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(4) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(5) {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(6) {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(7) {
  -webkit-transition-delay: 0.7s;
  transition-delay: 0.7s;
}
#gnb > ul > li .gnb-2dep.open ul li:nth-child(8) {
  -webkit-transition-delay: 0.8s;
  transition-delay: 0.8s;
}
/* 검색 오픈창 */
.header-allmenu-open-con {
  position: fixed;
  right: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  background: linear-gradient(to right, #55aa33 0%, #1a9ffc 100%);
  opacity: 0;
  filter: Alpha(opacity=0);
  visibility: hidden;
  z-index: 100;
}
.allmenu-close {
  position: absolute;
  right: 0;
  top: 0;
  width: 100px;
  height: 100px;
}
.allmenu-close button {
  background: var(--bs-dark) url("../images/header_all_menu_close.png") no-repeat center center;
  width: 90%;
  height: 90%;
  text-indent: -9999px
}
.header-allmenu-open-con .area-main {
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.header-allmenu-inner {
  width: 100%;
  margin: 0 auto;
}
.header-allmenu-open-con .area-main nav {
  width: 100%;
  text-align: left;
  padding: 10% 5%;
}
.header-allmenu-open-con .area-main a, .header-allmenu-open-con .area-main a:hover {
  -webkit-transition: all 0.8s;
  -moz-transition: all 0.8s;
  -o-transition: all 0.8s;
  -ms-transition: all 0.8s;
  transition: all 0.8s;
}
.header-allmenu-open-con .area-main nav > ul > li {
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  padding: 35px 0;
}
.header-allmenu-open-con .area-main nav > ul > li:last-child {
  border-bottom: none;
}
.header-allmenu-open-con .area-main nav > ul > li h5 {
  color: var(--bs-white);
  font-size: 2.1em;
  width: 25%;
  font-weight: 600;
  align-self: flex-start;
	font-family: 'DBDream';
}
.header-allmenu-open-con .allmenu-2dep {
  width: 75%;
}
.header-allmenu-open-con .allmenu-2dep > ul {
  display: flex;
  gap: 50px
}
.header-allmenu-open-con .allmenu-2dep > ul > li {
  padding: 5px 0;
}
.header-allmenu-open-con .allmenu-2dep a {
  color: var(--bs-white);
  font-size: 1.3em;
  font-weight: 600;
  display: block;
}
.header-allmenu-open-con .allmenu-2dep a:hover {
  color: var(--bs-white);
}
.header-allmenu-open-con.open {
  visibility: visible;
  opacity: 1.0;
  filter: Alpha(opacity=100);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
/* -------- Header :: GNB(Mobile) -------- */
.nav-open-btn {
  display: none;
}
#gnbM {
  display: none
}
/* ****************** FOOTER ********************** */
#footer {
  background:#1a1a1a;
  z-index: 10;
  position: relative;
}
#footerInner {
  position: relative;
  padding: 30px 2%;
  display: flex;
  display: -webkit-flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
/* Footer :: TOP버튼 */
.to-top-btn {
  position: fixed;
  bottom: -100px;
  right: 15px;
  display: block;
  width: 50px;
  height: 50px;
  background: var(--bs-dark);
  text-align: center;
  line-height: 50px;
  color: var(--bs-white);
  z-index: 99;
  opacity: 0;
  font-size: 1.2em;
  filter: Alpha(opacity=0);
  -webkit-transition: all 0.6s;
  -moz-transition: all 0.6s;
  -o-transition: all 0.6s;
  -ms-transition: all 0.6s;
  transition: all 0.6s;
  border-radius: 50%;
}
.to-top-btn i {
  display: inline-block;
}
.to-top-btn.fixed {
  bottom: 125px;
  opacity: 1.0;
  filter: Alpha(opacity=100);
}
#footerInner h1 {
  background: url(../images/footer_logo.png) no-repeat;
  background-size: 130px 57px;
  display: block;
  text-indent: -99999px;
  width: 130px;
  height: 57px;
}
.footer-address {
  width: calc(100% - 210px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.footer-address > div {
  width: calc(100% - 170px);
}
.footer-address p {
  color: #dbdbdb;
  line-height: 1.4em;
  font-size: 0.9em;
}
.footer-address span {
  display: inline-block;
  margin: 0 24px 0 0;
  font-weight: 400;
  position: relative;
}
.footer-copyright {
  font-weight: 300;
  margin-top: 5px;
}
#footerInner .select {
  position: relative;
  padding: 0px;
}
#footerInner .select .select-open-btn {
  display: block;
  width: 100%;
  height: 32px;
  line-height: 32px;
  color: var(--bs-gray-200);
  padding: 0 50px 0 15px;
  border-radius: 4px;
  background: var(--bs-white);
  text-align: left;
  border: 0;
}
#footerInner .select .select-open-btn:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  width: 17px;
  right: 10px;
  display: block;
  height: 4px;
  background: url(../images/icon_select.png) no-repeat center center;
}
#footerInner .select-list {
  position: absolute;
  bottom: 100%;
  left: 0px;
  width: 100%;
  padding: 15px;
  background: var(--bs-white);
  z-index: 11;
  display: none;
  border-radius: 4px;
  border-bottom: 1px solid var(--bs-gray);
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}
#footerInner .select-list a {
  display: block;
  padding: 5px 0;
  color: var(--bs-gray-200);
  font-size: 0.9em;
}
#footerInner .select-list a:hover {
  color: var(--bs-primary);
}
#visual {
  position: relative;
  width: 100%;
  height: 280px;
  z-index: 1;
}
#visual .visual-img-con {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-size: cover !important;
  text-align: center;
}
#visual.sub-visual-company .visual-img-con {
  background: #fff url(../images/sub01.png) no-repeat center center;
}
#visual.sub-visual-business .visual-img-con {
  background: #fff url(../images/sub02.png) no-repeat center center;
}
#visual.sub-visual-cs .visual-img-con {
  background: #fff url(../images/sub03.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: var(--bs-white);
}
#visual .visual-tit, #visual p {
  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;
  text-align: center;
}
#visual .visual-tit {
  font-weight: 700;
  font-size: 1.5em;
  -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: 'DBDream';
}
#visual p {
  font-weight: 300;
  font-size: 2.2em;
  -webkit-transition-delay: 0.6s;
  -moz-transition-delay: 0.6s;
  -o-transition-delay: 0.6s;
  -ms-transition-delay: 0.6s;
  transition-delay: 0.6s;
  margin-top: 1rem;
	font-family: 'DBDream';
}
#visual.active .visual-tit, #visual.active p {
  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);
}
#topMenu01 {
  line-height: 55px;
  border-top: 1px solid #cdcdcd;
  border-bottom: 1px solid #cdcdcd;
}
#topMenu01 .cm-top-menu {
  display: flex;
  align-items: center;
}
#topMenu01 .location-to-home-btn {
  padding: 0 2rem 0 0;
  background-color: transparent;
  text-align: center;
  position: relative;
}
#topMenu01 .location-to-home-btn:after {
  position: absolute;
  right: 0;
  top: 30%;
  height: 40%;
  width: 1px;
  display: block;
  content: "";
  background: #cdcdcd;
}
#topMenu01 .menu-location {
  position: relative;
  max-width: 150px;
  width: 100%;
  padding: 0 0 0 2rem;
}
#topMenu01 .menu-location > .cur-location {
  position: relative;
  display: block;
  width: 100%;
  height: 55px;
  padding: 0;
  text-align: left;
}
#topMenu01 .menu-location > .cur-location span {
  display: block;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--bs-gray-400);
  letter-spacing: -0.025em;
  padding-right: 30px;
}
#topMenu01 .menu-location > .cur-location .arrow {
  position: absolute;
  top: 50%;
  right: 0;
  width: 24px;
  line-height: 22px;
  font-size: 1.1em;
  color: #7f7f7f;
  transform: translateY(-50%);
  border: 1px solid #7f7f7f;
  border-radius: 50%;
  text-align: center;
}
#topMenu01 .menu-location.open > .cur-location .arrow {
  transform: rotate(-180deg);
  margin-top: -12px;
}
#topMenu01 .menu-location.location2 {
  max-width: 250px;
}
/* dep1 */
#topMenu01 .menu-location .location-menu-con {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background-color: var(--bs-white);
  z-index: 11;
  border: 1px solid #cdcdcd;
  border-top: 0;
}
#topMenu01 .menu-location .location-menu-con li:first-child {
  padding-top: 10px;
}
#topMenu01 .menu-location .location-menu-con li:last-child {
  padding-bottom: 10px;
}
#topMenu01 .menu-location .location-menu-con li a {
  display: block;
  padding: 7px 2rem;
  color: var(--bs-black);
  word-break: keep-all;
  line-height: 1.5;
  opacity: 0.7;
}
#topMenu01 .menu-location .location-menu-con li.on {
  position: relative;
}
#topMenu01 .menu-location .location-menu-con li a:hover {
  opacity: 1;
}
#topMenu01 .menu-location .location-menu-con li.on a {
  opacity: 1;
  font-weight: 700;
}
/* SUB LAYOUT :: 서브메뉴 Fixed (공통) */
#subContent {
  padding: 5% 0;
}
.content-tit {
  margin-bottom: 4rem;
  position: relative;
  font-size: 2.3rem;
  font-weight: 500;
  color: var(--bs-gray-200);
  text-align: center;
  padding-top: 100px;
	background-repeat:no-repeat;
	background-position:center top;
	font-family: 'DBDream';
}
.content-tit.content-tit01 {background-image: url("../images/title_icon_01.png");}
.content-tit.content-tit02 {background-image: url("../images/title_icon_02.png");}
.content-tit.content-tit03 {background-image: url("../images/title_icon_03.png");}
.content-tit.content-tit04 {background-image: url("../images/title_icon_04.png");}
.content-tit.content-tit05 {background-image: url("../images/title_icon_05.png");}
.content-tit.content-tit06 {background-image: url("../images/title_icon_06.png");}
.content-tit.content-tit07 {background-image: url("../images/title_icon_07.png");}
.content-tit.content-tit08 {background-image: url("../images/title_icon_08.png");}
.content-tit.content-tit09 {background-image: url("../images/title_icon_09.png");}
.content-tit.content-tit10 {background-image: url("../images/title_icon_10.png");}
.content-tit.content-tit11 {background-image: url("../images/title_icon_11.png");}

.content-subtit span {font-family: 'DBDream';display:inline-block;position:relative;font-size: 1.8rem;
  font-weight: 600;
  color: var(--bs-gray-200);}
.content-subtit span:after {position:absolute;right:-10px;top:-10px;    background: linear-gradient(to right, #55aa33 0%, #1a9ffc 100%);border-radius:50%;width:8px;height:8px;display:block;content:"";}

.dots li {
  padding: 7px 0 7px 13px;
  position: relative;
  line-height: 1.4em;
  word-break: keep-all;
	font-size:1.1em;
}
.dots li:before {
  position: absolute;
  top: 17px;
  left: 0px;
  width: 5px;
  height: 5px;
  background-color: #5199dd;
  border-radius: 50%;
  display: block;
  content: "";
}
.mb_view {
  display: none;
}