@charset "utf-8";
@import url("./main.css");
@import url("./sub.css");
@import url("./board.css");
#wrap {
  width: 100%;
  position: relative;
  overflow: hidden;
}
/* -------- 공통클래스 -------- */
.area {
  max-width: 1200px;
  margin: 0px auto;
  position: relative;
}
/* -------- HEADER -------- */
#header {
  height: 80px;
  width: 100%;
  z-index: 21;
  position: relative;
  left: 0;
  top: 0;
  border-top: 8px solid var(--bs-primary);
  background: var(--bs-third);
  -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%;
}
#header.fixed {
  position: fixed;
}
#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 15px;
  display: flex;
  align-items: center;
  max-width: 1630px;
}
#header .logo {
  position: relative;
  z-index: 10;
  padding: 22px 0;
  display: block;
  vertical-align: middle;
  margin-right: 3.5rem;
}
#header .logo a {
  display: block;
  padding: 0px 0;
  background: url(../images/common/logo.png);
  width: 150px;
  height: 28px;
  background-size: 150px 28px;
  text-indent: -999999px;
}
#header .all_menu {
  position: relative;
  padding: 22px 0;
  display: block;
  vertical-align: middle;
  margin-right: 36px;
  text-indent: -999999px;
  background: url("../images/common/btn_header_all_menu.png") no-repeat center center;
  background-size: 24px 24px;
  width: 24px;
  z-index: 1;
}
#header .header-search-wrap {
  border: 1px solid #53635c;
  overflow: hidden;
  border-radius: 30px;
  padding: 6px 15px;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s;
  display: flex;
}
#header .header-search-wrap:focus-within {
  border: 1px solid #72807a;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s;
}
#header .header-search-wrap input {
  border: none;
  background: transparent;
  max-width: 160px;
  color: var(--bs-white);
}
#header .header-search-wrap button {
  text-indent: -999999px;
  background: url("../images/common/btn_header_search.png");
  width: 22px;
  height: 22px;
  background-size: 22px auto;
}
#header .header-etc-menu-wrap {
  display: flex;
  align-items: center;
  margin-left: auto;
}
#header .header-etc-menu-wrap p {
  margin-left: 10px;
}
#header .header-etc-menu-wrap a {
  color: var(--bs-white);
  display: flex;
  letter-spacing: -1px;
}
#header .header-etc-menu-wrap span {
  display: inline-block;
  margin-left: 5px;
}
#header .header-etc-menu-wrap img {
  width: 19px;
  height: auto;
}
#allMenu {
  position: fixed;
  top: 15px;
  left: 0;
  width: 100%;
  z-index: 20;
}
#header .allMenu-wrap {
 
    background: rgba(39, 39, 39, 0.95);
  border-radius: 30px;
  border-top-left-radius: 0;
  box-shadow: rgba(149, 157, 165, 0.3) 0px 8px 24px;
  padding: 20px 40px 40px;
  max-width: 1243px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
#header .allMenu-wrap h4 {
  border-bottom: 4px solid var(--bs-white);
  color: var(--bs-white);
  font-size: 1.4em;
  font-weight: 800;
  padding: 0 1em 0.8em;
  margin-bottom: 1em;
}
#header .allMenu-wrap .allMenu-close-btn {
  background: url(../images/common/btn_header_all_menu_close.png) no-repeat center center;
  width: 24px;
  height: 24px;
  position: absolute;
  top: 20px;
  right: 30px;
  background-size: 24px 24px;
}
#header .allMenu-wrap .allMenu-menu {
  display: flex;
}
#header .allMenu-wrap .allMenu-menu > div {
  flex: 1 1 0;
  border-right: 1px solid rgba(255, 255, 255, 0.5);
  display: flex;
  padding: 0 1.5em;
  gap: 2em
}
#header .allMenu-wrap .allMenu-menu > div:last-child {
  border-right: none;
}
#header .allMenu-wrap .allMenu-menu > div p {
  color: var(--bs-white);
  font-size: 1.4em;
  font-weight: 500;
}
#header .allMenu-wrap .allMenu-menu > div a {
  font-size: 1.1em;
  padding: 10px 0;
  display: block;
  color: var(--bs-white);
  line-height: 1.4em;
  word-break: keep-all;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
