/* 기본 헤더 스타일 */
#site-header{
  position: sticky;
  top: 0;  
  z-index: 999;
	transition: background-color 0.4s ease 0.5s;
}
#site-header, #site-header * {
  box-sizing: border-box;
}
#site-header .header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  height: 76px;
  margin: 0 auto;
  max-width: 1920px;
  background-color: transparent;
}
#site-header:hover {
  transition-delay: 0s;
  background-color: white;
}
#site-header.scrolled{
  transition-delay: 0s;
  background-color: white;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

.nav-container{
	width:100%;
	height: 100%;
	display:flex;
	align-items:center;
	flex-direction: row;
}
.main-nav {
  flex: 1; 
  text-align: center;
  padding-right: 30px;
}

.main-nav .main-menu {
  display: flex;
  justify-content: center;
  gap: 110px;
}
.main-nav .main-menu > li {
  position: relative;
  cursor: pointer;
}
.logo { margin: 0;padding: 0;flex: 0 0 auto;
width:137px;display:flex;align-items: center;box-sizing: border-box;}

.main-nav .main-menu,
.mega-panel .full-menu,
.mega-panel .full-menu .sub-menu {
  list-style: none;
  margin: 0; 
  padding: 0;
}
.main-menu li::marker,
.full-menu li::marker {
  content: none;
}

#site-header .logo a {
  color: #ffffff;
  text-decoration: none;
  font-size: 25px;
}
#site-header .logo-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}
#site-header .logo-image {
  max-width: 45px;
  height: auto;
  display: block;
}
#site-header .logo-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
}
#site-header .site-title {
  font-size: 18px;
  font-weight: 700;
/*   display: block; */
  margin: 0;
}

.main-nav .main-menu a,
.mega-panel .full-menu a {
  color: #ffffff;
  text-decoration: none;
	font-size: 18px;
}

#site-header .logo a,
#site-header .logo-text,
#site-header .site-title,
#site-header .main-nav .main-menu a,
#site-header .mega-panel .full-menu a {
  transition: color 0.4s ease 0.5s; /* leave 시 0.5s delay */
}
#site-header:hover #site-header .logo a,
#site-header:hover .logo-text,
#site-header:hover .site-title,
#site-header:hover .main-nav .main-menu a,
#site-header:hover .mega-panel .full-menu a {
  color: #111111;
  transition-delay: 0s;
}
#site-header.scrolled #site-header .logo a,
#site-header.scrolled .logo-text,
#site-header.scrolled .site-title,
#site-header.scrolled .main-nav .main-menu a,
#site-header.scrolled .mega-panel .full-menu a {
  color: #111111;
}

#site-header .main-nav .main-menu a:hover,
#site-header .main-nav .main-menu a:focus,
#site-header .mega-panel .full-menu a:hover,
#site-header .mega-panel .full-menu a:focus{
  color: #0066CC !important;
  text-decoration: none;
}
#site-header .mega-panel .full-menu .current-menu-item > a,
#site-header .mega-panel .full-menu .current_page_item > a,
#site-header .mega-panel .full-menu .current-menu-ancestor > a,
#site-header .mega-panel .full-menu .current_page_parent > a {
  color: #0066CC !important;
  text-decoration: none !important;
  font-family: 'NanumSquareBold';
}
#site-header .mega-panel .full-menu .sub-menu li a:hover,
#site-header .mega-panel .full-menu .sub-menu li a:focus,
#site-header .mega-panel .full-menu .sub-menu li.current-menu-item > a {
  color: #0066CC !important;
}

#site-header .right-ham{ display: flex; flex-direction: row;align-items: center;padding: 0;box-sizing: border-box; width: 137px; }

