/**
 * UnicaSuite — Custom Login & Register Page Styles
 *
 * A beautiful, modern split-screen login experience.
 * Supports light + dark mode via data-theme attribute.
 *
 * @package unicasuite
 */

/* ==========================================================================
   0. CSS Custom Properties (Login Tokens — aliased from theme design tokens)
   ========================================================================== */

/*
 * All --login-* variables are intentionally aliased to the theme's
 * --color-* tokens so the login page automatically inherits any colour
 * scheme change set in the Customiser or theme-toggle.
 */

:root {
	/* Primary — mirrors theme tokens */
	--login-primary:         var(--color-primary,         #4F46E5);
	--login-primary-hover:   var(--color-primary-hover,   #4338CA);
	--login-primary-light:   var(--color-primary-light,   #818CF8);
	--login-primary-lighter: var(--color-primary-lighter, #C7D2FE);
	--login-primary-50:      var(--color-primary-50,      #EEF2FF);
	--login-primary-rgb:     var(--color-primary-rgb,     79, 70, 229);

	/* Semantic */
	--login-success: var(--color-success, #10B981);
	--login-error:   var(--color-error,   #EF4444);
	--login-warning: var(--color-warning, #F59E0B);

	/* Surfaces & text — mirrors theme tokens */
	--login-bg:           var(--color-bg,             #F8FAFC);
	--login-surface:      var(--color-surface,         #FFFFFF);
	--login-surface-alt:  var(--color-surface-alt,     #F8FAFC);
	--login-border:       var(--color-border,          #E2E8F0);
	--login-text:         var(--color-text,            #0F172A);
	--login-text-sec:     var(--color-text-secondary,  #475569);
	--login-text-muted:   var(--color-text-muted,      #94A3B8);
	--login-heading:      var(--color-heading,         #0F172A);
	--login-input-bg:     var(--color-surface,         #FFFFFF);
	--login-input-border: var(--color-border,          #E2E8F0);
	--login-input-focus:  var(--login-primary);

	/* Panel gradient uses primary colour */
	--login-panel-bg:   linear-gradient(135deg,
		var(--color-primary,       #4F46E5) 0%,
		var(--color-primary-hover, #4338CA) 60%,
		var(--color-primary-light, #818CF8) 100%
	);
	--login-panel-text: #FFFFFF;

	/* Shadows — mirrors theme tokens */
	--login-shadow-sm:   var(--shadow-sm,  0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04));
	--login-shadow-md:   var(--shadow-md,  0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.05));
	--login-shadow-lg:   var(--shadow-lg,  0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -4px rgba(0,0,0,0.04));
	--login-shadow-xl:   var(--shadow-xl,  0 20px 25px -5px rgba(0,0,0,0.08), 0 8px 10px -6px rgba(0,0,0,0.04));
	--login-shadow-form: 0 25px 50px -12px rgba(0,0,0,0.08);

	/* Typography */
	--login-font: var(--font-sans, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif);

	/* Radius — mirrors theme tokens */
	--login-radius-sm:  var(--radius-sm,  0.25rem);
	--login-radius-md:  var(--radius-md,  0.5rem);
	--login-radius-lg:  var(--radius-lg,  0.75rem);
	--login-radius-xl:  var(--radius-xl,  1rem);
	--login-radius-2xl: var(--radius-2xl, 1.5rem);

	/* Transition — mirrors theme tokens */
	--login-transition:      var(--transition,      250ms ease);
	--login-transition-fast: var(--transition-fast, 150ms ease);
}

/* Dark mode — theme tokens already change via [data-theme="dark"] in style.css;
   the aliases above automatically pick up the new values.
   We only need to adjust the panel gradient and form shadow here. */
[data-theme="dark"] {
	--login-shadow-form: 0 25px 50px -12px rgba(0,0,0,0.4);
	--login-panel-bg: linear-gradient(135deg,
		var(--color-primary,       #818CF8) 0%,
		var(--color-primary-hover, #6366F1) 60%,
		var(--color-primary-light, #A5B4FC) 100%
	);
}

/* ==========================================================================
   1. Base Reset (login page only)
   ========================================================================== */

body.login {
	background: var(--login-bg) !important;
	font-family: var(--login-font) !important;
	color: var(--login-text) !important;
	margin: 0 !important;
	padding: 0 !important;
	min-height: 100vh;
	overflow-x: hidden;
}

body.login *,
body.login *::before,
body.login *::after {
	box-sizing: border-box;
}

/* ==========================================================================
   2. Hide default WordPress elements
   ========================================================================== */

/* Hide WP logo completely */
body.login #login h1,
body.login #login h1 a,
body.login .login h1 a {
	display: none !important;
}

/* --- FORCEFULLY hide WP default password toggle button --- */
body.login .wp-hide-pw,
body.login .button.wp-hide-pw,
body.login .wp-pwd .wp-hide-pw,
body.login button.wp-hide-pw {
	display: none !important;
	visibility: hidden !important;
	width: 0 !important;
	height: 0 !important;
	overflow: hidden !important;
	position: absolute !important;
	pointer-events: none !important;
	opacity: 0 !important;
}

/* Remove WP password wrapper extra styles that conflict */
body.login .wp-pwd {
	position: relative !important;
	display: block !important;
}

/* Hide default dashicons used by WP toggle */
body.login .dashicons,
body.login .dashicons-visibility,
body.login .dashicons-hidden {
	display: none !important;
}

/* Hide default "Back to" and privacy links - we'll restyle them */
body.login #backtoblog,
body.login #nav {
	text-align: center;
	margin: 0;
	padding: 0;
}

/* Hide the WordPress default powered-by content */
body.login .privacy-policy-page-link {
	margin-top: 1rem;
	text-align: center;
}

/* ==========================================================================
   3. Main Layout — Split Screen
   ========================================================================== */

.unicasuite-login-wrapper {
	display: flex;
	min-height: 100vh;
	width: 100%;
}

/* --- Left Decorative Panel --- */

.unicasuite-login-panel {
	display: none;
	position: relative;
	width: 480px;
	min-width: 480px;
	background: var(--login-panel-bg);
	color: var(--login-panel-text);
	flex-direction: column;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	padding: 3rem 2.5rem;
}

@media (min-width: 1024px) {
	.unicasuite-login-panel {
		display: flex;
	}
}

/* Animated background orbs */
.unicasuite-login-panel__bg {
	position: absolute;
	inset: 0;
	overflow: hidden;
	pointer-events: none;
}

.unicasuite-login-panel__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.3;
	animation: loginOrbFloat 20s ease-in-out infinite;
}

.unicasuite-login-panel__orb--1 {
	width: 300px;
	height: 300px;
	background: rgba(255,255,255,0.2);
	top: -50px;
	right: -80px;
	animation-delay: 0s;
}

.unicasuite-login-panel__orb--2 {
	width: 200px;
	height: 200px;
	background: rgba(167, 139, 250, 0.3);
	bottom: 80px;
	left: -60px;
	animation-delay: -7s;
	animation-duration: 25s;
}

.unicasuite-login-panel__orb--3 {
	width: 150px;
	height: 150px;
	background: rgba(99, 102, 241, 0.25);
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	animation-delay: -14s;
	animation-duration: 18s;
}

@keyframes loginOrbFloat {
	0%, 100% { transform: translate(0, 0) scale(1); }
	25%      { transform: translate(30px, -20px) scale(1.05); }
	50%      { transform: translate(-20px, 30px) scale(0.95); }
	75%      { transform: translate(20px, 20px) scale(1.02); }
}

/* Panel content */
.unicasuite-login-panel__content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 360px;
}

.unicasuite-login-panel__logo {
	margin-bottom: 1.5rem;
}

.unicasuite-login-panel__logo img {
	width: 72px;
	height: 72px;
	filter: brightness(0) invert(1);
	transition: transform var(--login-transition);
}

.unicasuite-login-panel__logo img:hover {
	transform: scale(1.08) rotate(-3deg);
}

.unicasuite-login-panel__title {
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

.unicasuite-login-panel__desc {
	font-size: 1rem;
	opacity: 0.85;
	line-height: 1.6;
	margin: 0 0 2.5rem;
}

/* Feature list */
.unicasuite-login-panel__features {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	text-align: left;
}

.unicasuite-login-panel__feature {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 0.9375rem;
	opacity: 0.9;
}

.unicasuite-login-panel__feature-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	min-width: 40px;
	background: rgba(255,255,255,0.15);
	border-radius: 10px;
	backdrop-filter: blur(8px);
}

.unicasuite-login-panel__feature-icon svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
}

/* Panel footer */
.unicasuite-login-panel__footer {
	position: absolute;
	bottom: 2rem;
	left: 0;
	right: 0;
	text-align: center;
	z-index: 2;
}

.unicasuite-login-panel__footer p {
	font-size: 0.8125rem;
	opacity: 0.6;
	margin: 0;
}

/* --- Right Form Area --- */

.unicasuite-login-form-area {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem 1.5rem;
	min-height: 100vh;
	position: relative;
	background: var(--login-bg);
}

.unicasuite-login-form-area__inner {
	width: 100%;
	max-width: 420px;
	position: relative;
}

/* Mobile branding */
.unicasuite-login-mobile-brand {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	margin-bottom: 2rem;
}

.unicasuite-login-mobile-brand img {
	width: 40px;
	height: 40px;
}

[data-theme="dark"] .unicasuite-login-mobile-brand img {
	filter: brightness(1.5);
}

.unicasuite-login-mobile-brand__name {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--login-heading);
	letter-spacing: -0.02em;
}

@media (min-width: 1024px) {
	.unicasuite-login-mobile-brand {
		display: none;
	}
}

/* ==========================================================================
   4. Theme Toggle Button
   ========================================================================== */

.unicasuite-login-theme-toggle {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	width: 42px;
	height: 42px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--login-border);
	border-radius: 50%;
	background: var(--login-surface);
	color: var(--login-text-sec);
	cursor: pointer;
	transition: all var(--login-transition);
	z-index: 10;
	box-shadow: var(--login-shadow-sm);
}

.unicasuite-login-theme-toggle:hover {
	background: var(--login-primary-50);
	color: var(--login-primary);
	border-color: var(--login-primary);
	transform: rotate(15deg);
}

.unicasuite-login-theme-toggle__sun,
.unicasuite-login-theme-toggle__moon {
	position: absolute;
	transition: opacity var(--login-transition), transform var(--login-transition);
}

/* Light mode — show moon, hide sun */
:root:not([data-theme="dark"]) .unicasuite-login-theme-toggle__sun {
	opacity: 0;
	transform: rotate(-90deg) scale(0.5);
}
:root:not([data-theme="dark"]) .unicasuite-login-theme-toggle__moon {
	opacity: 1;
	transform: rotate(0) scale(1);
}

/* Dark mode — show sun, hide moon */
[data-theme="dark"] .unicasuite-login-theme-toggle__sun {
	opacity: 1;
	transform: rotate(0) scale(1);
}
[data-theme="dark"] .unicasuite-login-theme-toggle__moon {
	opacity: 0;
	transform: rotate(90deg) scale(0.5);
}

/* In minimal view, put the toggle in top-right of viewport */
@media (max-width: 1023px) {
	.unicasuite-login-theme-toggle {
		position: fixed;
		top: 1rem;
		right: 1rem;
	}
}

/* ==========================================================================
   5. Login Form Card
   ========================================================================== */

body.login #login {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

body.login #loginform,
body.login #registerform,
body.login #lostpasswordform,
body.login #resetpassform {
	background: var(--login-surface) !important;
	border: 1px solid var(--login-border) !important;
	border-radius: var(--login-radius-2xl) !important;
	padding: 2rem 2rem 1.75rem !important;
	margin: 0 0 1.25rem !important;
	box-shadow: var(--login-shadow-form) !important;
	transition: box-shadow var(--login-transition), border-color var(--login-transition);
	animation: loginCardIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes loginCardIn {
	from {
		opacity: 0;
		transform: translateY(16px) scale(0.98);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

body.login #loginform:hover,
body.login #registerform:hover,
body.login #lostpasswordform:hover,
body.login #resetpassform:hover {
	border-color: rgba(var(--login-primary-rgb), 0.2) !important;
	box-shadow: var(--login-shadow-xl), 0 0 0 1px rgba(var(--login-primary-rgb), 0.05) !important;
}

/* Form heading */
body.login #loginform::before {
	content: attr(data-title);
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--login-heading);
	margin-bottom: 0.25rem;
	letter-spacing: -0.02em;
}

body.login #loginform::after {
	display: none;
	content: none;
}

body.login #registerform::before {
	content: attr(data-title);
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--login-heading);
	margin-bottom: 0.25rem;
	letter-spacing: -0.02em;
}

body.login #registerform::after {
	content: attr(data-subtitle);
	display: block;
	font-size: 0.9375rem;
	color: var(--login-text-sec);
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

body.login #lostpasswordform::before {
	content: attr(data-title);
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--login-heading);
	margin-bottom: 0.25rem;
	letter-spacing: -0.02em;
}

body.login #lostpasswordform::after {
	content: attr(data-subtitle);
	display: block;
	font-size: 0.9375rem;
	color: var(--login-text-sec);
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

body.login #resetpassform::before {
	content: attr(data-title);
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--login-heading);
	margin-bottom: 0.25rem;
	letter-spacing: -0.02em;
}

body.login #resetpassform::after {
	content: attr(data-subtitle);
	display: block;
	font-size: 0.9375rem;
	color: var(--login-text-sec);
	margin-bottom: 1.5rem;
	line-height: 1.5;
}

/* ==========================================================================
   6. Form Labels
   ========================================================================== */

body.login label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--login-text) !important;
	margin-bottom: 0.375rem;
	letter-spacing: 0.01em;
}

body.login label[for="rememberme"] {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500;
	font-size: 0.875rem;
	color: var(--login-text-sec) !important;
	cursor: pointer;
}

/* ==========================================================================
   7. Form Inputs
   ========================================================================== */

body.login input[type="text"],
body.login input[type="email"],
body.login input[type="password"] {
	width: 100% !important;
	height: 48px !important;
	padding: 0 1rem !important;
	line-height: 1.2 !important;
	font-size: 0.9375rem !important;
	font-family: var(--login-font) !important;
	color: var(--login-text) !important;
	background: var(--login-input-bg) !important;
	border: 1.5px solid var(--login-input-border) !important;
	border-radius: var(--login-radius-lg) !important;
	outline: none !important;
	box-shadow: none !important;
	transition: border-color var(--login-transition-fast), box-shadow var(--login-transition-fast), background var(--login-transition-fast) !important;
	margin: 0 !important;
	margin-bottom: 1.25rem !important;
}

body.login input[type="text"]:focus,
body.login input[type="email"]:focus,
body.login input[type="password"]:focus {
	border-color: var(--login-primary) !important;
	box-shadow: 0 0 0 3px rgba(var(--login-primary-rgb), 0.15) !important;
	background: var(--login-surface) !important;
}

body.login input[type="text"]::placeholder,
body.login input[type="email"]::placeholder,
body.login input[type="password"]::placeholder {
	color: var(--login-text-muted) !important;
}

/* Input wrapper with icon (added via JS) */
.unicasuite-input-wrap {
	position: relative;
	margin-bottom: 1.25rem;
}

body.login .unicasuite-input-wrap input[type="text"],
body.login .unicasuite-input-wrap input[type="email"],
body.login .unicasuite-input-wrap input[type="password"] {
	padding-left: 2.75rem !important;
	margin-bottom: 0 !important;
}

/* Password field needs right padding for the toggle button */
body.login .unicasuite-input-wrap--password input[type="password"],
body.login .unicasuite-input-wrap--password input[type="text"] {
	padding-right: 3rem !important;
}

.unicasuite-input-icon {
	position: absolute;
	left: 0.875rem;
	top: calc(50% - 1px);
	transform: translateY(-50%);
	width: 20px;
	height: 20px;
	color: var(--login-text-muted);
	pointer-events: none;
	transition: color var(--login-transition-fast);
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
}

.unicasuite-input-icon svg {
	width: 20px;
	height: 20px;
	display: block;
}

.unicasuite-input-wrap input:focus ~ .unicasuite-input-icon,
.unicasuite-input-wrap:focus-within .unicasuite-input-icon {
	color: var(--login-primary);
}

/* Password toggle button */
.unicasuite-password-toggle {
	position: absolute;
	right: 0.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: none;
	background: transparent;
	color: var(--login-text-muted);
	cursor: pointer;
	border-radius: var(--login-radius-md);
	transition: color var(--login-transition-fast), background var(--login-transition-fast);
	z-index: 3;
	padding: 0;
	line-height: 0;
}

.unicasuite-password-toggle:hover {
	color: var(--login-primary);
	background: var(--login-primary-50);
}

.unicasuite-password-toggle:focus-visible {
	outline: 2px solid var(--login-primary);
	outline-offset: 2px;
}

.unicasuite-password-toggle svg {
	width: 18px;
	height: 18px;
	display: block;
}

.unicasuite-password-toggle .eye-off {
	display: none;
}

.unicasuite-password-toggle.is-visible .eye-on {
	display: none;
}

.unicasuite-password-toggle.is-visible .eye-off {
	display: block;
}

/* ==========================================================================
   8. Custom Checkbox
   ========================================================================== */

body.login input[type="checkbox"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 18px !important;
	height: 18px !important;
	min-width: 18px;
	border: 1.5px solid var(--login-input-border) !important;
	border-radius: 5px !important;
	background: var(--login-input-bg) !important;
	cursor: pointer;
	position: relative;
	transition: all var(--login-transition-fast);
	margin: 0 !important;
	padding: 0 !important;
	vertical-align: middle;
}

body.login input[type="checkbox"]:checked {
	background: var(--login-primary) !important;
	border-color: var(--login-primary) !important;
}

body.login input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	top: 2px;
	left: 5px;
	width: 5px;
	height: 9px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

body.login input[type="checkbox"]:focus {
	box-shadow: 0 0 0 3px rgba(var(--login-primary-rgb), 0.15) !important;
	outline: none !important;
}

/* ==========================================================================
   9. Submit Button
   ========================================================================== */

body.login .submit,
body.login p.submit {
	margin-top: 0.25rem !important;
	margin-bottom: 0.75rem !important;
}

body.login .submit.unicasuite-login-submit-row,
body.login p.submit.unicasuite-login-submit-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

body.login #wp-submit,
body.login input[type="submit"] {
	width: 100% !important;
	height: 48px !important;
	font-size: 0.9375rem !important;
	font-weight: 600 !important;
	font-family: var(--login-font) !important;
	color: #FFFFFF !important;
	background: var(--login-primary) !important;
	border: none !important;
	border-radius: var(--login-radius-lg) !important;
	cursor: pointer !important;
	transition: all var(--login-transition) !important;
	text-shadow: none !important;
	box-shadow: 0 1px 3px rgba(var(--login-primary-rgb), 0.3), 0 1px 2px rgba(var(--login-primary-rgb), 0.2) !important;
	position: relative;
	overflow: hidden;
	letter-spacing: 0.01em;
}

body.login .unicasuite-login-submit-row #wp-submit,
body.login .unicasuite-login-submit-row input[type="submit"] {
	flex: 1 1 auto;
	width: auto !important;
}

body.login #wp-submit:hover,
body.login input[type="submit"]:hover {
	background: var(--login-primary-hover) !important;
	box-shadow: 0 4px 12px rgba(var(--login-primary-rgb), 0.35), 0 2px 4px rgba(var(--login-primary-rgb), 0.2) !important;
	transform: translateY(-1px);
}

body.login #wp-submit:active,
body.login input[type="submit"]:active {
	transform: translateY(0);
	box-shadow: 0 1px 2px rgba(var(--login-primary-rgb), 0.3) !important;
}

body.login #wp-submit:focus,
body.login input[type="submit"]:focus {
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(var(--login-primary-rgb), 0.3), 0 4px 12px rgba(var(--login-primary-rgb), 0.25) !important;
}

/* Button ripple effect */
body.login #wp-submit::after {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at var(--ripple-x, 50%) var(--ripple-y, 50%), rgba(255,255,255,0.25) 0%, transparent 60%);
	opacity: 0;
	transition: opacity 0.4s ease;
}

body.login #wp-submit:active::after {
	opacity: 1;
}

/* ==========================================================================
   10. Remember Me & Form Footer Row
   ========================================================================== */

body.login .forgetmenot {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 !important;
}

body.login .forgetmenot label {
	margin: 0 !important;
	line-height: 1.4;
	white-space: nowrap;
}

body.login .unicasuite-login-options {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin: -0.25rem 0 1rem;
}

body.login .unicasuite-lost-password-link {
	color: var(--login-primary) !important;
	font-size: 0.875rem;
	font-weight: 650;
	text-decoration: none;
	white-space: nowrap;
}

body.login .unicasuite-lost-password-link:hover {
	color: var(--login-primary-hover) !important;
	text-decoration: underline;
	text-underline-offset: 3px;
}

@media (max-width: 420px) {
	body.login .unicasuite-login-options {
		align-items: flex-start;
		flex-direction: column;
		gap: 0.5rem;
	}
}

/* ==========================================================================
   11. Messages & Errors
   ========================================================================== */

body.login #login_error,
body.login .message,
body.login .success {
	border-radius: var(--login-radius-lg) !important;
	padding: 0.875rem 1rem !important;
	margin: 0 0 1.25rem !important;
	font-size: 0.875rem !important;
	line-height: 1.5 !important;
	border: 1px solid !important;
	box-shadow: none !important;
	animation: loginMsgIn 0.35s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes loginMsgIn {
	from {
		opacity: 0;
		transform: translateY(-8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

body.login #login_error {
	background: #FEF2F2 !important;
	border-color: #FECACA !important;
	color: #991B1B !important;
	border-left: 4px solid var(--login-error) !important;
}

[data-theme="dark"] body.login #login_error {
	background: rgba(239, 68, 68, 0.1) !important;
	border-color: rgba(239, 68, 68, 0.3) !important;
	color: #FCA5A5 !important;
}

body.login .message {
	background: #EFF6FF !important;
	border-color: #BFDBFE !important;
	color: #1E40AF !important;
	border-left: 4px solid #3B82F6 !important;
}

[data-theme="dark"] body.login .message {
	background: rgba(59, 130, 246, 0.1) !important;
	border-color: rgba(59, 130, 246, 0.3) !important;
	color: #93C5FD !important;
}

body.login .success {
	background: #F0FDF4 !important;
	border-color: #BBF7D0 !important;
	color: #166534 !important;
	border-left: 4px solid var(--login-success) !important;
}

[data-theme="dark"] body.login .success {
	background: rgba(16, 185, 129, 0.1) !important;
	border-color: rgba(16, 185, 129, 0.3) !important;
	color: #6EE7B7 !important;
}

body.login #login_error a,
body.login .message a,
body.login .success a {
	color: inherit !important;
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* WordPress Caps Lock warning — hidden entirely */
body.login .caps-warning,
body.login #caps-warning {
	display: none !important;
}

/* ==========================================================================
   12. Navigation Links (Back to blog, Register, Lost Password)
   ========================================================================== */

body.login #nav,
body.login #backtoblog {
	padding: 0 !important;
	margin: 0 0 0.75rem !important;
	text-align: center;
}

body.login #nav a,
body.login #backtoblog a,
body.login .privacy-policy-page-link a {
	color: var(--login-text-sec) !important;
	font-size: 0.875rem;
	text-decoration: none;
	transition: color var(--login-transition-fast);
	font-weight: 500;
}

body.login #nav a:hover,
body.login #backtoblog a:hover,
body.login .privacy-policy-page-link a:hover {
	color: var(--login-primary) !important;
}

/* Separator between Register / Lost password links */
body.login #nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
}

body.login #nav a {
	position: relative;
	padding: 0.375rem 0;
}

body.login #nav a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: var(--login-primary);
	transform: scaleX(0);
	transition: transform var(--login-transition);
	border-radius: 1px;
}

body.login #nav a:hover::after {
	transform: scaleX(1);
}

