/**
 * Savvy X — public login UI (split hero + dark glass card).
 * Scoped to body.savvy-login-page so Frappe login.bundle + Edge auto-dark stay overridden.
 */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap");

:root {
	--sx-ink: #0c1222;
	--sx-ink-soft: #1a2a40;
	--sx-gold: #ffc929;
	--sx-gold-deep: #e8a200;
	--sx-gold-glow: rgba(255, 201, 41, 0.45);
	--sx-ice: #e8f4ff;
	--sx-mist: #f5f7fb;
	--sx-text: #1e293b;
	--sx-muted: #64748b;
	--sx-line: rgba(15, 23, 42, 0.08);
	--sx-card: rgba(255, 255, 255, 0.78);
	--sx-card-solid: #ffffff;
	--sx-shadow-1: 0 1px 2px rgba(15, 23, 42, 0.04);
	--sx-shadow-2: 0 24px 48px -12px rgba(15, 23, 42, 0.12);
	--sx-shadow-3: 0 0 0 1px rgba(255, 255, 255, 0.6) inset, 0 40px 80px -24px rgba(12, 18, 34, 0.18);
	/* compat */
	--sx-ref-yellow: var(--sx-gold);
	--sx-ref-yellow-hover: #f5c400;
	--sx-ref-navy: var(--sx-ink-soft);
	--sx-ref-text: var(--sx-text);
	--sx-ref-muted: var(--sx-muted);
	--sx-ref-input-bg: rgba(248, 250, 252, 0.92);
	--sx-ref-page-bg: #eef1f8;
	--sx-ref-border: rgba(148, 163, 184, 0.35);
	--sx-ref-shadow: var(--sx-shadow-2);
	--sx-login-brand: var(--sx-ink-soft);
	--sx-login-brand-mid: #334155;
	--sx-login-surface: var(--sx-card-solid);
	--sx-login-border: var(--sx-ref-border);
}

/*
 * Dark login shell (scoped): beats Frappe login.bundle + Edge auto-dark.
 * Tokens only apply when body has .savvy-login-page (login route).
 */
body.savvy-login-page {
	--sx-ink: #f8fafc;
	--sx-text: #ffffff;
	--sx-muted: #94a3b8;
	--sx-ink-soft: #cbd5e1;
	--sx-card: rgba(20, 30, 50, 0.85);
	--sx-card-solid: rgba(24, 36, 58, 0.92);
	--sx-ref-page-bg: #0f1c2e;
	--sx-ref-input-bg: rgba(15, 23, 42, 0.45);
	--sx-ref-border: rgba(255, 255, 255, 0.12);
	--sx-login-surface: rgba(20, 30, 50, 0.88);
	--sx-login-border: rgba(255, 255, 255, 0.1);
	min-height: 100vh;
	font-family: Inter, system-ui, sans-serif;
	color-scheme: dark;
	color: #ffffff !important;
	background: #0f1c2e !important;
}

html:has(body.savvy-login-page) {
	background: #0f1c2e;
	color-scheme: dark;
}