.menu-toggle {
/*   display: none; */
  background: none;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  color: inherit;
  -webkit-tap-highlight-color:transparent;
	transition: color 0.4s ease 0.5s;
}
.overlay {
  position: fixed;
  top: 0; left: 0;
  width: 100vw; height: 100vh;
  background: rgba(0,0,0,0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  z-index: 998; /* nav-container 아래 */
}

/* 모바일 닫기 버튼 (X) */
.mobile-close {
  display: none;
  position: fixed;
  top: 18px;
  right: 20px;
  z-index: 10000;
  background: none;
  border: none;
  font-size: 25px;
  color: #333;
}

.mobile-close.open {
  display: block;
}
#close_i_btn{
	width: 25px;
    transform: rotate(45deg);
}

/* =============메가메뉴시작================== */
/* 메가메뉴 숨김 */
.mega-panel {
/*   position: absolute; */
  position:fixed;
  top: 76px;        /* 대메뉴 높이만큼 아래 */
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s ease .3s, visibility .01s linear .6s;
  box-shadow: 0 2px 3px rgba(0,0,0,0.1);
/*   padding: 20px 0; */
  pointer-events: none;  /* 숨겨졌을 때 클릭 방지 */
  z-index: 1000;
/*   border-top: 1px solid #d3d3d3; */
  background-size: cover;
}

/* hover 시 보이도록 */
.main-nav:hover .mega-panel,
.mega-panel:hover {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s, 0s;
}

/* .full-menu (Depth‑2) 정렬 */
.full-menu {
  display: flex;
  justify-content: center;
  gap: 43px;
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid #d3d3d3;
  background-color: #ffffff;
  background-repeat: no-repeat;
  background-position: 104% 110%;
  background-size: 250px auto;
}
.full-menu > .menu-item-has-children {
  /* 서브 항목을 갖는 li들 */
}
.full-menu .sub-menu {
  display: flex;
  flex-direction: column;
  gap: 18px;
/*   margin: 0; */
  margin-top: 45px;
  padding: 0;
}
.full-menu .sub-menu li {
    padding: 5px 0px;
}
.full-menu .sub-menu a {
  padding: 5px 10px;
  white-space: nowrap;
}

/* .mega-panel 안의 full-menu 에서, 직계 li의 > a(대메뉴 링크) 숨기기 */
.mega-panel .full-menu > li > a {
  display: none;
}
/* 헤더와 서브 메뉴 사이간격 */
.mega-panel .full-menu > li > ul.sub-menu {
  margin-top: 10px;
}

.full-menu > li {
  position: relative;
  /*height: 200px;*/ height: auto;
  padding-right: 15px;         
  padding-top: 25px;
  padding-bottom: 80px; 
}
.full-menu > li:last-child {
  border-right: none;    
  width: 103px;
}
/* =============메가메뉴끝================== */


@media (min-width: 1024px) {
  .mobile-header {
    display: none;      /* 모바일 메뉴 숨기기 */
  }
  .mobile-nav {
    display: none;      /* 모바일 메뉴 숨기기 */
  }
  .main-nav {
    display: flex;
	height: 100%;
    justify-content: center;
    align-items: center;
  }
  .mobile-close {
    display: none !important; /* PC 에서는 절대 안 보이게 */
  }
	
}

