/* 구매 플로우 회원가입 (/purchase/signup) — login.css 의 레이아웃·폼 공통 위에 덧씌움 */

body.signup-page--purchase {
	padding: 0 !important;
	background: #fafafa;
	overflow-x: hidden;
}

body.signup-page--purchase .signup-hint {
	font-size: 0.88rem;
	color: #666;
	text-align: center;
	margin-bottom: 1.25rem;
	line-height: 1.5;
}

body.signup-page--purchase .btn-block {
	width: 100%;
	padding: 0.85rem 1rem;
	border-radius: 12px;
	font-size: 1rem;
	cursor: not-allowed;
	border: 1px solid #ddd;
	background: #f5f5f5;
	color: #888;
	margin-bottom: 1.5rem;
}

body.signup-page--purchase .purchase-auth-card--signup .form-title {
	margin-bottom: 1.25rem;
}

body.signup-page--purchase .purchase-auth-wrap--wide {
	width: min(560px, calc(100vw - 2.5rem));
}

/* 이메일 인증 행 */
body.signup-page--purchase .email-verify-row {
	display: flex;
	flex-wrap: nowrap;
	gap: 10px;
	align-items: stretch;
}

body.signup-page--purchase .email-verify-row input {
	flex: 1 1 auto;
	min-width: 0;
	width: auto;
}

body.signup-page--purchase .mini-btn {
	flex: 0 0 auto;
	padding: 12px 14px;
	border: none;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	background-color: #4263eb;
	color: #fff;
	transition:
		background 0.2s ease,
		opacity 0.2s ease;
}

body.signup-page--purchase .mini-btn--block {
	width: 100%;
	margin-top: 8px;
}

body.signup-page--purchase .mini-btn:hover:not(:disabled) {
	background-color: #364fc7;
}

body.signup-page--purchase .mini-btn:disabled {
	background: #e9ecef;
	color: #adb5bd;
	cursor: not-allowed;
}

body.signup-page--purchase .mini-btn--dark {
	background-color: #364fc7;
}

body.signup-page--purchase .mini-btn--dark:hover:not(:disabled) {
	background-color: #2f44ad;
}

body.signup-page--purchase .mini-btn.is-active {
	background: #0064ff;
	color: #fff;
	border-color: #0064ff;
}

body.signup-page--purchase .mini-btn.is-verified {
	background: #d9ddea;
	color: #f8f9fc;
	border-color: #d9ddea;
}

body.signup-page--purchase .mini-btn--light {
	background: #eceff4;
	color: #8c95a8;
	border: 1px solid #e2e6ef;
}

body.signup-page--purchase .mini-btn--light:hover:not(:disabled) {
	background: #e2e7f0;
}

body.signup-page--purchase .mini-btn--light.is-active {
	background: #0064ff;
	color: #fff;
	border-color: #0064ff;
}

body.signup-page--purchase .mini-btn--light.is-error {
	background: #fff3f3;
	color: #c92a2a;
	border-color: #ffc9c9;
}

body.signup-page--purchase .purchase-email-compose {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

body.signup-page--purchase .purchase-email-compose-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
	gap: 8px;
	align-items: center;
}

body.signup-page--purchase .purchase-email-compose-row > * {
	min-width: 0;
}

body.signup-page--purchase .purchase-email-compose-row input,
body.signup-page--purchase .purchase-email-compose-row select,
body.signup-page--purchase .purchase-email-custom-domain {
	height: 44px;
	border: 1px solid #e1e1e1;
	border-radius: 8px;
	padding: 0 12px;
	background: #fff;
	font-size: 14px;
	color: #333;
	box-sizing: border-box;
}

body.signup-page--purchase .input-group .purchase-email-compose-row select.purchase-select,
body.signup-page--purchase .input-group .purchase-email-compose-row input {
	height: 44px;
	padding: 0 12px;
	font-size: 14px;
}

body.signup-page--purchase .purchase-email-at {
	font-size: 14px;
	color: #8b90a0;
	font-weight: 600;
}

body.signup-page--purchase .purchase-email-custom-domain.is-hidden,
body.signup-page--purchase .purchase-email-otp-row.is-hidden {
	display: none;
}

body.signup-page--purchase .purchase-email-otp-row {
	margin-top: 8px;
}

body.signup-page--purchase .email-verify-message {
	font-size: 13px;
	margin-top: 8px;
	margin-left: 4px;
	min-height: 1.25em;
}

body.signup-page--purchase .email-verify-message.ok {
	color: #2b8a3e;
}

body.signup-page--purchase .email-verify-message.fail {
	color: #c92a2a;
}