#header .allMenu-wrap .allMenu-menu > div li a {
  padding-top: 0;
}
#header .allMenu-wrap .allMenu-menu > div a:hover {
  font-weight: 600;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
/* -------- Header :: GNB(PC) -------- */
#gnb {
  position: relative;
  z-index: 9;
  transition: all 0.4s;
  margin-right: 36px;
}
#gnb > ul {
  display: flex;
}
#gnb > ul > li {
  position: relative;
  word-break: keep-all;
  /* width: 180px; */
}
#gnb > ul > li > a {
  position: relative;
  z-index: 100;
  display: block;
  height: 72px;
  line-height: 72px;
  color: #fff;
  font-size: 22px;
  padding: 0 36px;
  letter-spacing: -0.25px;
  font-weight: 800;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
#gnb.open > ul > li > a {
  color: var(--bs-white);
}
#gnb .gnb-inner {
  display: block;
}
#gnb > ul > li > a:hover, #gnb > ul > li.on > a {
  color: var(--bs-white);
  -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차 전체메뉴 */
#gnb > ul > li .gnb-2dep {
  position: absolute;
  top: 0;
  left: 0px;
  z-index: 99;
  width: 100%;
  text-align: left;
  visibility: hidden;
  padding-top: 90px;
  opacity: 0;
  filter: Alpha(opacity=0);
}
#gnb > ul > li .gnb-2dep:before {
  content: "";
  position: absolute;
  top: 70px;
  width: 0;
  left: 50%;
  height: 4px;
  background-color: var(--bs-white);
  -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 > ul > li .gnb-2dep:after {
  content: "";
  position: absolute;
  top: 5px;
  left: 0px;
  right: 0px;
  height: 0;
  opacity: 0;
  filter: Alpha(opacity=0);
      background: rgba(39, 39, 39, 0.95);
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -ms-transition: all 0.4s;
  transition: all 0.4s;
  box-shadow: rgba(149, 157, 165, 0.3) 0px 8px 24px;
  border-radius: 30px;
  border-top-left-radius: 0;
  z-index: 1;
}
#gnb > ul > li .gnb-2dep ul {
  padding: 0;
  position: relative;
  z-index: 2;
}
#gnb > ul > li .gnb-2dep ul li {
  position: relative;
  padding: 3px 18px;
  opacity: 0;
  filter: Alpha(opacity=0);
  -webkit-transition: all 0s 0s;
  -moz-transition: all 0s 0s;
  -o-transition: all 0s 0s;
  -ms-transition: all 0s 0s;
  transition: all 0s 0s;
}
#gnb > ul > li .gnb-2dep ul li a {
  display: block;
  color: var(--bs-white);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.3;
  opacity: 0.85;
  filter: Alpha(opacity=85);
}
#gnb > ul > li .gnb-2dep ul li.loadmap a {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  letter-spacing: -1px;
  padding-bottom: 0.6em;
  padding-left: 0.5em;
  position: relative;
  margin-bottom: 0.3em;
	color:var(--bs-primary);
}
#gnb > ul > li .gnb-2dep ul li.loadmap a:before {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 4px;
  height: 8px;
  background: var(--bs-primary);
}
#gnb > ul > li .gnb-2dep ul li a:hover {
  opacity: 1.0;
  filter: Alpha(opacity=100);
}
#gnb > ul > li .gnb-2dep .line {
  border-top: 1px solid rgba(255, 255, 255, 0.5);
  padding-top: 10px;
  margin-top: 5px;
}
#gnb > ul > li .gnb-2dep ul li ul li {
  padding: 3px 10px;
}
#gnb > ul > li:hover .gnb-2dep:after {
  height: calc(100% + 20px);
  opacity: 1.0;
  filter: Alpha(opacity=100);
}
#gnb > ul > li:hover .gnb-2dep:before {
  width: 80%;
  margin-left: -40%;
}
#gnb > ul > li .gnb-2dep.open {
  visibility: visible;
  opacity: 1.0;
  filter: Alpha(opacity=100);
}
#gnb > ul > li .gnb-2dep.open > ul li {
  opacity: 1.0;
  filter: Alpha(opacity=100);
  -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 > ul > li .gnb-2dep.open > ul > li:nth-child(1) {
  -webkit-transition-delay: 0.05s;
  -moz-transition-delay: 0.05s;
  -o-transition-delay: 0.05s;
  -ms-transition-delay: 0.05s;
  transition-delay: 0.05s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(2) {
  -webkit-transition-delay: 0.1s;
  -moz-transition-delay: 0.1s;
  -o-transition-delay: 0.1s;
  -ms-transition-delay: 0.1s;
  transition-delay: 0.1s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(3) {
  -webkit-transition-delay: 0.15s;
  -moz-transition-delay: 0.15s;
  -o-transition-delay: 0.15s;
  -ms-transition-delay: 0.15s;
  transition-delay: 0.15s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(4) {
  -webkit-transition-delay: 0.2s;
  -moz-transition-delay: 0.2s;
  -o-transition-delay: 0.2s;
  -ms-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(5) {
  -webkit-transition-delay: 0.25s;
  -moz-transition-delay: 0.25s;
  -o-transition-delay: 0.25s;
  -ms-transition-delay: 0.25s;
  transition-delay: 0.25s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(6) {
  -webkit-transition-delay: 0.3s;
  -moz-transition-delay: 0.3s;
  -o-transition-delay: 0.3s;
  -ms-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(7) {
  -webkit-transition-delay: 0.35s;
  -moz-transition-delay: 0.35s;
  -o-transition-delay: 0.35s;
  -ms-transition-delay: 0.35s;
  transition-delay: 0.35s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(8) {
  -webkit-transition-delay: 0.4s;
  -moz-transition-delay: 0.4s;
  -o-transition-delay: 0.4s;
  -ms-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(9) {
  -webkit-transition-delay: 0.45s;
  -moz-transition-delay: 0.45s;
  -o-transition-delay: 0.45s;
  -ms-transition-delay: 0.45s;
  transition-delay: 0.45s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(10) {
  -webkit-transition-delay: 0.5s;
  -moz-transition-delay: 0.5s;
  -o-transition-delay: 0.5s;
  -ms-transition-delay: 0.5s;
  transition-delay: 0.5s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(11) {
  -webkit-transition-delay: 0.55s;
  -moz-transition-delay: 0.55s;
  -o-transition-delay: 0.55s;
  -ms-transition-delay: 0.55s;
  transition-delay: 0.55s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(12) {
  -webkit-transition-delay: 0.6s;
  -moz-transition-delay: 0.6s;
  -o-transition-delay: 0.6s;
  -ms-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(13) {
  -webkit-transition-delay: 0.65s;
  -moz-transition-delay: 0.65s;
  -o-transition-delay: 0.65s;
  -ms-transition-delay: 0.65s;
  transition-delay: 0.65s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(14) {
  -webkit-transition-delay: 0.7s;
  -moz-transition-delay: 0.7s;
  -o-transition-delay: 0.7s;
  -ms-transition-delay: 0.7s;
  transition-delay: 0.7s;
}
#gnb > ul > li .gnb-2dep.open > ul > li:nth-child(15) {
  -webkit-transition-delay: 0.75s;
  -moz-transition-delay: 0.75s;
  -o-transition-delay: 0.75s;
  -ms-transition-delay: 0.75s;
  transition-delay: 0.75s;
}
/* -------- Header :: GNB(Mobile) -------- */
.nav-open-btn,
.nav-prev-btn {
  display: none;
}/*2025-03-24 추가*/
#gnbM {
  display: none
}
/* -------- FOOTER -------- */
#footer {
  background-color: var(--bs-white);
  border-top: 1px solid var(--bs-black);
}
/* Footer :: TOP 메뉴부분 */
.footerTop {
  border-bottom: 1px solid var(--bs-black);
}
.footerTop .footer-menu {
  display: flex;
  justify-content: center;
  align-items: center;
}
.footerTop .footer-menu > li:first-child {
  border-left: 1px solid var(--bs-gray-900);
}
.footerTop .footer-menu > li {
  border-right: 1px solid var(--bs-gray-900);
  flex: 1;
  text-align: center;
}
.footerTop .footer-menu > li > a {
  font-size: 0.9em;
  padding: 0px 5px;
  display: block;
  line-height: 32px;
  color: var(--bs-black);
  letter-spacing: -1px;
}
.footerTop .footer-menu > li > a:hover {
  color: var(--bs-primary);
}
.footerTop .family-site-box {
  position: relative;
  padding: 0px 5px;
}
.footerTop .family-site-box .family-site-open-btn {
  display: block;
  width: 100%;
  height: 32px;
  line-height: 32px;
  padding-right: 25px;
  font-size: 0.9em;
  color: var(--bs-black);
  padding: 0 30px 0 15px;
}
.footerTop .family-site-box .family-site-open-btn:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-family: xeicon;
  content: "\e936";
  color: var(--bs-black);
}
.footerTop .family-site-box.open .family-site-open-btn:after {
  transform: translateY(-50%) rotate(-180deg);
}
.footerTop .family-site-list {
  position: absolute;
  bottom: 100%;
  left: -1px;
  width: calc(100% + 2px);
  padding: 10px 15px;
  background: #fff;
  border: 1px solid var(--bs-black);
  z-index: 11;
  display: none;
}
.footerTop .family-site-list a {
  display: block;
  padding: 3px 0;
  font-size: 0.9em;
  color: var(--bs-black);
  text-align: left;
}
.footerTop .family-site-list a:hover {
  text-decoration: underline;
}
/* Footer :: 정보부분 */
.footerBottom {
  padding: 2rem 0;
}
.footerBottom h1 {
  display: block;
  margin: 0 auto 2rem;
  padding: 0px 0;
  background: url(../images/common/logo_black.png);
  width: 150px;
  height: 28px;
  background-size: 150px 28px;
  text-indent: -999999px;
}
.footerBottom .area > div {
  display: flex;
  justify-content: space-between;
}
.footerBottom .area > div > div {
  order: 1;
}
.footerBottom .footer-bottom-wrap {
  display: flex;
  justify-content: center;
  margin: 2rem 0;
  order: 2;
  align-self: flex-end;
}
.footerBottom li {
  padding: 0 15px;
}
.footerBottom p {
  font-size: 0.85em;
  line-height: 1.3;
  color: var(--bs-black);
  margin-bottom: 1rem;
}
.footerBottom p span {
  display: inline-block;
  padding: 0 5px;
}
.footerBottom p.footer-copyright {
  color: var(--bs-third);
  margin-bottom: 0;
  margin-top: 1.5rem;
}
/* Footer :: TOP버튼 */
.to-top-btn {
  position: fixed;
  bottom: -100px;
  right: 15px;
  display: block;
  width: 46px;
  height: 46px;
  background: var(--bs-primary);
  text-align: center;
  line-height: 46px;
  color: var(--bs-white);
  z-index: 20;
  opacity: 0;
  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: 25px;
  border-top-left-radius: 0;
}
.to-top-btn i {
  display: inline-block;
}
.to-top-btn.fixed {
  bottom: 15px;
  opacity: 1.0;
  filter: Alpha(opacity=100);
}