html, body {
	margin: 0;
	height: 100%;
	width: 100%;
}

.ui-widget.ui-widget-content {
	border: 0;
	background: #fff;
}

input[name=opt_input_code]::-webkit-inner-spin-button,
input[name=opt_input_code]::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

input[readonly="readonly"] {
	background: #f1f1f1;
}

.loginBody {
	background: linear-gradient(120deg, #76caf9 0%, #5583de 40%, #9574c9 100%);
	height: 100%;
}

.loginWrapper {
	height: 100%;
	background-image: url("../images/login/img_1.png");
	background-repeat: no-repeat;
	background-position: 80%;
}

.loginBox {
	height: 200px;
	width: 400px;
	color: #ffffff;
	text-align: center;
	position: absolute;
	top: 40%;
	left: 30%;
	transform: translate(-32%, -50%);
}

.loginBox .logo {
	vertical-align:top;
	height: 44px;
	width: 280px;
	margin: 0 auto 30px;
	background-image: url("../images/login/logo_b.png");
	background-repeat: no-repeat;
	background-position: center;
}

.loginBox .login_input {
	font-size: 14px;
	background-color: #f7f7f7;
	color: #403D54;
	width: 100%;
	height: 48px;
	padding-left: 10px;
	border-radius: unset;
	border: none;
}

.loginBox .remember {
	line-height: 20px;
}

.loginBox .remember input[type=checkbox] + label {
	color: inherit;
	margin-right: 0;
}
.loginBox .remember input[type=checkbox]+ label:before {
	bottom: 2px;
}
.loginBox .rememberLabel:after {
	content: '아이디 저장';
}

/* 비밀번호 , 회원가입 */
.searchPwd, .signup {
	line-height: 20px;
}

/* slide button style */
.link-effect-4 a {
	font-size: 1rem;
	padding: 0 10px;
	margin: 0 20px;
	color: #929292;
	text-shadow: none;
	position: relative;
}

.link-effect-4 a::before {
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	padding: 0 10px;
	max-height: 0;
	color: #EFB724;
	content: attr(data-hover);
	-webkit-transition: max-height 0.5s;
	-moz-transition: max-height 0.5s;
	transition: max-height 0.5s;
}

.link-effect-4 a:hover::before {
	max-height: 100%;
}

a.btn-small span.btn {
	height: 20px;
}

.btn-slide {
	position: relative;
	display: inline-block;
	margin-top: 20px;
	color: #ffffff;
	background: linear-gradient(54deg, #3459a4 0%, #3b2ba3 100%);
	position: relative;
	display: inline-block;
	height: 68px;
	width: 100%;
	line-height: 65px;
	padding: 0 20px;
	font-size: 24px;
	cursor: pointer;

	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;

	transition: .5s;
	-webkit-transition: .5s;
}

.btn-slide:hover {
	text-decoration: none;
	background: linear-gradient(0deg, #3459a4 0%, #3b2ba3 100%);
}

.btn-slide span.title {
	transition: .5s;
	-webkit-transition: .5s;
}

.loginBody .signup .signup-text,
.loginBody .searchPwd .searchPwd-text {
	padding-left : 20px;
	cursor: pointer;
}

.loginBody .login-text {
	display:inline-flex;
	margin-top: 20px;
}

.loginBody .field-label {
	float : left;
	min-width : 131px;
	max-width : 131px;
}

/* google login */
.google-login-box{
	/* border-bottom: 1px solid #7491ab;
	margin-bottom: 20px; */
}
.google-login-btn {
	position: relative;
	cursor: pointer;
	width: 100%;
	height: 48px; line-height: 40px;
	border: 3px solid #4081ec;
	border-style: solid;
	border-image: linear-gradient(to right, #4081ec 0%, #2ba24c 100%);
	border-image-slice: 1;
	margin-bottom: 10px;
}
.google-login-btn:before {
	content: '';
	width: 0;
	height: 100%;
	position: absolute;
	top: 0; left: 0;
	transition: all 0.5s ease;
	background: linear-gradient(to right, #4081ec 0%, #2ba24c 100%);
}
.google-login-btn:hover:before {
	width: 100%;
}

.google-login-btn .g-logo {
	display: inline-block;
	vertical-align: middle;
	background: url("../images/login/g-logo.png") left top no-repeat;
	background-size: cover;
	width: 18px; height: 18px;
	margin-right: 5px;
}

.google-login-btn > span {
	position: relative;
	z-index: 1;
}

/* apple login */
#appleid-signin{
	height: 48px;
	margin-bottom: 10px;
}

#appleid-signin div{
	max-width: none !important;
}

/* kakao login */
.kakao-login-box{
	background:#F7E600;
	height: 48px;
	margin-bottom: 10px;
	border-radius: 12px;
}

/* copyrights */
#copyrights {
	color: #fff;
	font-size: 14px;
	font-weight: 200;
	text-align: center;
	width: 100%;
	position: fixed;
	bottom: 20px;
	left: auto; right: auto;
}

/* --  _style2 -- */
.loginBody._style2 {
	background: #b2d6e6;
}
.loginBody._style2 .loginBox {
	color: #273e5b;
}
.loginBody._style2 .loginWrapper {
	background-image: url("../images/login/img_2.png");
}
.loginBody._style2 #copyrights {
	color: #273e5b;
}
.loginBody._style2 .google-login-btn .g-logo {
	background: url("../images/login/g-logo_b.png") left top no-repeat;
}
.loginBody._style2 .btn-slide {
	background: #376b86;
}
.loginBody._style2 .btn-slide:hover {
	color: #fff;
}


@media screen and (max-width: 1550px) {
	.loginBox {
		left: 20%;
	}
	.loginWrapper {
		background-position: 95%;
	}
}
@media screen and (max-width: 1076px) {
	.loginWrapper {
		background-size: 60%;
	}
}
@media screen and (max-width: 767px) {
	/* 모바일에 사용될 스트일 시트를 여기에 작성합니다. */
	/* .loginBody {
		background: #fff;
	} */

	.loginWrapper {
		background: none !important;
	}

	.loginBox {
		height: 400px;
		position: absolute;
		top: 35%;
		left: 50%;
		transform: translate(-50%, -50%);
		max-width: 280px;
		width: 80%;
	}

	.loginBox .logo {
		/* vertical-align:top;
		height: 143px;
		width: 100%;
		margin-bottom: 66px;
		background-image: url("../images/login/logo_m.png");
		background-repeat: no-repeat;
		background-position: center;
		background-position-x: center; */
		max-width: 280px;
		width: 100%;
		background-size: 100% auto;
	}

	.loginBox .login_input {
		width: 100%;
		height: 50px;
		padding-left: 0px;
		font-size: 16px;
		font-weight: bold;
		text-align: center;
		color: #696d6f;
		margin: auto;
	}

	.loginBox .login_input::placeholder {
		color: #b3bdc2;
	}

	.loginBox .rememberLabel:after {
		content: '아이디, 패스워드 저장';
	}

	/* .loginBox .btn-slide {
		border: none;
		background-color: #4a5164;
		margin-top: 45px;
		font-weight: bold;
		padding: 0px;
		text-align: center;
	} */

	.btn-slide span.circle {
		display: none;
	}

	.btn-slide span.title {
		position: initial;
		left: unset;
	}

	.btn-slide span.title-hover {
		display: none;
	}

	.btn-slide:hover {
		background-color: #4a5164;
		color: #ffffff;
		text-decoration: none;
	}

	.btn-slide:hover span.circle {
		display: none;
	}

	/* .btn-slide:hover span.title {
		left: 0px;
		opacity: unset;
	} */

	.btn-slide:hover span.title-hover {
		display: none;
	}

	#pwSearch {
		/* display: none; */
	}

	.loginBody .signup .signup-text,
	.loginBody .searchPwd .searchPwd-text {
		width: 50%;
		float: right;
		padding: 0;
		margin-top: 10px;
		text-decoration: underline;
	}

	.loginBody .login-text {
		display: block;
	}

	.loginBody .login-text .remember input[type=checkbox]+ label:before {
		bottom: 2px;
	}

	.loginBody .searchPwd, .signup {
		padding-top: 0;
	}

	.loginBody.ui-dialog .ui-dialog-titlebar {
		padding: .4em 1em;
	}

	.loginBody .field-label {
		float : unset;
		min-width : unset;
		max-width : unset;
	}

	.loginBody .grp_desc {
		font-size: 12px;
	}

	.loginBody .ui-dialog-buttonset .ui-button.btn-point {
		background-color: #1ab394;
		border-color: #1ab394;
	}


}


