/* ========================================
   Login Page Specific Styles
   ======================================== */
.login-container {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.main-content {
	flex: 1;
	padding: var(--space-6) var(--space-4);
	display: flex;
	flex-direction: column;
	max-width: 420px;
	margin: 0 auto;
	width: 100%;
}

.page-header {
	margin-bottom: var(--space-6);
}

.page-title {
	font-size: var(--font-size-xl);
	font-weight: 700;
	color: var(--color-gray-900);
	margin-bottom: var(--space-1);
}

.page-subtitle {
	font-size: var(--font-size-sm);
	color: var(--color-gray-500);
}

.mode-toggle {
	margin-bottom: var(--space-5);
}

.form-card {
	background: var(--color-white);
	border-radius: var(--radius-xl);
	border: 1px solid var(--color-gray-200);
	box-shadow: var(--shadow-card);
	padding: var(--space-5);
}

.form-group:last-of-type {
	margin-bottom: var(--space-5);
}

.form-input.with-toggle {
	padding-right: 42px;
}

.password-toggle {
	position: absolute;
	right: var(--space-3);
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--space-1);
	color: var(--color-gray-400);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color var(--transition-fast);
}

.password-toggle:hover {
	color: var(--color-gray-600);
}

.password-toggle svg {
	width: 18px;
	height: 18px;
}

.biometric-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--space-3);
	border: 1px solid var(--color-gray-300);
	border-radius: var(--radius-md);
	background: var(--color-white);
	font-family: inherit;
	font-size: var(--font-size-sm);
	font-weight: 500;
	color: var(--color-gray-700);
	cursor: pointer;
	transition: all var(--transition-fast);
}

.biometric-btn:hover {
	background: var(--color-gray-50);
	border-color: var(--color-gray-400);
}

.biometric-btn svg {
	width: 20px;
	height: 20px;
	color: var(--color-gray-500);
}

.help-section {
	margin-top: var(--space-5);
	text-align: center;
}

.help-link {
	font-size: var(--font-size-sm);
	color: var(--color-gray-500);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.help-link:hover {
	color: var(--color-primary);
}

/* Responsive */
@media (min-width: 640px) {
	.main-content {
		padding: var(--space-8) var(--space-4);
	}

	.form-card {
		padding: var(--space-6);
	}
}

@media (min-width: 768px) {
	.main-content {
		justify-content: center;
		padding: var(--space-10) var(--space-4);
	}

	.page-header {
		text-align: center;
	}
}

.error-box {
    color: #d60000;   /* 赤文字 */
    font-weight: 600;
    margin-bottom: 12px;
}