/* — Mobile (1023px 이하) — */
@media (max-width: 1023px) {

  .header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .menu-toggle {
    display: block;
    font-size: 2.3rem;
  }

  .nav-container {
    position: fixed;
    top: 0;
    right: -100%;           /* 화면 밖으로 숨김 */
    width: 75vw;
    height: 100vh;
	box-sizing: border-box;
    background-color: #fff;
    box-shadow: -2px 0 8px rgba(0,0,0,0.1);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 60px 0;  /* top 60px, 좌우 1.5rem, bottom 1.5rem */
    gap: 1.5rem;
    transition: right 0.3s ease;
    z-index: 9999;
  }

  .nav-container.open {
    right: 0;
  }
  .overlay.open {
    opacity: 1;
    visibility: visible;
  }
	
  .main-nav     { order: 1; }
	
  .main-nav,
  .mega-panel {
    width: 100%;
  }
  .main-nav .main-menu {
    flex-direction: column;
    gap: 1rem;
  }
  .mega-panel {
	order: 2;
    position: static;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    box-shadow: none;
    padding: 0;
  }
	
  .main-nav .main-menu {
    flex-direction: column;
    gap: 0;
  }
  .main-nav .main-menu > li {
    width: 100%;
  }
  .main-nav .main-menu .sub-menu {
    display: none;
    flex-direction: column;
    padding-left: 1rem;
    margin-top: 0.5rem;
  }
	
	/* 모바일 헤더(로고) 스타일 */
	.mobile-header {
		order: 0;
		position: absolute;
		top: 0; left: 0;
		width: 100%;
		height: 60px;         /* 메뉴 높이와 동일하게 */
		display: flex;
		align-items: center;
		padding: 0 1.5rem;
		background: #fff;
		border-bottom: 1px solid #ddd;
		z-index: 10000;       /* 메뉴 리스트보다 위 */
	  }
	.logo-mobile a {
	  font-size: 1.25rem;
	  font-weight: bold;
	  color: #2d2d2d;
	  text-decoration: none;
	}
	

/* 모바일 햄버거 메뉴- 아코디언 */
  .main-nav .main-menu, .mega-panel .full-menu, .mega-panel .full-menu .sub-menu{display:none;}
  .main-nav {
    display: none;      /* 기존 메가메뉴 숨기기 */
  }
  .mobile-nav {
	order: 3;
	width: 100%;
    display: block;     /* 모바일 전용 메뉴 보이기 */
	flex: none;              /* 남은 영역을 다 쓰고 */
    overflow-y: auto;
	max-height: calc(100vh - 140px);
	-webkit-overflow-scrolling: touch;
  }
  .mobile-menu{margin:0;padding:0;}

  /* 아코디언 기본 숨김 & 토글용 클래스 */
/*   .mobile-menu .sub-menu {
    display: none;
    flex-direction: column;
    padding-left: 2.3rem;
	padding-right: 2.3rem;
  }
  .mobile-menu .sub-menu.open {
    display: flex;
  } */
	/* ===== 모바일 아코디언: 부드러운 슬라이드 애니메이션용 CSS ===== */
	.mobile-menu .sub-menu {
	  /* display 속성 대신 높이로 숨김 처리 */
	  height: 0;
	  overflow: hidden;
	  transition: height 320ms cubic-bezier(.4,0,.2,1), opacity 200ms ease;
	  opacity: 0;
	  display: block; /* scrollHeight 정상 계산 */
	  box-sizing: border-box;
	  flex-direction: column;
	  padding-left: 1.9rem;
	  padding-right: 2.3rem;
	}

	/* 열렸을 때(시각적 상태) — JS가 inline height를 세팅 */
	.mobile-menu .sub-menu.open {
	  opacity: 1;
	  /* height은 JS에서 직접 설정(숫자 px) 또는 자동으로 처리 */
	}
	
  /* li 상태 (열렸을 때 스타일) */
	.mobile-menu .menu-item-has-children.open > a {
	  color: #222;
	}
	.mobile-menu .menu-item-has-children.open > a .menu-title {
	  color: #222;
	}

	/* 자식 항목 스타일 */
	.mobile-menu .sub-menu li a {
	  padding: 12px 0;
	  color: #222;
	  text-decoration: none;
	   font-size: var(--fs-md);
	}
	.mobile-menu .menu-section {
	  padding: 12px 20px;
	  color: #222;
	  font-weight: 700;
	  margin-top: 8px;
	  border-radius: 4px;
	}
	/* 각 대메뉴 항목(부모) 기본 스타일 */
	.mobile-menu > .menu-item {
	  display: flex;
	  flex-direction: column;
	  border-bottom: 1px solid #d3d3d3;
	  padding-bottom: 26px;
	}
	.mobile-menu > .menu-item:last-child{
		padding-bottom: 5px;
	}
	.mobile-menu .menu-item-has-children > a[aria-expanded="true"] {
	  font-family: 'NanumSquareBold';
	}
	
	/* 대메뉴(부모) 스타일 */
	  .mobile-menu > li {
		list-style: none;
		margin: 0;
		padding: 0;
	  }
	  .mobile-menu > li > a {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 20px 24px;
		padding-top: 30px;
		font-size: 16px;
		color: #2d2d2d;
		text-decoration: none;
/* 		border-bottom: 1px solid #d3d3d3; */
	  }
	.mobile-menu .sub-menu{list-style: none;}
	.mobile-menu .sub-menu li{padding: 12px 0;}
	.mobile-menu .sub-menu li:last-child{border-bottom:0px;}
}

