:root{
	--cm-login-bg: #08111f;
	--cm-login-bg-2: #0c1730;
	--cm-login-bg-3: #111d39;

	--cm-login-panel: rgba(10, 19, 40, 0.72);
	--cm-login-panel-2: rgba(255,255,255,0.05);
	--cm-login-stroke: rgba(255,255,255,0.10);
	--cm-login-stroke-strong: rgba(255,255,255,0.16);

	--cm-login-text: rgba(255,255,255,0.94);
	--cm-login-text-soft: rgba(255,255,255,0.72);
	--cm-login-text-muted: rgba(255,255,255,0.52);

	--cm-login-pink: #123a73;
	--cm-login-purple: #355f96;
	--cm-login-blue: #4f7bb8;
	--cm-login-cyan: #7ea1c9;
	--cm-login-green: #b9c2cc;
	--cm-login-orange: #c89b2d;
	--cm-login-yellow: #d4af37;

	--cm-login-shadow: 0 28px 80px rgba(0,0,0,0.40);
	--cm-login-radius: 24px;
	--cm-login-radius-sm: 16px;
	--cm-login-transition: .22s ease;
}

/* ===== CONTENEDOR GENERAL ===== */
.col-centro{
	position: fixed;
	inset: 0;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: clamp(70px, 13vh, 140px);
	padding-left: 18px;
	padding-right: 18px;
	padding-bottom: 30px;
	z-index: 10;
	overflow-y: auto;
}

.col-centro::before{
	content: "";
	position: fixed;
	inset: 0;
	background:
		radial-gradient(920px 520px at 12% -8%, rgba(52,120,199,.24), transparent 56%),
		radial-gradient(760px 460px at 88% 8%, rgba(10,38,84,.42), transparent 50%),
		radial-gradient(620px 420px at 72% 100%, rgba(24,76,145,.14), transparent 54%),
		linear-gradient(180deg, var(--cm-login-bg), var(--cm-login-bg-2) 46%, var(--cm-login-bg-3));
	z-index: -2;
}

.col-centro::after{
	content: "";
	position: fixed;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(255,255,255,.02), transparent 24%),
		radial-gradient(circle at center, rgba(255,255,255,.015), transparent 70%);
	backdrop-filter: blur(1px);
	z-index: -1;
	pointer-events: none;
}

/* ===== FORMULARIO ===== */
.login-form{
	position: relative;
	width: min(430px, 100%);
	padding: 28px 24px 24px;
	border-radius: var(--cm-login-radius);
	background:
		linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)),
		linear-gradient(135deg, rgba(24,76,145,.10), rgba(10,38,84,.14) 42%, rgba(52,120,199,.08));
	border: 1px solid var(--cm-login-stroke);
	backdrop-filter: blur(18px);
	box-shadow: var(--cm-login-shadow);
	overflow: hidden;
}

.login-form::before{
	content: "";
	position: absolute;
	inset: 0 auto auto 0;
	width: 100%;
	height: 1px;
	background: linear-gradient(90deg, rgba(255,255,255,.26), transparent);
	pointer-events: none;
}

.login-form::after{
	content: "";
	position: absolute;
	top: -90px;
	right: -60px;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(24,76,145,.12), transparent 65%);
	pointer-events: none;
}

.login-form h2{
	position: relative;
	margin: 0 0 18px 0;
	font-size: clamp(24px, 2vw, 28px);
	font-weight: 900;
	line-height: 1.08;
	letter-spacing: -.02em;
	text-align: center;
	color: var(--cm-login-text);
	text-wrap: balance;
}

/* ===== INPUTS ===== */
.login-field{
	position: relative;
	margin-bottom: 14px;
}

.login-input{
	width: 100%;
	min-height: 52px;
	padding: 0 16px;
	border-radius: var(--cm-login-radius-sm);
	border: 1px solid var(--cm-login-stroke);
	background: rgba(255,255,255,.055);
	outline: none;
	color: var(--cm-login-text);
	font-size: 14px;
	font-weight: 500;
	transition:
		border-color var(--cm-login-transition),
		box-shadow var(--cm-login-transition),
		background var(--cm-login-transition),
		transform var(--cm-login-transition);
}

.login-input::placeholder{
	color: var(--cm-login-text-muted);
}

.login-input:hover{
	background: rgba(255,255,255,.07);
	border-color: rgba(255,255,255,.14);
}

.login-input:focus{
	background: rgba(255,255,255,.08);
	border-color: rgba(24,76,145,.34);
	box-shadow: 0 0 0 4px rgba(24,76,145,.10);
}

/* autofill */
.login-input:-webkit-autofill,
.login-input:-webkit-autofill:hover,
.login-input:-webkit-autofill:focus{
	-webkit-text-fill-color: var(--cm-login-text);
	-webkit-box-shadow: 0 0 0 1000px rgba(255,255,255,.06) inset;
	transition: background-color 9999s ease-in-out 0s;
}