/* Style the separator "|" between nav links */
body.login #nav .login-nav-sep {
	color: var(--login-border);
	font-size: 0.75rem;
}

body.login #nav .unicasuite-auth-nav__register-link {
	display: none !important;
}

body.login #nav.unicasuite-auth-nav--processed {
	display: none !important;
}

body.login .unicasuite-auth-switch {
	position: relative;
	overflow: hidden;
	margin: 0 0 1rem;
	padding: 1rem;
	border: 1px solid rgba(var(--login-primary-rgb), 0.18);
	border-radius: var(--login-radius-xl);
	background:
		radial-gradient(circle at top right, rgba(var(--login-primary-rgb), 0.16), transparent 34%),
		linear-gradient(135deg, var(--login-surface), var(--login-primary-50));
	box-shadow: var(--login-shadow-md);
}

body.login .unicasuite-auth-switch::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.55);
}

body.login .unicasuite-auth-switch__eyebrow {
	display: inline-flex;
	align-items: center;
	margin-bottom: 0.45rem;
	color: var(--login-primary);
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

body.login .unicasuite-auth-switch strong {
	display: block;
	margin-bottom: 0.35rem;
	color: var(--login-heading);
	font-size: 1rem;
	line-height: 1.35;
}

body.login .unicasuite-auth-switch p {
	margin: 0 0 0.85rem;
	color: var(--login-text-sec);
	font-size: 0.86rem;
	line-height: 1.6;
}

body.login .unicasuite-auth-switch__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	width: 100%;
	min-height: 46px;
	padding: 0.75rem 1rem;
	border-radius: var(--login-radius-lg);
	background: linear-gradient(135deg, var(--login-primary), var(--login-primary-hover));
	color: #fff !important;
	font-size: 0.9rem;
	font-weight: 800;
	text-decoration: none;
	box-shadow: 0 12px 26px rgba(var(--login-primary-rgb), 0.28);
	transition: transform var(--login-transition-fast), box-shadow var(--login-transition-fast), filter var(--login-transition-fast);
}