body.savvy-login-page.sx-login-advanced {
	background:
		radial-gradient(ellipse 100% 80% at 50% -30%, rgba(250, 204, 21, 0.08), transparent 55%),
		radial-gradient(ellipse 70% 50% at 100% 50%, rgba(56, 189, 248, 0.05), transparent 50%),
		linear-gradient(165deg, #0f1c2e 0%, #121f33 45%, #0b1422 100%) !important;
}

body.savvy-login-page .web-footer {
	display: none;
}

body.savvy-login-page .page-content-wrapper {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

body.savvy-login-page main.container {
	max-width: min(100%, 100vw) !important;
	width: 100%;
	box-sizing: border-box;
	padding-left: 0;
	padding-right: 0;
	flex: 1;
	display: flex;
	flex-direction: column;
}

body.savvy-login-page .page_content {
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 0;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* Frappe / Bootstrap: full-width form column (bundle often sets max-widths on .form-control) */
body.savvy-login-page .page_content > div {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

body.savvy-login-page .email-field,
body.savvy-login-page .password-field {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

body.savvy-login-page .email-field .form-control,
body.savvy-login-page .password-field .form-control,
body.savvy-login-page .page-card-body .form-control {
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
}

/* ========== Shell ========== */
.savvy-login-shell.savvy-login-ref-shell {
	flex: 1;
	display: flex;
	flex-direction: row;
	align-items: stretch;
	width: 100%;
	min-height: 100vh;
	max-width: none;
	margin: 0;
	padding: 0;
	gap: 0;
	box-sizing: border-box;
	overflow: hidden;
}

/* Entrance: right column only (form always becomes visible; no blank flash). */
.savvy-login-main.savvy-login-ref-main {
	opacity: 0;
	-webkit-transform: translateY(18px);
	transform: translateY(18px);
	transition:
		opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1),
		-webkit-transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

body.sx-login-shell-ready .savvy-login-main.savvy-login-ref-main {
	opacity: 1;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

/* ========== Hero (left) ========== */
.savvy-login-hero.savvy-login-ref-hero {
	position: relative;
	/* 50 / 50 split with login column */
	flex: 1 1 50%;
	min-width: 0;
	min-height: 100vh;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	isolation: isolate;
}

.savvy-login-hero__aurora {
	position: absolute;
	inset: -35%;
	background:
		conic-gradient(
			from 210deg at 50% 50%,
			rgba(255, 201, 41, 0.35) 0deg,
			rgba(56, 189, 248, 0.2) 90deg,
			rgba(99, 102, 241, 0.22) 180deg,
			rgba(255, 201, 41, 0.28) 270deg,
			rgba(255, 201, 41, 0.35) 360deg
		);
	opacity: 0.55;
	animation: sx-aurora-rotate 28s linear infinite;
	pointer-events: none;
}

@keyframes sx-aurora-rotate {
	to {
		transform: rotate(360deg);
	}
}

.savvy-login-hero__mesh {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(155deg, rgba(12, 18, 34, 0.92) 0%, rgba(26, 42, 64, 0.88) 42%, rgba(12, 18, 34, 0.94) 100%),
		radial-gradient(ellipse 90% 60% at 10% 20%, rgba(255, 201, 41, 0.15), transparent 50%),
		radial-gradient(ellipse 70% 50% at 90% 80%, rgba(56, 189, 248, 0.12), transparent 45%);
}

.savvy-login-hero__noise {
	position: absolute;
	inset: 0;
	opacity: 0.04;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	pointer-events: none;
	mix-blend-mode: overlay;
}

.savvy-login-hero__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 48px 48px;
	mask-image: radial-gradient(ellipse 70% 70% at 50% 40%, black 20%, transparent 70%);
	pointer-events: none;
}

.savvy-login-hero__inner {
	position: relative;
	z-index: 2;
	padding: 2.5rem 1.5rem;
	padding: clamp(2rem, 5vw, 4rem);
	color: #fff;
	width: 100%;
	max-width: 36rem;
}

.savvy-login-hero__highlights {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: 1.75rem;
}

.sx-hero-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.92);
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.sx-hero-pill-glow {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--sx-gold);
	box-shadow: 0 0 12px var(--sx-gold-glow);
	animation: sx-pulse 2.4s ease-in-out infinite;
}

@keyframes sx-pulse {
	0%,
	100% {
		opacity: 1;
		transform: scale(1);
	}
	50% {
		opacity: 0.65;
		transform: scale(0.92);
	}
}

.savvy-login-ref-company {
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.72);
	margin: 0 0 1rem;
}

.savvy-login-ref-company-strong {
	color: #fff;
}

.savvy-login-ref-sep {
	opacity: 0.45;
	padding: 0 0.2em;
}

.savvy-login-ref-tagline {
	font-family: "Plus Jakarta Sans", Inter, sans-serif;
	font-size: 1.85rem;
	font-size: clamp(1.85rem, 3.8vw, 3rem);
	font-weight: 800;
	line-height: 1.12;
	color: #fff;
	margin: 0 0 1rem;
	letter-spacing: -0.03em;
}

.savvy-login-ref-tagline-accent {
	background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0.75) 40%, var(--sx-gold) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
}

.savvy-login-hero__lede {
	font-size: clamp(0.95rem, 1.5vw, 1.1rem);
	line-height: 1.55;
	color: rgba(226, 232, 240, 0.88);
	margin: 0 0 2rem;
	max-width: 28ch;
	margin-left: auto;
	margin-right: auto;
}

.savvy-login-hero__statrow {
	display: flex;
	justify-content: center;
	gap: clamp(0.75rem, 3vw, 2rem);
	flex-wrap: wrap;
}

.sx-hero-stat {
	min-width: 5.5rem;
	padding: 0.75rem 1rem;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	text-align: center;
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}

.sx-hero-stat-value {
	display: block;
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	color: var(--sx-gold);
	letter-spacing: 0.02em;
}

.sx-hero-stat-label {
	display: block;
	font-size: 0.65rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: rgba(226, 232, 240, 0.55);
	margin-top: 0.2rem;
}

.savvy-login-ref-left {
	text-align: center;
}

/* ========== Main (right) ========== */
.savvy-login-main.savvy-login-ref-main {
	flex: 1 1 50%;
	min-height: 100vh;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 2rem 1.5rem;
	padding: clamp(1.5rem, 4vw, 3rem);
	box-sizing: border-box;
	background:
		radial-gradient(ellipse 60% 40% at 80% 20%, rgba(250, 204, 21, 0.05), transparent 55%),
		linear-gradient(180deg, #0f1c2e 0%, #0c1829 55%, #0a1524 100%) !important;
	position: relative;
}

.savvy-login-main.savvy-login-ref-main::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	inset: 0;
	background: radial-gradient(circle at 10% 90%, rgba(99, 102, 241, 0.05), transparent 40%);
	pointer-events: none;
}

/* ========== Login card ========== */
body.savvy-login-page .sx-login-auth-shell {
	position: relative;
	width: 100%;
	/* 100% of the login column — not 100vw (half-column was wider than parent in Fx/Edge). */
	max-width: min(560px, 100%);
	min-width: 0;
	margin-left: auto;
	margin-right: auto;
	border-radius: 16px;
	/* visible: do not clip absolutely positioned “Show” / focus rings on resize */
	overflow: visible;
	background: rgba(20, 30, 50, 0.85) !important;
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	box-shadow: 0 24px 48px rgba(0, 0, 0, 0.35), 0 1px 0 rgba(255, 255, 255, 0.06) inset;
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	color: #ffffff;
}

body.savvy-login-page .sx-login-auth-shell::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	inset: 0;
	border-radius: inherit;
	padding: 1px;
	background: linear-gradient(
		135deg,
		rgba(255, 201, 41, 0.55) 0%,
		rgba(255, 255, 255, 0.15) 35%,
		rgba(148, 163, 184, 0.25) 70%,
		rgba(255, 201, 41, 0.25) 100%
	);
	-webkit-mask:
		linear-gradient(#fff 0 0) content-box,
		linear-gradient(#fff 0 0);
	mask:
		linear-gradient(#fff 0 0) content-box,
		linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
	z-index: 1;
}

/* Same horizontal inset as ``.login-content.page-card`` so logo + title line up with fields. */
body.savvy-login-page .sx-login-auth-shell .page-card-head {
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-left: clamp(1.35rem, 3vw, 1.85rem);
	padding-right: clamp(1.35rem, 3vw, 1.85rem);
}

body.savvy-login-page .sx-login-auth-shell .sx-login-ref-form-header {
	position: relative;
	z-index: 2;
	text-align: center;
	margin-bottom: 0;
	padding-top: 1.65rem;
	padding-bottom: 0.35rem;
	background: transparent;
	border: none;
}

/* Soft divider between hero logo and form (square SVG fills tile without double matting). */
body.savvy-login-page .sx-login-auth-shell .sx-login-ref-form-header::after {
	content: "";
	display: block;
	width: 100%;
	max-width: 24rem;
	height: 1px;
	margin: 1rem auto 0;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(148, 163, 184, 0.35) 20%,
		rgba(255, 201, 41, 0.35) 50%,
		rgba(148, 163, 184, 0.35) 80%,
		transparent
	);
	opacity: 0.85;
}

body.savvy-login-page .sx-login-auth-shell .login-content.page-card {
	position: relative;
	z-index: 2;
	margin-top: 0;
	border-radius: 0;
	border: none;
	box-shadow: none;
	background: transparent;
}

/* Square SVG asset (512×512 viewBox); scales with shell width but stays inside form column. */
body.savvy-login-page .sx-login-erp-logo {
	width: 5rem;
	height: 5rem;
	width: clamp(4.75rem, 19vw, 5.75rem);
	height: auto;
	max-width: 100%;
	max-height: none;
	min-height: 0;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	object-position: center;
	border-radius: 1.35rem;
	margin: 0 auto 0.4rem;
	display: block;
	padding: 0;
	box-sizing: border-box;
	background: transparent;
	border: none;
	box-shadow: none;
	filter: drop-shadow(0 10px 28px rgba(15, 23, 42, 0.16));
	-webkit-transition:
		-webkit-transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		filter 0.35s ease;
	transition:
		-webkit-transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
		filter 0.35s ease;
}

body.savvy-login-page.sx-login-shell-ready .sx-login-erp-logo {
	animation: sx-logo-breathe 5s ease-in-out infinite;
}

@keyframes sx-logo-breathe {
	0%,
	100% {
		-webkit-transform: translateY(0) scale(1);
		transform: translateY(0) scale(1);
		filter: drop-shadow(0 10px 28px rgba(15, 23, 42, 0.16));
	}
	50% {
		-webkit-transform: translateY(-3px) scale(1.02);
		transform: translateY(-3px) scale(1.02);
		filter:
			drop-shadow(0 18px 42px rgba(15, 23, 42, 0.2))
			drop-shadow(0 0 36px rgba(255, 201, 41, 0.22));
	}
}

body.savvy-login-page section:not(.for-login) .page-card-head .sx-login-erp-logo {
	width: 3.5rem;
	height: 3.5rem;
	width: clamp(3.25rem, 11vw, 3.5rem);
	height: auto;
	max-width: 100%;
	aspect-ratio: 1 / 1;
	animation: none;
	padding: 0;
}

body.savvy-login-page .sx-login-ref-heading {
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 1.85rem;
	font-weight: 800;
	color: var(--sx-ink);
	margin: 0.4rem 0 0.25rem;
	letter-spacing: -0.03em;
	line-height: 1.15;
}

body.savvy-login-page .sx-login-ref-subtitle {
	font-size: 0.9rem;
	color: var(--sx-muted);
	margin: 0 0 0.25rem;
	line-height: 1.5;
	font-weight: 500;
}

/* Frappe's .page-card from login.bundle — override to dark glass */
body.savvy-login-page .for-login .page-card,
body.savvy-login-page .for-forgot .page-card,
body.savvy-login-page .for-signup .page-card,
body.savvy-login-page .for-email-login .page-card,
body.savvy-login-page .for-login-with-email-link .page-card,
body.savvy-login-page .page-card {
	width: 100%;
	max-width: 560px;
	padding: 1.5rem;
	padding: clamp(1.25rem, 3vw, 1.75rem) clamp(1.25rem, 3vw, 1.75rem);
	background: rgba(20, 30, 50, 0.85) !important;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	color: #ffffff !important;
}

body.savvy-login-page .sx-login-auth-shell .login-content.page-card {
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-bottom: 1.5rem;
	padding-left: clamp(1.35rem, 3vw, 1.85rem);
	padding-right: clamp(1.35rem, 3vw, 1.85rem);
	padding-bottom: clamp(1.35rem, 3vw, 1.85rem);
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	background: transparent !important;
	backdrop-filter: none;
}

/* ========== Form fields ========== */
body.savvy-login-page .sx-login-primary-stack {
	width: 100%;
}

body.savvy-login-page .sx-login-primary-stack .social-logins {
	margin-top: 1.15rem;
	padding-top: 1.15rem;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

body.savvy-login-page .sx-login-primary-stack .login-divider {
	margin: 0 0 0.75rem;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sx-muted);
}

body.savvy-login-page .sx-login-primary-stack .btn-login-with-email-link,
body.savvy-login-page .sx-login-primary-stack .btn-login-option {
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	background: rgba(255, 255, 255, 0.06) !important;
	color: #f1f5f9 !important;
	-webkit-text-fill-color: #f1f5f9;
	font-weight: 600;
	padding-top: 0.7rem;
	padding-bottom: 0.7rem;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.15s ease;
}

body.savvy-login-page .sx-login-primary-stack .btn-login-with-email-link:hover,
body.savvy-login-page .sx-login-primary-stack .btn-login-option:hover {
	border-color: rgba(255, 201, 41, 0.65);
	box-shadow: 0 8px 24px rgba(255, 201, 41, 0.18);
	-webkit-transform: translateY(-1px);
	transform: translateY(-1px);
}

body.savvy-login-page .page-card-head:not(.sx-login-ref-form-header) {
	text-align: center;
	margin-bottom: 0.5rem;
}

body.savvy-login-page:not(.savvy-login-logo-ready) .page-card-head .app-logo {
	opacity: 0;
}

body.savvy-login-page.savvy-login-logo-ready .page-card-head .app-logo {
	opacity: 1;
	transition: opacity 0.25s ease;
}

body.savvy-login-page .page-card-head h4 {
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--sx-ink);
	margin-top: 0.5rem;
	letter-spacing: -0.02em;
}

body.savvy-login-page .page-card-body .form-group {
	margin-bottom: 1.1rem;
	overflow: visible;
}

body.savvy-login-page .email-field,
body.savvy-login-page .password-field {
	position: relative;
	overflow: visible;
	border-radius: 14px;
	transition: box-shadow 0.22s ease;
}

body.savvy-login-page .email-field:focus-within,
body.savvy-login-page .password-field:focus-within {
	box-shadow:
		0 0 0 3px rgba(250, 204, 21, 0.2),
		0 12px 28px rgba(0, 0, 0, 0.3);
}

body.savvy-login-page .page-card-body input[type="text"],
body.savvy-login-page .page-card-body input[type="email"],
body.savvy-login-page .page-card-body input[type="password"],
body.savvy-login-page .form-control {
	border-radius: 14px !important;
	border: 1px solid rgba(255, 255, 255, 0.2) !important;
	background: transparent !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff;
	padding: 0.9rem 1.05rem !important;
	font-size: 0.95rem;
	font-weight: 500;
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		background 0.2s ease;
}

body.savvy-login-page .form-control::placeholder,
body.savvy-login-page .page-card-body input::placeholder {
	color: rgba(255, 255, 255, 0.5) !important;
	-webkit-text-fill-color: rgba(255, 255, 255, 0.5);
	opacity: 1 !important;
}

/* Left glyph + gap before typed text / placeholder; password: room for Show on the right */
body.savvy-login-page .page-card-body .email-field .field-icon,
body.savvy-login-page .page-card-body .password-field .field-icon {
	position: absolute;
	left: 1.15rem;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 2;
	pointer-events: none;
	color: rgba(255, 255, 255, 0.5);
	opacity: 0.95;
}

body.savvy-login-page .page-card-body .email-field .form-control,
body.savvy-login-page .page-card-body .email-field input[type="text"],
body.savvy-login-page .page-card-body .email-field input[type="email"] {
	padding-left: 2.95rem !important;
	padding-right: 1.2rem !important;
}

body.savvy-login-page .page-card-body .password-field .form-control,
body.savvy-login-page .page-card-body .password-field input[type="password"] {
	position: relative;
	z-index: 1;
	padding-left: 2.95rem !important;
	padding-right: 5.5rem !important;
}

/* Chrome/Edge: sit above input + webkit autofill layer */
body.savvy-login-page .page-card-body .password-field .toggle-password {
	position: absolute;
	right: 0.55rem;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 10 !important;
	margin: 0;
	padding: 0.35rem 0.55rem !important;
	line-height: 1.25;
	white-space: nowrap;
	display: inline-flex !important;
	align-items: center;
	visibility: visible !important;
	opacity: 1 !important;
	cursor: pointer;
	pointer-events: auto !important;
	font-size: 0.8125rem !important;
	font-weight: 600 !important;
	font-family: Inter, system-ui, sans-serif !important;
	color: #0f1c2e !important;
	-webkit-text-fill-color: #0f1c2e !important;
	background: linear-gradient(135deg, #fde047, #facc15) !important;
	border: 1px solid rgba(15, 23, 42, 0.15);
	border-radius: 10px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}

body.savvy-login-page .page-card-body .password-field .toggle-password:hover {
	filter: brightness(1.05);
}

/* Kill Bootstrap/Frappe .text-muted on this control (was washing out in Chromium) */
body.savvy-login-page .password-field .toggle-password.text-muted {
	color: #0f1c2e !important;
	-webkit-text-fill-color: #0f1c2e !important;
}

/* WebKit autofill must not paint over the Show pill */
body.savvy-login-page .password-field input[type="password"]:-webkit-autofill,
body.savvy-login-page .password-field input[type="password"]:-webkit-autofill:focus {
	-webkit-text-fill-color: #ffffff !important;
	box-shadow: 0 0 0 1000px rgba(15, 23, 42, 0.65) inset !important;
	transition: background-color 99999s ease-out 0s;
}

body.savvy-login-page .page-card-body input:focus,
body.savvy-login-page .form-control:focus {
	outline: none !important;
	border-color: rgba(250, 204, 21, 0.75) !important;
	background: rgba(15, 23, 42, 0.55) !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff;
	box-shadow: 0 0 0 3px rgba(250, 204, 21, 0.2) !important;
}

/* Primary CTA */
body.savvy-login-page .btn-login.btn-primary,
body.savvy-login-page .btn-forgot.btn-primary,
body.savvy-login-page .page-card-actions .btn-primary,
body.savvy-login-page .btn-primary {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, #facc15, #f59e0b) !important;
	color: #000000 !important;
	-webkit-text-fill-color: #000000;
	border: none !important;
	border-radius: 14px;
	font-family: "Plus Jakarta Sans", sans-serif;
	font-weight: 800;
	font-size: 0.95rem;
	letter-spacing: 0.03em;
	padding-top: 0.9rem !important;
	padding-bottom: 0.9rem !important;
	box-shadow:
		0 4px 12px rgba(255, 201, 41, 0.35),
		0 16px 32px -8px rgba(232, 162, 0, 0.35),
		inset 0 1px 0 rgba(255, 255, 255, 0.45);
	transition:
		transform 0.15s ease,
		box-shadow 0.2s ease,
		filter 0.2s ease;
}

body.savvy-login-page .btn-login.btn-primary::after,
body.savvy-login-page .page-card-actions .btn-primary::after {
	content: "";
	position: absolute;
	inset: 0;
	left: -100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.45), transparent);
	transform: skewX(-18deg);
	transition: left 0.55s ease;
	pointer-events: none;
}

