@charset "UTF-8";

/* 로그인 */
main:has(section.user-login) {
	background-color: #F1F3F5;
}

.simple-footer {
	display: flex;
	flex-direction: column;
	gap: 20px;
	align-items: center;
	padding: 0 16px 70px;
}

.simple-footer ul {
	display: flex;
}

.simple-footer ul li {
	padding: 4px 10px;
	position: relative;
}

.simple-footer ul li a {
	color: #7C7E81;
	font-size: 14px;
	font-weight: 400;
}

.simple-footer ul li:not(:first-child) a:after {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	margin-top: -6px;
	width: 1px;
	height: 12px;
	background: #DDD;
}

.simple-footer .copyright {
	font-size: 14px;
	font-weight: 400;
	color: #959AA0;
	padding: 0 10px;
}

.login {
	width: 460px;
	margin: 0 auto;
	padding-top: 140px;
	padding-bottom: 150px;
}

.login.user-login {
	max-width: 574px;
	margin: 0 auto;
	width: 100%;
	padding-top: 100px;
	padding-bottom: 91px;
}

.user-login .login-wrap {
	background-color: #FFFFFF;
	padding: 64px 57px 78px;
	border-radius: 15px;
}

.user-login .login-wrap .top {
	display: flex;
	justify-content: center;
	padding-bottom: 63px;
}

.user-login .login-wrap .top a {
	display: block;
	padding: 10px
}

.user-login .login-wrap .top a img {
	width: 182px;
}

.login h2 {
	font-size: 32px;
	font-weight: 600;
	letter-spacing: -1.6px;
	color: #111;
	text-align: center;
	line-height: normal;
}

.login .input-box {
	margin-top: 41px;
}

.login .input-box > div {
	position: relative;
}

.login .input {
	display: block;
	margin-top: 15px;
}

.login .login-sub {
	margin: 18px 0 50px;
}

.login .login-sub span {
	font-size: 0;
}

.login .login-sub a {
	position: relative;
	margin-left: 12px;
	padding-left: 12px;
	font-size: 15px;
	font-weight: 400;
	line-height: 20px;
	letter-spacing: -0.15px;
	color: #555;
}

.login .login-sub a:after {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	margin-top: -6px;
	width: 1px;
	height: 12px;
	background: #ebebeb;
}

.login .login-sub a:first-child {
	margin-left: 0;
	padding-left: 0;
}

.login .login-sub a:first-child:after {
	display: none;
}

.login .login-sub input[type="checkbox"] + label {
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
	font-weight: 400;
	line-height: 20px;
	color: #999999;
	cursor: pointer;
	letter-spacing: -0.14px;
	height: 20px;
}

.login .login-sub input[type="checkbox"] + label span {
	position: relative;
	margin-right: 8px;
	display: inline-block;
	vertical-align: middle;
	background: none;
	width: 20px;
	height: 20px;
	border: 1px solid #DEDEDE;
	border-radius: 3px;
	box-sizing: border-box;
}

.login .login-sub input[type="checkbox"]:checked + label span {
	background: #111 url('../images/default/icon/bg_checkbox-w.svg');
	background-position: -1px;
	background-size: 20px 20px;
	border-color: #111;
}

.login .sns-box {
	margin-top: 43px;
}

.login .sns-box strong {
	display: block;
	font-size: 16px;
	line-height: normal;
	letter-spacing: -0.48px;
	text-align: center;
	color: #7C838A;
	font-weight: 500;
}

.login .sns-box ul {
	margin-top: 18px;
	font-size: 0;
	text-align: center;
}

.login .sns-box li {
	display: inline-block;
	vertical-align: middle;
	margin: 0 14px;
}

.login.on .btn-type01 {
	background: #ffd013;
	color: #111;
}

.login.on .input-box > div a {
	position: absolute;
	top: 0;
	right: 0;
	padding-left: 20px;
	background: url('../images/default/icon/ico_faq.svg') 0 50% no-repeat;
	background-size: 15px 15px;
	font-size: 14px;
	font-weight: 500;
	color: #f45452;
	letter-spacing: -0.05em;
}

.login.on .input-box .ico-faq { /* margin-top: 10px; */
}

.login.on .on-cont {
	display: flex;
	margin-top: 10px;
	margin-bottom: 20px;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 4px;
}

.login .notice { /*padding-left:21px;background: url('../images/default/icon/ico_notice.svg') 0 50% no-repeat;background-size: 15px 15px;*/
	font-size: 14px;
	font-weight: 500;
	color: #f45452;
	letter-spacing: -0.05em;
	line-height: 20px;
	padding-right: 7px;
}