/* 이름/비밀번호 규칙 리스트 */
body.signup-page--purchase .rule-list {
	list-style: none;
	margin: -8px 0 16px 4px;
	padding: 0;
	font-size: 12px;
	color: #666;
	line-height: 1.5;
}

body.signup-page--purchase .purchase-password-rule-list {
	margin: 8px 0 14px 4px;
}

body.signup-page--purchase .rule-item {
	display: flex;
	align-items: flex-start;
	gap: 6px;
	margin-bottom: 4px;
}

body.signup-page--purchase .rule-item i {
	margin-top: 2px;
	flex-shrink: 0;
	width: 1em;
	text-align: center;
}

body.signup-page--purchase .rule-item.is-ok {
	color: #2b8a3e;
}

body.signup-page--purchase .rule-item.is-fail {
	color: #c92a2a;
}

body.signup-page--purchase .input-group select.purchase-select,
body.signup-page--purchase .input-group input.purchase-input-date {
	width: 100%;
	padding: 15px;
	border: 1px solid #e1e1e1;
	border-radius: 8px;
	font-size: 16px;
	color: #333;
	background-color: #fff;
	box-sizing: border-box;
}

body.signup-page--purchase .input-group select.purchase-select:focus,
body.signup-page--purchase .input-group input.purchase-input-date:focus {
	outline: none;
	border-color: #4263eb;
}

body.signup-page--purchase .input-group input[type='file'] {
	width: 100%;
	padding: 12px 15px;
	border: 1px solid #e1e1e1;
	border-radius: 8px;
	font-size: 14px;
	color: #333;
	background-color: #fff;
	box-sizing: border-box;
}

body.signup-page--purchase .input-group input[type='file']::file-selector-button {
	margin-right: 12px;
	padding: 8px 14px;
	border: none;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 600;
	background: #edf2ff;
	color: #4263eb;
	cursor: pointer;
}

body.signup-page--purchase .input-group input[type='file']::file-selector-button:hover {
	background: #dbe4ff;
}

/* 학습 목적 · 동의 체크박스 */
body.signup-page--purchase .input-group--purposes .input-label {
	margin-bottom: 10px;
}

body.signup-page--purchase .purchase-purpose-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

body.signup-page--purchase .purchase-checkbox {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 14px;
	color: #444;
	line-height: 1.45;
	cursor: pointer;
}

body.signup-page--purchase .purchase-checkbox input {
	width: auto;
	margin-top: 3px;
	flex-shrink: 0;
	accent-color: #4263eb;
}

body.signup-page--purchase .purchase-checkbox--block {
	padding: 10px 12px;
	border: 1px solid #e9ecef;
	border-radius: 8px;
	background: #fafafa;
}