body.login .unicasuite-auth-switch__button:hover {
	color: #fff !important;
	filter: brightness(1.03);
	transform: translateY(-1px);
	box-shadow: 0 16px 30px rgba(var(--login-primary-rgb), 0.34);
}

body.login .unicasuite-auth-switch__button svg {
	flex: 0 0 auto;
}

body.login .unicasuite-auth-switch--login {
	background:
		radial-gradient(circle at bottom left, rgba(var(--login-primary-rgb), 0.12), transparent 36%),
		var(--login-surface-alt);
	box-shadow: none;
}

body.login .unicasuite-auth-switch--login .unicasuite-auth-switch__button {
	background: var(--login-surface);
	color: var(--login-primary) !important;
	border: 1.5px solid rgba(var(--login-primary-rgb), 0.28);
	box-shadow: none;
}

body.login .unicasuite-auth-switch--login .unicasuite-auth-switch__button:hover {
	background: var(--login-primary-50);
	color: var(--login-primary) !important;
	box-shadow: none;
}

body.login .notylab-code-login-link {
	margin: 0 0 0.85rem !important;
	text-align: center !important;
}

body.login .notylab-code-login-link a,
body.login .unicasuite-email-code-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	min-height: 38px;
	padding: 0.5rem 0.8rem;
	border: 1px solid rgba(var(--login-primary-rgb), 0.2);
	border-radius: 999px;
	background: rgba(var(--login-primary-rgb), 0.06);
	color: var(--login-primary) !important;
	font-size: 0.8125rem;
	font-weight: 750;
	text-decoration: none;
	transition: border-color var(--login-transition-fast), color var(--login-transition-fast), background var(--login-transition-fast), transform var(--login-transition-fast);
}

