/* 로그인 - CLS 통합 테마 */
body {
	margin: 0;
	min-height: 100vh;
	font-family: "Pretendard", -apple-system, sans-serif;
	background: var(--cls-bg);
	-webkit-user-select: none;
	user-select: none;
	color-scheme: dark;
}

.login-wrap {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}

.login-box {
	width: 100%;
	max-width: 420px;
	background: var(--cls-card);
	border-radius: var(--cls-radius-lg);
	border: 1px solid var(--cls-border);
	box-sizing: border-box;
	overflow: hidden;
	box-shadow: var(--cls-shadow-lg);
}

.login-section {
	padding: 2rem 2.25rem;
	box-sizing: border-box;
}

.login-header {
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--cls-border);
}

.login-title {
	margin: 0;
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--cls-text);
	letter-spacing: -0.03em;
}

.login-subtitle {
	margin: 0.35rem 0 0;
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--cls-accent);
	letter-spacing: 0.02em;
}

.login-body {
	padding-top: 1.75rem;
	padding-bottom: 1rem;
}

.login-desc {
	margin: 0 0 1rem;
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--cls-text-secondary);
}

.login-note {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.6;
	color: var(--cls-text-muted);
}

.login-actions {
	padding-top: 1rem;
	padding-bottom: 2rem;
}

.login-err {
	margin: 0 0 1.25rem;
	padding: 0.85rem 1rem;
	font-size: 0.9rem;
	color: var(--cls-error);
	background: rgba(239, 68, 68, 0.1);
	border: 1px solid rgba(239, 68, 68, 0.2);
	border-radius: var(--cls-radius);
}

.login-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.6rem;
	width: 100%;
	padding: 1rem 1.5rem;
	box-sizing: border-box;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: var(--cls-accent);
	border-radius: var(--cls-radius);
	border: none;
	text-decoration: none;
	transition: background 0.2s;
}

.login-btn:hover {
	background: var(--cls-accent-hover);
	color: #fff;
}

.login-btn img {
	width: 20px;
	height: 20px;
}
