/**
 * Login Form Component Styles
 *
 * @package EduHub
 * @since 1.0.0
 */

/* Form fields layout */
.eduhub-login-form__fields {
	display: flex;
	flex-direction: column;
	gap: var(--eduhub-field-gap);
}

/* Password header with forgot link */
.eduhub-login-form__password-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--eduhub-spacing-3);
}

.eduhub-login-form__forgot-link {
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--eduhub-primary);
	text-decoration: none;
	transition: color var(--eduhub-transition-base) var(--eduhub-ease-out);
}

.eduhub-login-form__forgot-link:hover {
	color: var(--eduhub-primary-hover);
	text-decoration: underline;
}

.eduhub-login-form__forgot-link:focus-visible {
	outline: 2px solid var(--eduhub-primary);
	outline-offset: 2px;
	border-radius: var(--eduhub-radius-sm);
}

/* Password visibility toggle */
.eduhub-login-form__toggle-password {
	position: absolute;
	right: var(--eduhub-spacing-3);
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	padding: 0;
	background: transparent;
	border: none;
	color: var(--eduhub-text-secondary);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: color var(--eduhub-transition-base) var(--eduhub-ease-out);
}

.eduhub-login-form__toggle-password:hover {
	color: var(--eduhub-primary);
}

.eduhub-login-form__toggle-password:focus-visible {
	outline: 2px solid var(--eduhub-primary);
	outline-offset: 2px;
	border-radius: var(--eduhub-radius-sm);
}

.eduhub-login-form__toggle-password svg {
	width: 20px;
	height: 20px;
}

/* Remember me spacing */
.eduhub-login-form__remember {
	margin-top: calc(-1 * var(--eduhub-spacing-2));
}

.eduhub-login-form__remember + .eduhub-btn {
	margin-top: var(--eduhub-spacing-3);
}

/* Error & Success Banners */
.eduhub-login-form__error-banner,
.eduhub-login-form__success-banner {
	display: flex;
	align-items: center;
	gap: var(--eduhub-spacing-3);
	padding: var(--eduhub-spacing-3) var(--eduhub-spacing-4);
	border-radius: var(--eduhub-radius-md);
	font-size: 0.875rem;
	font-weight: 500;
	margin-bottom: var(--eduhub-spacing-4);
}

.eduhub-login-form__error-banner {
	background: var(--eduhub-error-light);
	color: var(--eduhub-error);
	border: 1px solid var(--eduhub-error);
}

.eduhub-login-form__success-banner {
	background: var(--eduhub-success-light);
	color: var(--eduhub-success);
	border: 1px solid var(--eduhub-success);
}

.eduhub-login-form__error-icon,
.eduhub-login-form__success-icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.eduhub-login-form__error-icon svg,
.eduhub-login-form__success-icon svg {
	width: 100%;
	height: 100%;
}

/* Message transitions */
.eduhub-login-form__message-enter {
	animation: eduhub-message-enter var(--eduhub-transition-base) var(--eduhub-ease-out);
}

.eduhub-login-form__message-leave {
	animation: eduhub-message-leave var(--eduhub-transition-fast) var(--eduhub-ease-out);
}

/* Payment notice */
.eduhub-auth-notice {
	display: flex;
	align-items: center;
	gap: var(--eduhub-spacing-3);
	width: 100%;
	padding: var(--eduhub-spacing-3) var(--eduhub-spacing-4);
	background: var(--eduhub-primary-light);
	border: 1px solid var(--eduhub-primary);
	border-radius: var(--eduhub-radius-md);
}

.eduhub-auth-notice__icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	color: var(--eduhub-primary);
}

.eduhub-auth-notice__text {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--eduhub-text-primary);
	line-height: 1.4;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
	.eduhub-login-form__message-enter,
	.eduhub-login-form__message-leave {
		animation: none;
	}
}
