/* ======================================================
   FORGOT PASSWORD
   (derived from reset-password.css)
   ====================================================== */

:root {
	--login-max-width: min(100%, 460px);

	--radius-card: 22px;
	--radius-field: 16px;
	--radius-pill: 999px;

	--c-bg-page:
		radial-gradient(circle at 15% 0%, rgba(86, 228, 255, .14), transparent 55%),
		radial-gradient(circle at 85% 100%, rgba(126, 75, 220, .18), transparent 60%);

	--c-bg-card: radial-gradient(circle at 0% 0%, rgba(255, 255, 255, .14), transparent 55%)
		rgba(10, 12, 28, .78);

	--c-bg-field: rgba(7, 9, 24, .92);
	--c-bg-field-focus: rgba(7, 9, 24, .98);

	--c-text-main: #f8fbff;
	--c-text-muted: #b8c3d6;
	--c-text-soft: #8fa0b8;

	--c-accent-1: #56e4ff;
	--c-accent-2: #7e4bdc;
	--c-accent-strong: #0a6bff;
	--c-accent-strong-2: #00a2ff;

	--c-error: rgba(255, 80, 80, .95);
	--c-border-soft: rgba(255, 255, 255, .12);
}

html {
	-webkit-text-size-adjust: 100%;
}

input:-webkit-autofill + label {
	top: -11px;
}

/* -----------------------------------------------
   Wrapper
----------------------------------------------- */

.login-wrapper {
	width: 100%;
	padding: 54px 12px 54px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	background: var(--c-bg-page);
}

@media (min-width: 992px) {
	.login-wrapper {
		min-height: calc(100vh - 140px);
		align-items: center;
	}
}

/* -----------------------------------------------
   Card
----------------------------------------------- */

.login-card {
	width: 100%;
	max-width: var(--login-max-width);
	background: var(--c-bg-card);
	border-radius: var(--radius-card);
	padding: clamp(20px, 4vw, 32px) clamp(16px, 4vw, 26px);
	border: 1px solid var(--c-border-soft);
	backdrop-filter: blur(26px) saturate(180%);
	box-shadow:
		0 24px 60px rgba(0, 0, 0, .75),
		0 0 40px rgba(86, 228, 255, .18);
	position: relative;
	overflow: hidden;
}

.login-card::before {
	content:"";
	position: absolute;
	inset: -40%;
	background:
		radial-gradient(circle at 0% 0%, rgba(86, 228, 255, .22), transparent 60%),
		radial-gradient(circle at 100% 100%, rgba(126, 75, 220, .22), transparent 60%);
	opacity: .12;
	pointer-events: none;
}

/* -----------------------------------------------
   Header
----------------------------------------------- */

.login-header {
	text-align: center;
	margin-bottom: clamp(18px, 4vw, 26px);
}

.login-title {
	font-size: clamp(1.35rem, 5vw, 1.8rem);
	font-weight: 800;
	margin-bottom: 6px;
	background: linear-gradient(120deg, #f5f5ff, var(--c-accent-1), var(--c-accent-2));
	-webkit-background-clip: text;
	color: transparent;
}

.login-subtitle {
	font-size: clamp(.85rem, 2.5vw, .95rem);
	color: var(--c-text-muted);
	line-height: 1.4;
}

/* -----------------------------------------------
   Error Box
----------------------------------------------- */

.login-error {
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(255, 80, 80, .14);
	border-left: 3px solid var(--c-error);
	color: #ffd2d2;
	font-size: .9rem;
	margin-bottom: 18px;
}

.d-none { display: none !important; }

/* -----------------------------------------------
   Fields
----------------------------------------------- */

.field-shell {
	margin-bottom: clamp(16px, 3vw, 22px);
	transition:
		box-shadow 0.35s ease,
		transform 0.35s ease;
}

.field-inner {
	position: relative;
	display: flex;
	align-items: center;
	padding: 12px 14px 11px 42px;
	background: var(--c-bg-field);
	border-radius: var(--radius-field);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .04);
	transition: .25s ease;
}

.field-inner:focus-within {
	background: var(--c-bg-field-focus);
	box-shadow:
		inset 0 0 0 1px rgba(86, 228, 255, .9),
		0 0 16px rgba(86, 228, 255, .35);
	transform: translateY(-1px);
}

.field-inner input {
	flex: 1;
	background: transparent;
	border: none;
	outline: none;
	font-size: 1rem;
	color: var(--c-text-main);
	padding-right: 34px;
	min-height: 22px;
	line-height: 1.3;
}

/* Icons */
.field-icon {
	position: absolute;
	left: 14px;
	font-size: 1.15rem;
	color: var(--c-accent-1);
	transition: .25s ease;
}

.field-inner:focus-within .field-icon {
	transform: scale(1.1);
}

/* Floating Label */
.field-inner label {
	position: absolute;
	left: 42px;
	top: 50%;
	transform: translateY(-50%);
	font-size: .85rem;
	color: #9facbf;
	opacity: .7;
	pointer-events: none;
	transition: .25s ease;
}

.field-inner input:focus + label,
.field-inner input:not(:placeholder-shown) + label {
	top: 6px;
	font-size: .68rem;
	color: var(--c-accent-1);
	opacity: .9;
}

.field-border {
	position: absolute;
	left: 14px;
	right: 14px;
	bottom: 6px;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(
		90deg,
		var(--c-accent-1),
		var(--c-accent-2)
	);
	opacity: 0;
	transform: scaleX(.3);
	transition: .3s ease;
}

.field-inner:focus-within .field-border {
	opacity: 1;
	transform: scaleX(1);
}

.field-icon,
.field-border {
	transition:
		color 0.3s ease,
		background 0.3s ease,
		transform 0.25s ease;
}