.login.on .login-sub {
	margin-top: 17px;
}

.password-find .desc {
	margin-top: 10px;
	font-size: 14px;
	font-weight: 500;
	line-height: 20px;
	letter-spacing: -0.05em;
	color: #777;
}

.password-find .btn-type01 {
	margin-top: 62px;
}

.password-find .btn-type01:not(.on) {
	pointer-events: none;
}

.password-find .btn-flex {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.password-find .btn-flex a {
	font-size: 15px;
	font-weight: 500;
	letter-spacing: -0.025em;
	color: #555;
}

.password-find .password-confirm {
	margin-top: 40px;
	padding: 50px 0 45px;
	border-top: 1px solid #f4f4f4;
	border-bottom: 1px solid #f4f4f4;
	text-align: center;
}

.password-find .password-confirm strong {
	display: block;
	font-size: 20px;
	line-height: 21px;
	font-weight: 600;
	color: #222;
}

.password-find .password-confirm p {
	margin-top: 10px;
	font-size: 18px;
	line-height: 23px;
	font-weight: 500;
	color: #777;
}

.password-find .password-confirm + .btn-type01 {
	margin-top: 50px;
}

.password-find.on .desc {
	display: none;
}

.password-find.on .notice {
	background-position: 0 3px;
}


.speech-bubble {
	position: absolute;
	background: #111111;
	border-radius: 15px;
	width: 130px;
	height: auto;
	top: calc(100% + 11px);
	left: 50%;
	display: none;
	transform: translateX(-50%);
	box-shadow: 0px 4px 6px 0px rgba(0, 0, 0, 0.1);
}

.speech-bubble.lastLogin {
	display: block;
}

.speech-bubble.inputBox {
	z-index: 1;
);
);
}

.speech-bubble h1 {
	color: #efefef;
	font-size: 14px;
	text-align: center;
	line-height: 32px;
	font-family: 'Pretendard';
	font-weight: 400;
	letter-spacing: -0.42px;
}

.speech-bubble:after {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	width: 0;
	height: 0;
	border: 6px solid transparent;
	border-bottom-color: #111111;
	border-top: 0;
	margin-left: -6px;
	margin-top: -5px;
}

#article2,
#s-tab2 {
	display: none;
}


/* 회원가입 */
.join .text {
	margin-top: 38px;
	line-height: 25px;
	letter-spacing: -0.025em;
	text-align: center;
}

.join .text strong {
	display: block;
	font-size: 20px;
	font-weight: 600;
	color: #111;
}

.join .text span {
	display: block;
	font-size: 14px;
	font-weight: 500;
	color: #777;
}

.join .btn-type01 {
	margin-top: 35px;
}

.join-step {
	margin-top: 40px;
	font-size: 0;
	text-align: center;
}

.join-step li {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	margin-right: 14px;
	padding-right: 20px;
	font-size: 15px;
	font-weight: 500;
	line-height: 18px;
	color: #868686;
	letter-spacing: -0.025em;
}

.join-step li:after {
	content: '';
	position: absolute;
	right: 0;
	top: calc(50% - 1px);
	width: 9px;
	height: 11px;
	margin-top: -5px;
	background: url('../images/default/arrow/bg_next-arrow-on2.svg') no-repeat;
	position: absolute;
	opacity: 0.3;
}

.join-step li:last-child {
	margin-right: 0;
	padding-right: 0;
}

.join-step li:last-child:after {
	display: none;
}

.join-step li em {
	display: inline-block;
	margin-right: 6px;
	width: 18px;
	height: 18px;
	background: #ccc;
	border-radius: 100%;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: -0.05em;
	color: #fff;
	text-indent: -1px;
}

.join-step li.on {
	font-weight: 600;
	color: #222;
}

.join-step li.on em {
	background: #222;
}

.join-step li.on:after {
	opacity: 1;
}

.join.on li > p {
	display: none;
}

.agree-wrap {
	margin-top: 25px;
}

.agree-wrap .all-agree {
	display: block;
	padding: 25px 0;
	border-bottom: 1px solid #e5e5e5;
}

.agree-wrap .all-agree input[type="checkbox"] + label {
	display: block;
	vertical-align: middle;
	font-size: 16px;
	font-weight: 600;
	line-height: 20px;
	color: #222;
	cursor: pointer;
}

.agree-wrap .all-agree input[type="checkbox"] + label span {
	position: relative;
	margin-right: 15px;
	display: inline-block;
	vertical-align: middle; /* background:url('../images/default/check/bg_check.jpg') no-repeat; */
	width: 20px;
	height: 20px;
	box-sizing: border-box;
	border: 1px solid #E1E1E1;
	border-radius: 3px;
}