body.login .notylab-code-login-link a:hover,
body.login .unicasuite-email-code-link:hover {
	border-color: rgba(var(--login-primary-rgb), 0.38);
	background: var(--login-primary-50);
	color: var(--login-primary) !important;
	transform: translateY(-1px);
}

body.login .unicasuite-email-code-link {
	flex: 0 0 auto;
	height: 48px;
	white-space: nowrap;
}

@media (max-width: 420px) {
	body.login .submit.unicasuite-login-submit-row,
	body.login p.submit.unicasuite-login-submit-row {
		align-items: stretch;
		flex-direction: column;
		gap: 0.6rem;
	}

	body.login .unicasuite-email-code-link {
		width: 100%;
	}
}

/* ==========================================================================
   13. Divider (Social login separator — future use)
   ========================================================================== */

.unicasuite-login-divider {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin: 1.5rem 0;
	color: var(--login-text-muted);
	font-size: 0.8125rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 500;
}

.unicasuite-login-divider::before,
.unicasuite-login-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: var(--login-border);
}

/* ==========================================================================
   14. Password Strength Meter
   ========================================================================== */

body.login #pass-strength-result {
	margin: -0.75rem 0 1rem !important;
	padding: 0.5rem 0.75rem !important;
	border-radius: var(--login-radius-md) !important;
	font-size: 0.8125rem !important;
	font-weight: 500 !important;
	border: none !important;
	background: var(--login-surface-alt) !important;
	text-align: center;
}