/* otp popup */
.otp-wrap {
	margin: 0 20px;
}
.otp-sum {
	background-color: #f2f2f2;
	border-radius: 5px;
	padding: 10px 15px;
	margin-bottom: 15px;
}

.otp-sum ol {
	margin-bottom: 0;
}
.otp-sum li {
	color: #666;
	font-size: 0.9rem;
	margin-bottom: 8px;
}
.otp-sum li strong {
	color: #222;
	font-size: 1rem;
}

.otp-btn {
	line-height: 1.6;
	display: inline-block;
	border-radius: 3px;
	background-color: #bacfd1;
	padding: 0 5px;
}
.otp-btn:hover {
	color: #fff;
	text-decoration: none;
	background-color: #5a9197;
}

.otp-action {
	display: flex;
	margin-bottom: 20px;
	border: 1px solid #E4E0DE;
	padding: 10px;
	border-radius: 5px;
}
.otp-item {
	text-align: center;
	flex: 0 0 50%;
}
.otp-item:first-child {
	border-right: 1px solid #f1f1f1;
}

.otp-item h5 {
	display: inline-block;
	border-radius: 20px;
	background-color: #dfe7eb;
	margin: 0;
	padding: 5px 10px;
}

.qrimg,
.certify-key {
	height: 100px;
}
.qrimg {
	margin-top: 10px;
}
.qrimg img {
	width: auto;
	height: 100%;
}