.agree-wrap .agree-list {
	margin-top: 13px;
}

.agree-wrap .agree-list li {
	position: relative;
}

.agree-wrap .agree-list li a {
	display: block;
	font-size: 15px;
	font-weight: 500;
	line-height: 15px;
	color: #555;
}

.agree-wrap .agree-list li a .checkbox {
	width: calc(100% - 28px);
	padding: 12px 0;
}

.agree-wrap .agree-list li a .checkbox div {
	display: inline-block;
	width: calc(100% - 40px);
}

.agree-wrap .agree-list span {
	display: block;
}

.agree-wrap .agree-list br {
	display: none;
}

.agree-wrap .agree-list input[type="checkbox"] + label {
	display: inline-block;
	vertical-align: middle;
	font-size: 15px;
	font-weight: 500;
	line-height: 24px;
	color: #555;
	cursor: pointer;
}

.agree-wrap .agree-list input[type="checkbox"] + label span {
	position: relative; /* margin-right:15px; */
	margin: 3px 15px 3px 0;
	display: inline-block;
	vertical-align: top;
	width: 20px;
	height: 20px;
	border-radius: 100%;
}

.agree-wrap .agree-list input[type="checkbox"] + label span,
.agree-wrap .all-agree input[type="checkbox"] + label span {
	background-color: transparent;
	border: 1px solid #E1E1E1;
	box-sizing: border-box;
}

.agree-wrap .agree-list input[type="checkbox"] + label[for="agree04"] span:last-child {
	border: none;
	display: inline;
	background: none;
}

.agree-wrap .agree-list .on input[type="checkbox"] + label span,
.agree-wrap .all-agree input[type="checkbox"]:checked + label span {
	border-color: #111;
	background-image: url('../images/default/icon/bg_checkbox-w.svg');
	background-color: #111;
	background-repeat: no-repeat;
	background-size: 20px 20px;
	background-position: -1px -1px;
}

.agree-wrap .agree-list .arrow {
	position: absolute;
	right: -15px;
	top: 0;
	padding: 20px 15px 21px 15px;
	width: 13px;
	height: 7px;
	transition: 0.2s rotate;
}

.agree-wrap .agree-list :has(.agree-text.open) .arrow {
	rotate: 180deg;
}

.agree-wrap .agree-text {
	display: none;
	margin-bottom: 18px;
	height: 215px;
	overflow-y: scroll;
	padding: 20px;
	background: #fafafa;
	border: 1px solid #f1f1f1;
	border-radius: 5px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-ms-box-sizing: border-box;
}

.agree-wrap .agree-text > strong {
	display: block;
	font-size: 14px;
	font-weight: 600;
	line-height: 23px;
	letter-spacing: -0.025em;
	color: #777;
}

.agree-wrap .agree-text > ol > li,
.agree-wrap .agree-text strong {
	display: block;
	margin-top: 16px;
}

.agree-wrap .agree-text ol li:first-child,
.agree-wrap .agree-text strong:first-child {
	margin-top: 0;
}

.agree-wrap .agree-text ol strong {
	display: block;
	font-size: 14px;
	font-weight: 600;
	line-height: 29px;
	letter-spacing: -0.025em;
	color: #777;
}

.agree-wrap .agree-text ol p {
	margin-top: 3px;
	font-size: 14px;
	font-weight: 500;
	line-height: 23px;
	letter-spacing: -0.025em;
	color: #777;
}

.agree-wrap .agree-text ol ol li {
	font-size: 14px;
	font-weight: 500;
	line-height: 23px;
	letter-spacing: -0.025em;
	color: #777;
}

.agree-wrap .agree-text ul li {
	position: relative;
	padding-left: 8px;
	font-size: 14px;
	font-weight: 500;
	line-height: 23px;
	letter-spacing: -0.025em;
	color: #777;
}

.agree-wrap .agree-text ul li:before {
	content: '';
	position: absolute;
	top: 10px;
	left: 0;
	width: 3px;
	height: 3px;
	background: #898989;
}

.agree-wrap .btn-type01 {
	margin-top: 34px;
}

.info-write .btn-type01:not(.on):hover, .agree-wrap .btn-type01:not(.on):hover {
	background: #f5f5f5;
	color: #c7c7c7;
	cursor: default;
}

.info-write .input {
	margin-top: 0;
}

.info-write li {
	margin-top: 15px;
}

.info-write .mt-gap {
	margin-top: 30px;
}

.info-write .btn-type01 {
	margin-top: 50px;
}

.write-list {
	margin-top: 50px;
}

.write-list .email {
	font-size: 0;
}

