@charset "utf-8";

/* ====================================================================================================================== */
/*                                                  Header Style Set                                                      */
/* ====================================================================================================================== */
/* Default : dropdown nav.dark menu */
header.header { color:#fff; height:50px; margin:0 0 20px 0; background:#1e1e2d; border-bottom:3px solid #bb845b; box-shadow: 0 2px 3px #a4a4a4; }
header.header>div.container { height: 100%; }
nav.dark { height: 100%; display: flex; justify-content: space-between; align-items: center; }
nav.dark > ul.nav { height: 100%; }
nav.dark > ul.nav > li { padding:10px 3px; display: flex; align-items: center; position: relative; }
nav.dark > ul.nav > li.logo { padding:10px 20px 10px 10px; }
nav.dark > ul.nav > li > a { color:#fff; font-weight:400; background-color:transparent; }
nav.dark > ul.nav > li:hover > a,
nav.dark > ul.nav > li:focus > a { color:#fff; background-color:rgba(0,0,0,0.03); }
nav.dark > ul.nav > li.active > a { color:#888; background-color:#fff; }
nav.dark > ul.nav > li.active:hover > a { color:#fff; background-color:rgba(0,0,0,0.03); }
nav.dark > ul.nav > li > a { padding-right:25px; -webkit-border-radius: 0; -moz-border-radius: 0; border-radius: 0; font-size:14px; font-weight:600; }
/* nav.dark > ul.nav > li > a:after{ display: block; content: "\f107"; position: absolute; top: 50%; right: 10px; margin: -5px 0 0; font-family: FontAwesome; font-size: 12px; opacity: .3; line-height: 1em; -webkit-transition: -webkit-transform .2s  ease-in; -moz-transition: -moz-transform .2s ease-in; -ms-transition: -ms-transform .2s ease-in; -o-transition: -o-transform .2s ease-in; transition: transform .2s ease-in; } */
nav.dark > ul.nav > li > a:after { content: ""; display: inline-block; margin-left: .255em; vertical-align: .255em; border-top: .3em solid #777;
  border-right: .3em solid transparent; border-bottom: 0; border-left: .3em solid transparent; }
nav.dark > ul.nav > li > a.single:after{ content: ""; }
nav.dark li:hover > ul.dropdown-menu { display:block; }
nav.dark .dropdown-submenu { position: relative; min-width: 150px; }
nav.dark .dropdown-submenu > .dropdown-menu { top: 0; left: 100%; margin-top: -2px;	margin-left: -1px; }
nav.dark .dropdown-submenu:hover > .dropdown-menu { display: block; }
nav.dark .dropdown-submenu:hover > a:after { border-left-color: #fff; }
nav.dark .dropdown-submenu.pull-left { float: none; }
nav.dark .dropdown-submenu.pull-left > .dropdown-menu { left: -100%; margin-left: 10px; }
nav.dark ul.dropdown-menu {top:47px;padding: 0;	border:0;	border-top:2px solid #bb845b;	min-width: 150px;	background: #333;	box-shadow: rgba(0,0,0,0.2) 0 6px 12px;
	-webkit-transition: top .4s ease;	-o-transition: top .4s ease;	transition: top .4s ease;	-webkit-border-radius: 0;	-moz-border-radius: 0;	border-radius: 0; }
nav.dark ul.dropdown-menu li > a { color:#ccc; font-size:13px; padding:10px; letter-spacing:-0.08em; display: block; }
nav.dark ul.dropdown-menu li > a:hover { color:#fff; background-color: rgba(0,0,0,0.15); }
nav.dark ul.dropdown-menu li > a.dropdown-toggle { background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAoCAMAAADJ7yrpAAAABlBMVEX///+ZmZmOUEqyAAAAAXRSTlMAQObYZgAAAB1JREFUeNrtyLERAAAAATH2X9oQf1RSRkd4tPyuKhKVAAqFOyFzAAAAAElFTkSuQmCC') no-repeat right; }
nav.dark ul.dropdown-menu li > a.dropdown-toggle:hover { color:#fff; background-color: rgba(0,0,0,0.15); }
nav.dark ul.dropdown-menu li.divider { margin:0; overflow: hidden; background-color: rgba(255,255,255,0.1); }
nav.dark ul.dropdown-menu li > a > i { margin-right:10px; }
nav.dark .mega-menu { position:inherit; }
nav.dark .mega-menu > ul { max-width: calc(100% - 30px); width: 100%; top: inherit; margin: 0 0 0 15px; }

nav.dark .dropdown-toggle::after {
  display: none;
  margin-left: .255em;
  vertical-align: .255em;
  content: "";
  border-top: .3em solid;
  border-right: .3em solid transparent;
  border-bottom: 0;
  border-left: .3em solid transparent;
}

/* GNB(header menu) style - 1 */
header.style1 { position: fixed; top: 0; left: 0; z-index: 1000; width: 100%; background-color: #fff; box-shadow: 0 2px 3px 0 rgba(0,0,0,.16); transition: all .2s ease; }
header.style1>div.container { position: relative; top: 0; z-index: 5; min-height: 80px; transition: all .55s ease; transition-delay: .45s; opacity: 1; }
header.style1 .header-bg { border-top: 1px solid transparent; height: 0; transition: all ease 0.25s; }
header.style1 .header-bg.on { border-top: 1px solid #e9e9e9; }
header.style1 .logo { position: absolute; top: 0; bottom: 0; left: 20px; width: 150px; height: fit-content; z-index: 2; margin: auto; }
header.style1 .logo a { display: block; width: 100%; height: 100%; }
header.style1 nav.menu { position: absolute; top: 0; left: 0; width: 100%; min-height: 80px; z-index: 1; text-align: center; }
header.style1 nav.menu ul.gnb-main { display: inline-flex; flex-direction: row; justify-content: center; align-items: flex-start; margin-left: -100px; }
header.style1 nav.menu ul.gnb-main>li { position: relative; }
header.style1 nav.menu ul.gnb-main>li.current>a { color:#007a9c; }
header.style1 nav.menu ul.gnb-main>li:hover { border-bottom: 1px solid #555; }
header.style1 nav.menu ul.gnb-main>li:hover>a { color:#007a9c; }
header.style1 nav.menu ul.gnb-main>li>a { display: block; padding: 0 24px; height: 100%; font-size: 16px; font-weight: 600; line-height: 80px; letter-spacing: -0.32px;
  text-align: center; color: #003057; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2 { display: none; position: absolute; z-index: 1; top: 80px; left: 0; width: 200px; padding-top: 25px; padding-bottom: 25px; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2>ul { display: flex; flex-direction: column; justify-content: start; align-items: flex-start; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2>ul li { text-align: left; width: 100%; min-width: 160px; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2>ul li a { display: block; width: 100%; padding: 8px 25px; font-size: 15px; font-weight: normal; line-height: 1;
  letter-spacing: -0.28px; text-align: left; color: #003057; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2>ul li a:hover { color:#007a9c; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2>ul li>strong { display: block; width: 100%; padding: 8px 25px; font-size: 15px; font-weight: 600; line-height: 1;
  letter-spacing: -0.28px; text-align: left; color: #003057; }
header.style1 nav.menu ul.gnb-main>li>div.depth-2.dept2-multi>ul { -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-direction: row;
  -ms-flex-direction: row;  flex-direction: row; }

/* GNB(header menu) style - 2 */
header.style2 { position: fixed; top:0; left:0; right:0; z-index: 100; width:100%; height: 62px; display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; background: #fff; border-bottom: 1px solid rgba(80, 80, 80, 0.2);  background-color: #fff; box-shadow: 0 11px 10px -10px rgba(17, 17, 17, 0.16); }
header.style2 .logo { width: 150px; }
header.style2 .logo a { display: block; width: 100%; height: 100%; }
header.style2 .gnb { flex: 1 1 0%; display: flex; justify-content: center; height: 100%; }
header.style2 .gnb>ul.main-menu { display: flex; flex-direction: row; height: 100%; }
header.style2 .gnb>ul.main-menu>li>.menu-wrap { position: relative; height: 100%; }
header.style2 .gnb>ul.main-menu>li>.menu-wrap>a { padding: 0px 20px; position: relative; height: 100%; display: flex; align-items: center; color: #333; }
header.style2 .gnb>ul.main-menu>li>.menu-wrap>a>p { font-weight: 500; font-size: 16px; line-height: 26px; }
header.style2 .gnb>ul.main-menu>li>.menu-wrap>ul { display: flex; flex-direction: row; align-items: center; column-gap: 32px; white-space: nowrap; position: absolute;
  z-index: 99; left: 0px; top: calc(100% + 1px); height: 61px; padding: 0px 20px; background-color: rgb(255, 255, 255); }
header.style2 .gnb>ul.main-menu>li>.menu-wrap>ul.sub-menu>li>a { font-weight: 400; font-size: 14px; line-height: 30px; color: rgb(51, 51, 51); }
header.style2 .gnb>ul.main-menu>li:not(:hover):not(:has(:focus-visible)) ul.sub-menu:not(:focus):not(:focus-within):not(caption) { position: absolute !important; }
header.style2 .gnb>ul.main-menu>li:not(:hover) ul.sub-menu { width: 1px !important; height: 1px !important; padding: 0px !important; margin: -1px !important;
  overflow: hidden !important; clip: rect(0px, 0px, 0px, 0px) !important; white-space: nowrap !important; border: 0px !important; }
header.style2 .gnb>ul.main-menu>li:hover { box-shadow: rgb(26, 124, 210) 0px -2px inset; }
header.style2 .gnb>ul.main-menu>li:hover::after { overflow: hidden; content: ""; position: absolute; background-color: rgb(255, 255, 255); inset: 100% 0px -62px;
  height: 62px; border-top: 1px solid rgb(230, 230, 230); box-shadow: rgba(0, 0, 0, 0.16) 0px 11px 10px -10px; }
header.style2 .gnb>ul.main-menu>li>.menu-wrap>ul.sub-menu>li>a:hover { color: rgb(26, 124, 210); text-decoration: underline; text-underline-position: under; }
header.style2 .menu button { width: 26px; height: 21px; border-top: 3px solid #333; border-bottom: 3px solid #333; position: relative; top: -2px; margin-left: 20px; }
header.style2 .menu button:after { content: ''; width: 100%; height: 3px; background-color: #333; position: absolute; top:0; bottom: 0; left:0; margin: auto; }
header.style2 .login { display: inline-flex; align-items: center; padding-right: 15px; }
header.style2 .login>button { border: 1px solid #999; border-radius: 20px; background-color: rgba(0,0,0,0); padding: 6px 10px; font-size: 12px; font-weight: 500;
  color:#555; margin-left: 6px; transition: all ease-in 0.15s; }
header.style2 .login>button:hover { border-color: rgb(26, 124, 210); color:rgb(26, 124, 210); }
header.style2 .login>button.bt-logout { border-color: #d16a6a; color: #d16a6a; }
header.style2 .login>button.bt-logout:hover { background-color: #d16a6a; color:#fff; }
header.style2 .login>.member-info { padding: 0 12px; }
header.style2 .login>.member-info>span {  font-size: 13px; display: block; text-align: center; line-height: 15px; }
header.style2 .login>.member-info>span:nth-child(2) { font-size: 11px; color: #636363; border-top: 1px solid #808080; }

/* GNB(header menu) style - 3 */
header.style3 { position: absolute; top:0; width: 100%; height: 130px; background: #fff; z-index: 111; }
header.style3 .hd-top { height: 80px; }
header.style3 .hd-top>div.container{ display: flex; align-items: center; justify-content: space-between; padding: 0px 20px 10px; }
header.style3 .hd-top .logo { width: 160px; }
header.style3 .hd-top .logo a { display: block; width: 100%; height: 100%; }
header.style3 .hd-top .func { width: 30%; }
header.style3 .hd-top .func ul { display: flex; justify-content: right; }
header.style3 .hd-top .func ul>li { position: relative;  margin-left: 10px; padding-left: 10px; }
header.style3 .hd-top .func ul>li::before { content: ""; display: block; clear: both; position: absolute; left: 0; top: 10px; width: 1px; height: 12px; background: #d3d3d3; }
header.style3 .hd-top .func ul>li:first-child::before { display: none; }
header.style3 .hd-top .func ul>li>a { color:#555;  font-size: 14px; display: block; padding: 5px 1px; }
header.style3 .hd-top .func ul>li>a:hover { color: #00223f; }
header.style3 .hd-top .func .input-group input { border: 2px solid #00223f; font-size: 14px; }
header.style3 .hd-top .func .input-group button { width: 50px; background-image: url('/images/icons/btn_search.png'); background-size: 40%; background-position: center;
  background-repeat: no-repeat; background-color: #00223f; color:#fff; text-indent: -99999%; overflow: hidden; border-top-right-radius: .375rem;
  border-bottom-right-radius: .375rem; }
header.style3 .hd-top .func .input-group button:hover { opacity: 0.85; }
header.style3 nav.menu { position: relative; background-color: #00223f;  overflow: hidden; }
header.style3 nav.menu .gnb-bg { position: absolute; left: 0; top: 50px; width: 100%; height: calc(100% - 50px); z-index: 1; background: #fff;
  border-bottom: 1px solid #eee; transition: height ease 0.25s; }
header.style3 nav.menu .container { position: relative; z-index: 10; }
header.style3 nav.menu ul.gnb-main { position: relative; display: flex; flex-wrap: wrap; height: auto; margin-right: 50px; }
header.style3 nav.menu ul.gnb-main>li { width: 20%; }
header.style3 nav.menu ul.gnb-main>li>a { color:#fff; position: relative; display: block; height: 50px; line-height: 50px; text-align: center; font-size: 20px;
  font-weight: 500; letter-spacing: -1px; transition: all .3s ease; }
header.style3 nav.menu ul.gnb-main>li>a:hover { background:#0966b6; }
header.style3 nav.menu ul.gnb-main ul.menuBox { display: none; height: calc(100% - 50px); padding: 10px 0; border-right: 1px solid #eee; }
header.style3 nav.menu ul.gnb-main ul.menuBox.active { background-color: #f2f5f7; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a { display: block; height: 44px; padding: 10px 20px; font-size: 15px; font-weight: 600; color:#00223f;
  background: transparent; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a:hover,
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep.hov>a { background: #00223f; color:#fff; font-weight: 500; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a.depth { position: relative; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a.depth:before  { content:""; position: absolute; width:11px; height:1px; right:25px; top:20px; background:#555; z-index:2;}
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a.depth:after { content:""; position: absolute; width:1px; height:11px; right:30px; top:15px; background:#555; 
  transition:all .15s ease; z-index:2; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep.hov>a.depth:before,
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep.hov>a.depth:after,
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a.depth:hover::before, 
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a.depth:hover::after { background:#fff; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep.hov>a.depth:after { transform: rotate(90deg); ;}
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>a+ul.group { display: none; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>ul.group>li { padding: 10px 10px 10px 20px; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>ul.group>li::before { left:10px; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>ul.group>li>a { font-size: 14px; color:#333; font-weight: 500; }
header.style3 nav.menu ul.gnb-main ul.menuBox>li.dep>ul.group>li>a:hover { text-decoration: underline; }
header.style3 a.sitemap { display: block; position: absolute; right: 20px; top: 0px; width: 50px; height: 50px; padding: 7px 14px 14px 14px; }
header.style3 a.sitemap:hover { background:#0966b6; }
header.style3 a.sitemap span { display:block; width:70%; margin:7px 0 0; height:2px; background:#fff; }
header.style3 a.sitemap span:first-child {width:100%;}
header.style3 a.sitemap span:last-child {width:100%;}
header.style3 a.sitemap:hover span{width:100%;}
header.style3 a.sitemap, 
header.style3 a.sitemap span { transition:all .3s ease; }

/* GNB(header menu) style - 4 */
header.style4  { height: 62px; overflow: hidden; }
header.style4 .navbar-logo {padding: 15px;	color: #fff; }
header.style4 nav.menu { background-color: #5161ce;padding: 0px; }
header.style4 nav.menu .gnb { position: relative; padding: 0 20px 0 40px; }
header.style4 nav.menu .gnb .navbar-nav { padding: 0px;	margin: 0px; flex-direction: row; }
header.style4 nav.menu .gnb .navbar-nav li { float: left; }
header.style4 nav.menu .gnb .navbar-nav li a { color: rgba(255,255,255,0.5); font-size: 15px; font-weight: 600; display: block; padding: 20px 20px; transition-duration:0.6s;
	transition-timing-function: cubic-bezier(0.68, -0.1, 0.265, 1.55); position: relative; }
header.style4 nav.menu .gnb .navbar-nav li.active>a { color: #5161ce; background-color: transparent;	transition: all 0.7s; }
header.style4 .hori-selector {display:inline-block;	position:absolute; height: 100%; top: 0px; left: 0px;	transition-duration:0.6s;
	transition-timing-function: cubic-bezier(0.68, -0.1, 0.265, 1.55); background-color: #fff;	border-top-left-radius: 15px;	border-top-right-radius: 15px; margin-top: 10px; }
header.style4 .hori-selector .right,
header.style4 .hori-selector .left { position: absolute; 	width: 25px;height: 25px;	background-color: #fff;	bottom: 10px; }
header.style4 .hori-selector .right{ right: -25px; }
header.style4 .hori-selector .left{	left: -25px; }
header.style4 .hori-selector .right:before,
header.style4 .hori-selector .left:before{ content: '';  position: absolute; width: 50px; height: 50px; border-radius: 50%; background-color: #5161ce; }
header.style4 .hori-selector .right:before{ bottom: 1px; right: -25px; }
header.style4 .hori-selector .left:before{ bottom: 1px; left: -25px; }
@media (max-width: 991px){
	header.style4 nav.menu .gnb .navbar-nav li a { padding: 12px 30px; }
	header.style4 .hori-selector{	margin-top: 0px; margin-left: 10px; border-radius: 0;	border-top-left-radius: 25px;	border-bottom-left-radius: 25px; }
	header.style4 .hori-selector .left,
	header.style4 .hori-selector .right{ right: 10px;	}
	header.style4 .hori-selector .left{	top: -25px;	left: auto; }
	header.style4 .hori-selector .right{ bottom: -25px;	}
	header.style4 .hori-selector .left:before{ left: -25px;	top: -25px;	}
	header.style4 .hori-selector .right:before{	bottom: -25px; left: -25px;	}
}