/* Hints */
.field-hint {
	font-size: .78rem;
	color: var(--c-text-soft);
	margin-top: 4px;
	
	opacity: 0;
	max-height: 0;
	transform: translateY(-4px);
	transition: .25s ease;
	overflow: hidden;
}

.field-hint .ok {
	color: #56e4ff;
	font-weight: 600;
}

.field-hint .no {
	color: #ff6b6b;
}

.field-shell.show-hint .field-hint {
	opacity: .9;
	max-height: 40px;
	transform: translateY(0);
}

/* States */
.field-shell.valid {
	animation: recover-soft .25s ease;
}

@keyframes recover-soft {
	from { transform: scale(0.98); }
	to { transform: scale(1); }
}

.field-shell.invalid .field-inner {
	box-shadow:
		inset 0 0 0 1px rgba(255, 90, 90, .95),
		0 0 16px rgba(255, 40, 40, .35);
}

.field-shell.valid .field-inner {
	box-shadow:
		inset 0 0 0 1px rgba(86, 228, 255, 1),
		0 0 14px rgba(86, 228, 255, .55);
}

@keyframes shake-soft {
	0%, 100% { transform: translateX(0); }
	25% { transform: translateX(-2px); }
	75% { transform: translateX(2px); }
}

.field-shell.invalid {
	animation: shake-soft .25s ease;
}

.field-shell.valid .field-icon {
	color: #56e4ff;
}

.field-shell.invalid .field-icon {
	color: #ff6b6b;
}

.field-shell.valid .field-border {
	background: linear-gradient(90deg, #56e4ff, #7ed957);
}

.field-shell.invalid .field-border {
	background: linear-gradient(90deg, #ff6b6b, #ff8844);
}

.field-shell.valid .field-hint {
	color: #56e4ff;
}

.field-shell.invalid .field-hint {
	color: #ff6b6b;
}

/* -----------------------------------------------
   BUTTON
----------------------------------------------- */

.login-btn {
	position: relative;
	width: 100%;
	padding: clamp(12px, 3vw, 14px);
	border-radius: var(--radius-pill);
	border: none;
	font-size: clamp(.95rem, 3vw, 1rem);
	font-weight: 600;
	color: #fff;
	background: linear-gradient(120deg, var(--c-accent-strong), var(--c-accent-strong-2));
	box-shadow:
		0 12px 30px rgba(0, 0, 0, .9),
		0 0 24px rgba(86, 228, 255, .45);
	transition: .2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	overflow: hidden;
}

.login-btn:hover:not(:disabled) {
	transform: translateY(-1px);
	filter: brightness(1.05);
}

.login-btn.success {
	background: linear-gradient(120deg, #56e4ff, #7ed957);
	box-shadow:
		0 0 30px rgba(86, 228, 255, .8),
		0 0 60px rgba(126, 217, 87, .6);
	transform: scale(1.04);
}

.login-btn:disabled {
	opacity: .75;
	cursor: wait;
}

/* -----------------------------------------------
   Spinner
----------------------------------------------- */

.poke-spinner {
	width: 26px;
	height: 26px;
	border-radius: 50%;
	background:
		linear-gradient(to bottom, #ff3434 0 50%, white 50% 100%);
	border: 3px solid black;
	animation: pokespin .8s linear infinite;
}

@keyframes pokespin {
	to { transform: rotate(360deg); }
}

/* -----------------------------------------------
   Toast
----------------------------------------------- */

.auth-toast {
	position: fixed;
	left: 50%;
	bottom: max(16px, env(safe-area-inset-bottom));
	transform: translateX(-50%) translateY(140%) scale(.95);
	min-width: 260px;
	max-width: 90vw;
	background: rgba(10, 14, 28, .75);
	backdrop-filter: blur(28px) saturate(240%);
	border: 1px solid rgba(255, 255, 255, .08);
	padding: 14px 16px;
	border-radius: 20px;
	display: flex;
	gap: 10px;
	opacity: 0;
	transition: .45s ease;
	z-index: 9999;
	pointer-events: none;
}

.auth-toast.show {
	opacity: 1;
	transform: translateX(-50%) translateY(0) scale(1);
}

.auth-toast.success .toast-icon i { color: #56e4ff; }
.auth-toast.error .toast-icon i { color: #ff6b6b; }

.toast-title {
	font-weight: 600;
	font-size: .9rem;
	color: #f6f7ff;
}

.toast-message {
	font-size: .84rem;
	color: #ced6f2;
}

/* -----------------------------------------------
   Responsiveness
----------------------------------------------- */

@media (min-width: 992px) {
	.login-wrapper {
		align-items: center;
	}
}

/* -----------------------------------------------
   Login Switch
----------------------------------------------- */

.login-switch {
	margin-top: 16px;
	text-align: center;
	font-size: .9rem;
	color: var(--c-text-muted);
}

.login-switch-link {
	color: var(--c-accent-1);
	font-weight: 600;
	text-decoration: none;
	transition: .25s ease;
}

.login-switch-link:hover {
	color: #fff;
	text-shadow: 0 0 10px rgba(86, 228, 255, .9);
}

.btn-checkmark {
	position: absolute;
	font-size: 1.3rem;
	font-weight: 800;
	color: #7ed957;
	opacity: 0;
	transform: scale(0.4);
	transition: .35s cubic-bezier(.2, 1.6, .4, 1);
	text-shadow: 0 0 12px rgba(126, 217, 87, .8);
	pointer-events: none;
}

.login-btn.ready .btn-checkmark {
	opacity: 1;
	transform: scale(1);
}

.login-btn.ready #resetPwText {
	opacity: 0;
	transform: translateY(6px);
}

.login-btn span {
	transition: .3s ease;
}