/* ============================================================
   BACKFLOW SCHOOL — wp-login.php custom styles
   ============================================================ */

/* PAGE */
body.login {
	background: #0B1E38 !important;
	font-family: 'Manrope', sans-serif !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: flex-start !important;
	min-height: 100vh !important;
	padding: 48px 20px 40px !important;
	position: relative !important;
	overflow-x: hidden !important;
}

body.login::before {
	content: '';
	position: fixed;
	top: -120px;
	right: -120px;
	width: 400px;
	height: 400px;
	border-radius: 50%;
	background: rgba(232, 96, 26, 0.08);
	pointer-events: none;
	z-index: 0;
}

/* CARD */
#login {
	width: 100% !important;
	max-width: 420px !important;
	padding: 36px 40px !important;
	background: #ffffff !important;
	border-radius: 16px !important;
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.25) !important;
	position: relative !important;
	z-index: 1 !important;
}

/* LOGO */
.login h1 {
	text-align: center !important;
	padding: 0 !important;
}

.login h1 a {
	display: inline-block !important;
	width: 172px !important;
	height: 172px !important;
	background-size: contain !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	text-indent: -9999px !important;
	overflow: hidden !important;
	box-shadow: none !important;
	outline: none !important;
	border-radius: 0 !important;
}

/* FORM WRAPPERS — strip WP defaults */
#loginform,
#registerform,
#lostpasswordform,
#resetpassform {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* FORM TITLES via ::before */
#loginform::before,
#registerform::before,
#lostpasswordform::before,
#resetpassform::before {
	display: block !important;
	font-family: 'Outfit', sans-serif !important;
	font-size: 22px !important;
	font-weight: 500 !important;
	color: #1A3E6F !important;
	margin-bottom: 20px !important;
	line-height: 1.2 !important;
}

#loginform::before      { content: 'Welcome back' !important; }
#registerform::before   { content: 'Create an account' !important; }
#lostpasswordform::before { content: 'Reset your password' !important; }
#resetpassform::before  { content: 'Choose a new password' !important; }

/* LABELS */
.login label {
	font-family: 'Manrope', sans-serif !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	color: #1A3E6F !important;
	letter-spacing: 0.3px !important;
	text-transform: uppercase !important;
	margin-bottom: 6px !important;
	display: block !important;
	line-height: 1.4 !important;
}

/* Remember Me — don't inherit uppercase/navy */
.login .forgetmenot label {
	font-size: 13px !important;
	text-transform: none !important;
	font-weight: 400 !important;
	letter-spacing: 0 !important;
	color: #666666 !important;
}

/* INPUTS */
.login input[type="text"],
.login input[type="password"],
.login input[type="email"] {
	width: 100% !important;
	height: 42px !important;
	border: 1.5px solid #E8ECF2 !important;
	border-radius: 10px !important;
	padding: 0 14px !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 14px !important;
	color: #222222 !important;
	background: #ffffff !important;
	box-shadow: none !important;
	outline: none !important;
	transition: border-color 0.15s ease !important;
	margin: 0 0 16px !important;
	display: block !important;
}

.login input[type="text"]:focus,
.login input[type="password"]:focus,
.login input[type="email"]:focus {
	border-color: #1A3E6F !important;
	box-shadow: none !important;
}

/* FIELD WRAPPER PARAGRAPHS */
#loginform p,
#registerform p,
#lostpasswordform p,
#resetpassform p {
	margin: 0 !important;
	padding: 0 !important;
}

/* WP 6.x password wrapper */
.login .user-pass-wrap {
	margin-bottom: 0 !important;
}

.login .wp-pwd {
	position: relative !important;
}

.login .wp-pwd input {
	padding-right: 42px !important;
}