.certify-key {
	display: flex;
	align-items: center;
}

.certify-key span {
	width: 100%;
}

.otp-wrap .text-group {
	margin: 20px 0;
}

/* terms */
.terms-btn button {
	color: #fff;
}

#Privacy {
	color: #ffe30b;
	text-decoration: underline;
}

.terms-wrap {
	width: 100%;
	display: flex;
	flex-direction: column;
	background-color: #fff;
}
#terms-tab {
	position: relative;
	display: flex;
	justify-content: center;
}
#terms-tab:before {
	content: '';
	position: absolute;
	bottom:0;
	left: 0;
	width:100%; height: 1px;
	background-color: #f3f4f5;
}
#terms-tab .tab {
	position: relative;
	cursor: pointer;
	color: #8b8b8b;
	padding: 10px 0;
	margin: 0 10px;
	transition: all 0.3s ease;
	border-bottom: 2px solid transparent;
}
#terms-tab .tab._active {
	color: #668f7a;
	border-color: #668f7a;
	font-weight: 700;
}
#terms-tab .tab:not(._active):hover {
	color: #293846;
}
#terms-tab .tab:hover:before,
#terms-tab .tab._active:before {
	background-color: #668f7a;
}

.terms-wrap .tab-container {
	overflow-y: auto;
}
.terms-wrap .terms-content {
	display: none;
	padding: 20px;
}

.terms-wrap .terms-content._active {
	display: block;
}

.terms-content h2 {
	color: #646d68;
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0 0 15px;
}

.terms-content h3 {
	color: #375f49;
	font-size: 1.1rem;
	font-weight: 600;
	margin: 30px 0 10px;
	position: relative;
	padding-left: 16px;
}
.terms-content h3:before {
	content: '';
	position: absolute;
	top: 4px;
	left: 0;
	width: 10px; height: 10px;
	background: #cdc8af;
	border-radius: 50%;
}

