@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:1640px){
	.inner{width:93.75%;}
}

/* header */
#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; left:-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 {left: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:#6ca2ab; 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 {
	width: 240px;
	height: 100vh;
	/* overflow-y: auto; */
	text-align: center;
	padding: 30px 0 60px;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	background-color: #fff;
	border-right: 1px solid #dbdbdb;
}

a.com_btn01 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 28px;
	height: 56px;
	width: 100%;
	max-width: 180px;
	font-size: 16px;
	letter-spacing: -0.025em;
	font-weight: 600;
	color: #fff ;
	gap: 7px;
	transition: all 0.3s ease-in-out;
}

a.com_btn01:hover {
	opacity: 0.7;
}

#header .com_btn01+.com_btn01 {
	margin-top: 8px;
}

.bgColor01 {
	background-color: #6ca2ab;
}

.bgColor02 {
	background-color: #323232;
}

.bgColor03 {
	background-color: #223588;
}

#header .gnb .login_box {
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
}

#header .gnb .login_box a {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0.02em;
	color: #6ca2ab;
}

#header .gnb .login_box a:first-child {
	position: relative;
	margin-right: 10px;
	padding-right: 10px;
}

#header .gnb .login_box a:first-child::after {
	content: '/';
	position: absolute;
	right: 0;
	top: 0;
	transform: translateX(50%);
}

#header .gnb>ul>li>a {
	font-size: 18px;
	letter-spacing: 0;
	font-weight: 600;
	color: #222;
	transition: all 0.3s ease;
	padding: 16px 0;
	width: 100%;
	display: inline-block;
}

#header .gnb>ul>li>a:hover {
	color: #223588;
	text-decoration: underline;
	text-underline-position: under;
}

#header .flex_box {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
}
#header .gnb > ul {
	position: relative;
}
#header .gnb .depth02 {
    opacity: 0;
	display: none;
    position: absolute;
    top: 0;
    left: 100%;
    width: 240px;
    z-index: 10;
    height: 100vh;
    cursor: auto;
	transition: all 0.3s ease;
}
#header .gnb .depth02 > li > a {
	font-weight: 600;
	font-size: 18px;
	letter-spacing: -0.025em;
	color: rgba(255,255,255,0.75);
	padding: 16px 0;
	width: 100%;
	text-align: center;
	transition: all 0.3s ease;
	display: inline-block;
}
#header .gnb .depth02 > li > a:hover {
	color: #fff;
	text-decoration: underline;
	text-underline-position: under;
}
#header .gnb .depth02.active {
	opacity: 1;
	display: block;
}

@media all and (max-width:1024px) {
	#header {
		width: 100%;
		top: 0;
		left: 0;
		right: 0;		
		height: 85px;
		padding: unset;
		padding: 0 3.125%;
		border-bottom: 1px solid #ddd;
	}
	#header .logo {
		display: none;
	}
	#header .m_btn {
		margin: unset;
	}
	#header .flex_box {
		justify-content: center;
	}
	#header .m_btn i:nth-of-type(2) {
		width: 100%;
	}
	#m_menu .h_btn_box .com_btn01 {
		width: 100%;
		max-width: unset;
		border-radius: unset;
	}
	#header .h_btn_box {
		display: flex;
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
	}
	#header .com_btn01+.com_btn01 {
		margin: unset;
	}
	#header .com_btn01 {
		flex: 1;
		max-width: unset;
		border-radius: unset;
	}
}
/* END header */

/* wrap */
#wrap {
	width: calc(100% - 240px);
	margin-left: 240px;
}

@media all and (max-width:1024px) {
	#wrap {
		width: 100%;
		margin-left: unset;
		/* padding-top: 85px; */
		padding-bottom: 56px;
	}
}
/* END wrap */

/* footer */
#footer {
	padding: 80px 0 100px;
	background-color: #111422;
}
#footer .inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
#footer .f_top {
	display: flex;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.025em;
}
#footer .f_top a {
	position: relative;
	margin-right: 5px;
	padding-right: 5px;	
	color: #ffffff;
}
#footer .f_top a:not(:last-child):after {
	content: '·';
	position: absolute;
	right: 0;
	top: 50%;
	transform: translate(50%, -50%);
}
#footer .f_alt {
	font-size: 16px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.66);	
}

#footer .f_alt .box {
	display: flex;
	flex-wrap: wrap;
}
#footer .f_alt .box.bar p {
	position: relative;
	margin-right: 20px;
	padding-right: 20px;
	line-height: 1.8em;
}
#footer .f_alt .box.bar p:not(:last-child):after {
	content: '';
	position: absolute;
	width: 1px;
	height: 12px;
	background-color: rgba(255, 255, 255, 0.33);
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
#footer .f_alt .copy {
	color: rgba(255, 255, 255, 0.33);
}
#footer .f_sns_box {
	display: flex;
	align-items: center;
	gap: 20px;
}
#footer .f_sns_box a {
	transition: all 0.3s ease;
}
#footer .f_sns_box a:hover {
	filter: grayscale(100%) brightness(0);	
}

