@charset "utf-8";

/* header, footer, subpage 공통 네비게이션 ui */

/* 로딩중 */
#loading {
	width: 100%; height: 100%;
	position: fixed; top: 0; bottom: 0;
	background: rgba(255,255,255,0.6);
	z-index: 1000;
}
#loading #loading_image{
	position: absolute; top: 50%; left: 50%;
	text-align: center;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
#loading #loading_image > img {
	width: 150px;
}
#loading #loading_image span {
	display: block;
	padding: 0px 5px;
	font-weight: bold; font-size: 1.2rem;
}

/* 브라우저 버전 알림 */
#browser {
	padding: 20px;
	position: relative;
	text-align: center; color: #fff;
	background-color: #d93b3b;
}
#browser a {
	font-weight: bold; color: #f9c461;
}
#browser .upgradeinfo_close {
	display: inline-block;
	padding: 0 5px; margin-left: 10px;
}

/* 에러페이지 */
.error_wrap {
	width: 100%; height: 100%; min-height: 768px;
	position: relative;
	background-color: #f1f1f1;
}
.error_box {
	width: 700px; height: auto;
	margin-left: -350px; margin-top: -95px;
	position: absolute; top: 50%; left: 50%;
	text-align: left; color: #727272;
}
.error_box img {
	display: block;
	width: 250px; height: auto;
	position: absolute; right: 0; top: -50px;
	opacity: 0.4;
}
.error_box strong {
	display: block;
	margin-bottom: 20px;
	font-size: 2rem; color: #464646;
}
.error_box p {
	margin-bottom: 20px;
	font-size: 1.2rem; line-height: 1.8em;
}
.error_box a {
	display: inline-block;
	padding: 10px 20px;
	font-size: 1.1rem; color: #fff;
	background: #727272;
	-webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;
}
.error_box a:hover {
	background-color: #454545;
}


/* 페이지 전체 영역 */
.page_wrap {
	position: relative;
	min-height: 100vh; 
	overflow-x: hidden;
	background-color: #fafafa;
}
.page_wrap.mainpage {
	background-color: #f9f9f9;
	background-image: url(../../images/client/main/bg_mainpage.png);
	background-size: cover;
	background-position: center;
}
.page_wrap.mainpage > h1, h2, h3, h4, h5, h6, p, li, strong, a { 
	font-family: NanumSquareR, ' 나눔스퀘어', '맑은고딕', 'Apple SD Gothic Neo', Arial, sans-serif;
}

/* skip-nav */
.skip_nav {
	width: 100%;
	text-align: center;
}
.skip_nav a {
	display: block;
	width: 100%;
	padding: 1em;
	position: absolute; top: -200px;
	color: #fff;
}
.skip_nav a:focus {
	top: 0; left: 0;
	background-color: rgba(0,0,0,0.5);
}

