@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;}
}
/* font */
.jost{font-family: 'Jost', sans-serif;}
/* basic */
.inner{width:100%; max-width:1400px; margin:0 auto; position:relative;}
.inner.full {max-width: 1840px;}

@media all and (max-width: 1840px) {
	.inner.full {width: 93.75%;}
}
@media all and (max-width:1400px){
	.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; 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:#1c2cf3; 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;
	width: 100%;
	z-index: 10;
	background-color: transparent;
}

#header .h_inner {
	display: flex;
	padding: 0 120px;
	height: 125px;
	position: relative;
	justify-content: space-between;
}

#header .h_inner .logo {
	display: flex;
	align-items: center;
}

#header .gnb > ul {
	display: flex;
	height: 100%;
}
#header .gnb > ul > li > a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	font-size: 20px;
	letter-spacing: -0.025em;
	color: #fff;
	padding: 0 40px;
	font-weight: 700;
	transition: all 0.3s ease;
}
#header .h_inner .login_box {
	display: flex;
}
#header .h_inner .login_box a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	font-size: 18px;
	transition: all 0.3s ease;
	font-weight: 500;
	letter-spacing: -0.025em;
	color: #fff;
}
#header .h_inner .login_box a + a {
	position: relative;
	margin-left: 15px;
	padding-left: 15px;
}
#header .h_inner .login_box a + a::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 1px;
	height: 13px;
	background-color: rgba(255, 255, 255, 0.3);
}
#header .logo img {
	display: none;
	transition: all 0.3s ease;
}
#header .gnb > ul > li > a,
#header .h_inner .login_box a {
	color: #222;
}
#header .logo .active {
	display: block;
}
.main #header .logo .active {
	display: none;
}
.main #header .logo .basic {
	display: block;
}
.main #header .gnb > ul > li > a,
.main #header .h_inner .login_box a  {
	color: #fff;
}
.main #header.fix .logo .basic {
	display: none;
}
.main #header.fix .logo .active {
	display: block;
}
.main #header.fix .gnb > ul > li > a,
.main #header.fix .h_inner .login_box a {
	color: #222;
}

.fp-viewing-se01 #header .logo .basic,
.fp-viewing-se05 #header .logo .basic,
.fp-viewing-se06 #header .logo .basic,
.fp-viewing-se07 #header .logo .basic {
	display: block;
}
.fp-viewing-se02 #header .logo .active,
.fp-viewing-se03 #header .logo .active,
.fp-viewing-se04 #header .logo .active,
.fp-viewing-se08 #header .logo .active,
.fp-viewing-se09 #header .logo .active,
.fp-viewing-9 #header .logo .active {
	display: block;
}
.fp-viewing-se02 #header .gnb > ul > li > a,
.fp-viewing-se02 #header .h_inner .login_box a,
.fp-viewing-se03 #header .gnb > ul > li > a,
.fp-viewing-se03 #header .h_inner .login_box a,
.fp-viewing-se04 #header .gnb > ul > li > a,
.fp-viewing-se04 #header .h_inner .login_box a,
.fp-viewing-se08 #header .gnb > ul > li > a,
.fp-viewing-se08 #header .h_inner .login_box a,
.fp-viewing-se09 #header .gnb > ul > li > a,
.fp-viewing-se09 #header .h_inner .login_box a,
.fp-viewing-9 #header .gnb > ul > li > a,
.fp-viewing-9 #header .h_inner .login_box a {
	color: #222;
}
.sub_wrap #header {
	background-color: #fff;
}

@media all and (max-width:1500px) {
	#header .h_inner {
		padding: 0 40px;
	}
	#header .gnb > ul > li > a {
		padding: 0 20px;
		font-size: 18px;
	}
	#header .h_inner .login_box a {
		font-size: 16px;
	}
	
}