.write-list .email .input, .write-list .email .email-domain {
	display: inline-block;
	vertical-align: middle;
	width: 215px;
}

.write-list .email em {
	display: inline-block;
	vertical-align: middle;
	margin: 0 8px;
	font-size: 15px;
	font-weight: 500;
	letter-spacing: -0.025em;
	color: #555;
	line-height: 60px;
}

.write-list .email .email-domain .select-box button {
	color: #555;
}

.write-list .email .email-domain .select-box {
	display: inline-block;
	position: relative;
}

.write-list .email .email-domain .select-box .input {
	display: block;
	width: calc(100% - 20px);
	border: 0;
}

.write-list .email .email-domain .select-box .input input {
	border: 0;
}

.write-list .email .email-domain .select-box button {
	height: 60px;
	width: fit-content;
	right: 0;
	position: absolute;
	top: 0;
}

.write-list .email .email-domain .select-box > div:not(.mo-dimm) {
	top: 56px;
}

.write-list .info { /* margin-top: 10px; */
	padding-left: 8px;
	background: url('../images/loginJoin/bg_info-dot.jpg') 0 50% no-repeat;
	font-size: 14px;
	font-weight: 500;
	line-height: 18px;
	color: #868686;
	letter-spacing: -0.025em;
}

.write-list #emailNotice {
	padding-top: 15px;
}

.write-list #passCont, .write-list #nickCont {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.choice-wrap { /*margin-top:30px;padding-top:30px;border-top:1px solid #f4f4f4;*/
	padding-top: 15px;
}

.choice-wrap .radio-wrap {
	font-size: 0;
}

.choice-wrap .radio-wrap strong {
	display: inline-block;
	vertical-align: middle;
	margin-right: 15px;
	font-size: 15px;
	font-weight: 500;
	line-height: 23px;
	color: #868686;
	letter-spacing: -0.025em;
}

.choice-wrap .radio-wrap .radio-box {
	display: inline-block;
	vertical-align: middle;
}

.choice-wrap input[type="radio"] + label {
	display: inline-block;
	vertical-align: middle;
	margin-right: 20px;
	font-size: 15px;
	font-weight: 500;
	line-height: 19px;
	color: #555;
	cursor: pointer;
}

.choice-wrap input[type="radio"] + label span {
	position: relative;
	margin-right: 10px;
	display: inline-block;
	vertical-align: middle;
	width: 19px;
	height: 19px;
	border: 2px solid #E1E1E1;
	border-radius: 100%;
}

.choice-wrap input[type="radio"]:checked + label span {
	background: url('../images/default/check/bg_radio-on.svg') -2px -2px no-repeat;
	border: 2px solid #333;
	border-radius: 100%;
}

.choice-list {
	margin-top: 25px;
}

.optional-wrap {
	font-size: 17px;
	font-weight: 500;
	line-height: 23px;
	color: #1e1e1e;
	letter-spacing: -0.025em;
	padding-top: 24px;
	padding-bottom: 12px
}

.mail-cert {
	margin-top: 50px;
}

.mail-cert .cert-send {
	padding: 50px 0 48px;
	border-top: 1px solid #f4f4f4;
	border-bottom: 1px solid #f4f4f4;
	text-align: center;
}

.mail-cert .cert-send strong {
	display: block;
	font-size: 20px;
	font-weight: 600;
	line-height: 20px;
	color: #222;
}

.mail-cert .cert-send p {
	margin-top: 15px;
	font-size: 18px;
	font-weight: 500;
	line-height: 18px;
	color: #777;
}

.mail-cert .cert-send p br {
	display: none;
}

.mail-cert .check-text {
	margin-top: 30px;
}

.mail-cert .check-text strong {
	display: block;
	padding-left: 28px;
	background: url('../images/default/icon/bg_checklist-on.svg') 5px 50% no-repeat;
	font-size: 15px;
	font-weight: 600;
	line-height: 15px;
	color: #111;
}

.mail-cert .check-text ul {
	margin-top: 20px;
	padding: 19px 100px 25px 19px;
	border: 1px solid #f1f1f1;
	border-radius: 5px;
	background: #fafafa;
}

.mail-cert .check-text li {
	margin-top: 4px;
	padding-left: 8px;
	background: url('../images/loginJoin/bg_info-dot.jpg') 0 10px no-repeat;
	font-size: 14px;
	font-weight: 500;
	line-height: 23px;
	color: #868686;
	letter-spacing: -0.025em;
}

.mail-cert .check-text li:first-child {
	margin-top: 0;
}