@media (prefers-reduced-motion: reduce) {
  .mobile-menu .sub-menu,
  .mobile-menu .sub-menu.open {
    transition: none;
  }
}


/* 250929_추가 */
/* 1) 풀스크린 메가 (데스크탑 햄버거 클릭 시) */
.mega-fullscreen {
  position: fixed;
  inset: 0;            /* top:0; left:0; right:0; bottom:0 */
  display: none;       /* 기본 숨김 */
  height: 60vh;
  background: #fff;
  z-index: 10050;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.mega-fullscreen.open {
  display: block;
}
.mega-fullscreen-inner{
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 40px;
  padding: 60px 24px;
  box-sizing: border-box;
  align-items: flex-start;
}
/* 왼쪽 소개 블록 */
.mega-left {
  width: 320px;
  flex: 0 0 320px;
  padding-right: 24px;
  border-right: 1px solid #eee;
}
.mega-left .mega-logo{ margin-bottom: 18px; }
.mega-left .mega-hero h2{ font-size: 28px; margin: 0 0 8px;}
.mega-left .mega-hero p{ color:#666; font-size:14px; margin:0;}

/* 오른쪽: 메뉴 컬럼 */
.mega-right { flex: 1; padding-left: 24px; }
.mega-right-inner .full-menu {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  flex-wrap: wrap;
}
.mega-right-inner .full-menu > li {
  min-width: 160px;
  padding: 0;
  border-right: none;
}

/* 닫기 버튼 */
.mega-close {
  position: absolute;
  top: 20px;
  right: 15px;
  background: none;
  border: none;
  font-size: 2.5rem;
  cursor: pointer;
  line-height: 1;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}

/* 배경 오버레이 (공통) */
/* .header-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 10040;
  display: none;
}
.header-overlay.open { display: block; } */

.mega-hd_inner{
	display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    height: 76px;
    margin: 0 auto;
    max-width: 1920px;
    background-color: transparent;
}
.mega-hd_inner .lang-switch span{
	font-size:18px;
}
/* ---------------------
   모바일: 위에서 아래로 내려오는 메뉴 (1023px 이하)
   기존에서 변경되는 부분만
   --------------------- */

@media (max-width: 1023px) {
  /* 네비를 오른쪽에서 슬라이드하는 대신, top에서 내려오는 방식으로 변경 */
  .nav-container {
    right: 0;               /* 항상 0으로 두고 top으로 숨김 */
    left: 0;
    width: 100%;
    height: auto;
    box-sizing: border-box;
    transform: translateY(-100%);  /* 화면 밖 (위) */
    transition: transform 300ms ease;
    max-height: 100vh;
    overflow: auto;
  }
  .nav-container.open {
    transform: translateY(0);      /* 내려옴 */
  }
  /* 모바일에서 .mobile-header (로고) 는 그대로 위에 고정 */
  .mobile-header { position: fixed; top: 0; left: 0; right: 0; z-index: 10001; }

  /* 모바일의 닫기 버튼 위치 */
  .mobile-close {
	  display: none; /* 기본적으로 숨김 */
	  position: fixed;
	  top: 18px;
	  right: 20px;
	  z-index: 10002;
	  background: none;
	  border: none;
	  font-size: 25px;
	  color: #333;
	}
	.mobile-close.open {
	  display: block;
	}
	
	.right-ham .lang-switch { display: none; }

  /* 네비가 열렸을 때 nav-container 안의 lang-switch (복제된 것) 보이게 */
  .nav-container .lang-switch.mobile-clone { display: inline-block; margin: 14px 20px; }
  .nav-container.open .lang-switch.mobile-clone { display: inline-block; }

  /* 모바일에서 lang-menu 스타일 약간 보정 */
  .nav-container .lang-switch .lang-toggle { color: #2d2d2d; }

	/* 우선 모든 nav-container 내부 언어링크의 언더라인을 제거 */
  .nav-container .lang-link,
  .nav-container .lang-toggle {
    border-bottom: none !important;
    padding-bottom: 0 !important;
    text-decoration: none !important;
  }
	/* 활성(is-active)이 붙은 항목만 언더라인 보이게 */
  .nav-container .lang-link.is-active,
  .nav-container .lang-toggle.is-active{
		display: inline-block;
    padding-bottom: 4px;
	}
}

.main-nav .main-menu > li > a:focus {
  outline: none;
}
.main-nav .main-menu > li > a:focus-visible {
  outline: 2px solid #0066CC; 
  outline-offset: 4px;
}

/*251002_추가*/
/* ---------- 언어 선택 (lang-switch) ---------- */
.lang-switch {
  width:100px;
  position: relative;
  display: inline-block;
/*   z-index: 10010; */
/* header-inner 내에서 위치 제어(아래 참고) */
}
.lang-switch .lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 15px;
  color: #fff;              /* 헤더가 투명 바탕이면 흰색, 필요시 변경 */
  padding: 6px 10px;
  transition: color 0.4s ease 0.5s;
}
.lang-switch .chev { font-size: 10px; opacity: 0.9; }

/* 언어 목록 (숨김/표시) */
.lang-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 55px;
  background: #fff;
  border: 1px solid #e4e4e4;
  box-shadow: 0 6px 18px rgba(0,0,0,0.12);
  list-style: none;
  padding: 6px 0;
  margin: 0;
  border-radius: 4px;
  display: none;        /* 기본 숨김 */
  box-sizing: border-box;
	z-index: 11000;
}
.lang-menu li { padding: 0; }
.lang-menu li a {
  display: block;
  padding: 8px 12px;
  color: #222;
  text-decoration: none;
  font-size: 14px;
}
.lang-menu li a:hover,
.lang-menu li a:focus { background: #f4f4f4; outline: none; }
#site-header:hover .lang-switch .lang-toggle{color:#111; transition-delay: 0s; }
#site-header:hover .menu-toggle { transition-delay: 0s; }
#site-header .mega-fullscreen.open .mega-hd_inner,
#site-header .mega-fullscreen.open .mega-hd_inner .lang-switch,
#site-header .mega-fullscreen.open .mega-hd_inner .lang-switch .lang-toggle,
#site-header .mega-fullscreen.open .mega-close,
#site-header .mega-fullscreen.open .mobile-close,
#site-header .mega-fullscreen.open .mega-hd_inner .logo a {
	color: #111 !important;
	opacity: 1 !important;
	transition: none !important;
}
#site-header .mega-fullscreen.open .mega-hd_inner .lang-switch .lang-link{text-decoration: none;
  color: inherit;
  padding: 4px 8px;display: inline-block;}