@media all and (max-width:1200px) {
	#footer .inner {
		flex-direction: column;
		gap: 60px;
		align-items: center;
		text-align: center;
	}
	#footer .f_top,
	#footer .f_alt .box {
		justify-content: center;
	}
}

@media all and (max-width:700px) {
	#footer {
		padding: 80px 0;
	}
}
/* END footer */

/* gnb */
.gnb_bg {
	opacity: 0;
    z-index: 9;
    position: fixed;
    transition: all 0.5s ease;
    left: 240px;
	transform: translateX(-100%);
    top: 0;
    width: 100%;
    height: 100%;
	overflow: auto;
    max-width: 240px;
	background-color: rgba(108, 162, 171, 0.75);
}
.gnb_bg.active {
	opacity: 1;
	transform: translateX(0);
}

@media all and (max-width:1024px) {
	.gnb_bg {
		display: none;
	}
}
/* END gnb */

/* sub_visual */
.sub_visual {
	height: 100vh;
	width: 100%;
	position: relative;
	padding: 140px 0;
	color: #fff;
}
.sub_visual .inner { 
	height: 100%;
	display: flex;
	flex-direction: column;
}
.sub_visual .label {
	font-size: 28px;
	letter-spacing: 0;
	font-weight: 700;
}
.sub_visual .tit_box {
	margin-top: auto;
}
.sub_visual .tit_box .tit {
	font-size: 72px;
	font-weight: 600;
	letter-spacing: -0.025em;
	margin-bottom: 15px;
}

@media all and (max-width:700px) {
	.sub_visual .tit_box .tit {
		font-size: 50px;
	}
	.sub_visual .label {
		font-size: 20px;
	}
	.sub_visual {
		padding: 140px 0;
	}
}
/* END sub_visual */

/* inquiry_modal */
.inquiry_modal {
	position: absolute;
	z-index: 11;
	padding: 0 6.25vw;
	padding-bottom: 10vh;
	left: 0;
	top: 0;
	height: 100vh;
	background: rgba(108,162, 171, 0.9);
	display: flex;
	align-items: flex-end;
	text-align: left;
	color: #fff;
	transform: translate(-100%);
	transition: all 0.3s ease-in-out;
}
.inquiry_modal.active {
	transform: translateX(0);
}
.inquiry_modal .close_btn {
	position: absolute;
	right: 2.3vw;
	top: 3.2vh;
}
/* .inquiry_modal div,
.inquiry_modal form {
	width: 100%;
} */
a.common_btn02 {	
	min-width: 640px;
	max-width: 90%;
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
	border-radius: 35px;
	border: 2px solid #fff;
	color: #fff;
	font-weight: 600;
	letter-spacing: -0.025em;
	font-size: 20px;
}
a.common_btn02:hover {
	background-color: rgba(255, 255, 255, 0.2);
}
.inquiry_modal a.common_btn02 {
	margin-top: 6vh;
}
.common_chk_flex_box02 {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: -0.025em;
	color: #dbe5e7;
}
.common_chk_box01 {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: -0.025em;
	color: #fff;
}
.common_chk_box01 input {
	outline: unset;
	padding: unset;
	margin: unset;
	appearance: unset;
	aspect-ratio: 1/1;
	min-width: 20px;
	width: 20px;
	background: url('/img/com_chk01.png') no-repeat center / cover;
}
.common_chk_box01 input:checked {
	background: url('/img/com_chk01_active.png') no-repeat center / cover;
}
.inquiry_modal .common_chk_flex_box02 {
	margin-top: 2.7vh;
}
.inquiry_modal .tit {
	font-size: 48px;
	font-weight: 600;
	letter-spacing: -0.025em;
	color: #fff;
}
.inquiry_modal .alt {
	font-size: 18px;
	font-weight: 400;
	letter-spacing: -0.025em;
	margin: 3.7vh 0 6vh;
	word-break: auto-phrase;
}
.inquiry_modal .modal_body_box .flex_box02 {
	display: flex;
	flex-wrap: wrap;
	gap: 25px;
	margin-bottom: 2.5vh;
}
.inquiry_modal .modal_body_box .flex_box02 .write_label_box {
	width: calc(50% - 12.5px);
}
.write_label_box p {
	font-size: 20px;	
	letter-spacing: -0.025em;
	font-weight: 300;
	padding-bottom: 10px;
}
.input_style_box01 {
	width: 100%;
	background-color: #fff;
	padding: 0 20px;
	height: 48px;
}
.textarea_style_box01 {
	width: 100%;
	background-color: #fff;
	padding: 20px;
	height: 18.5vh;
}
.textarea_style_box01 textarea {
	outline: unset;
	padding: unset;
	margin: unset;
	border: unset;
	width: 100%;
	height: 100%;
	resize: none;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: -0.025em;
	color: #9b9b9b;
	background-color: transparent;
}
.input_style_box01 input {
	outline: unset;
	padding: unset;
	margin: unset;
	border: unset;
	width: 100%;
	height: 100%;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: -0.025em;
	color: #9b9b9b;
	background-color: transparent;
}
body.active {
    touch-action: none;
    overflow: hidden !important;
    -webkit-user-select: none;
}