/* ===== PASSWORD EYE ===== */
.login-password{
	position: relative;
}

.login-password .login-input{
	padding-right: 56px;
}

.login-eye{
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 38px;
	height: 38px;
	border-radius: 12px;
	background: transparent;
	cursor: pointer;
	transition: transform var(--cm-login-transition), background var(--cm-login-transition);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0;
}

.login-eye:hover{
	transform: translateY(-50%) translateY(-1px);
	background: rgba(255,255,255,.06);
}

.login-eye:active{
	transform: translateY(-50%);
}

/* ===== OJO (icono CSS) ===== */
.eye{
	width: 18px;
	height: 18px;
	position: relative;
	display: block;
	opacity: .9;
}

.eye.eye-closed::before{
	content:"";
	position:absolute;
	inset: 0;
	border: 2px solid rgba(255,255,255,.78);
	border-radius: 999px;
}

.eye.eye-closed::after{
	content:"";
	position:absolute;
	left: -2px;
	right: -2px;
	top: 50%;
	height: 2px;
	background: rgba(255,255,255,.78);
	transform: rotate(-18deg);
}

.eye.eye-open::before{
	content:"";
	position:absolute;
	inset: 0;
	border: 2px solid rgba(255,255,255,.78);
	border-radius: 999px;
}

.eye.eye-open::after{
	content:"";
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: rgba(255,255,255,.85);
	position:absolute;
	left:50%;
	top:50%;
	transform: translate(-50%, -50%);
}

/* ===== CHECKBOX ===== */
.custom-checkbox{
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 4px 0 18px 0;
	font-size: 13px;
	font-weight: 600;
	color: var(--cm-login-text-soft);
	user-select: none;
	cursor: pointer;
}

.custom-checkbox input{
	display: none;
}

.custom-checkbox .checkmark{
	width: 18px;
	height: 18px;
	border-radius: 6px;
	border: 1px solid rgba(255,255,255,.20);
	background: rgba(255,255,255,.05);
	position: relative;
	flex: 0 0 18px;
	transition: border-color var(--cm-login-transition), background var(--cm-login-transition), box-shadow var(--cm-login-transition);
}

.custom-checkbox:hover .checkmark{
	border-color: rgba(255,255,255,.28);
	background: rgba(255,255,255,.08);
}

.custom-checkbox input:checked + .checkmark{
	border-color: rgba(0,174,141,.42);
	background: rgba(0,174,141,.18);
	box-shadow: 0 0 0 4px rgba(0,174,141,.08);
}

.custom-checkbox input:checked + .checkmark::after{
	content:"";
	width: 9px;
	height: 5px;
	border-left: 2px solid rgba(255,255,255,.96);
	border-bottom: 2px solid rgba(255,255,255,.96);
	position:absolute;
	left:50%;
	top:50%;
	transform: translate(-50%, -60%) rotate(-45deg);
}

/* ===== BOTÓN ===== */
.login-btn{
	width: 100%;
	min-height: 52px;
	padding: 0 16px;
	border-radius: var(--cm-login-radius-sm);
	border: 1px solid rgba(24,76,145,.26);
	background: linear-gradient(135deg, var(--cm-login-pink), var(--cm-login-purple));
	color: rgba(255,255,255,.96);
	font-size: 14px;
	font-weight: 900;
	letter-spacing: .01em;
	cursor: pointer;
	transition:
		transform var(--cm-login-transition),
		filter var(--cm-login-transition),
		box-shadow var(--cm-login-transition);
	box-shadow: 0 16px 36px rgba(10,38,84,.30);
}

.login-btn:hover{
	transform: translateY(-1px);
	filter: brightness(1.05);
	box-shadow: 0 20px 44px rgba(10,38,84,.36);
}

.login-btn:active{
	transform: translateY(0);
}

.login-btn:focus{
	outline: none;
	box-shadow:
		0 0 0 4px rgba(24,76,145,.12),
		0 20px 44px rgba(10,38,84,.36);
}

/* ===== MENSAJES DEL PLUGIN / WP ===== */
#login_error,
#message{
	width: min(430px, 100%);
	margin: 0 auto 16px;
	padding: 14px 16px;
	border-radius: 16px;
	border: 1px solid rgba(255,255,255,.10);
	backdrop-filter: blur(12px);
	box-shadow: 0 12px 32px rgba(0,0,0,.20);
}

#login_error{
	background: rgba(242,97,34,.12);
	border-color: rgba(242,97,34,.20);
	color: #ffe8de;
}

#message{
	background: rgba(0,174,141,.12);
	border-color: rgba(0,174,141,.20);
	color: #ddfff6;
}

/* ===== LINKS AUXILIARES DEL PLUGIN ===== */
.cpnav{
	width: min(430px, 100%);
	margin: 16px auto 0;
	padding: 14px 16px;
	border-radius: 18px;
	background: rgba(255,255,255,.045);
	border: 1px solid rgba(255,255,255,.08);
	backdrop-filter: blur(12px);
	text-align: center;
}