body.login #pass-strength-result.bad {
	background: #FEF2F2 !important;
	color: #DC2626 !important;
}

body.login #pass-strength-result.good {
	background: #FFFBEB !important;
	color: #D97706 !important;
}

body.login #pass-strength-result.strong {
	background: #F0FDF4 !important;
	color: #16A34A !important;
}

[data-theme="dark"] body.login #pass-strength-result.bad {
	background: rgba(220, 38, 38, 0.15) !important;
	color: #FCA5A5 !important;
}

[data-theme="dark"] body.login #pass-strength-result.good {
	background: rgba(217, 119, 6, 0.15) !important;
	color: #FCD34D !important;
}

[data-theme="dark"] body.login #pass-strength-result.strong {
	background: rgba(22, 163, 74, 0.15) !important;
	color: #86EFAC !important;
}

/* ==========================================================================
   15. Two-Factor / Interim Login
   ========================================================================== */

body.login.interim-login #login {
	padding: 0 !important;
}

/* ==========================================================================
   16. Language Switcher
   ========================================================================== */

body.login .language-switcher {
	margin-top: 1rem;
	text-align: center;
}

body.login .language-switcher select {
	padding: 0.5rem 2rem 0.5rem 0.75rem;
	border: 1px solid var(--login-border);
	border-radius: var(--login-radius-md);
	background: var(--login-input-bg);
	color: var(--login-text);
	font-size: 0.875rem;
	font-family: var(--login-font);
	cursor: pointer;
}