html.active {
    touch-action: none;
    overflow: hidden !important;
    overscroll-behavior: none;
    -webkit-user-select: none;
}

@media all and (max-width:1024px) {
	.inquiry_modal {
		position: fixed;
		transform: unset;
		opacity: 0;
		z-index: -1;
		pointer-events: none;
		visibility: hidden;
		padding: 40px;
		width: 100%;
		height: max-content;
		max-width: 95%;
		max-height: 90%;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
		align-items: center;
	}
	.inquiry_modal .close_btn {
		top: 15px;
		right: 15px;
	}
	.inquiry_modal.active {
		opacity: 1;
		z-index: 11;
		pointer-events: auto;
		visibility: visible;
		transform: translate(-50%, -50%);
	}
	a.common_btn02 {
		min-width: unset;
		max-width: unset;
	}
	.inquiry_modal .tit {
		font-size: 30px;
	}
	.inquiry_modal .alt {
		margin: 2.7vh 0 3vh;
		font-size: 14px;
	}
	.write_label_box p,
	.input_style_box01 input {
		font-size: 16px;
	}
	.inquiry_modal .modal_body_box .flex_box02 {
		margin-bottom: 2vh;
	}
	.inquiry_modal a.common_btn02 {
		margin-top: 4vh;
	}
}
@media all and (max-width:700px) {
	.inquiry_modal .modal_body_box .flex_box02 .write_label_box {
		width: 100%;
	}
	.inquiry_modal .modal_body_box .flex_box02 {
		gap: 2vh;
	}
	.com_con_txt_box .com_alt {
		word-break: auto-phrase;
	}
	.com_con_txt_box .com_alt br {
		display: none;
	}
}
/* END inquiry_modal */


.login_pop_bg {
	display: none;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, .4);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 102;
}

.login_pop {
	box-sizing: border-box;
	min-height: calc(100vh - 315px);
	display: flex; align-items: center;
}

.login_pop .center_box{max-width: 480px; width: 100%; margin: 0 auto;}
.login_pop .tit_box {
	text-align: center;
}

.login_pop .tit_box h3 {
	font-size: 48px;
	font-weight: 700;
	letter-spacing: 0;
	color: #222222;
}

.login_pop .tit_box p {
	font-size: 18px;
	letter-spacing: 0;
	color: #444444;
}

.login_pop .user_box {
	margin-top: 60px;
}

.login_pop .input_box {
	height: 70px;
	width: 100%;
	border-radius: 8px;
	box-sizing: border-box;
	background-color: #f4f4f5;
}

.login_pop .input_box input {
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	outline: none;
	border: none;
	background-color: transparent;
	padding: 0 30px;
	font-size: 18px;
	color: #222;
}

.login_pop .input_box input::placeholder {
	font-size: 18px;
	color: #a5a5b2;
}

.login_pop .flex_box {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 20px;
}

.login_pop .flex_box .left_box label {
	display: flex;
	align-items: center;
	gap: 8px;
}

.login_pop .flex_box .left_box label span {
	font-size: 16px;
	color: #87878e;
	letter-spacing: -0.025em;
}

.login_pop .flex_box .left_box input[type="checkbox"]:checked~span {
	color: #6ca2ab;
}

.login_pop .flex_box .left_box input[type="checkbox"] {
	display: none;
}

.login_pop .flex_box .left_box input[type="checkbox"]~i {
	display: block;
	width: 22px;
	aspect-ratio: 1/1;
	box-sizing: border-box;
	border-radius: 4px;
	border: 2px solid #6ca2ab;
}

.login_pop .flex_box .left_box input[type="checkbox"]:checked~i {
	background: #6ca2ab url(/img/check_icon01.png)no-repeat center center;
}

.login_pop .flex_box .right_box ul {
	display: flex;
	align-items: center;
	gap: 20px;
}

.login_pop .flex_box .right_box ul li {
	position: relative;
}

.login_pop .flex_box .right_box ul li a {
	font-size: 16px;
	color: #87878e;
	letter-spacing: -0.025em;
}

.login_pop .flex_box .right_box ul li+li:before {
	position: absolute;
	content: '';
	left: -10px;
	top: 50%;
	width: 1px;
	height: 12px;
	background-color: #ccccd3;
	transform: translateY(-50%);
}

.login_pop .submit_box {
	margin-top: 60px;
}

.login_pop .submit_box a {
	width: 100%;
	height: 70px;
	box-sizing: border-box;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #6ca2ab;
	border-radius: 8px;
	color: #fff;
	font-size: 20px;
	font-weight: 600;
	letter-spacing: -0.025em;
}

.login_pop .closed_btn {
	position: absolute;
	top: 40px;
	right: 40px;
	width: 24px;
	aspect-ratio: 1/1;
	display: block;
	cursor: pointer;
}

.login_pop .closed_btn i {
	display: inline-block;
	width: 100%;
	height: 2px;
	background-color: #444444;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
}

.login_pop .closed_btn i:nth-child(2) {
	transform: translate(-50%, -50%) rotate(-45deg);
}


@media all and (max-width:768px) {
	.login_pop {
		padding: 50px 30px;
	}
}