.mail-cert .check-text li a {
	font-size: 14px;
	font-weight: 500;
	line-height: 23px;
	color: #868686;
	letter-spacing: -0.025em;
	border-bottom: 1px solid #999;
}

.mail-cert .check-text .notice {
	display: block;
	margin-top: 12px;
	padding-left: 22px;
	font-size: 13px;
	color: #f45452;
	letter-spacing: -0.025em;
	text-decoration: underline;
}

.mail-cert .btn-type01 {
	margin-top: 50px;
}

.mail-cert .go-back {
	display: block;
	margin-top: 20px;
	padding-left: 24px;
	background: url('../images/default/arrow/btn_profile-arrow.svg') 0 50% no-repeat;
	font-size: 15px;
	font-weight: 500;
	color: #555;
	letter-spacing: -0.025em;
}


/**
jconfirm
*/
.jconfirm {
	position: fixed;
	left: 0px;
	top: 0px;
	z-index: 1000;
	width: 100%;
	height: 100%;
}

.jconfirm-bg {
	position: absolute;
	width: 100%;
	height: 100%;
	background: #000000;
	opacity: 0.65;
}

.jconfirm-scrollpane {
	position: relative;
	width: 390px;
	margin: 0 auto;
	margin-top: 200px;
}

.jconfirm-row {
	font-weight: 700;
	background-color: #ffffff;
}


.jconfirm-content {
	padding: 39px 35px 0px;
}

.jconfirm-content.event {
	padding: 0px;
}

.jconfirm-content.event .rdo {
	padding: 0 0 0 25px;
}

.jconfirm-content.event .rdo span::before {
	width: 20px;
	height: 20px;
	background-size: 20px;
	background-position: 0 0px;
	top: 12px;
}

.jconfirm-content.event .rdo input:checked + span:before {
	background-position: 0 -20px;
}

.jconfirm-buttons {
	display: flow-root;
	padding-top: 30px;
	padding-right: 35px;
	padding-bottom: 40px;
}

.jconfirm-buttons.event {
	padding-right: 0px;
	text-align: center;
	padding-bottom: 20px;
	padding-top: 20px;
}

.jconfirm-buttons > .btn {
	cursor: pointer;
	line-height: 36px;
	text-align: center;
	margin-left: 8px;
	font-size: 16px;
	width: 108px;
	height: 36px;
	background-color: #424242;
	opacity: 1;
	color: #FFFFFF;
	border: 1px solid #424242;
	float: right;
	line-height: 16px;
}

.jconfirm-buttons.event > .btn {
	float: none;
}

.jconfirm-buttons > .btn.event {
	width: 150px;
	border-radius: 30px;
}

/*.jconfirm-closeIcon {*/
/*	background-image: url(../images/common/banner_close_white.png);*/
/*	width: 17px;*/
/*	height: 17px;*/
/*	position: absolute;*/
/*	right: 7px;*/
/*	top: 7px;*/
/*	cursor: pointer;*/
/*}*/

.login.on .notice.auth {
	color: #000;
	font-size: 15px;
	background: none;
	padding-left: 0px;
}

.on-cont .email-tit {
	background: url(../images/loginJoin/img_confirm.png) center left no-repeat;
	padding: 20px 0;
	font-size: 17px;
	padding-left: 35px;
}

.on-cont .email-tit > div > span {
	color: #cc3838
}

#article2,
#s-tab2 {
	display: none
}

#join-1,
#join-2,
#join-3 {
	display: none
}

.list-more > li:nth-child(n+6) {
	display: none
}


.name .division.service0,
.mypage-top-free > em {
	background-color: #1b222f !important;
}

.name .division.service1,
.mypage-top-student > em {
	background-color: #26bcb7 !important;
}

.name .division.service2,
.mypage-top-normal > em {
	background-color: #006dfe !important;
}

.name .division.service4,
.mypage-top-proPlus > em {
	background-color: #F63587 !important;
}

.mypage-top-pro > em {
	background-color: #4e2bf4 !important;
}

#userInfoButton,
.sns > li,
#passSubmit {
	pointer-events: none;
}

#userInfoButton.on,
.sns > li.on,
#passSubmit.on {
	pointer-events: auto;
}

.sns-connection-on {
	display: flex
}

#snsContentList > div:nth-child(n+2) {
	margin-top: 0;
	border-top: none
}

#snstab2,
#snstab3,
#snstab4,
#snstab5,
#snstab6 {
	display: none
}


/**
회원가입
**/

#ages,
#job,
#singupPath,
#usage {
	border: none
}

.noEvents {
	pointer-events: none;
}

.pop-message.pop-type01 .btn-box {
	border: none;
}


.mo-dimm {
	display: none;
}