#site-header .mega-fullscreen .mega-hd_inner{padding-right: 80px; }

header#site-header .nav-container .mega-fullscreen .lang-link.is-active,
header#site-header .right-ham .lang-link.is-active,
header#site-header .lang-switch .lang-link.is-active {
  text-decoration: none;
  text-underline-offset: 4px;
  font-family: 'NanumSquareBold';
}
/* 활성 언어: 항상 언더라인 */
#site-header .lang-link.is-active {
  display: inline-block;           /* border-bottom을 안정적으로 보여주기 위해 */
  padding-bottom: 2px;             /* 언더라인과 텍스트 사이 여백 */
  border-bottom: 2px solid #111 !important;
  text-decoration: none !important;
  transition: none !important;     /* hover/transition 영향 차단 */
}
/* 활성 언어의 hover 상태도 동일하게 유지 */
#site-header .lang-link.is-active:hover,
#site-header .lang-link.is-active:focus {
  border-bottom-color: #111 !important;
  outline: none;
}

/* 열림 상태 클래스 */
.lang-switch.open .lang-menu { display: block; }
.lang-switch.open .lang-toggle { background: rgba(255,255,255,0.03); }

/* ---------- header-inner 플렉스 순서 조절(햄버거 끝 배치) ---------- */
/* header-inner 기본이 display:flex 인 경우에만 작동합니다 */
#site-header .header-inner > .logo      { order: 1; }
#site-header .header-inner .nav-container { order: 2; flex: 1 1 auto; } /* 가운데 메뉴가 남는 공간 차지 */
#site-header .header-inner .right-ham{order: 3;}