body.login .language-switcher .button {
	padding: 0.5rem 1rem;
	border: 1px solid var(--login-border);
	border-radius: var(--login-radius-md);
	background: var(--login-surface);
	color: var(--login-text);
	font-size: 0.875rem;
	font-family: var(--login-font);
	cursor: pointer;
	transition: all var(--login-transition-fast);
	margin-left: 0.5rem;
}

body.login .language-switcher .button:hover {
	border-color: var(--login-primary);
	color: var(--login-primary);
}

/* ==========================================================================
   17. Animations
   ========================================================================== */

/* Stagger animation for child elements */
body.login .unicasuite-login-form-area__inner > * {
	animation: loginFadeUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}

body.login .unicasuite-login-form-area__inner > *:nth-child(1) { animation-delay: 0.05s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(2) { animation-delay: 0.1s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(3) { animation-delay: 0.15s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(4) { animation-delay: 0.2s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(5) { animation-delay: 0.25s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(6) { animation-delay: 0.3s; }
body.login .unicasuite-login-form-area__inner > *:nth-child(7) { animation-delay: 0.35s; }

@keyframes loginFadeUp {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Panel features stagger */
.unicasuite-login-panel__feature {
	animation: panelFeatureIn 0.6s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.unicasuite-login-panel__feature:nth-child(1) { animation-delay: 0.3s; }
.unicasuite-login-panel__feature:nth-child(2) { animation-delay: 0.45s; }
.unicasuite-login-panel__feature:nth-child(3) { animation-delay: 0.6s; }

@keyframes panelFeatureIn {
	from {
		opacity: 0;
		transform: translateX(-16px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* ==========================================================================
   18. Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* ==========================================================================
   19. Print
   ========================================================================== */

@media print {
	.unicasuite-login-panel,
	.unicasuite-login-theme-toggle {
		display: none !important;
	}
}

/* ==========================================================================
   20. Loading state for submit button
   ========================================================================== */

body.login #wp-submit.is-loading {
	pointer-events: none;
	opacity: 0.8;
}

body.login #wp-submit.is-loading::before {
	content: '';
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255,255,255,0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: loginSpinner 0.6s linear infinite;
	margin-right: 0.5rem;
	vertical-align: middle;
}

@keyframes loginSpinner {
	to { transform: rotate(360deg); }
}

/* ==========================================================================
   21. Responsive Fine-Tuning
   ========================================================================== */

@media (max-width: 480px) {
	body.login #loginform,
	body.login #registerform,
	body.login #lostpasswordform,
	body.login #resetpassform {
		padding: 1.5rem 1.25rem !important;
		border-radius: var(--login-radius-xl) !important;
	}

	.unicasuite-login-form-area {
		padding: 1.5rem 1rem;
	}
}

@media (min-width: 1440px) {
	.unicasuite-login-panel {
		width: 540px;
		min-width: 540px;
	}
}

/* ==========================================================================
   22. Focus Visible for Accessibility
   ========================================================================== */

body.login a:focus-visible,
body.login button:focus-visible,
body.login input:focus-visible,
body.login select:focus-visible {
	outline: 2px solid var(--login-primary);
	outline-offset: 2px;
}

body.login input[type="text"]:focus-visible,
body.login input[type="email"]:focus-visible,
body.login input[type="password"]:focus-visible {
	outline: none;
}

/* ==========================================================================
   23. Registration page specifics
   ========================================================================== */

body.login.action-register #reg_passmail {
	font-size: 0.8125rem;
	color: var(--login-text-muted);
	margin-top: -0.5rem;
	margin-bottom: 1rem;
	line-height: 1.5;
}

body.login.action-register #reg_passmail.unicasuite-register-note-hidden {
	display: none !important;
}

body.login #registerform.unicasuite-register-steps[data-step="email"] .unicasuite-register-step-account,
body.login #registerform.unicasuite-register-steps[data-step="email"] .unicasuite-register-password-help {
	display: none !important;
}

body.login #registerform.unicasuite-register-steps[data-step="account"] .unicasuite-register-step-account,
body.login #registerform.unicasuite-register-steps[data-step="account"] .unicasuite-register-password-help {
	animation: loginFadeUp 0.25s cubic-bezier(0.16, 1, 0.3, 1) both;
}

body.login .unicasuite-register-step-note,
body.login .unicasuite-register-password-help {
	margin: 0 0 18px;
	padding: 12px 14px;
	border: 1px solid rgba(var(--login-primary-rgb), 0.16);
	border-radius: var(--login-radius-lg);
	background: var(--login-primary-50);
	color: var(--login-text-sec);
	font-size: 13px;
	line-height: 1.6;
}

body.login .unicasuite-register-password-help strong,
body.login .unicasuite-register-password-help span {
	display: block;
}

body.login .unicasuite-register-password-help strong {
	margin-bottom: 3px;
	color: var(--login-text);
}

/* ==========================================================================
   24. Lost Password specifics
   ========================================================================== */

body.login.action-lostpassword .message {
	margin-bottom: 1.25rem !important;
}

/* ==========================================================================
   25. Reset Password specifics
   ========================================================================== */

body.login #resetpassform .description.indicator-hint {
	margin: 0 0 1rem !important;
	padding: 12px 14px !important;
	border: 1px solid var(--login-border) !important;
	border-radius: var(--login-radius-lg) !important;
	background: var(--login-surface-alt) !important;
	color: var(--login-text-sec) !important;
	font-size: 0.8125rem !important;
	line-height: 1.6 !important;
}

body.login #resetpassform .reset-pass-submit {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

body.login #resetpassform .reset-pass-submit .wp-generate-pw,
body.login #resetpassform .reset-pass-submit #wp-submit {
	flex: 1 1 180px;
	width: auto !important;
}

body.login #resetpassform .wp-generate-pw {
	height: 48px !important;
	padding: 0 1rem !important;
	font-size: 0.875rem !important;
	font-weight: 600 !important;
	color: var(--login-text) !important;
	background: var(--login-surface) !important;
	border: 1.5px solid var(--login-input-border) !important;
	border-radius: var(--login-radius-lg) !important;
	cursor: pointer !important;
	transition: all var(--login-transition-fast) !important;
	box-shadow: none !important;
}

body.login #resetpassform .wp-generate-pw:hover {
	border-color: var(--login-primary) !important;
	color: var(--login-primary) !important;
	background: var(--login-primary-50) !important;
}

body.login #resetpassform .wp-generate-pw:focus {
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(var(--login-primary-rgb), 0.2) !important;
}

/* ==========================================================================
   26. Hide default WP login footer (powered by WP)
   ========================================================================== */

body.login .clear {
	display: none;
}