.cpnav a{
	display: inline-block;
	margin: 4px 8px;
	color: var(--cm-login-text-soft);
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	transition: color var(--cm-login-transition), transform var(--cm-login-transition);
}

.cpnav a:hover{
	color: #fff;
	transform: translateY(-1px);
}

/* ===== FORMULARIOS ANTIGUOS DEL PLUGIN ===== */
#login.contenido,
#login #wrap{
	position: relative;
	z-index: 1;
}

#login #wrap{
	width: min(430px, 100%);
	margin: 0 auto;
	padding: 26px 24px 22px;
	border-radius: var(--cm-login-radius);
	background:
		linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)),
		linear-gradient(135deg, rgba(24,76,145,.10), rgba(10,38,84,.14) 42%, rgba(52,120,199,.08));
	border: 1px solid var(--cm-login-stroke);
	backdrop-filter: blur(18px);
	box-shadow: var(--cm-login-shadow);
}

#login #wrap p{
	color: var(--cm-login-text-soft);
	font-size: 14px;
	line-height: 1.5;
}

#login form input[type="text"],
#login form input[type="email"],
#login form input[type="password"],
#login form input[type="number"],
#login form textarea,
#login form select{
	width: 100%;
	min-height: 52px;
	margin: 0 0 14px;
	padding: 0 16px;
	border-radius: var(--cm-login-radius-sm);
	border: 1px solid var(--cm-login-stroke);
	background: rgba(255,255,255,.055);
	outline: none;
	color: var(--cm-login-text);
	font-size: 14px;
	transition: border-color var(--cm-login-transition), box-shadow var(--cm-login-transition), background var(--cm-login-transition);
}

#login form textarea{
	min-height: 110px;
	padding-top: 14px;
	padding-bottom: 14px;
}

#login form input:focus,
#login form textarea:focus,
#login form select:focus{
	background: rgba(255,255,255,.08);
	border-color: rgba(24,76,145,.34);
	box-shadow: 0 0 0 4px rgba(24,76,145,.10);
}

#login form button,
#login form input[type="submit"]{
	width: 100%;
	min-height: 52px;
	padding: 0 16px;
	border-radius: var(--cm-login-radius-sm);
	border: 1px solid rgba(24,76,145,.26);
	background: linear-gradient(135deg, var(--cm-login-pink), var(--cm-login-purple));
	color: rgba(255,255,255,.96);
	font-size: 14px;
	font-weight: 900;
	cursor: pointer;
	box-shadow: 0 16px 36px rgba(10,38,84,.30);
	transition: transform var(--cm-login-transition), filter var(--cm-login-transition);
}

#login form button:hover,
#login form input[type="submit"]:hover{
	transform: translateY(-1px);
	filter: brightness(1.05);
}

#login form label{
	display: block;
	margin-bottom: 8px;
	color: var(--cm-login-text-soft);
	font-size: 13px;
	font-weight: 700;
}

/* ===== MÓVIL ===== */
@media (max-width: 640px){
	.col-centro{
		padding-top: 9vh;
		padding-left: 14px;
		padding-right: 14px;
		padding-bottom: 20px;
	}

	.login-form,
	#login #wrap{
		padding: 22px 18px 18px;
		border-radius: 20px;
	}

	.login-form h2{
		font-size: 22px;
		margin-bottom: 16px;
	}

	.login-input,
	#login form input[type="text"],
	#login form input[type="email"],
	#login form input[type="password"],
	#login form input[type="number"],
	#login form textarea,
	#login form select,
	.login-btn,
	#login form button,
	#login form input[type="submit"]{
		min-height: 50px;
	}

	.cpnav{
		padding: 12px 14px;
	}
}

.manager-locked-screen{
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: calc(100vh - var(--topbar-h, 88px));
	width: 100%;
}

.manager-locked-box{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 240px;
}

.manager-locked-box .sidebar-login-btn{
	width: 56px;
	height: 56px;
	border-radius: 18px;
}

.manager-login-btn{
	display: inline-flex;
	align-items: center;
	gap: 10px;

	min-height: 46px;
	padding: 0 16px;

	border-radius: 16px;
	border: 1px solid rgba(24,76,145,.30);

	background: linear-gradient(135deg, #123a73, #355f96);
	color: rgba(255,255,255,.96);

	font-size: 14px;
	font-weight: 800;
	letter-spacing: .01em;

	cursor: pointer;
	text-decoration: none;

	transition: all var(--transition);
	box-shadow: 0 12px 30px rgba(10,38,84,.35);
}

.manager-login-btn svg{
	width: 18px;
	height: 18px;
}

.manager-login-btn:hover{
	transform: translateY(-1px);
	filter: brightness(1.05);
	box-shadow: 0 16px 40px rgba(10,38,84,.45);
}

.manager-login-btn:active{
	transform: translateY(0);
}