/* WP built-in password toggle button */
.login .wp-hide-pw {
	position: absolute !important;
	right: 10px !important;
	top: calc(50% - 8px) !important; /* offset for the 16px bottom margin on input */
	transform: translateY(-50%) !important;
	margin: 0 !important;
	padding: 0 4px !important;
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	color: #999999 !important;
	min-height: auto !important;
	height: auto !important;
	cursor: pointer !important;
}

.login .wp-hide-pw:hover,
.login .wp-hide-pw:focus {
	color: #1A3E6F !important;
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
}

.login .wp-hide-pw .dashicons {
	font-size: 16px !important;
	width: 16px !important;
	height: 16px !important;
}

/* SUBMIT BUTTON */
.login .button-primary,
.login input[type="submit"].button-primary {
	width: 100% !important;
	height: 46px !important;
	background: #E8601A !important;
	color: #ffffff !important;
	border: none !important;
	border-radius: 24px !important;
	font-family: 'Outfit', sans-serif !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	cursor: pointer !important;
	transition: background 0.15s ease !important;
	box-shadow: none !important;
	text-shadow: none !important;
	margin-top: 8px !important;
	display: block !important;
	line-height: 1 !important;
	padding: 0 !important;
}

.login .button-primary:hover,
.login input[type="submit"].button-primary:hover,
.login .button-primary:focus,
.login input[type="submit"].button-primary:focus {
	background: #BF4A10 !important;
	color: #ffffff !important;
	box-shadow: none !important;
	outline: none !important;
}

.login p.submit {
	margin: 0 !important;
	padding: 0 !important;
}

/* NAV LINKS (lost password, register) */
#nav {
	text-align: center !important;
	margin-top: 20px !important;
	padding: 0 !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	color: #666666 !important;
}

#nav a {
	color: #E8601A !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	text-decoration: none !important;
}

#nav a:hover {
	color: #BF4A10 !important;
	text-decoration: underline !important;
}

/* BACK TO BLOG (outside the card) */
#backtoblog {
	text-align: center !important;
	margin-top: 20px !important;
	padding: 0 !important;
}

#backtoblog a {
	color: rgba(255, 255, 255, 0.45) !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 12px !important;
	font-weight: 400 !important;
	text-decoration: none !important;
	transition: color 0.15s ease !important;
}

#backtoblog a:hover {
	color: rgba(255, 255, 255, 0.8) !important;
}

/* ERROR MESSAGES */
#login_error {
	background: #fff5f5 !important;
	border-left: 4px solid #E8601A !important;
	border-radius: 8px !important;
	color: #444444 !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	line-height: 1.5 !important;
	padding: 12px 16px !important;
	margin-bottom: 20px !important;
	box-shadow: none !important;
}

#login_error a {
	color: #E8601A !important;
}

/* SUCCESS / INFO MESSAGES */
.message,
p.message {
	background: #EEF3FB !important;
	border-left: 4px solid #1A3E6F !important;
	border-radius: 8px !important;
	color: #1A3E6F !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	line-height: 1.5 !important;
	padding: 12px 16px !important;
	margin-bottom: 20px !important;
	box-shadow: none !important;
}

/* WP NOTICES (admin-style notices sometimes appear on login) */
.login .notice {
	background: #EEF3FB !important;
	border-left: 4px solid #1A3E6F !important;
	border-radius: 8px !important;
	padding: 12px 16px !important;
	margin-bottom: 16px !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	color: #1A3E6F !important;
	box-shadow: none !important;
}

/* PRIVACY POLICY LINK */
.privacy-policy-page-link {
	text-align: center !important;
	font-size: 12px !important;
	color: rgba(255, 255, 255, 0.4) !important;
	margin-top: 16px !important;
}

.privacy-policy-page-link a {
	color: rgba(255, 255, 255, 0.5) !important;
	text-decoration: none !important;
}

/* RESPONSIVE */
@media (max-width: 480px) {
	body.login {
		padding: 24px 16px 32px !important;
	}

	#login {
		padding: 28px 24px !important;
	}
}
