@charset "utf-8";
/* 기본프로그램 사용자모듈 메뉴 - PC */
.all_m_btn {padding:10px; background:#323337;}
.all_m_btn img {position:absolute; top:28%; left:15px; width:10%; max-width:40px; cursor:pointer;}
.all_m_btn .mutit {text-align:center; font-weight:900; font-size:26px; color:#fff;}
.pro_m_wrap {display:none; font-family:'Nanum Gothic', sans-serif; transition:all 0.3s linear;}
.pro_m_wrap .m_menu {width:200px;}
.pro_m_wrap .bg_black {display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.7); z-index:-1;}


/* 기본프로그램 사용자모듈 메뉴 - MOBILE */
.pro_m_wrap .subleftmenu {
	list-style:none;
	margin:0;
	padding:0;
}
.pro_m_wrap .subleftmenu li {
	border-bottom:1px solid #515155;
	background:#323337;
}
.pro_m_wrap .subleftmenu a {
	display:block;
	color:#b5b2b2;
	font-size:14px;
	padding:11px 5px 11px 15px;
	font-family:'Noto Sans KR';
}
.sub_title_m{
	font-size:28px !important;
	font-weight:bold;
	color:#fff !important;
	padding:12px 5px 12px 15px !important;
}
.pro_m_wrap .subleftmenu a:hover {
	background:#307dd4;
	color:#fff;
}
.sub_title_m:hover {
	background:#323337 !important;
	cursor:default;
}

@media all and (max-width:999px){
	.pro_m_wrap {display:block; position:absolute; left:-100%; top:0; z-index:999;}
	.pro_m_wrap.view {left:0;}
}

/* basic */
.inner{width:100%; max-width:1400px; margin:0 auto; position:relative;}

@media all and (max-width:1400px){
	.inner{width:93.75%;}
}

/* 햄버거 메뉴 */
#header .m_btn {display:none; width:24px; margin:0 auto; text-align:right; cursor:pointer; }
#header .m_btn i{display:inline-block; width:100%; height:2px; margin:3px 0; background:#000; transition:all 0.5s;}
#header .m_btn i:nth-of-type(2){width:84%;}
#header .m_btn.on i:nth-of-type(1){margin:11px 0 -2px; transform:rotate(-45deg); -webkit-transform:rotate(-45deg); -moz-transform:rotate(-45deg); -ms-transform:rotate(-45deg);-o-transform:rotate(-45deg);}
#header .m_btn.on i:nth-of-type(2){width:0; margin:0;}
#header .m_btn.on i:nth-of-type(3){margin:0 0 11px; transform:rotate(45deg); -webkit-transform:rotate(45deg); -moz-transform:rotate(45deg); -ms-transform:rotate(45deg); -o-transform:rotate(45deg);}


@media all and (max-width:1024px){
	#header .gnb{display: none;}
	#header .m_btn{display: inline-block;}
}

/* 모바일 메뉴 */
.m_menu_bg {z-index:101; position:fixed; left:0; top:0; display:none; width:100%; height:100%; background:rgba(0,0,0,.7); cursor:pointer; }
#m_menu {z-index:102; position:fixed; right:-100%; top:0; width:500px; max-width:80%; height:100%; background-color:#fff; box-sizing:Border-box; transition:all 0.5s; overfloW-y:auto;}
#m_menu.on {right:0; }
#m_menu .top_box {position:relative; padding:10px; box-sizing:border-box; }
#m_menu .top_box .close_btn {position:absolute; right:20px; top:calc(50% - 15px); width:30px; height:30px; }
#m_menu .top_box .close_btn i {display:block; width:100%; height:2px; background-color:#333; }
#m_menu .top_box .close_btn i:first-of-type {-webkit-transform:rotate(45deg) translate(9px,9px); -moz-transform:rotate(45deg) translate(9px,9px); -ms-transform:rotate(45deg) translate(9px,9px); -o-transform:rotate(45deg) translate(9px,9px); transform:rotate(45deg) translate(9px,9px); }
#m_menu .top_box .close_btn i:last-of-type {-webkit-transform:rotate(-45deg) translate(-7px,8px); -moz-transform:rotate(-45deg) translate(-7px,8px); -ms-transform:rotate(-45deg) translate(-7px,8px); -o-transform:rotate(-45deg) translate(-7px,8px); transform:rotate(-45deg) translate(-7px,8px); }
#m_menu .login_box {padding:20px 0; background-color:#292929; text-align:center; }
#m_menu .login_box a {position:relative; padding:0 30px; font-size:20px; color:#fff; letter-spacing:-0.04em; }
#m_menu .login_box a:first-of-type:before {content:''; position:absolute; right:-1px; top:calc(50% - 7px); width:2px; height:15px; background-color:#fff; }
#m_menu .gnb_box {border-top:1px solid #ddd; }
#m_menu .gnb_box > ul > li {border-bottom:1px solid #dddddd; }
#m_menu .gnb_box > ul > li > a {position:relative; display:block; padding:20px 20px; font-size:20px; font-weight:bold; color:#222222; letter-spacing:-0.04em; box-sizing:border-box; }
#m_menu .gnb_box .depth02 {display:none; padding:10px 0; background-color:#000; }
#m_menu .gnb_box .depth02 li a {position:relative; display:block; padding:7px 20px; font-size:18px; color:#fff; letter-spacing:-0.04em; box-sizing:border-box; }


/* #header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; transition: all 0.3s; background: transparent; }
#header.scrolled { background: white; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); }
#header .inner { max-width: 1400px; margin: 0 auto; padding: 0 20px; height: 80px; display: flex; align-items: center; justify-content: space-between; }
#header .logo { display: block; width: 112px; transition: transform 0.3s; }
#header .logo:hover { transform: scale(1.05); }
#header .logo img { width: 100%; height: auto; filter: brightness(0.75) invert(1); transition: filter 0.3s; }
#header.scrolled .logo img { filter: brightness(1) invert(0); }
#header .gnb { display: flex; }
#header .gnb > ul { display: flex; align-items: center; gap: 32px; list-style: none; margin: 0; padding: 0; }
#header .gnb > ul > li > a { color: white; font-size: 14px; font-family: 'Pretendard', sans-serif; font-weight: 500; text-decoration: none; transition: color 0.3s; text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1); }
#header.scrolled .gnb > ul > li > a { color: #374151; text-shadow: none; }
#header .gnb > ul > li > a:hover { color: #FF6B6B; }
#header .contact_btn { display: flex; align-items: center; gap: 8px; background: #FF6B6B; color: white; padding: 10px 20px; border-radius: 9999px; font-size: 14px; font-family: 'Pretendard', sans-serif; font-weight: 700; text-decoration: none; transition: all 0.3s; box-shadow: 0 4px 14px rgba(255, 107, 107, 0.3); }
#header .contact_btn:hover { background: #FF5252; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(255, 107, 107, 0.4); }
#header .contact_btn .icon_mail { width: 16px; height: 16px; background: url('/img/icon_mail.png') no-repeat center; background-size: contain; }
#header .m_btn { display: none; width: 28px; height: 28px; flex-direction: column; justify-content: space-between; cursor: pointer; }
#header .m_btn i { width: 100%; height: 3px; background: white; transition: all 0.3s; border-radius: 2px; }
#header.scrolled .m_btn i { background: #374151; }
.m_menu_bg { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.5); z-index: 1998; }
#m_menu { position: fixed; top: 0; right: -100%; width: 300px; height: 100%; background: white; z-index: 1999; transition: right 0.3s; overflow-y: auto; }
#m_menu.on { right: 0; }
#m_menu .top_box { display: flex; align-items: center; justify-content: space-between; padding: 20px; border-bottom: 1px solid #E5E7EB; }
#m_menu .top_box img { width: 100px; }
#m_menu .close_btn { width: 32px; height: 32px; position: relative; cursor: pointer; }
#m_menu .close_btn i { position: absolute; width: 24px; height: 2px; background: #374151; top: 50%; left: 50%; border-radius: 2px; }
#m_menu .close_btn i:first-child { transform: translate(-50%, -50%) rotate(45deg); }
#m_menu .close_btn i:last-child { transform: translate(-50%, -50%) rotate(-45deg); }
#m_menu .gnb_box { padding: 20px 0; }
#m_menu .gnb_box > ul { list-style: none; margin: 0; padding: 0; }
#m_menu .gnb_box > ul > li { border-bottom: 1px solid #F3F4F6; }
#m_menu .gnb_box > ul > li > a { display: block; padding: 16px 20px; color: #374151; font-size: 16px; font-family: 'Pretendard', sans-serif; font-weight: 500; text-decoration: none; transition: color 0.3s; }
#m_menu .gnb_box > ul > li > a:hover { color: #FF6B6B; }
#m_menu .m_contact_btn { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 20px; padding: 12px; background: #FF6B6B; color: white; border-radius: 12px; font-size: 16px; font-family: 'Pretendard', sans-serif; font-weight: 700; text-decoration: none; transition: background 0.3s; }
#m_menu .m_contact_btn:hover { background: #FF5252; }
#m_menu .m_contact_btn .icon_mail { width: 16px; height: 16px; background: url('/img/icon_mail.png') no-repeat center; background-size: contain; }

@media (max-width: 768px) {
  #header .inner { height: 70px; padding: 0 15px; }
  #header .logo { width: 80px; }
  #header .gnb { display: none; }
  #header .contact_btn { display: none; }
  #header .m_btn { display: flex; }
} */