@charset "UTF-8";

.join { flex: 1; display: flex; flex-direction: column; align-items: center; width: 100%; background: #FBFBFB; padding: 100px 0; line-height: 1.2; }
.join--white { background: #FFFFFF; }
.join--pd0 { padding: 0 0 50px; }
.join__tit { font-size: 30px; font-weight: bold; }

/* 로그인 */
.login { display: flex; flex-direction: column; margin-top: 8px; }
.login__txt { width: 100%; text-align: center; font-size: 18px; margin-bottom: 40px; }
.login__select { display: flex; justify-content: center; align-items: center; margin-bottom: 10px; }
.login__box { display: flex; flex-direction: column; width: 100%; margin-bottom: 14px; }
.login__label { display: block; font-size: 14px; margin-bottom: 6px; }
.login__cover { display: block; width: 400px; height: 48px; position: relative; }
.login__input { display: block; width: 100%; height: 100%; box-sizing: border-box; border: 1px solid #E0E0E0; background: #FFFFFF; font-size: 16px; padding: 12px 20px; }
.login__input::placeholder { color: #B4B4B4; font-weight: 400; }
.login__dl { display: flex; justify-content: space-between; align-items: center; margin-bottom: 40px; }
.login__dt { display: flex; align-items: center; }
.login__label-check { display: flex; align-items: center; font-size: 16px; cursor: pointer; }
.login__save { display: flex; justify-content: center; align-items: center; width: 23px; height: 23px; border: 1px solid #ADADAD; background: #ADADAD; border-radius: 8px; margin-right: 6px; transition: all 0.3s; }
.login__icon { color: #3A84C4; line-height: 23px; font-size: 14px; font-weight: bold; opacity: 0; transition: all 0.3s; }
.login__checkbox { display: block; }
.login__checkbox:checked + .login__label-check .login__save { border: 1px solid #3A84C4; background: #FFFFFF; }
.login__checkbox:checked + .login__label-check .login__save .login__icon { opacity: 1; }
.login__find { display: block; font-size: 14px; text-decoration: underline; color: #666666; }
.login__btn-box { display: flex; flex-direction: column; width: 100%; }
.login__btn { display: flex; justify-content: center; align-items: center; width: 100%; height: 48px; font-size: 16px; border: 1px solid #E0E0E0; background: #FFFFFF; border-radius: 4px; margin-bottom: 14px; }
.login__btn--blue { background: #5732FB; color: #FFFFFF; border: 0; }
.login__list { display: flex; align-items: center; }
.login__item { display: flex; justify-content: center; align-items: center; width: 33.3333%; height: 48px; border: 1px solid #E0E0E0; background: #FFFFFF; margin-right: 14px; border-radius: 4px; font-size: 14px; cursor: pointer; }
.login__item--naver { border: 0; background: #00BF19; color: #FFFFFF; }
.login__item:last-child { margin-right: 0; }
.login__link { display: flex; justify-content: center; align-items: center; width: 100%; height: 100%; }
.login__img { display: block; width: 22px; height: 22px; object-fit: contain; margin-right: 4px; }
.login__img--git { height: 15px; }
.login__desc { display: none; }

/* 회원가입 01 */
.join-intro { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 710px; height: 305px; background: #FFFFFF; margin-top: 30px; }
.join-intro__mark { display: flex; justify-content: center; align-items: center; width: 60px; height: 60px; border: 2px solid #FF510F; border-radius: 50%; font-size: 23px; line-height: 60px; color: #FF510F; margin-bottom: 20px; }
.join-intro__desc { font-size: 18px; text-align: center; margin-bottom: 40px; }
.join-intro__btn { display: flex; justify-content: center; align-items: center; width: 400px; height: 48px; background: #5732FB; border-radius: 4px; color: #FFFFFF; margin-bottom: 20px; cursor: pointer; }
.join-intro__prev { display: block; text-align: center; font-size: 14px; color: #666666; text-decoration: underline; cursor: pointer; }

/* 약관동의 */
.privacy { display: flex; flex-direction: column; width: 100%; max-width: 710px; }
.privacy__label { display: flex; align-items: center; }
.privacy__label--all { font-size: 18px; }
.privacy__check { display: none; justify-content: center; align-items: center; width: 23px; height: 23px; border: 1px solid #ADADAD; background: #ADADAD; border-radius: 8px; margin-right: 6px; transition: all 0.3s; }
.privacy__check--all { width: 26px; height: 26px; }
.privacy__icon { color: #3A84C4; line-height: 23px; font-size: 14px; font-weight: bold; opacity: 0; transition: all 0.3s; }
.privacy__icon--all { font-size: 17px; }
.privacy__checkbox { display: inline-block; width: 17px; height: 17px; border-radius: 8px; margin-right: 6px; }
.privacy__checkbox:checked + .privacy__label .privacy__check { border: 1px solid #3A84C4; background: #FFFFFF; }
.privacy__checkbox:checked + .privacy__label .privacy__check .privacy__icon { opacity: 1; }
.provacy__bold { font-weight: bold; }
.privacy__input-box { display: flex; align-items: center; margin-bottom: 4px; }
.privacy__input-box--mgb30 { margin-bottom: 30px; }
.privacy__provision { display: block; width: 100%; height: 200px; overflow-y: scroll; background: #FFF; margin-bottom: 20px; padding: 20px; }
.privacy__provision--ㅡmgb50 { margin-bottom: 50px; }
.privacy__btn-box { width: 100%; display: flex; justify-content: center; }
.privacy__btn { display: flex; justify-content: center; align-items: center; width: 200px; height: 48px; border-radius: 4px; background: #5732FB; color: #FFF; }
/* 기존 이용약관 테이블스타일 */
.etcpop_table { width: 100%; border-top: 1px solid #dcdcdc; border-bottom: 1px solid #222; border-collapse: collapse; border-spacing: 0; table-layout: fixed; font-size: 13px; }
caption { display: none; }
.etcpop_table thead tr th { padding: 10px 0; font-weight: bold; color: #222; text-align: center; vertical-align: middle; border-bottom: 1px solid #222; background: #f8f8fa; }
.etcpop_table tbody tr td { padding: 10px 5px; color: #666; vertical-align: middle; border-top: 1px solid #dcdcdc; text-align: center; }
.agreeP2 { font-size: 13px; text-align: left; text-decoration: underline; padding: 0 0 0 0; font-weight: bold; }

/* 회원가입 인증 */
.certification { display: flex; align-items: center; margin-bottom: 20px; }
.certification__btn { display: flex; justify-content: center; align-items: center; width: 195px; height: 48px; border: 1px solid #E0E0E0; border-radius: 4px; font-size: 16px; }
.certification__btn--mgr10 { margin-right: 10px; }

/* 신분선택 */
.identity { display: flex; flex-direction: column; align-items: center; width: 710px; background: #FFFFFF; margin-top: 30px; padding: 40px 123px; }
.identity__tit { font-size: 18px; font-weight: bold; margin-bottom: 5px; }
.identity__desc { font-size: 18px; text-align: center; margin-bottom: 40px; }
.identity__btn { display: flex; justify-content: center; align-items: center; width: 100%; max-width: 400px; height: 48px; border: 1px solid #E0E0E0; border-radius: 4px; font-size: 16px; color: #1A1641; margin-bottom: 10px; cursor: pointer; transition: all 0.3s; }
.identity__btn:hover { border: 0; background: #3173C0; color: #FFFFFF; }

/* 정보입력 */
.join-reg { display: flex; flex-direction: column; width: 586px; }
.join-reg__tit { width: 100%; padding: 20px 0; border-bottom: 1px solid #000; text-align: center; position: relative; margin-bottom: 20px; }
.join-reg__tit-bold { font-size: 30px; font-weight: bold; }
.join-reg__tit-red { font-size: 14px; color: #FF3974; position: absolute; top: 50%; right: 0; transform: translateY(-50%); }
.join-reg__dl { display: flex; align-items: center; width: 100%; margin-bottom: 10px; }
.join-reg__dt { display: flex; min-width: 125px; font-size: 16px; font-weight: 600; }
.join-reg__dt--wd85 { min-width: 85px; }
.join-reg__star { color: #FF3974; }
.join-reg__dd { display: flex; align-items: center; width: 100%; }
.join-reg__dd--grid { display: grid; grid-template-columns: 1fr 82px; gap: 10px; }
.join-reg__dd--gird02 { display: grid; grid-template-columns: 1fr 120px; gap: 10px; }
.join-reg__dd--grid03 { display: grid; grid-template-columns: 1fr auto 1fr; gap: 10px; }
.join-reg__dd--grid04 { display: grid; grid-template-columns: 1fr 82px; gap: 10px; }
.join-reg__input { display: block; width: 100%; height: 40px; border: 1px solid #E2E2E2; background: #FFF; padding: 10px 15px; font-size: 16px; box-sizing: border-box; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.join-reg__input2 { display: block; width: 100%; height: 30px; border: 1px solid #E2E2E2; background: #FFF; padding: 5px 10px; font-size: 14px; box-sizing: border-box; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-align: left; }
.join-reg__input--col { grid-column: 1 / 3; }
.join-reg__select { display: block; width: 100%; height: 40px; border: 1px solid #E2E2E2; background: #FFF; padding: 7px 15px; font-size: 16px; box-sizing: border-box; }
.join-reg__select--mgr10 { margin-right: 10px; }
.join-reg__btn { display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; border: 1px solid #E2E2E2; background: #FFF; font-size: 16px; cursor: pointer; }
.join-reg__btn2 { display: flex; justify-content: center; align-items: center; width: 100%; height: 30px; border: 1px solid #E2E2E2; background: #FFF; font-size: 14px; cursor: pointer; }
.join-reg__btn2--disabled {background: #f2f2f2; pointer-events: none; opacity: 0.5;}
.join-reg__btn2:hover { background: #f2f2f2; }
.join-reg__btn:focus { outline: 3px solid red; }
.join-reg__info { display: flex; flex-direction: column; width: 100%; border: 1px solid #E2E2E2; background: #FBFBFB; padding: 20px; margin-bottom: 25px; }
.join-reg__info-box { display: flex; align-items: center; margin-bottom: 5px; }
.join-reg__info-box:last-child { margin-bottom: 0; }
.join-reg__info-left { width: 130px; font-size: 16px; font-weight: 600; color: #666666; }
.join-reg__info-right { font-size: 16px; }
.join-detail { display: flex; flex-direction: column; margin-bottom: 25px; }
.join-detail__tit { font-size: 20px; font-weight: bold; padding: 15px 0; border-bottom: 1px solid #E0E0E0; text-align: center; }
.join-detail__tit--mgb20 { margin-bottom: 20px; }
.join-detail__desc { font-size: 14px; color: #FF3974; margin-bottom: 20px; }
.join-detail__block { display: flex; padding-top: 20px; }
.join-detail__fig { display: flex; flex-direction: column; min-width: 105px; margin-right: 20px; }
.join-detail__img { display: block; width: 100%; height: 105px; object-fit: contain; }
.join-detail__btn { display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; border: 1px solid #E2E2E2; }
.ui-datepicker-trigger { display: block; width: 100% !important; height: 40px !important; background: #FFF !important; border: 1px solid #E2E2E2 !important; border-radius: 0 !important; object-fit: contain; padding: 0 !important; }
.ui-datepicker-trigger img { display: block; width: 100%; height: 100%; object-fit: contain; }
.join-reg__save { display: flex; justify-content: center; align-items: center; width: 100%; margin-top: 25px; }
.join-reg__save-btn { display: flex; justify-content: center; align-items: center; width: 200px; height: 48px; border-radius: 4px; background: #5732FB; color: #FFFFFF; cursor: pointer; }
.join-reg__add { margin-bottom: 30px; }
.join-detail__add-btnbox { display: flex; justify-content: center; align-items: center; width: 100%; }
.join-detail__add-btn { display: flex; justify-content: center; align-items: center; width: 130px; height: 50px; border: 1px solid #BDBDBD; background: #FFF; border-radius: 30px; font-size: 16px; font-weight: 400; cursor: pointer; }
.join-detail__add-btn--blue { border: 0; background: #5732FB; color: #FFF; margin-right: 20px; }

.join-box { padding: 20px; background: #F6F6F6; font-size: 14px; line-height: 1.5; margin-bottom: 20px; }

/* 회원가입 완료 */
.complete { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 710px; height: 211px; position: relative; margin-top: 30px; }
.complete__tit { font-size: 18px; margin-bottom: 6px; }
.complete__desc { font-size: 14px; margin-bottom: 40px; }
.complete__link { display: flex; justify-content: center; align-items: center; width: 200px; height: 48px; border-radius: 4px; background: #5732FB; font-size: 16px; color: #FFFFFF; }
.complete__img { display: block; width: 207px; position: absolute; }
.complete__img--left { top: -64px; left: 0; }
.complete__img--right { top: -64px; right: 0; }

.mnto_intro_flx { display: flex; align-items: center; gap: 10px; }
.mnto_intro_rls_yn { /* appearance: none; */ display: ilnine-block; width: 23px; height: 23px; border: 1px solid #E2E2E2; background: #E2E2E2; border-radius: 50%; margin: 0; position: relative; transition: all 0.3s; }
.mnto_intro_rls_yn::before { content: ''; display: block; width: 9px; height: 9px; border-radius: 50%; background: #E2E2E2; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); transition: all 0.3s; }
.mnto_intro_rls_yn:checked { border: 1px solid #1876FB; background: #fff; }
.mnto_intro_rls_yn:checked::before { background: #1876FB; }


@media (max-width: 768px) {
	.join { justify-content: center; padding: 40px 0; background: #FFFFFF; }
	.join--bg { background: #F7F7F7; }
	.join__tit { font-size: 20px; }
	.join__tit--none { display: none; }
	
	.login { width: 100%; padding: 0 30px; margin-top: 5px; }
	.login__txt { font-size: 14px; margin-bottom: 30px; }
	.login__box { margin-bottom: 10px; }
	.login__label { display: none; }
	.login__cover { width: 100%; height: 45px; }
	.login__input { border: 1px solid #EEEEEE; font-size: 14px; padding: 15px 11px; border-radius: 10px; }
	.login__save { width: 16px; height: 16px; border-radius: 5px; }
	.login__icon { font-size: 10px; }
	.login__label-check { font-size: 14px; font-weight: 400; }
	.login__find { font-size: 12px; font-weight: 400; color: #ADADAD; }
	.login__btn-box { margin-bottom: 50px; }
	.login__btn { height: 50px; border: 1px solid #EEEEEE; font-weight: 400; border-radius: 10px; margin-bottom: 0; }
	.login__btn--blue { margin-bottom: 10px; }
	.login__desc { display: block; text-align: center; font-size: 15px; font-weight: bold; margin-bottom: 20px; }
	.login__item { margin-right: 10px; border-radius: 10px; font-weight: 400; }
	.login_text { display: none; }
	.login__img { width: 20px; height: 20px; }
	.login__img--git { height: 13px; }
	
	.join-intro { width: 100%; height: auto; margin-top: 0; padding: 0 30px; }
	.join-intro__mark { width: 87px; height: 87px; border: 1px solid #FF510F; font-size: 33px; margin-bottom: 15px; }
	.join-intro__desc { font-size: 14px; }
	.join-intro__btn { width: 100%; height: 50px; border-radius: 10px; font-weight: 400; }
	.join-intro__prev { font-size: 12px; font-weight: 400; color: #ADADAD; }
	
	.privacy { padding: 0 15px;  }
	.privacy__input-box { margin-bottom: 0; }
	.privacy__input-box--mgb30 { margin-bottom: 40px; }
	.privacy__provision { border-radius: 0 0 10px 10px; font-size: 12px; }
	.etcpop_table { font-size: 11px; }
	.privacy__label { width: 100%; padding: 15px; background: #FFFFFF; border-radius: 10px 10px 0 0; border-bottom: 1px solid #EEEEEE; font-size: 14px; }
	.privacy__label--all { width: 100%; height: 60px; border-radius: 10px; background: #ADADAD; font-size: 15px; font-weight: bold; padding: 15px; transition: all 0.3s; }
	.privacy__check { width: 15px; height: 15px; border-radius: 4px; }
	.privacy__icon { font-size: 8px; }
	.privacy__checkbox--all:checked + .privacy__label--all { background: #1F4690; color: #FFFFFF; }
	.privacy__checkbox--all:checked + .privacy__label--all .privacy__check--all { border: 0; background: transparent; }
	.privacy__checkbox--all:checked + .privacy__label--all .privacy__check--all .privacy__icon--all { color: #FFFFFF; }
	.privacy__btn { position: fixed; bottom: 65px; left: 0; width: 100%; height: 60px; z-index: 3; color: #FFFFFF; background: #1F4690; border-radius: 0; font-size: 20px; }
	
	.certification { width: 100%; }
	.certification__btn { width: 100%; border-radius: 10px; border: 1px solid #EEEEEE; font-size: 16px; font-weight: 400; }
	
	.identity { padding: 0 30px; width: 100%; }
	.identity__tit { font-size: 14px; }
	.identity__desc { font-size: 14px; }
	.identity__btn { height: 50px; border-radius: 10px; border: 1px solid #EEEEEE; font-size: 16px; font-weight: 400; }
	
	.join-reg { width: 100%; padding: 0 20px; }
	.join-reg__tit { text-align: left; border-bottom: 0; }
	.join-reg__tit-bold { display: none; }
	.join-reg__tit-red { position: relative; top: 0; left: 0; transform: translateY(0); font-size: 10px; }
	.join-reg__dl { flex-direction: column; align-items: flex-start; margin-bottom: 20px; }
	.join-reg__dt { min-width: 100%; font-size: 12px; color: #888888; margin-bottom: 6px; }
	.join-reg__dd--grid { grid-template-columns: 1fr 75px; }
	.join-reg__dd--grid04 { grid-template-columns: 1fr; gap: 0; position: relative; }
	.join-reg__input { border: 0; height: 48px; background: #F5F5F5; border-radius: 10px; font-size: 15px; padding: 15px; }
	.join-reg__input--date { padding: 15px 40px 15px 15px; }
	.join-reg__btn { height: 48px; border: 1px solid #EEEEEE; border-radius: 10px; font-size: 14px; }
	.join-reg__info { border: 1px solid #EEEEEE; background: #FFFFFF; border-radius: 10px; padding: 15px; margin-top: 10px; }
	.join-reg__info-left { width: 100px; font-size: 12px; color: #ADADAD; }
	.join-reg__info-right { font-size: 12px; }
	.join-detail__tit { font-size: 17px; text-align: left; padding: 10px 0; border-bottom: 1px solid #000; }
	.join-detail__block { flex-direction: column; align-items: center; }
	.join-detail__fig { align-items: center; min-width: 173px; margin-right: 0; }
	.join-detail__img { width: 150px; height: 150px; margin-bottom: 12px; }
	.join-detail__cap { width: 100%; }
	.join-detail__btn { height: 48px; border-radius: 10px; border: 1px solid #EEEEEE; font-size: 14px; }
	.join-reg__select { border: 0; height: 48px; background: #F5F5F5; border-radius: 10px; font-size: 15px; padding: 10px 15px; }
	.join-reg__mobile { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
	.join-reg__dd--date { grid-template-columns: 1fr; gap: 0; position: relative; }
	.ui-datepicker-trigger { width: 20px !important; height: 20px !important; background: transparent !important; border: 0 !important; position: absolute; top: 50%; right: 12px; transform: translateY(-50%);  }
	.join-reg__save-btn { position: fixed; bottom: 65px; left: 0; width: 100%; height: 60px; background: #1F4690; font-size: 20px; z-index: 3; border-radius: 0; }
	
	.complete { width: 100%; height: auto; margin-top: 0; padding: 0 50px; }
	.complete__tit { font-size: 14px; font-weight: bold; margin-bottom: 0; }
	.complete__desc { text-align: center; }
	.complete__link { width: 150px; height: 38px; font-size: 14px; position: relative; z-index: 2; }
	.complete__img { width: 125px; z-index: 1; }
	.complete__img--left { top: 55px; }
	.complete__img--right { right: -31px; }
}