/* Profile Builder - Nutri Ajustes */

:root {
	--mgnpb-green: #A7DD52;
	--mgnpb-green-hover: #98CF42;
	--mgnpb-text: #1F3440;
	--mgnpb-muted: #66757E;
	--mgnpb-border: #E5EBDD;
	--mgnpb-soft: #F7FAF2;
	--mgnpb-white: #ffffff;
	--mgnpb-shadow: 0 18px 42px rgba( 31, 52, 64, 0.08 );
}

#wppb-login-wrap,
#wppb-register-user,
#wppb-recover-password-container,
.wppb-alert,
#wppb_register_pre_form_message {
	box-sizing: border-box;
	width: min( 100%, 720px );
	margin: 24px 0 34px;
	padding: 28px;
	border: 1px solid var( --mgnpb-border );
	border-radius: 22px;
	background: var( --mgnpb-white );
	box-shadow: var( --mgnpb-shadow );
	color: var( --mgnpb-text );
}

#wppb-register-user {
	width: min( 100%, 780px );
}

#wppb-login-wrap *,
#wppb-register-user *,
#wppb-recover-password-container *,
.wppb-alert *,
#wppb_register_pre_form_message * {
	box-sizing: border-box;
}

#wppb-login-wrap form,
#wppb-register-user,
#wppb-recover-password-container form {
	margin: 0;
}

#wppb-login-wrap p,
#wppb-register-user p,
#wppb-recover-password-container p {
	margin-top: 0;
}

#wppb-register-user ul,
#wppb-recover-password ul {
	display: grid;
	gap: 16px;
	margin: 0;
	padding: 0;
	list-style: none;
}

#wppb-login-wrap .wppb-form-field,
#wppb-register-user .wppb-form-field,
#wppb-recover-password .wppb-form-field {
	margin: 0 0 16px;	
	padding: 0;
	border: 0;
}

#wppb-register-user .wppb-form-field {
	margin-bottom: 0;
}

#wppb-login-wrap label,
#wppb-register-user label,
#wppb-recover-password label {
	display: block;
	margin: 0 0 7px;
	color: var( --mgnpb-text );
	font-size: 15px;
	font-weight: 700;
	line-height: 1.25;
}

#wppb-login-wrap input[type="text"],
#wppb-login-wrap input[type="email"],
#wppb-login-wrap input[type="password"],
#wppb-register-user input[type="text"],
#wppb-register-user input[type="email"],
#wppb-register-user input[type="password"],
#wppb-register-user input[type="url"],
#wppb-register-user textarea,
#wppb-recover-password input[type="text"],
#wppb-recover-password input[type="email"],
#wppb-recover-password input[type="password"],
#wppb-recover-password textarea {
	width: 100%;
	min-height: 46px;
	margin: 0;
	padding: 11px 14px;
	border: 1px solid var( --mgnpb-border );
	border-radius: 13px;
	background: var( --mgnpb-soft );
	box-shadow: none;
	color: var( --mgnpb-text );
	font-size: 16px;
	line-height: 1.3;
	transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

#wppb-register-user textarea,
#wppb-recover-password textarea {
	min-height: 96px;
	resize: vertical;
}

#wppb-login-wrap input:focus,
#wppb-register-user input:focus,
#wppb-register-user textarea:focus,
#wppb-recover-password input:focus,
#wppb-recover-password textarea:focus {
	outline: none;
	border-color: var( --mgnpb-green );
	background: var( --mgnpb-white );
	box-shadow: 0 0 0 4px rgba( 167, 221, 82, 0.16 );
}

#wppb-login-wrap .wppb-password-field-container,
#wppb-register-user .wppb-password-field-container,
#wppb-recover-password .wppb-password-field-container {
	display: block;
	position: relative;
	width: 100%;
}

#wppb-login-wrap .wppb-password-field-container input,
#wppb-register-user .wppb-password-field-container input,
#wppb-recover-password .wppb-password-field-container input {
	padding-right: 46px;
}

#wppb-login-wrap .login-remember {
	display: flex;
	align-items: center;
	gap: 9px;
	margin: -2px 0 18px;
}

#wppb-login-wrap .login-remember input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin: 0;
	accent-color: var( --mgnpb-green );
}

#wppb-login-wrap .login-remember label {
	margin: 0;
	font-size: 14px;
	font-weight: 600;
	color: var( --mgnpb-muted );
}

#wppb-login-wrap .form-submit,
#wppb-register-user .form-submit,
#wppb-recover-password .form-submit {
	margin: 18px 0 0;
	padding: 0;
}

#wppb-login-wrap input[type="submit"],
#wppb-register-user input[type="submit"],
#wppb-recover-password input[type="submit"],
#wppb-login-wrap .mgnpb-button,
#wppb-register-user .mgnpb-button,
#wppb-recover-password .mgnpb-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 12px 22px;
	border: 0;
	border-radius: 999px;
	background: var( --mgnpb-green );
	box-shadow: 0 10px 24px rgba( 167, 221, 82, 0.24 );
	color: var( --mgnpb-white );
	font-size: 15px;
	font-weight: 800;
	line-height: 1.1;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.16s ease, background-color 0.16s ease, box-shadow 0.16s ease;
}