@media all and (max-width:1024px) {
	#header .h_inner {
		width:93.75%;
		margin: 0 auto;
		padding: unset;
	}	
	#header .h_inner .login_box {
		display: none;
	}
	#header .m_btn {
		margin: unset;
		margin-left: auto;
		justify-content: center;
		display: flex;
		flex-direction: column;
	}
	#header .m_btn i:nth-of-type(2) {
		width: 100%;
	}
	#header .h_inner {
		height: 80px;
	}
}

/*ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ

 * footer *
    
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ*/
#footer .input_box{width: 203px;}
#footer input[type="text"]{width: 100%; height: 48px; border: none; border-bottom: 1px solid #41474b; box-sizing: border-box;}

#footer .custom_select{position: relative; height: fit-content;}
#footer .custom_select input[type="text"]{width: 203px; height: 48px; font-family: 'Montserrat'; padding: 20px 0; cursor: pointer;font-size: 16px; color: #222; font-weight: 500; letter-spacing: -0.05em; box-sizing: border-box; background-color: transparent; background-image: url(/img/footer_input_bg.png); background-repeat: no-repeat; background-position: center right;}
#footer .custom_select input[type="text"]::placeholder{color: rgba(255, 255, 255, 0.4);}
#footer .custom_select .air_box{display: none; position: absolute; top: 100%; left: 0; width: 100%; background-color: #fff; border: 1px solid #c2c2c2; box-sizing: border-box;}
#footer .custom_select .air_box ul li a{display: block; padding: 10px 20px; box-sizing: border-box; width: 100%; color: #000000; font-size: 16px; font-weight: 500; letter-spacing: -0.02em; cursor: pointer;}
#footer .custom_select .air_box ul li:hover a{font-weight: bold;}

#footer {
	background-color: #111619;
}

#footer .f_top {
	border-bottom: 1px solid #3b3f42;
	height: 70px;
}
#footer .f_top .inner {
	padding: 0 203px;
	height: 100%;
	position: relative;
}
#footer .input_box {
	position: absolute;
	right: 0;
	height: 100%;
	top: 0;
}
#footer .custom_select {
	height: 100%;
	display: flex;
	align-items: center;
}
#footer .custom_select input[type="text"] {
	border: unset;
	height: 100%;
}

#footer .f_nav {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	height: 100%;
}

#footer .f_nav a {
	font-size: 16px;
	letter-spacing: -0.05em;
	color: #fff;
	font-weight: 400;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 25px;
}

#footer .f_btm {
	padding: 60px 0;
}

#footer .f_logo {
	margin-right: 65px;
}

#footer .f_btm .flex_box {
	display: flex;
	flex-wrap: wrap;
}

#footer .f_alt {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: -0.05em;
	color: #818a90;
	line-height: 1.65em;
}
#footer .f_alt.f_end{display: flex; flex-direction: column; width: 100%;}
#footer .f_alt p {
	display: flex;
	flex-wrap: wrap;
	gap: 0 20px;
}

#footer .f_right {
	margin-top: auto;
	margin-left: auto;
}
#footer .f_right .bar {
	display: block;
	position: relative;
	margin-right: 20px;
}

#footer .f_right .bar::after {
	content: '';
	position: absolute;
	right: -19.5px;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	height: 12px;
	background-color: #393d3f;
}

#footer .f_sns {
	display: flex;
	margin-top: 20px;
	justify-content: flex-end;
	gap: 5px;
}

#footer .f_sns a {
	aspect-ratio: 1/1;
	border-radius: 50%;
}

#footer p.copy{text-align: center; color: #818a90; margin-top: 30px;}

@media all and (max-width:1400px) {
	#footer .f_top {
		height: auto;
		min-height: 70px;
	}
	#footer .f_nav a {
		height: 70px;
	}
	#footer .f_top .inner {
		padding: unset;
	}
	#footer .input_box {
		position: relative;
		bottom: unset;
		margin-left: auto;
	}
}

