/* ==================================================================
   The Longevity Edge — wp-login.php branding
   ------------------------------------------------------------------
   Loaded only on /wp-login.php and its sub-actions (lost-pw, reset-pw,
   register). Self-contained — depends only on tokens.css (CSS vars).
   ================================================================== */

html, body.login {
	background: var(--canvas) !important;
	font-family: var(--font-body, "Inter", system-ui, sans-serif) !important;
	color: var(--ink-900) !important;
	min-height: 100vh;
}
body.login {
	padding: var(--s-7) var(--s-5) !important;
}

/* Centered card layout — wider than WP default to accommodate brand polish */
.login #login {
	width: 100%;
	max-width: 420px;
	padding: 0 !important;
	margin: 7vh auto 0;
}

/* Logo H1 wrap (background-image set by inline style from PHP) */
.login h1 {
	margin: 0 0 var(--s-4) !important;
}

/* Welcome line above the form (set by login_message filter) */
.le-login-welcome {
	text-align: center;
	font-family: var(--font-body);
	font-size: var(--fs-base);
	color: var(--ink-700);
	line-height: var(--lh-snug);
	margin: 0 0 var(--s-5);
	padding: 0 var(--s-3);
}

/* The form card */
.login form#loginform,
.login form#registerform,
.login form#lostpasswordform,
.login form#resetpassform {
	background: var(--surface) !important;
	border: 1px solid var(--navy-100) !important;
	border-radius: var(--r-lg) !important;
	box-shadow: 0 10px 28px rgba(14, 26, 43, 0.07) !important;
	padding: var(--s-6) var(--s-6) var(--s-5) !important;
	margin: 0 0 var(--s-4) !important;
}

/* Field labels */
.login label[for="user_login"],
.login label[for="user_email"],
.login label[for="user_pass"],
.login label[for="pass1"],
.login label[for="pass2"] {
	display: block;
	font-family: var(--font-body) !important;
	font-size: var(--fs-sm) !important;
	font-weight: 600 !important;
	color: var(--navy-900) !important;
	margin-bottom: 6px !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
}

/* Form rows */
.login form p {
	margin: 0 0 var(--s-3) !important;
}

/* Input fields */
.login .input,
.login input[type="text"],
.login input[type="email"],
.login input[type="password"] {
	width: 100% !important;
	height: 52px !important;
	padding: 0 var(--s-4) !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-base) !important;
	line-height: 1.4 !important;
	color: var(--navy-900) !important;
	background: #fff !important;
	border: 1.5px solid var(--navy-100) !important;
	border-radius: var(--r-md) !important;
	box-sizing: border-box !important;
	box-shadow: none !important;
	margin: 0 !important;
	transition: border-color 180ms ease, box-shadow 180ms ease;
}
.login .input:focus,
.login input[type="text"]:focus,
.login input[type="email"]:focus,
.login input[type="password"]:focus {
	outline: none !important;
	border-color: var(--gold-600) !important;
	box-shadow: 0 0 0 3px rgba(196, 156, 88, 0.2) !important;
}

/* Submit button */
.login .button-primary,
.login p.submit .button-primary {
	float: none !important;
	width: 100% !important;
	height: 52px !important;
	padding: 0 var(--s-4) !important;
	background: var(--cta-600) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: var(--r-md) !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-base) !important;
	font-weight: 700 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
	text-shadow: none !important;
	box-shadow: 0 4px 12px rgba(168, 38, 50, 0.22) !important;
	cursor: pointer !important;
	transition: background 180ms ease, box-shadow 180ms ease, transform 180ms ease !important;
}
.login .button-primary:hover {
	background: var(--cta-700, #8e1f29) !important;
	box-shadow: 0 6px 16px rgba(168, 38, 50, 0.28) !important;
}

/* "Remember Me" checkbox */
.login .forgetmenot {
	margin: var(--s-3) 0 var(--s-4) !important;
}
.login .forgetmenot label {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	cursor: pointer !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-sm) !important;
	font-weight: 500 !important;
	color: var(--ink-700) !important;
}
.login .forgetmenot input[type="checkbox"] {
	width: 18px !important;
	height: 18px !important;
	accent-color: var(--gold-600) !important;
	margin: 0 !important;
}

/* "Show password" toggle */
.login .wp-pwd .button.wp-hide-pw {
	right: 4px !important;
	top: 4px !important;
	height: 44px !important;
	width: 44px !important;
	color: var(--ink-700) !important;
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
}
.login .wp-pwd .button.wp-hide-pw:hover {
	color: var(--gold-600) !important;
}

/* "Lost your password?" + "Back to site" links */
.login #nav,
.login #backtoblog {
	text-align: center !important;
	padding: 0 !important;
	margin: var(--s-3) 0 !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-sm) !important;
}
.login #nav a,
.login #backtoblog a {
	color: var(--gold-600) !important;
	font-weight: 600 !important;
	text-decoration: none !important;
	transition: color 180ms ease !important;
}
.login #nav a:hover,
.login #backtoblog a:hover {
	color: var(--cta-600) !important;
	text-decoration: underline !important;
}

/* Privacy policy link on register screen */
.login .privacy-policy-page-link {
	text-align: center !important;
	margin-top: var(--s-3) !important;
	font-size: var(--fs-xs) !important;
	color: var(--ink-500) !important;
}
.login .privacy-policy-page-link a {
	color: var(--gold-600) !important;
	font-weight: 600;
}

/* Login notice + error messages */
.login .message,
.login .notice,
.login #login_error {
	background: #fff !important;
	border-radius: var(--r-md) !important;
	padding: var(--s-3) var(--s-4) !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-sm) !important;
	color: var(--navy-900) !important;
	box-shadow: 0 4px 12px rgba(14, 26, 43, 0.06) !important;
	margin: 0 0 var(--s-4) !important;
	line-height: var(--lh-snug, 1.4) !important;
}
.login .message {
	border-left: 4px solid var(--success, #4a8a3b) !important;
}
.login #login_error {
	border-left: 4px solid var(--cta-600) !important;
}

/* Password strength meter (on register + reset) */
.login #pass-strength-result {
	margin: 8px 0 0 !important;
	padding: 8px 12px !important;
	border-radius: var(--r-sm) !important;
	font-family: var(--font-body) !important;
	font-size: var(--fs-xs) !important;
	font-weight: 600 !important;
	border: 0 !important;
}

/* Hide WP language switcher footer (rarely needed for TLE) */
.login #language-switcher,
.login .login-action-login #language-switcher { display: none !important; }

/* Hide WP version footer */
.login .wp-toolbar { display: none; }
.login .login-action-login,
.login.no-js .hide-if-no-js { /* keep noscript fallbacks visible */ }

/* Mobile polish */
@media (max-width: 480px) {
	body.login { padding: var(--s-5) var(--s-4) !important; }
	.login #login { margin: 3vh auto 0; max-width: 100%; }
	.login form#loginform,
	.login form#registerform,
	.login form#lostpasswordform,
	.login form#resetpassform {
		padding: var(--s-5) !important;
	}
}