body.signup-page--purchase .input-group--consents {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

body.signup-page--purchase .purchase-empty-hint {
	font-size: 13px;
	color: #868e96;
	margin: 0;
}

body.signup-page--purchase .auth-links--spaced {
	margin-top: 1.5rem;
}

body.signup-page--purchase .purchase-social-signup-hint {
	font-size: 0.9rem;
	color: #495057;
	line-height: 1.55;
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	background: #f8f9fa;
	border-radius: 8px;
	border: 1px solid #e9ecef;
}

body.signup-page--purchase .purchase-input-readonly {
	background: #f1f3f5 !important;
	color: #495057;
	cursor: not-allowed;
}

body.signup-page--purchase .purchase-field-locked-note {
	font-size: 0.82rem;
	color: #868e96;
	margin: 0.35rem 0 0;
	line-height: 1.45;
}

body.signup-page--purchase .purchase-field-locked-note--block {
	margin: 0.5rem 0 0.75rem;
}

/* purchase signup wizard */
body.signup-page--purchase .purchase-fixed-logo {
	height: 36px;
	width: auto;
	object-fit: contain;
	margin-bottom: 32px;
	margin-top: 32px;
}

body.signup-page--purchase .purchase-signup-header {
	height: 72px;
	border-bottom: 1px solid #e8e9ea;
	display: flex;
	align-items: center;
	padding: 0 16px;
	background: #fafafa;
}

body.signup-page--purchase .purchase-signup-wizard-wrap {
	width: min(360px, calc(100vw - 32px));
	margin: 20px auto 28px;
	background: transparent;
	border-radius: 0;
	border: 0;
	padding: 0;
}

body.signup-page--purchase .purchase-signup-stepper {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	width: 100%;
	margin: 0 0 18px;
	padding-bottom: 14px;
	border-bottom: 1px solid #e4e8f0;
}

body.signup-page--purchase .purchase-step {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	color: #9aa0b5;
	font-size: 13px;
}

body.signup-page--purchase .purchase-step:not(:last-child)::after {
	content: '';
	position: absolute;
	top: 16px;
	left: calc(50% + 17px);
	width: calc(100% - 34px);
	height: 2px;
	background: repeating-linear-gradient(to right, #b8c0d4 0 10px, transparent 10px 16px);
	z-index: 0;
}

body.signup-page--purchase .purchase-step-dot {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: #c4c8d8;
	color: #fff;
	margin: 0 auto 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 1;
	font-size: 12px;
}

body.signup-page--purchase .purchase-step.is-active,
body.signup-page--purchase .purchase-step.is-done {
	color: #0064ff;
}

body.signup-page--purchase .purchase-step.is-active .purchase-step-dot,
body.signup-page--purchase .purchase-step.is-done .purchase-step-dot {
	background: #0064ff;
}

body.signup-page--purchase .purchase-step.is-active:not(:last-child)::after,
body.signup-page--purchase .purchase-step.is-done:not(:last-child)::after {
	background: repeating-linear-gradient(to right, #0064ff 0 10px, transparent 10px 16px);
}

body.signup-page--purchase .purchase-signup-panel {
	display: none;
	width: 100%;
}

body.signup-page--purchase .purchase-signup-panel.is-active {
	display: block;
}

body.signup-page--purchase .purchase-signup-section-title {
	font-size: 22px;
	font-weight: 700;
	width: 100%;
	margin: 0 0 14px;
}

body.signup-page--purchase .purchase-signup-subtitle {
	font-size: 14px;
	color: #4a4f5d;
	margin: 0 0 8px;
	line-height: 1.5;
}

body.signup-page--purchase .purchase-signup-panel[data-step-panel='1'] .purchase-signup-subtitle,
body.signup-page--purchase .purchase-signup-panel[data-step-panel='1'] .purchase-terms-box,
body.signup-page--purchase .purchase-signup-panel[data-step-panel='1'] .purchase-step-actions {
	width: 100%;
	margin-left: 0;
	margin-right: 0;
}

body.signup-page--purchase .purchase-terms-box {
	border: 1px solid #e5e8f0;
	border-radius: 10px;
	padding: 10px 10px 2px;
	margin-bottom: 14px;
	background: #fff !important;
	width: 100%;
	box-sizing: border-box;
}

body.signup-page--purchase .purchase-terms-item {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	font-size: 14px;
	width: 100%;
	box-sizing: border-box;
}

body.signup-page--purchase .purchase-terms-item input[type='checkbox'] {
	width: 20px;
	height: 20px;
	margin: 0;
	flex-shrink: 0;
	accent-color: #0064ff;
}

body.signup-page--purchase .purchase-terms-item:first-child {
	padding-bottom: 12px;
	margin-bottom: 12px;
	border-bottom: 1px solid #d9deea;
}

body.signup-page--purchase .purchase-grid-2 {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

body.signup-page--purchase .purchase-country-trigger,
body.signup-page--purchase .purchase-dropdown-trigger {
	width: 100%;
	height: 46px;
	border: 1px solid #e1e5ee;
	border-radius: 8px;
	background: #fff;
	padding: 0 12px;
	text-align: left;
	color: #4a4f5d;
	cursor: pointer;
}

body.signup-page--purchase .purchase-gender-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

body.signup-page--purchase .purchase-gender-btn {
	height: 44px;
	border: 1px solid #d9deea;
	border-radius: 8px;
	background: #fff;
	color: #606778;
	cursor: pointer;
}

body.signup-page--purchase .purchase-gender-btn.is-active {
	border-color: #0064ff;
	color: #0064ff;
	background: #eef4ff;
}

body.signup-page--purchase .purchase-step-actions {
	margin-top: 18px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}

body.signup-page--purchase .purchase-step-btn {
	height: 46px;
	border-radius: 10px;
	border: 1px solid #cfd4e3;
	background: #d8dbe7;
	color: #fff;
	font-weight: 600;
	cursor: pointer;
}

body.signup-page--purchase .purchase-step-btn.primary {
	background: #0064ff;
	border-color: #0064ff;
}

body.signup-page--purchase .purchase-step-btn:disabled {
	background: #c7cbd9 !important;
	border-color: #c7cbd9 !important;
	color: #eef0f6 !important;
	cursor: not-allowed;
}

body.signup-page--purchase .purchase-step-btn.ghost {
	background: #d0d3de;
	border-color: #d0d3de;
	color: #fff;
}

body.signup-page--purchase .purchase-profile-preview {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	overflow: hidden;
	margin: 0 auto 10px;
	background: #eceff6;
	border: 1px solid #dfe4f0;
}

body.signup-page--purchase .purchase-profile-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

body.signup-page--purchase .purchase-upload-btn {
	margin: 0 auto 16px;
	display: block;
	width: 124px;
	height: 36px;
	border-radius: 8px;
	border: 1px solid #d8deea;
	background: #fff;
	cursor: pointer;
}

body.signup-page--purchase .purchase-hidden-file {
	display: none;
}

body.signup-page--purchase .purchase-inline-btn {
	min-width: 120px;
	height: 46px;
	border-radius: 8px;
	border: 1px solid #d9deea;
	background: #f4f6fb;
	color: #525c73;
	font-weight: 600;
	cursor: pointer;
}

body.signup-page--purchase .purchase-password-help {
	font-size: 13px;
	color: #a0a6b5;
	line-height: 1.4;
	margin: 4px 0 8px;
}

body.signup-page--purchase .purchase-password-wrap {
	position: relative;
}

body.signup-page--purchase .purchase-password-wrap input {
	padding-right: 42px !important;
}

body.signup-page--purchase .purchase-password-toggle {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	border: none;
	background: transparent;
	color: #9aa0af;
	cursor: pointer;
	width: 28px;
	height: 28px;
}

body.signup-page--purchase .purchase-dropdown {
	position: relative;
}

body.signup-page--purchase .purchase-dropdown-menu {
	display: none;
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	right: 0;
	border: 1px solid #d9deea;
	border-radius: 10px;
	background: #fff;
	max-height: 220px;
	overflow: auto;
	z-index: 30;
	padding: 8px;
}

body.signup-page--purchase .purchase-dropdown.is-open .purchase-dropdown-menu {
	display: block;
}

body.signup-page--purchase .purchase-dropdown-item {
	display: flex;
	gap: 8px;
	align-items: center;
	padding: 8px;
	border-radius: 8px;
	font-size: 14px;
}

/* login.css의 .input-group input 공통 스타일이 체크박스에 먹지 않게 보정 */
body.signup-page--purchase .purchase-dropdown-item input[type='checkbox'] {
	width: auto;
	padding: 0;
	margin: 0;
	border: 1px solid #c7cedd;
	border-radius: 4px;
	flex-shrink: 0;
	accent-color: #4263eb;
}

body.signup-page--purchase .purchase-complete-wrap {
	text-align: center;
}

body.signup-page--purchase .purchase-complete-wrap img {
	width: min(100%, 520px);
	border-radius: 10px;
	margin: 8px auto 16px;
	display: block;
}

body.signup-page--purchase .purchase-complete-message {
	font-size: 20px;
	font-weight: 700;
	line-height: 1.3;
	margin: 8px 0 14px;
}

body.signup-page--purchase .purchase-complete-login {
	width: 100%;
	max-width: 520px;
	margin: 0 auto;
	height: 56px;
	border: none;
	border-radius: 14px;
	background: #0064ff;
	color: #fff;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: center;
}

body.signup-page--purchase .purchase-modal {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.35);
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 100;
}

body.signup-page--purchase .purchase-modal.is-open {
	display: flex;
}

body.signup-page--purchase .purchase-modal-panel {
	width: min(420px, calc(100vw - 24px));
	background: #fff;
	border-radius: 12px;
	padding: 14px 14px 12px;
}

body.signup-page--purchase .purchase-country-title {
	font-size: 24px;
	margin: 0 0 10px;
	font-weight: 700;
}

body.signup-page--purchase .purchase-country-list {
	max-height: 300px;
	overflow: auto;
	border-top: 1px solid #eaedf4;
	border-bottom: 1px solid #eaedf4;
	padding: 8px 0;
}

body.signup-page--purchase .purchase-country-item {
	width: 100%;
	border: 0;
	background: #fff;
	text-align: left;
	padding: 8px 8px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}

body.signup-page--purchase .purchase-country-item:hover {
	background: #f5f8ff;
}

body.signup-page--purchase .purchase-country-left {
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 0;
}

body.signup-page--purchase .purchase-country-flag {
	width: 16px;
	text-align: center;
	font-size: 13px;
}

body.signup-page--purchase .purchase-country-name {
	font-size: 14px;
	color: #232836;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

body.signup-page--purchase .purchase-country-check {
	width: 18px;
	height: 18px;
	border-radius: 4px;
	border: 1px solid #d6dcea;
	background: #f2f4f8;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
}

body.signup-page--purchase .purchase-country-item.is-selected .purchase-country-check {
	background: #2a6df1;
	border-color: #2a6df1;
}

body.signup-page--purchase .purchase-country-actions {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	margin-top: 12px;
}

body.signup-page--purchase .purchase-country-btn {
	height: 42px;
	border-radius: 10px;
	border: 1px solid #d8deea;
	background: #fff;
	color: #7a8090;
	font-weight: 600;
	cursor: pointer;
}

body.signup-page--purchase .purchase-country-btn.primary {
	background: #0064ff;
	border-color: #0064ff;
	color: #fff;
}