/* header */
.nav_wrap {
	position: relative;
}
.header_wrap {
	position: fixed; top: 0; left: 0; z-index: 10;
	width: 100%;
}
.header_top {
	position: relative; z-index: 100;
}
.header_top > .grid_content {
	position: relative;
	display: flex;
    margin-bottom: 15px;
	height: 130px;
	align-items: center;
}
.header_logo {
	position: absolute; top: 50%; left: 50%;
	width: 140px; height: 70px;
	-webkit-transform: translate(-50%,-50%);
	-moz-transform: translate(-50%,-50%);
	-o-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
.header_logo a {
	display: block;
}
.header_logo img {
	display: block;
	width: 100%;
}
.btn_log {
	display: inline-block;
	padding: 0 15px;
	margin-right: 20px;
	height: 30px;
	color: #fff; font-size: 1.1rem; line-height: 30px; letter-spacing: -0.03em;
    font-family: NotoKr, sans-serif;
	background-color: #00427c; 
	-webkit-border-radius: 15px;
	-moz-border-radius: 15px;
	border-radius: 15px;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
.btn_log::before {
	content: "";
	display: inline-block;
	margin-right: 10px;
	width: 11px; height: 26px;
	vertical-align: top;
	background-repeat: no-repeat;
	background-position: center;
}
.btn_log.login::before {
	background-image: url(../../images/client/common/icon_login.png);
}
.btn_log.logout::before {
	background-image: url(../../images/client/common/icon_logout.png);
}
.user_info {
	display: inline-block;
	padding-left: 25px;
	color: #fff;
    font-family: NotoKr, sans-serif;
	background: url(../../images/client/common/icon_user.png) no-repeat left center;
}
.user_info strong {
	font-weight: 600; vertical-align: text-top;
}
.btn_admin {
	position: absolute; top: 50%; right: 40px;
	padding-left: 27px;
	color: #fff; font-weight: 400; line-height: 26px; font-size: 1.1rem; 
    font-family: NotoKr, sans-serif;
	background: url(../../images/client/common/icon_admin.png) no-repeat left center;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
}
.btn_menu {
	display: none;
}
/*.btn_searchunified {
	position: absolute; top: 50%; right: 0;
	display: inline-block;
	margin-top: -10px;
	width: 20px; height: 20px;
	font-size: 0; line-height: 0;
	background: url(../../images/client/common/icon_search.png) no-repeat center;
}*/

.header_bottom {
	position: relative; z-index: 50; 
	text-align: center;
    overflow: visible;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_wrap {
	height: auto;
}
.gnb_list {
	font-size: 0; line-height: 0; text-align: center;
}
.gnb_1depth {
	position: relative;
	display: inline-block;
	margin-right: 15px;
	width: 95px;
}
.gnb_1depth:last-child {
	margin-right: 0;
}
.gnb_1depth > a {
	position: relative;
	display: block;
	letter-spacing: -0.03em; font-size: 1.6rem; color: #1e2446;
	line-height: 1em; font-weight: 500;
    font-family: NotoKr, sans-serif; 
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_1depth > a::before {
	content: "";
	position: relative; z-index: 10;
	display: block;
	margin: 0 auto 5px;
	width: 70px; height: 70px;
	background-repeat: no-repeat;
	background-position: center;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_menu1 > a::before {
	background-image: url(../../images/client/common/icon_gnb01.png);
}
.gnb_menu2 > a::before {
	background-image: url(../../images/client/common/icon_gnb02.png);
    background-position: center 13px;
}
.gnb_menu3 > a::before {
	background-image: url(../../images/client/common/icon_gnb03.png);
    background-position: 15px center;
}
.gnb_menu4 > a::before {
	background-image: url(../../images/client/common/icon_gnb04.png);
}
.gnb_menu5 > a::before {
	background-image: url(../../images/client/common/icon_gnb05.png);
    background-position: 12px center;
}
.gnb_menu6 > a::before {
	background-image: url(../../images/client/common/icon_gnb06.png);
    background-position: 16px center;
}
.gnb_menu7 > a::before {
	background-image: url(../../images/client/common/icon_gnb07.png); 
}
.gnb_menu8 > a::before {
	background-image: url(../../images/client/common/icon_gnb08.png);
    background-position: 10px center;
}
.gnb_menu9 > a::before {
	background-image: url(../../images/client/common/icon_gnb09.png);
}
.gnb_menu10 > a::before {
	background-image: url(../../images/client/common/icon_gnb10.png);
}
.gnb_1depth > a::after {
    content: "";
    position: absolute; top: 0; left: 50%; z-index: -1;
    display: block;
    width: 70px; height: 70px;
    background-color: #fff;
    -webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;
    -webkit-transform: translateX(-50%);
	-moz-transform: translateX(-50%);
	-o-transform: translateX(-50%);
	transform: translateX(-50%);
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

.gnb_1depth a {
	display: block;
}
.gnb_1depth > a > span {
	display: block;
	padding: 0 5px 10px;
	color: #fff; line-height: 28px; font-size: 1.15rem; font-weight: 500;
	font-family: Notokr, sans-serif;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}
.gnb_2depth {
	position: absolute; top: 115px; left: 50%;
	display: none;
	margin-left: -95px;
	padding: 13px 0;
	width: 190px; height: auto;
	background-color: #fff;
	-webkit-border-radius: 10px 40px 10px 10px;
	-moz-border-radius: 10px 40px 10px 10px;
	border-radius: 10px 40px 10px 10px;
	box-shadow: 0 3px 10px rgba(0,0,0,0.2);
	overflow: hidden;
}
.gnb_2depth > li {
	position: relative;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_2depth > li::before {
	position: absolute; left: 0;
	content: "";
	display: inline-block;
	width: 0px; height: 100%;
	background-color: #3a6c98;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_2depth a {
	position: relative;
	padding: 10px 3px; 
	display: block;
	word-break: keep-all; letter-spacing: -0.05em;
	font-size: 1.1rem; line-height: 1.3em; color: #000; font-weight: 500;
	font-family: Notokr, sans-serif;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	-o-transition: all 0.2s;
	transition: all 0.2s;
}
.gnb_more {
	position: static;
	display: inline-block;
	margin-top: 3px; margin-left: 3px;
	width: 13px; height: 13px;
	font-size: 0; line-height: 0; vertical-align: top;
	background-image: url(../../images/client/common/icon_gnb_more.png); 
	background-position: center;
	background-size: contain;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
} 

/* 사이트맵 */
.btn_sitemapmenu {
	position: absolute; top: 50%; right: 0;
	display: inline-block;
	width: 20px; height: 13px;
	font-size: 0; line-height: 0; vertical-align: top;
	background: url(../../images/client/common/icon_sitemap.png) no-repeat center;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	transform: translateY(-50%);
}
.sitemap {
	position: fixed; top: -100%; left: 0; z-index: 100;
	width: 100%; 
	transition: 0.6s;
}
.sitemap.on {
	top: 0;
}
.sitemap > .inner {
	position: relative;
	height: 100vh; max-height: 100vh;
	font-size: 0; line-height: 0;
    background: linear-gradient(180deg, rgba(243,164,230,1) 0%, rgba(1,209,253,1) 100%);
	border-radius: 0 0 100% 100% ;
	-webkit-transition: 0.4s ease 0.2s;
	-moz-transition: 0.4s ease 0.2s;
	-o-transition: 0.4s ease 0.2s;
	transition: 0.4s ease 0.2s;
}
.sitemap.on > .inner { 
	-webkit-border-radius: 0;
	-moz-border-radius: 0;
	border-radius: 0;
}
.btn_sitemap {
	position: absolute; top: 50px; right: 0; z-index: 12;
	display: block;
	width: 16px; height: 16px;
	font-size: 0; line-height: 0;
	background: url(../../images/client/common/btn_sitemapclose.png) no-repeat center;
	background-size: contain;
}
.sitemap .grid_content {
	position: relative;
	padding-bottom: 20px;
	max-height: 100%;
	overflow-y: auto;
	opacity: 0;
}
.sitemap.on .grid_content {
	opacity: 1;
	-webkit-transition: 0.8s ease-out 0.6s;
	-moz-transition: 0.8s ease-out 0.6s;
	-o-transition: 0.8s ease-out 0.6s;
	transition: 0.8s ease-out 0.6s;
}
.sitemap .gnb_2depth {
	position: relative; top: inherit; left: inherit;
	display: inline-block;
	margin: 80px 0 0;
	padding: 0 20px;
	width: 20%;
	font-size: 1.5rem; line-height: 1.5em; vertical-align: top;
	background: transparent;
	box-shadow: none;
} 
.sitemap .gnb_tit {
	position: relative; z-index: 10;
	display: inline-flex;
	margin-bottom: 15px; padding-top: 25px; padding-bottom: 5px;
	font-size: 1.8rem; font-weight: 800;
	font-family: NanumSquare, sans-serif; color: #00427c;
}
.sitemap .gnb_tit::after {
	position: absolute; bottom: 0; left: 0;
	content: "";
	display: inline-block;
	width: 0; height: 2px;
	background-color: #00427c;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
.sitemap a {
	color: #858c94; font-size: 1.6rem;
}
.sitemap .gnb_2depth > ul > li {
	margin-bottom: 12px;
}
.sitemap .gnb_2depth > ul > li:last-child {
	margin-bottom: 0;
}
.sitemap .gnb_2depth > ul > li > a {
	padding: 0;
}
.sitemap .gnb_2depth a {
	color: #fff; font-size: 1.3rem; font-weight: 600;
    font-family: NanumSquare, sans-serif;
}
.sitemap .gnb_2depth .direct_link::after {
	background-image: url(../../images/client/common/icon_direct_gray.png);
}

/* header - login */
.login_area {
	overflow: hidden;
	display: inline-block;
	height: 88px;
	vertical-align: top;
}
.login_area a {
	display: inline-block;
	width: 80px; height: 78px;
	padding-top: 50px;
	text-align: center; font-size: 1rem; font-family: NanumSquareB; line-height: 1.5em;
	background-color: #dbecf6;
	background-repeat: no-repeat;
	background-position: center 15px;
	background-size: 23px;
	-webkit-transition: background 0.5s;
	-moz-transition: background 0.5s;
	-o-transition: background 0.5s;
	transition: background 0.5s;
}
.btn_login {
	background-image: url(../../images/client/common/icon_login.png);
}
.btn_logout {
	background-image: url(../../images/client/common/icon_logout.png);
}
.login_area a:hover {
	background-color: #289dd3;
	color: #fff;
}
.btn_login:hover {
	background-image: url(../../images/client/common/icon_login_on.png);
}
.btn_logout:hover {
	background-image: url(../../images/client/common/icon_logout_on.png);
}

.view_admin {
	padding: 10px 25px 10px 50px;
	position: absolute; top: 80px; right: 0;
	color: #fff; font-size: 1.1rem;
	background:#00427c url(../../images/client/common/icon_admin.png) no-repeat 20px center;
	border-radius: 0 0 10px 10px;
}
.view_admin:hover {
	background-color: #0d65d9;
}

/* 모바일 버튼 */
.mobile_menubtn {
	display: none;
}

/* footer */
.footer_wrap {
	width: 100%; height: 125px; 
	position: relative;
	color: #fff;
	background-color: #7f7f7f; 
}
.footer_wrap .grid_content { 
    display: flex;
    height: 100%; 
    flex-direction: column;
    justify-content: center;
    background-image: url(../../images/client/common/footer_logo.png);
    background-position: right center;
    background-repeat: no-repeat;
}
.footer_wrap .footer_top {
	height: 35px;
	text-align: left;
}
.footer_wrap .footer_top a {
	display: inline-block;
	padding: 0 10px;
	line-height: 40px; font-size: 1rem;
}
.footer_wrap .footer_top a:first-child {
	padding-left: 0;
	font-weight: 600;
	background: url(../../images/client/common/bar_footer.png) no-repeat right center;
} 
.footer_wrap .footer address {
	font-size: 0.9rem; text-align: center; 
}
.footer_wrap .footer address ul li {
	text-align: left;
}
.footer_wrap .footer address p {
	margin-top: 5px;
	text-align: left;
}

.move_top {
	display: block;
	width: 80px; height: 80px;
	padding-top: 45px;
	position: fixed; bottom: 50px; right: 3%;
	text-align: center; color: #fff;
	background: url(../../images/client/common/img_movetop.png) center 15px no-repeat;
	z-index: 80;
}

/* 바디 설정 */
body { overflow: visible; }
body.on { overflow: hidden; }

/* header 스크롤시 */

body.scrolly .header_wrap {
	top: -100px;
	width: 100%; 
	background-color: rgba(255, 255, 255, 0.5);
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1);
}
body.scrolly .header_top > .grid_content {
    margin-bottom: 0;
    height: 100px;
    overflow: visible;
}
body.scrolly .header_logo {
	top: 113px; left: 0; z-index: 60;
    width: 110px;
	background-repeat: no-repeat;
	background-size: contain;
	background-image: url(../../images/client/common/header_logo_blue.png);
	-webkit-transform: none;
	-moz-transform: none;
	-o-transform: none;
	transform: none;
} 
body.scrolly .header_logo img {
	display: none;
}
body.scrolly .gnb_wrap {
	height: 80px;
}
body.scrolly .gnb_list {
	text-align: right;
}
body.scrolly .gnb_1depth {
	margin-right: 35px;
	width: auto;
}
body.scrolly .gnb_1depth:last-child {
	margin-right: 0;
}
body.scrolly .gnb_1depth > a {
	display: flex;
	height: 80px;
	align-items: center;
	color: #000;
}
body.scrolly .gnb_1depth > a > span { 
    padding: 0 5px;
	color: #000;
}
body.scrolly .gnb_1depth > a::before {
	display: none;
}
body.scrolly .gnb_1depth > a::after {
	display: none;
}
body.scrolly .gnb_2depth {
	top: 80px;
	text-align: center;
}
body.scrolly .gnb_1depth:nth-last-child(2) .gnb_2depth .gnb_3depth, body.scrolly .gnb_1depth:last-child .gnb_2depth .gnb_3depth {
	left: -190px;
	-webkit-border-radius: 10px 0 10px 10px;
	-moz-border-radius: 10px 0 10px 10px;
	border-radius: 10px 0 10px 10px;
}


/* 서브페이지 전체 영역 */
.subcontent_wrap {
	overflow: hidden;
	position: relative;
	padding-bottom: 3em;
	background-color: #fafafa;
}

/* 서브페이지 - 상단 비주얼 */
.subpage_visual {
	height: 460px;
	background: linear-gradient(180deg, rgba(243,164,230,0.8015581232492998) 0%, rgba(1,209,253,0.7987570028011204) 100%);
}

.subpage_visual > div { 
	position: relative;
	height: 100%;
	background-repeat: no-repeat;
	background-size: auto;
	background-position: bottom left;
}
.subpage_visual h2 {
	position: absolute; right: 0; bottom: 60px;
	text-align: right;
	color: #fff; font-size: 2.1rem; line-height: 1.8em; font-weight: 600; 
	text-shadow: 3px 0px 7px rgba(0, 0, 0, 0.54);
}
.subpage_visual h2 span {
	display: block;
	margin-top: 10px;
	font-size: 1.2rem; font-weight: 400; word-break: keep-all;
}
.subpage_visual .page_info {
	text-align: center; color: #fff; font-size: 1.2rem;
}
.subpage_visual .page_info span {
	display: block;
	width: 30px; height: 3px;
	margin: 0.7em auto;
	background-color: #fff;
}

.visual1 > div{ 
	background-image: url(../../images/client/sub/img_visual1.png);
}
.visual2 > div{ 
	background-image: url(../../images/client/sub/img_visual2.png);
}
.visual3 > div{ 
	background-image: url(../../images/client/sub/img_visual3.png);
}
.visual4 > div{ 
	background-image: url(../../images/client/sub/img_visual4.png);
}
.visual5 > div{ 
	background-image: url(../../images/client/sub/img_visual5.png);
}
.visual6 > div{ 
	background-image: url(../../images/client/sub/img_visual6.png);
}
.visual7 > div{ 
	background-image: url(../../images/client/sub/img_visual7.png);
}
.visual8 > div{ 
	background-image: url(../../images/client/sub/img_visual8.png);
}
.visual9 > div{ 
	background-image: url(../../images/client/sub/img_visual9.png);
}
.visual10 > div{ 
	background-image: url(../../images/client/sub/img_visual10.png);
}


/* lnb */
.lnb_wrap {
	width: 100%;
	background-color: #c5f1fe;
	border-top: 1px solid #d7d7d7;
	border-bottom: 1px solid #d7d7d7;
	z-index: 90;
} 
.lnb_list {
	width: 1280px;
	margin: 0 auto;
	font-size: 0; line-height: 0;
}
.lnb_list li {
	display: inline-block;
	height: auto;
	position: relative;
	vertical-align: top;
}
.lnb_list li a {
	display: block;
	padding: 0 1.2em;
	position: relative;
	color: #222222; font-size: 1rem; line-height: 45px; font-weight: 600;
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}
.lnb_list li a:hover {
	color: #0356a0;
}
.lnb_list li a.on {
	font-weight: 600; font-size: 1.2rem; color: #00427c;
}
.lnb_list li a.on span {
	display: none;
}
/* .sub_lnb {
	min-width: 100px; width: 100%;
	padding: 10px 0;
	text-align: center;
	background-color: #fff2f2;
}
.sub_lnb li {
	display: block;
	height: 35px;
}
.sub_lnb li a {
	margin: 0;
	font-size: 1rem; line-height: 34px;
}
.sub_lnb li a.on {
	font-size: 1.1rem;
} */

/* 교외활동 내 그래프 */
.multigraph {
	width: 100%; height: 30px;
	font-size: 0; line-height: 0;
}
.multigraph p {
	display: inline-block;
	position: relative;
}


@media screen and (max-width:1279px) {
	
	/* header 1279 */
	.gnb_1depth {
		margin-right: 2px; 
	}
	.gnb_1depth > a > span {
		font-size: 1.05rem;
	}
	.gnb_2depth a {
		font-size: 1.05rem;
	}
	/* header - login */
	/*.login_area.login_2length {
		padding: 7px;
	}
	.login_area.login_2length a {
		display: block;
		width: 80px; height: 35px;
		padding-top: 0px; padding-left: 20px; margin-left: 0;
		text-align: center; line-height: 34px;
		background-position: 10px center;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
	}*/
	.view_admin {
		margin-top: 5px;
	}
	
	/* gnb */
	.gnb_list .gnb_menu > a {
		width: 75px;
	}
	
	/* 사이트맵 1279 */
	.sitemap .gnb_tit {
		font-size: 1.6rem;
	}
	.sitemap .gnb_2depth a {
		font-size: 1.2rem;
	}

	/* header 스크롤시 1279 */
	body.scrolly .header_logo {
		top: 105px;
	}
	body.scrolly .gnb_wrap {
		height: 70px;
	}
	body.scrolly .gnb_1depth {
		margin-right: 20px;
	}
	body.scrolly .gnb_1depth > a {
		height: 70px;
	}
	body.scrolly .gnb_2depth {
		top: 70px;
	}
	body.scrolly .gnb_1depth:last-child .gnb_2depth {
		margin-left: -140px;
		background-position: right 40px top;
	}
	body.scrolly .gnb_1depth:nth-last-child(3) .gnb_3depth {
		left: -190px;
		-webkit-border-radius: 10px 0 10px 10px;
		-moz-border-radius: 10px 0 10px 10px;
		border-radius: 10px 0 10px 10px;
	}
	
}

@media screen and (max-width: 1079px) {
	
	/* 메인 진단센터 */
	.main_test_list li {
		min-height: 120px !important;
	}
	.main_test_list li dl {
		width: 100% !important;
	}
	
	/* lnb */
	.lnb_list li a {
		padding: 0 0.8em;
	}
	
}


/*=================== hover ===================*/
@media screen and (min-width:1025px) {
	
	/* header hover */
	.btn_log:hover {
		box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
	}

	.gnb_1depth:hover > a::after { 
		background-color: #00427c;
        box-shadow: 5px 5px 6px 0px rgba(0, 0, 0, 0.2);
	}
	.gnb_1depth:hover > a span { 
        color: #00427c;
	}
	body.scrolly .gnb_1depth:hover > a > span {
		color: #1e2446;
		background-color: transparent;
	}

	.gnb_2depth > li:hover::before {
		width: 5px;
	}
	.gnb_2depth > li:hover a {
		color: #3a6c98;
	}

	/* lnb hover */
	.lnb_list li a:hover {
		color: #1e2446;
	}
	.lnb_list li a:hover::before {
		width: 100%;
	}

	/* 사이트맵 hover */
    .sitemap .gnb_2depth {
        padding: 0 10px;
    }
	.sitemap .gnb_2depth:hover::before {
		-webkit-transform: rotate(180deg);
		-moz-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		transform: rotate(180deg);
	}
	.sitemap .gnb_2depth:hover .gnb_tit::after {
		width: 100%;
	}
	.sitemap .gnb_2depth a:hover {
		color: #00427c;
	}
	
}


@media screen and (max-width:1024px) {
	
	.page_wrap {
		padding-top: 70px;
	}
	.page_wrap.mainpage {
		padding-bottom: 0;
	}
	
	/* header 1024 */
	.header_wrap {
		position: fixed; top: 0; z-index: 20;
		width: 100%; height: 70px;
		background-color: #00427c;
	}
	.header_top {
		margin-bottom: 0;
		height: 70px;
	}
	.header_top > .grid_content {
		height: 100%;
	}
	.header_logo {
		left: 0;
		width: 120px; height: auto;
		-webkit-transform: translateY(-50%);
		-moz-transform: translateY(-50%);
		-o-transform: translateY(-50%);
		transform: translateY(-50%);
	} 
	.header_logo a img {
        width: 95px;
	}
	.user_info {
		display: none;
	}
	.btn_admin {
		top: 0; right: 10px;
		padding: 0 10px;
		color: #fff; font-size: 0.9rem; line-height: 22px;
		background-color: #2183d9;
		background-image: none;
		-webkit-border-radius: 0 0 10px 10px;
		-moz-border-radius: 0 0 10px 10px;
		border-radius: 0 0 10px 10px;
		-webkit-transform: none;
		-moz-transform: none;
		-o-transform: none;
		transform: none;
	}

	.btn_menu {
		display: block;
	}
	.btn_menu {
		position: absolute; top: 25px; right: 0; 
		display: block;
		width: 30px; height: 21px;
		font-size: 0; line-height: 0;
		background-color: rgba(0,0,0,0);
	}
	.btn_menu::after {
		content: "";
		display: block;
		clear: both;
	}
	.btn_menu span {
		float: right;
		display: block;
		width: 30px; height: 3px;
		margin-bottom: 6px;
		background-color: #fff;
		-webkit-border-radius: 2px;
		-moz-border-radius: 2px;
		border-radius: 2px;
	}
	.btn_menu span:nth-child(2)::before, .btn_menu span:nth-child(2)::after {
		content: "";
		position: absolute; top: 50%; left: 50%;
		display: block;
		margin-top: -1px; margin-left: -15px;
		width: 30px; height: 3px;
		background: #fff;
		-webkit-border-radius: 2px;
		-moz-border-radius: 2px;
		border-radius: 2px;
		-webkit-transition: 0.2s;
		-moz-transition: 0.2s;
		-o-transition: 0.2s;
		transition: 0.2s;
		opacity: 0;
	}
	.btn_menu.on {
		top: 23px;
		height: 24px;
	}
	.btn_menu.on span:first-child, .btn_menu.on span:last-child {
		display: none;
	}
	.btn_menu.on span:nth-child(2){
		width: 20px;
		background: rgba(0,0,0,0);
	}
	.btn_menu.on span:nth-child(2)::before {
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
		opacity: 1;
	}
	.btn_menu.on span:nth-child(2)::after {
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg);
		opacity: 1;
	}
	.btn_log {
		position: absolute; right: 50px; z-index: 10;
		margin: 0;
		padding: 0; 
		width: 37px; height: 35px;
		font-size: 0;
		background-color: transparent; background-repeat: no-repeat; 
		background-position: center;
		border: none;
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		border-radius: 0;
	}
	.btn_log::before {
		display: none;
	}
	.btn_log.login {
		background-image: url(../../images/client/common/icon_login_mobile.png);
	}
	.btn_log.logout {
		background-image: url(../../images/client/common/icon_logout_mobile.png);
	}
	.header_bottom {
		position: fixed; top: 70px;
		display: none;
		margin: 0;
		width: 100%;
	}
	.gnb_wrap {
		background-color: #fff;
		box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.2), 4px 4px 6px rgba(0,0,0,0.1); 
		overflow-y: auto;
		-ms-overflow-style: none;
		-webkit-transition: all 0.2s;
		-moz-transition: all 0.2s;
		-o-transition: all 0.2s;
		transition: all 0.2s;
	}
	.gnb_list {
		padding: 35px 15px 20px;
		white-space: nowrap;
		overflow-x: auto;
	}
	.gnb_list::-webkit-scrollbar {
		display: none;
	}
	.gnb_1depth {
		position: static;
		vertical-align: top;
	}
	.gnb_1depth > a {
		-webkit-transition: none;
		-moz-transition: none;
		-o-transition: none;
		transition: none;
	}
	.gnb_1depth > a::before {
        margin: 0 auto;
		-webkit-transition: none;
		-moz-transition: none;
		-o-transition: none;
		transition: none;
	} 
	.gnb_1depth.on > a::after { 
		z-index: 1;
		background-color: #00427c;
	}
    .gnb_1depth > a > span { 
        padding: 0;
        color: #00427c;
    }
	.gnb_1depth.on > a > span {
		text-shadow: 0 2px 2px rgba(0, 0, 0, 0.25);
	}
	.gnb_2depth {
		top: 153px; left: 0; z-index: -1;
		margin: 0;
		width: 100%; height: calc( 100vh - 223px);
		text-align: left;
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		border-radius: 0;
		box-shadow: none;
		overflow-y: auto;
	}
	.gnb_2depth a {
		padding: 15px;
	}
	.gnb_more {
		display: none;
	}

	body.on .header_wrap::after {
		content: "";
		position: absolute; top: 70px; left: 0; 
		display: block;
		width: 100vw; height: calc( 100vh - 70px );
		background: rgba(0,0,0,0.3);
	}
	body.on .header_bottom {
		display: block;
	}
	
	/* 사이트맵 1024 */
	.btn_sitemapmenu {
		display: none;
	}
	.sitemap {
		display: none;
	}
	.sitemap > .inner {
		display: none;
	}

	/* 서브페이지 - 상단 비주얼 */
	.subpage_visual {
		height: 210px;
	}
	.subpage_visual h2 { 
		top: 55px; bottom: auto;
		font-size: 1.6rem;
		background-image: none;
	}
	.subpage_visual h2 span {
		margin-top: 0;
		margin-left: 40%;
		font-size: 1rem; 
	}
	.subpage_visual h2 span br {
		display: none;
	}
	.subpage_visual > div { 
		background-position: bottom left 50px;
	}
	.visual1 > div {
		background-size: auto 170px;
	}
	.visual2 > div {
		background-size: auto 150px;
		background-position: bottom left -10px;
	}
	.visual3 > div {
		background-size: auto 180px; 
	}
	.visual4 > div {
		background-size: auto 165px;
		background-position: bottom left 40px;
	}
	.visual5 > div {
		background-size: auto 170px;
	}
	.visual6 > div {
		background-size: auto 165px;
	}
	.visual7 > div {
		background-size: auto 165px;
	}
	.visual8 > div {
		background-size: auto 160px;
	}
	.visual9 > div {
		background-size: auto 160px;
	}
	.visual10 > div {
		background-size: auto 170px;
	}
	
	/* lnb */
	.lnb_wrap {
		display: none;
	}
	
	
}
@media screen and (max-width:767px) {
	
	/* header 768 */
	.gnb_1depth { 
		width: 95px;
	}
	.gnb_1depth > a > span {
		padding: 0;
	}
	/* footer 768 */
	.footer_wrap { 
		font-size: 1.4rem;
	}
    .footer_wrap .grid_content {
        background-image: none;
    }
	.footer_top li {
		font-size: 1.4rem;
	}
	.footer_wrap.mainpage {
		margin-top: 0;
	}

	/* 서브페이지 - 상단 비주얼 */
	.subpage_visual {
		height: 190px;
	}
	.subpage_visual h2 {
		font-size: 1.5rem;
	}
	.subpage_visual h2 span {
		margin-left: 30%;
	}
	.subpage_visual > div { 
		background-position: bottom left;
	}
	.visual1 > div {
		background-size: auto 130px;
		background-position: bottom left 10px;
	}
	.visual2 > div {
		background-size: auto 110px;
		background-position: bottom left -70px;
	}
	.visual3 > div {
		background-size: auto 140px;
	}
	.visual4 > div {
		background-size: auto 125px;
	}
	.visual5 > div {
		background-size: auto 130px;
	}
	.visual6 > div {
		background-size: auto 125px;
	}
	.visual7 > div {
		background-size: auto 125px;
	}
	.visual8 > div {
		background-size: auto 120px;
	}
	.visual9 > div {
		background-size: auto 120px;
	}
	.visual10 > div {
		background-size: auto 130px;
	}

}
@media screen and (max-width:480px) {
	
	/* footer */
	.footer_wrap {
		height: 150px;
	}
	
	/* 서브페이지 - 상단 비주얼 */
	.subpage_visual {
		height: 140px;
	}
	.subpage_visual h2 { 
		top: 50%; right: 20px;
		font-size: 1.6rem;
		-webkit-transform: translateY(-50%);
		-moz-transform: translateY(-50%);
		-o-transform: translateY(-50%);
		transform: translateY(-50%);   
	}
	.subpage_visual h2 span {
		display: none;
	} 
	.subpage_visual > div {
		background-position: bottom left 20px;
	}
	.visual1 > div {
		background-size: auto 100px;
	}
	.visual2 > div {
		background-size: auto 90px;
		background-position: bottom left -20px;
	}
	.visual3 > div {
		background-size: auto 110px;
		background-position: bottom left 10px;
	}
	.visual4 > div {
		background-size: auto 95px;
		background-position: bottom left -10px;
	}
	.visual5 > div {
		background-size: auto 100px;
		background-position: bottom left 30px;
	}
	.visual6 > div {
		background-size: auto 97px;
		background-position: bottom left;
	}
	.visual7 > div {
		background-size: auto 95px;
		background-position: bottom left;
	}
	.visual8 > div {
		background-size: auto 90px;
		background-position: bottom left 10px;
	}
	.visual9 > div {
		background-size: auto 100px;
		background-position: bottom left 30px;
	}
	.visual10 > div {
		background-size: auto 100px;
	}
}