/* 작은 화면(모바일)에서 언어 스위치와 햄버거 배치 */
@media (max-width: 1023px) {
  /* 모바일에서 header-inner는 top 고정일 때, .mobile-header와 충돌하지 않도록 조정 */
  .lang-switch .lang-toggle { color: #2d2d2d; } /* 모바일에서는 글자색 조정 */
  #site-header .header-inner .nav-container { order: 4; } /* 메뉴 컨테이너는 아래로 */
  #site-header .header-inner .logo { order: 1; }
  #site-header .header-inner .right-ham{order: 2; justify-content: flex-end;}
}

/* 색상/디자인: 투명 헤더에서 흰색 텍스트, 스크롤/hover 시 바뀌는 경우 처리 */
#site-header { color: #fff; }
#site-header.scrolled, #site-header:hover { color: #111; }
#site-header.scrolled .lang-switch .lang-toggle,
#site-header.scrolled .menu-toggle,
#site-header.scrolled .logo a { color: #111; }

/* 간단 반응형: 언어박스가 화면 밖으로 나가지 않도록 우측 경계 체크 */
.lang-menu { right: auto; left: 0; }
@media (min-width: 1400px) {
  /* 넓은 화면에서 메뉴가 화면 오른쪽 끝에 너무 가깝다면 조정 가능 */
}


/*251014_추가*/
/* ---------------------------
   Mobile: header 안에 X버튼 정렬 및 언어 위치 보정
   (1023px 이하에만 적용)
   --------------------------- */
@media (max-width: 1023px) {

  /* mobile header: logo | lang-switch | close(X) */
  .mobile-header {
    display: flex;
    align-items: center;
    justify-content: space-between; /* logo 시작, lang 다음, close는 absolute로 오른쪽에 둠 */
    gap: 12px;
    padding: 0 56px 0 24px; /* 오른쪽 여유를 둬서 close 아이콘이 겹치지 않게 */
    box-sizing: border-box;
    height: 60px; /* 기존과 동일 */
  }

  .mobile-header .logo-mobile {
    flex: 0 0 auto;
  }

  /* 언어 버튼을 로고 옆(가운데 방향)으로 위치 */
  .mobile-header .lang-switch {
    margin-left: 8px;
    order: 2;
    display: flex;
    gap: 8px;
    align-items: center;
  }
  /* 언어 토글 내부 스타일(간단 조정) */
  .mobile-header .lang-switch .lang-toggle {
    padding: 6px 4px;
    font-size: 15px;
    color: #2d2d2d;
  }

  /* 모바일 X 버튼을 mobile-header 내부로 이동했을 때의 스타일 */
  .mobile-header .mobile-close {
    position: absolute;               /* mobile-header가 fixed 이므로 absolute로 오른쪽에 배치 */
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10003;
    background: none;
    border: none;
    display: none;                    /* JS에서 header로 이동 시 .open-in-header 클래스 추가하여 보이게 함 */
    padding: 6px;
    cursor: pointer;
  }
  /* 열렸을 때 보이게 하는 클래스 */
  .mobile-header .mobile-close.open-in-header {
    display: block;
  }

  /* 모바일 메뉴가 열렸을 때 nav-container는 top에서 내려오는 방식(기존 변경 유지) */
  .nav-container {
    padding-top: 60px; /* 모바일헤더 높이만큼 패딩을 줘서 header와 겹치지 않게 */
  }

  /* nav-container 내부의 복제된 lang-switch 가 있다면 header에 있는 것과 겹치지 않게 숨김 처리 */
  .nav-container .lang-switch.mobile-clone {
    display: none;
  }

	/* 모바일 메뉴: hover / focus */
	#site-header .mobile-nav .mobile-menu a:hover,
	#site-header .mobile-nav .mobile-menu a:focus,
	#site-header .nav-container.open .mobile-menu a:hover,
	#site-header .nav-container.open .mobile-menu a:focus {
	  color: #0066CC ;
	  text-decoration: none ;
	}

	/* 모바일 메뉴: 현재 활성 메뉴(워드프레스 클래스) */
	#site-header .mobile-nav .mobile-menu .current-menu-item > a,
	#site-header .mobile-nav .mobile-menu .current_page_item > a,
	#site-header .mobile-nav .mobile-menu .current-menu-ancestor > a,
	#site-header .mobile-nav .mobile-menu .current_page_parent > a,
	#site-header .nav-container.open .mobile-menu .current-menu-item > a {
	  color: #0066CC ;
	  text-decoration: none ;
	  font-family: 'NanumSquareBold' ;
	}
	#site-header .mobile-nav .mobile-menu .current-menu-ancestor > a,
	#site-header .mobile-nav .mobile-menu .current_page_parent > a,
	#site-header .mobile-nav .mobile-menu .menu-item-has-children > a {
	  color: #222; 
	  text-decoration: none;
	}
}