#wppb-login-wrap input[type="submit"]:hover,
#wppb-register-user input[type="submit"]:hover,
#wppb-recover-password input[type="submit"]:hover,
#wppb-login-wrap .mgnpb-button:hover,
#wppb-register-user .mgnpb-button:hover,
#wppb-recover-password .mgnpb-button:hover {
	background: var( --mgnpb-green-hover );
	box-shadow: 0 13px 26px rgba( 167, 221, 82, 0.30 );
	color: var( --mgnpb-white );
	transform: translateY( -1px );
}

#wppb-login-wrap input[type="submit"]:focus-visible,
#wppb-register-user input[type="submit"]:focus-visible,
#wppb-recover-password input[type="submit"]:focus-visible,
#wppb-login-wrap .mgnpb-button:focus-visible,
#wppb-register-user .mgnpb-button:focus-visible,
#wppb-recover-password .mgnpb-button:focus-visible {
	outline: 3px solid rgba( 167, 221, 82, 0.35 );
	outline-offset: 3px;
}

#wppb-login-wrap .login-register-lost-password {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 12px;
	align-items: center;
	margin: 18px 0 0;
	padding-top: 18px;
	border-top: 1px solid var( --mgnpb-border );
	font-size: 14px;
}

#wppb-login-wrap .login-register-lost-password a,
#wppb-recover-password-container a,
#wppb-register-user a {
	color: var( --mgnpb-green-hover );
	font-weight: 700;
	text-decoration: none;
}

#wppb-login-wrap .login-register-lost-password a:hover,
#wppb-recover-password-container a:hover,
#wppb-register-user a:hover {
	text-decoration: underline;
}

#wppb-login-wrap .login-separator {
	color: var( --mgnpb-border );
}

#wppb-register-user .wppb-description-delimiter,
#wppb-recover-password .wppb-description-delimiter {
	display: block;
	margin-top: 6px;
	color: var( --mgnpb-muted );
	font-size: 13px;
	font-weight: 400;
	line-height: 1.35;
}

#wppb-register-user .wppb-required,
#wppb-recover-password .wppb-required {
	margin-left: 3px;
	color: var( --mgnpb-green-hover );
}

#wppb-login-wrap .wppb-error,
#wppb-login-wrap .wppb-success,
#wppb-register-user .wppb-error,
#wppb-register-user .wppb-success,
#wppb-recover-password-container .wppb-error,
#wppb-recover-password-container .wppb-success,
#wppb-recover-password-container .alert,
#wppb-register-user .alert {
	margin: 0 0 16px;
	padding: 12px 14px;
	border-radius: 14px;
	font-size: 14px;
	line-height: 1.4;
}

#wppb-login-wrap .wppb-success,
#wppb-register-user .wppb-success,
#wppb-recover-password-container .wppb-success {
	border: 1px solid rgba( 167, 221, 82, 0.34 );
	background: rgba( 167, 221, 82, 0.11 );
	color: #3d5d14;
}

#wppb-login-wrap .wppb-error,
#wppb-register-user .wppb-error,
#wppb-recover-password-container .wppb-error,
#wppb-recover-password-container .alert,
#wppb-register-user .alert {
	border: 1px solid rgba( 190, 69, 56, 0.22 );
	background: rgba( 190, 69, 56, 0.08 );
	color: #8b2e24;
}

#wppb-register-user .wppb-form-error,
#wppb-recover-password .wppb-form-error {
	display: block;
	margin-top: 6px;
	color: #8b2e24;
	font-size: 13px;
	font-weight: 700;
}


#wppb-login-wrap .login-username,
#wppb-login-wrap .login-password {
	margin: 0 0 16px;
}

#wppb-login-wrap .login-username label,
#wppb-login-wrap .login-password label {
	float: none !important;
	width: auto !important;
}

#wppb-login-wrap .login-username input,
#wppb-login-wrap .login-password input {
	float: none !important;
	width: 100% !important;
}

#wppb-login-wrap input[type="submit"]:active,
#wppb-register-user input[type="submit"]:active,
#wppb-recover-password input[type="submit"]:active,
#wppb-login-wrap .mgnpb-button:active,
#wppb-register-user .mgnpb-button:active,
#wppb-recover-password .mgnpb-button:active {
	background: #86BF34;
	box-shadow: 0 9px 20px rgba( 167, 221, 82, 0.22 );
	transform: translateY( 0 );
}

.wppb-alert,
#wppb_register_pre_form_message {
	font-size: 16px;
	line-height: 1.5;
}

.wppb-alert a,
#wppb_register_pre_form_message a {
	color: var( --mgnpb-green-hover );
	font-weight: 800;
	text-decoration: none;
}