@media all and (max-width:1024px) {
	#footer .f_logo {
		margin-right: unset;
	}
	#footer .f_btm .flex_box {
		flex-direction: column;
		gap: 40px;
		align-items: center;
	}
	#footer .f_right {
		margin-left: unset;
	}
	#footer .f_sns {
		justify-content: center;
	}
}

/* header */
#header.fix {
	background-color: #fff;
}
/* END header */

/* modal 추가 */
.modal01_bg {
	background-color: rgba(0, 0, 0, 0.2);
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 99;
	display: none;
}
.modal01 {
	max-width: 95%;
	max-height: 95%;
	overflow: auto;
	width: 1040px;
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background-color: #fff;
	z-index: 100;
	border-radius: 20px;
	padding: 80px 50px;
	display: none;
}
.modal01 .modal_tit {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid #e5e5e5;
	padding-bottom: 30px;
}
.modal01 .modal_body_box {
	overflow: auto;
}
.modal01 .modal_tit span {
	font-size: 24px;
	font-weight: 600;
	letter-spacing: -0.025em;
	color: #1c2cf3;
}

.modal01 .modal_tit a {
	width: 32px;
	height: 32px;
	opacity: 0.8;
	display: block;
	position: relative;
}

.modal01 .modal_tit a:before,
.modal01 .modal_tit a:after {
	position: absolute;
	left: 15px;
	top: 50%;
	content: ' ';
	height: 22px;
	width: 2px;
	background-color: #000;
}

.modal01 .modal_tit a:before {
	transform: translateY(-50%) rotate(45deg);
}

.modal01 .modal_tit a:after {
	transform: translateY(-50%) rotate(-45deg);
}
.modal01 .modal_body_box .box {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	padding: 40px 0;
}
.modal01 .modal_body_box .box:last-child {
	border-bottom: 1px solid #e5e5e5;
}

.modal01 .modal_body_box .box + .box {
	border-top: 1px solid #e5e5e5;
}
.modal01 .modal_body_box .box .img {
	text-align: center;
	width: 26%;
}
.modal01 .modal_body_box .box .alt {
	width: 74%;
	font-size: 16px;
	letter-spacing: -0.01em;
	color: #666666;
	font-weight: 200;
	word-break: auto-phrase;
	line-height: 1.85em;
}
.modal01 .modal_body_box .box .img .txt {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: #222;
	margin-top: 20px;
}
body.on {
	touch-action: none;
	overflow: hidden !important;
	-webkit-user-select: none;
}

html.on {
	touch-action: none;
	overflow: hidden !important;
	overscroll-behavior: none;
	-webkit-user-select: none;
}
.modal_tit02 {
	font-size: 22px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: #000000;
}
.add_payment_modal .modal01 {
	text-align: center;
}
.modal_alt_02 {
	font-size: 22px;
	letter-spacing: -0.01em;
	font-weight: 300;
	color: #000;
	line-height: 1.4em;
}
.modal_alt_02 span {
	color: #ff3399;
}
a.modal_btn02 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 23px;
	height: 45px;
	width: 185px;
	background-color: #1c2cf3;
	color: #fff;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: -0.01em;
	margin-top: 40px;
}
@media all and (max-width:700px) {
	.modal01 .modal_body_box {
		max-height: 400px;
	}
	.modal01 {
		padding: 60px 30px;
	}
	.modal01 .modal_body_box .box .img,
	.modal01 .modal_body_box .box .alt {
		width: 100%;
	}
	.modal01 .modal_body_box .box  {
		gap: 20px 0;
	}
}
/* END modal */

.quick_right{position: fixed; bottom: 40px; right: 40px; z-index: 100;}
.quick_right a{width: 56px; aspect-ratio: 1/1; box-sizing: border-box; border-radius: 20px; display: flex; align-items: center; justify-content: center; text-align: center; background-color: var(--bg); box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.10);}
.quick_right a + a{margin-top: 10px;}

@media all and (max-width:1024px){
	.quick_right{display: none;}
}