body.savvy-login-page .btn-login.btn-primary:hover::after,
body.savvy-login-page .page-card-actions .btn-primary:hover::after {
	left: 100%;
}

body.savvy-login-page .btn-login.btn-primary:hover,
body.savvy-login-page .btn-forgot.btn-primary:hover,
body.savvy-login-page .page-card-actions .btn-primary:hover {
	filter: brightness(1.03);
	-webkit-transform: translateY(-1px);
	transform: translateY(-1px);
	box-shadow:
		0 6px 16px rgba(255, 201, 41, 0.45),
		0 20px 40px -10px rgba(232, 162, 0, 0.4),
		inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

body.savvy-login-page .btn-login.btn-primary:active,
body.savvy-login-page .page-card-actions .btn-primary:active {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}

body.savvy-login-page .sign-up-message,
body.savvy-login-page .forgot-password-message a {
	font-size: 0.88rem;
}

body.savvy-login-page .forgot-password-message a,
body.savvy-login-page .sign-up-message a {
	color: #cbd5e1 !important;
	font-weight: 600;
}

body.savvy-login-page .text-muted {
	color: #94a3b8 !important;
}

/* LDAP / secondary */
body.savvy-login-page .btn-default.btn-login {
	background: rgba(255, 255, 255, 0.08) !important;
	color: #f8fafc !important;
	border: 1px solid rgba(255, 255, 255, 0.22) !important;
}

body.savvy-login-page .navbar {
	background: transparent;
	border: none;
	box-shadow: none;
}

body.savvy-login-page .navbar .container {
	max-width: 1280px;
}

/* ========== Auth mask ========== */
body.savvy-login-page .savvy-login-auth-mask {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	inset: 0;
	z-index: 100000;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.25rem;
	background: rgba(12, 18, 34, 0.35);
	backdrop-filter: blur(14px) saturate(1.1);
	-webkit-backdrop-filter: blur(14px) saturate(1.1);
	color: #fff;
	font-weight: 600;
	font-size: 1rem;
	animation: sx-mask-in 0.35s ease;
}

@keyframes sx-mask-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

.savvy-login-auth-mask__spinner {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 3px solid rgba(255, 255, 255, 0.2);
	border-top-color: var(--sx-gold);
	animation: sx-spin 0.75s linear infinite;
}

@keyframes sx-spin {
	to {
		transform: rotate(360deg);
	}
}

.savvy-login-auth-mask__label {
	font-family: "Plus Jakarta Sans", sans-serif;
	letter-spacing: 0.04em;
}

body.savvy-login-page .savvy-login-auth-mask img {
	max-height: 52px;
	width: auto;
	filter: drop-shadow(0 4px 20px rgba(0, 0, 0, 0.25));
}

/* ----- Engines without backdrop-filter / mask compositing (readable fallback) ----- */
@supports not ((backdrop-filter: blur(2px)) or (-webkit-backdrop-filter: blur(2px))) {
	body.savvy-login-page .sx-login-auth-shell {
		background: rgba(24, 36, 58, 0.96);
	}

	body.savvy-login-page .for-login .page-card,
	body.savvy-login-page .for-forgot .page-card,
	body.savvy-login-page .for-signup .page-card,
	body.savvy-login-page .for-email-login .page-card,
	body.savvy-login-page .for-login-with-email-link .page-card,
	body.savvy-login-page .page-card {
		background: rgba(24, 36, 58, 0.96);
	}

	body.savvy-login-page .sx-hero-stat,
	body.savvy-login-page .sx-hero-pill {
		background: rgba(255, 255, 255, 0.1);
	}
}

@supports not ((-webkit-mask-composite: xor) or (mask-composite: exclude)) {
	body.savvy-login-page .sx-login-auth-shell::before {
		display: none;
	}
}

@supports not (aspect-ratio: 1) {
	body.savvy-login-page .sx-login-erp-logo {
		width: 5rem;
		height: 5rem;
		max-width: 100%;
	}

	body.savvy-login-page section:not(.for-login) .page-card-head .sx-login-erp-logo {
		width: 3.5rem;
		height: 3.5rem;
	}
}

/* Edge / OS dark: keep the same intentional dark UI (no flash of mixed bundle styles). */
@media (prefers-color-scheme: dark) {
	body.savvy-login-page {
		background: #0f1c2e !important;
		color: #ffffff !important;
		color-scheme: dark;
	}

	html:has(body.savvy-login-page) {
		background: #0f1c2e;
	}
}

/* ========== Reduced motion ========== */
@media (prefers-reduced-motion: reduce) {
	body.sx-login-shell-ready .savvy-login-main.savvy-login-ref-main,
	.savvy-login-main.savvy-login-ref-main {
		opacity: 1;
		transform: none;
		transition: none;
	}

	.savvy-login-hero__aurora {
		animation: none;
	}

	.sx-hero-pill-glow {
		animation: none;
	}

	body.savvy-login-page.sx-login-shell-ready .sx-login-erp-logo {
		animation: none;
	}

	body.savvy-login-page .btn-login.btn-primary::after,
	body.savvy-login-page .page-card-actions .btn-primary::after {
		display: none;
	}

	.savvy-login-auth-mask__spinner {
		animation: none;
		border-color: rgba(255, 255, 255, 0.35);
	}
}

/* ========== Mobile / small tablets ========== */
@media (max-width: 991px) {
	body.savvy-login-page {
		-webkit-text-size-adjust: 100%;
		min-height: 100vh;
		min-height: 100dvh;
		overflow-x: hidden;
		width: 100%;
		max-width: 100vw;
		position: relative;
	}

	body.savvy-login-page .page-content-wrapper {
		min-height: 100vh;
		min-height: 100dvh;
		overflow-x: hidden;
		width: 100%;
		max-width: 100vw;
		box-sizing: border-box;
		padding-left: env(safe-area-inset-left, 0px);
		padding-right: env(safe-area-inset-right, 0px);
	}

	body.savvy-login-page .page_content {
		min-height: 100vh;
		min-height: 100dvh;
		overflow-x: hidden;
		width: 100% !important;
		max-width: 100vw !important;
		box-sizing: border-box;
	}

	/* Neutralize Bootstrap `.container` horizontal padding + max-width on small screens */
	body.savvy-login-page main.container {
		width: 100% !important;
		max-width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		padding-left: max(0.75rem, env(safe-area-inset-left, 0px)) !important;
		padding-right: max(0.75rem, env(safe-area-inset-right, 0px)) !important;
		box-sizing: border-box !important;
	}

	.savvy-login-shell.savvy-login-ref-shell {
		flex-direction: column;
		min-height: 100vh;
		min-height: 100dvh;
		overflow-x: hidden;
		width: 100%;
		max-width: 100%;
	}

	.savvy-login-hero.savvy-login-ref-hero {
		display: none;
	}

	.savvy-login-main.savvy-login-ref-main {
		flex: 1 1 auto;
		min-height: 0;
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
		padding-top: max(1rem, env(safe-area-inset-top, 0px));
		padding-right: max(0.5rem, env(safe-area-inset-right, 0px));
		padding-bottom: max(2rem, env(safe-area-inset-bottom, 12px));
		padding-left: max(0.5rem, env(safe-area-inset-left, 0px));
	}

	body.savvy-login-page .sx-login-auth-shell {
		max-width: 100% !important;
		width: 100% !important;
		box-sizing: border-box;
		margin-left: auto !important;
		margin-right: auto !important;
	}

	/* iOS: 16px+ prevents automatic zoom on input focus */
	body.savvy-login-page .form-control,
	body.savvy-login-page .page-card-body input[type="text"],
	body.savvy-login-page .page-card-body input[type="email"],
	body.savvy-login-page .page-card-body input[type="password"] {
		font-size: 16px !important;
		min-height: 48px;
		box-sizing: border-box;
	}

	body.savvy-login-page .btn-login.btn-primary,
	body.savvy-login-page .btn-forgot.btn-primary,
	body.savvy-login-page .page-card-actions .btn-primary,
	body.savvy-login-page .btn-default.btn-login,
	body.savvy-login-page .sx-login-primary-stack .btn-login-option,
	body.savvy-login-page .sx-login-primary-stack .btn-login-with-email-link {
		min-height: 48px;
		touch-action: manipulation;
		box-sizing: border-box;
	}

	body.savvy-login-page .sx-login-ref-heading {
		font-size: clamp(1.35rem, 5.2vw, 1.75rem);
	}
}

/* Narrow phones: tighter card + ensure no horizontal scroll */
@media (max-width: 480px) {
	body.savvy-login-page main.container {
		padding-left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
		padding-right: max(0.5rem, env(safe-area-inset-right, 0px)) !important;
	}

	body.savvy-login-page .sx-login-auth-shell {
		border-radius: 14px;
	}

	body.savvy-login-page .sx-login-auth-shell .page-card-head {
		padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
		padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
	}

	body.savvy-login-page .sx-login-auth-shell .login-content.page-card {
		padding-left: max(0.75rem, env(safe-area-inset-left, 0px)) !important;
		padding-right: max(0.75rem, env(safe-area-inset-right, 0px)) !important;
		padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px)) !important;
	}

	body.savvy-login-page .for-login .page-card,
	body.savvy-login-page .for-forgot .page-card,
	body.savvy-login-page .for-signup .page-card,
	body.savvy-login-page .for-email-login .page-card,
	body.savvy-login-page .for-login-with-email-link .page-card,
	body.savvy-login-page .page-card {
		border-radius: 14px;
		padding: 1rem !important;
	}

	body.savvy-login-page .sx-login-erp-logo {
		width: min(4.25rem, 20vw) !important;
	}

	body.savvy-login-page .page-card-actions .btn,
	body.savvy-login-page .sx-login-primary-stack .btn {
		width: 100%;
	}
}