.wppb-alert a:hover,
#wppb_register_pre_form_message a:hover {
	text-decoration: underline;
}

#wppb-recover-password-container > p,
#wppb-recover-password > p:first-child {
	margin-bottom: 18px;
	color: var( --mgnpb-muted );
	font-size: 15px;
	line-height: 1.5;
}

@media ( max-width: 782px ) {
	#wppb-login-wrap,
	#wppb-register-user,
	#wppb-recover-password-container,
	.wppb-alert,
	#wppb_register_pre_form_message {
		width: calc( 100% - 24px ) !important;
		max-width: calc( 100% - 24px ) !important;
		margin: 16px auto 28px !important;
		padding: 22px;
		border-radius: 18px;
	}

	#wppb-login-wrap input[type="submit"],
	#wppb-register-user input[type="submit"],
	#wppb-recover-password input[type="submit"] {
		width: 100%;
	}

	#wppb-login-wrap .login-register-lost-password {
		justify-content: center;
		text-align: center;
	}
}

@media ( max-width: 480px ) {
	#wppb-login-wrap,
	#wppb-register-user,
	#wppb-recover-password-container,
	.wppb-alert,
	#wppb_register_pre_form_message {
		padding: 18px;
		border-radius: 16px;
		box-shadow: 0 12px 28px rgba( 40, 58, 30, 0.08 );
	}

	#wppb-login-wrap label,
	#wppb-register-user label,
	#wppb-recover-password label {
		font-size: 14px;
	}

	#wppb-login-wrap input[type="text"],
	#wppb-login-wrap input[type="email"],
	#wppb-login-wrap input[type="password"],
	#wppb-register-user input[type="text"],
	#wppb-register-user input[type="email"],
	#wppb-register-user input[type="password"],
	#wppb-register-user input[type="url"],
	#wppb-register-user textarea,
	#wppb-recover-password input[type="text"],
	#wppb-recover-password input[type="email"],
	#wppb-recover-password input[type="password"] {
		min-height: 44px;
		font-size: 15px;
	}
}


/*
 * Ajuste desktop v0.1.6:
 * La alineación horizontal se calcula con JS tomando como referencia el H1 real
 * de cada página. Así no tocamos contenedores padre del tema/FSE.
 */
@media ( min-width: 783px ) {
	#wppb-login-wrap,
	#wppb-register-user,
	#wppb-recover-password-container,
	.wppb-alert,
	#wppb_register_pre_form_message {
		will-change: transform;
	}
}

/*
 * Ajuste desktop v0.1.7:
 * La pantalla que ya quedaba bien era el aviso .wppb-alert, porque seguía el flujo normal
 * del contenido. Replicamos esa lógica en login, registro y recuperación: el bloque de
 * shortcode y la tarjeta arrancan a la izquierda del área de contenido, sin centrados
 * heredados del tema o del bloque de WordPress.
 */
@media ( min-width: 783px ) {
	body.mgnpb-profile-builder-page .mgnpb-auth-title,
	body.mgnpb-profile-builder-page .entry-title,
	body.mgnpb-profile-builder-page .wp-block-post-title,
	body.mgnpb-profile-builder-page main h1:first-of-type {
		text-align: left !important;
		margin-left: 0 !important;
		margin-right: auto !important;
	}

	body.mgnpb-profile-builder-page .mgnpb-auth-shell-parent,
	body.mgnpb-profile-builder-page .mgnpb-auth-shell,
	body.mgnpb-profile-builder-page .wp-block-shortcode:has( #wppb-login-wrap ),
	body.mgnpb-profile-builder-page .wp-block-shortcode:has( #wppb-register-user ),
	body.mgnpb-profile-builder-page .wp-block-shortcode:has( #wppb-recover-password-container ),
	body.mgnpb-profile-builder-page .wp-block-shortcode:has( .wppb-alert ),
	body.mgnpb-profile-builder-page .wp-block-shortcode:has( #wppb_register_pre_form_message ) {
		display: block !important;
		width: 100% !important;
		max-width: none !important;
		margin-left: 0 !important;
		margin-right: auto !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		text-align: left !important;
		justify-self: stretch !important;
		align-self: auto !important;
		place-self: auto stretch !important;
		overflow: visible !important;
		transform: none !important;
	}

	body.mgnpb-profile-builder-page #wppb-login-wrap,
	body.mgnpb-profile-builder-page #wppb-register-user,
	body.mgnpb-profile-builder-page #wppb-recover-password-container,
	body.mgnpb-profile-builder-page .wppb-alert,
	body.mgnpb-profile-builder-page #wppb_register_pre_form_message,
	body.mgnpb-profile-builder-page .mgnpb-auth-card {
		margin-left: 0 !important;
		margin-right: auto !important;
		text-align: left !important;
		justify-self: start !important;
		align-self: start !important;
		transform: none !important;
	}
}