/*251014_추가 끝*/

/*251014_스타일수정*/
/* --- 풀스크린 메가 전용 --- */
header#site-header .nav-container .mega-fullscreen {
	min-height: 550px;
}
header#site-header .nav-container .mega-fullscreen .full-menu{
	border-top:none; gap: 0px; align-items: stretch;

}
header#site-header .nav-container .mega-fullscreen .full-menu a:hover,
header#site-header .nav-container .mega-fullscreen .full-menu a:focus,
header#site-header .nav-container .mega-fullscreen .full-menu .current-menu-item > a {
  color: #0066CC !important;
}
header#site-header .nav-container .mega-fullscreen .full-menu > li {
  flex: 1 1 0;
  padding: 8px 24px 8px 6%;
  box-sizing: border-box;
  min-width: 160px;
  position: relative;
  min-height: 330px;
}
/* 컬럼 사이 분리선 (첫 컬럼 제외) */
header#site-header .nav-container .mega-fullscreen .full-menu > li + li {
  border-left: 1px solid #e8e8e8;
}
/* 각 컬럼의 제목 (링크) */
header#site-header .nav-container .mega-fullscreen .full-menu > li > a {
  display: block;
  font-family: 'NanumSquareBold';
/*   margin-bottom: 12px; */
  color: #111;
  text-decoration: none;
  font-size: 24px;
}

/* 서브메뉴 스타일 */
header#site-header .nav-container .mega-fullscreen .full-menu > li ul {
  list-style: none;
  padding: 0;
  margin-top: 35px;
  gap:0px;
}
header#site-header .nav-container .mega-fullscreen .full-menu > li ul li {
  margin-bottom: 8px; padding: 8px 0px;
}
header#site-header .nav-container .mega-fullscreen .full-menu > li ul li a {
  color: #111;
  text-decoration: none;
  font-size: 18px;
  display: inline-block;
  padding: 0;
}

/*en-header*/
.eng-header .full-menu{gap:0;}
.eng-header .full-menu > li:last-child{width: 177px;}
.eng-header .full-menu > li{padding-right: 30px;}
.eng-header .full-menu > li:first-child{padding-right: 6px;}
header#site-header.eng-header .nav-container .mega-fullscreen .full-menu > li{padding: 8px 24px 8px 3%;}