.terms-content h4 {
	font-size: 1rem;
	font-weight: 600;
	margin: 25px 0 0;
	position: relative;
	padding-left: 10px;
}
.terms-content h4:after {
	content: '';
	display: block;
	width: 15px; height: 3px;
	background: #646d68;
	background: linear-gradient(90deg, #646d68 50%,#cdc8af 50%);
	margin: 10px 0 5px;
}

.terms-content h5 {
	color: #668f7a;
	font-size: 1rem;
	font-weight: 600;
	margin: 15px 0 10px;
	padding-left: 10px;
	text-decoration: underline;
}

.terms-content .subs {
	padding-left: 10px;
	margin: 0 0 10px;
}

.terms-content li > .subs {
	padding-left: 0;
}

.terms-content .sum {
	background-color: #f3f4f5;
	padding: 10px 15px;
	margin-bottom: 20px;
}

.terms-content .marT40 {
	margin-top: 40px;
}

.terms-content p {
	font-size: inherit;
}

.terms-content ._red {
	color: #d31212;
}

.terms-content p.title {
	font-weight: 700;
}

.terms-content a {
	text-decoration: underline;
}


.terms-content table {
	width: 100%;
	border-top: 2px solid #646d68;
}

.terms-content table thead th,
.terms-content table tbody th,
.terms-content table tbody td {
	text-align: center;
	border-bottom: 1px solid #e5e5e5;
	padding: 5px;
	font-weight: 500;
}

.terms-content table thead th,
.terms-content table tbody th {
	text-align: center;
	color: #646d68;
	font-weight: 700;
}

.terms-content table tbody tr:nth-child(odd) {
	background-color: #F7F7F7;
}

.terms-content ol:not(.circle, .none) {
	margin-left: 15px;
}

.terms-content ol.circle > li > ol {
	font-size: 0.9rem;
	margin-left: 0;
}

.terms-content ol.circle > li > ul {
	font-size: 0.9rem;
	padding-left: 0;
}

.terms-content ul > li > ul {
	padding-left: 0;
}

.terms-content ol.none {
	padding-left: 0;
}

.terms-content ol.none > li,
.terms-content ol.circle > li {
	list-style: none;
}

.terms-content ol.circle > li {
	position: relative;
	padding-left: 15px;
}
.terms-content ol.circle > li:before {
	position: absolute;
	top: 1px; left: -3px;
	font-size: 1.1rem;
}
.terms-content ol.circle > li:nth-child(1):before {content: '①';}
.terms-content ol.circle > li:nth-child(2):before {content: '②';}
.terms-content ol.circle > li:nth-child(3):before {content: '③';}
.terms-content ol.circle > li:nth-child(4):before {content: '④';}
.terms-content ol.circle > li:nth-child(5):before {content: '⑤';}
.terms-content ol.circle > li:nth-child(6):before {content: '⑥';}
.terms-content ol.circle > li:nth-child(7):before {content: '⑦';}
.terms-content ol.circle > li:nth-child(8):before {content: '⑧';}
.terms-content ol.circle > li:nth-child(9):before {content: '⑨';}
.terms-content ol.circle > li:nth-child(10):before {content: '⑩';}
.terms-content ol.circle > li:nth-child(11):before {content: '⑪';}
.terms-content ol.circle > li:nth-child(12):before {content: '⑫';}
.terms-content ol.circle > li:nth-child(13):before {content: '⑬';}
.terms-content ol.circle > li:nth-child(14):before {content: '⑭';}
.terms-content ol.circle > li:nth-child(15):before {content: '⑮';}

.terms-content ul.dot > li,
.terms-content ul.dash > li {
	list-style: none;
	position: relative;
	padding-left: 10px;
}

.terms-content ul.dot > li:before {
	content: '';
	position: absolute;
	top: 11px; left: 0;
	width: 5px; height: 5px;
	background-color: #aab9b1;
}

.terms-content ul.dash > li:before {
	content: '';
	position: absolute;
	top: 12px; left: 0;
	width: 6px; height: 2px;
	background-color: #6c757d;
}


@media all and (max-width: 420px) {
	.otp-action {
		flex-wrap: wrap;
	}

	.otp-item {
		flex: 0 0 100%;
	}

	.otp-item:first-child {
		border-right: 0;
		margin-bottom: 20px;
	}

	.certify-key {
		height: auto;
		font-size: 1rem;
		margin-top: 10px;
	}
}