@font-face {
	font-display: swap;
	font-family: "Michroma";
	font-style: normal;
	font-weight: 400;
	src: url("/assets/exp_theme/fonts/michroma-regular.ttf") format("truetype");
}

body[data-path="login"] {
	--exp-login-bg: #eef7fb;
	--exp-login-bg-soft: #f7fbff;
	--exp-login-panel: rgba(255, 255, 255, 0.92);
	--exp-login-panel-strong: #ffffff;
	--exp-login-border: rgba(25, 68, 96, 0.14);
	--exp-login-text: #162033;
	--exp-login-muted: #667388;
	--exp-login-primary: #41c7ee;
	--exp-login-accent: #6158e8;
	--exp-login-shadow: 0 24px 70px rgba(28, 45, 76, 0.14);
	--exp-login-card-width: 480px;
	--exp-login-page-logo: url("/assets/exp_theme/img/exp-login-logo-cyan.svg");
	--exp-login-splash-logo: url("/assets/exp_theme/img/exp-login-logo-cyan.svg");
	background:
		linear-gradient(128deg, rgba(65, 199, 238, 0.2), transparent 34rem),
		linear-gradient(236deg, rgba(97, 88, 232, 0.14), transparent 32rem),
		linear-gradient(135deg, var(--exp-login-bg), var(--exp-login-bg-soft));
	color: var(--exp-login-text);
	min-height: 100vh;
}

body[data-path="login"][data-exp-login-theme="dark"] {
	--exp-login-bg: #070b16;
	--exp-login-bg-soft: #0a1020;
	--exp-login-panel: rgba(15, 23, 40, 0.9);
	--exp-login-panel-strong: #111c30;
	--exp-login-border: rgba(135, 190, 230, 0.18);
	--exp-login-text: #eef3ff;
	--exp-login-muted: #9ca8bd;
	--exp-login-page-logo: url("/assets/exp_theme/img/exp-login-logo-cyan.svg");
	--exp-login-splash-logo: url("/assets/exp_theme/img/exp-login-logo-white.png");
	--exp-login-shadow: 0 28px 80px rgba(0, 0, 0, 0.42);
}

body[data-path="login"] .splash {
	background:
		linear-gradient(128deg, rgba(65, 199, 238, 0.2), transparent 34rem),
		linear-gradient(236deg, rgba(97, 88, 232, 0.14), transparent 32rem),
		var(--exp-login-bg);
}

body[data-path="login"] .splash img {
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	content: var(--exp-login-splash-logo) !important;
	filter: drop-shadow(0 18px 36px rgba(65, 199, 238, 0.18));
	height: auto !important;
	max-width: 140px !important;
	object-fit: contain;
	padding: 0 !important;
	width: auto !important;
}

body[data-path="login"] .page-content-wrapper {
	align-items: center;
	display: flex;
	min-height: 100vh;
	padding: 32px 24px;
	position: relative;
}

body[data-path="login"] main.container {
	max-width: none !important;
	padding: 0 !important;
	position: relative;
	width: 100%;
}

body[data-path="login"] .page_content {
	align-items: center;
	display: grid;
	gap: clamp(32px, 5vw, 84px);
	grid-template-columns: minmax(420px, 1fr) minmax(360px, var(--exp-login-card-width));
	margin: 0 auto;
	max-width: 1120px;
	width: min(100%, calc(100vw - 48px));
}

body[data-path="login"] .page_content::before {
	aspect-ratio: 1 / 1;
	background-image: var(--exp-login-page-logo);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	filter: drop-shadow(0 28px 58px rgba(65, 199, 238, 0.18));
	grid-column: 1;
	justify-self: center;
	max-width: 560px;
	opacity: 0.86;
	width: min(46vw, 560px);
}

body[data-path="login"] .page_content::after {
	background-image: var(--exp-login-page-logo);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	inset: 6vh auto auto 5vw;
	opacity: 0.07;
	pointer-events: none;
	position: fixed;
	width: min(46vw, 580px);
	aspect-ratio: 1 / 1;
}

body[data-path="login"] .exp-login-theme-toggle {
	align-items: center;
	background: color-mix(in srgb, var(--exp-login-panel-strong) 86%, transparent);
	border: 1px solid var(--exp-login-border);
	border-radius: 999px;
	box-shadow: 0 16px 38px rgba(28, 45, 76, 0.12);
	color: var(--exp-login-text);
	cursor: pointer;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	padding: 0;
	position: fixed;
	right: 24px;
	top: 24px;
	transition:
		background-color 140ms ease,
		border-color 140ms ease,
		color 140ms ease,
		transform 140ms ease;
	width: 42px;
	z-index: 20;
}

body[data-path="login"] .exp-login-theme-toggle:hover,
body[data-path="login"] .exp-login-theme-toggle:focus-visible {
	border-color: rgba(65, 199, 238, 0.72);
	color: var(--exp-login-primary);
	outline: none;
	transform: translateY(-1px);
}

body[data-path="login"] .exp-login-theme-toggle .icon {
	height: 1rem;
	width: 1rem;
}

body[data-path="login"] .page_content > div {
	grid-column: 2;
	justify-self: start;
	max-width: var(--exp-login-card-width);
	transform: translateX(-3%);
	width: 100%;
}

body[data-path="login"] section.for-login,
body[data-path="login"] section.for-email-login,
body[data-path="login"] section.for-signup,
body[data-path="login"] section.for-forgot,
body[data-path="login"] section.for-login-with-email-link {
	max-width: var(--exp-login-card-width);
	width: 100%;
}

body[data-path="login"] .page-card-head {
	border: 0 !important;
	margin: 0 0 24px !important;
	padding: 0 !important;
	text-align: center;
	width: 100%;
}

body[data-path="login"] .page-card-head .app-logo {
	display: none !important;
}

body[data-path="login"] .page-card-head h4 {
	color: var(--exp-login-text);
	font-size: 26px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0;
}

body[data-path="login"] section.for-login .page-card-head h4 {
	color: transparent;
	font-size: 0;
}

body[data-path="login"] section.for-login .page-card-head h4::after {
	color: var(--exp-login-text);
	content: "EXP Omniverse";
	display: block;
	font-family: "Michroma", Inter, "Segoe UI", Arial, sans-serif;
	font-size: clamp(20px, 2vw, 28px);
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.28;
}

body[data-path="login"] .login-content.page-card {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.72), transparent 52px),
		var(--exp-login-panel) !important;
	border: 1px solid var(--exp-login-border) !important;
	border-radius: 8px;
	box-shadow: var(--exp-login-shadow) !important;
	margin: 0 !important;
	max-width: none;
	padding: 30px;
	width: 100%;
}

body[data-path="login"] .page-card-body,
body[data-path="login"] .page-card-actions {
	padding: 0;
}

body[data-path="login"] .form-group {
	margin-bottom: 16px;
}

body[data-path="login"] .email-field,
body[data-path="login"] .password-field {
	position: relative;
}

body[data-path="login"] .form-control {
	background: rgba(255, 255, 255, 0.86) !important;
	border: 1px solid var(--exp-login-border) !important;
	border-radius: 8px;
	color: var(--exp-login-text) !important;
	font-size: 15px;
	height: 46px;
	padding-left: 42px;
	padding-right: 52px;
}

body[data-path="login"] .email-field .form-control {
	padding-right: 16px;
}

body[data-path="login"] .form-control:focus {
	background: var(--exp-login-panel-strong) !important;
	border-color: rgba(65, 199, 238, 0.72) !important;
	box-shadow: 0 0 0 3px rgba(65, 199, 238, 0.16) !important;
}

body[data-path="login"] .field-icon {
	color: var(--exp-login-muted);
	fill: var(--exp-login-muted);
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
}

body[data-path="login"] .password-field .toggle-password {
	align-items: center;
	color: var(--exp-login-muted);
	display: inline-flex;
	font-size: 0 !important;
	height: 24px;
	justify-content: center;
	line-height: 0;
	overflow: hidden;
	right: 13px !important;
	top: 50% !important;
	transform: translateY(-50%);
	width: 24px;
}

body[data-path="login"] .password-field .toggle-password::before {
	border: 2px solid currentColor;
	border-radius: 75% 15%;
	content: "";
	height: 16px;
	position: absolute;
	transform: rotate(45deg);
	width: 16px;
}

body[data-path="login"] .password-field .toggle-password::after {
	background: currentColor;
	border-radius: 999px;
	content: "";
	height: 5px;
	position: absolute;
	width: 5px;
}

body[data-path="login"] .forgot-password-message {
	margin: 2px 0 20px;
	text-align: right;
}

body[data-path="login"] .forgot-password-message a,
body[data-path="login"] .sign-up-message,
body[data-path="login"] .sign-up-message a,
body[data-path="login"] .login-divider {
	color: var(--exp-login-muted) !important;
}

body[data-path="login"] .btn.btn-primary,
body[data-path="login"] .btn-login {
	background: linear-gradient(135deg, var(--exp-login-primary), var(--exp-login-accent)) !important;
	border: 0 !important;
	border-radius: 8px;
	box-shadow: 0 16px 32px rgba(65, 199, 238, 0.22) !important;
	color: #ffffff !important;
	font-weight: 700;
	height: 44px;
	margin-top: 0;
}

body[data-path="login"] .btn.btn-default,
body[data-path="login"] .btn-login-option {
	background: rgba(255, 255, 255, 0.72) !important;
	border: 1px solid var(--exp-login-border) !important;
	border-radius: 8px;
	color: var(--exp-login-text) !important;
	height: 40px;
}

body[data-path="login"] .login-button-wrapper + .login-button-wrapper,
body[data-path="login"] .social-login-buttons + .social-login-buttons {
	margin-top: 10px;
}

body[data-path="login"] .btn-login-with-frappe-cloud,
body[data-path="login"] .login-button-wrapper:has(.btn-login-with-frappe-cloud) {
	display: none !important;
}

body[data-path="login"] .web-footer,
body[data-path="login"] .footer,
body[data-path="login"] #footer,
body[data-path="login"] footer,
body[data-path="login"] .page-breadcrumbs,
body[data-path="login"] .page-footer,
body[data-path="login"] .page-header-wrapper {
	display: none !important;
}

body[data-path="login"][data-exp-login-theme="dark"] .form-control,
body[data-path="login"][data-exp-login-theme="dark"] .btn.btn-default,
body[data-path="login"][data-exp-login-theme="dark"] .btn-login-option {
	background: rgba(17, 28, 48, 0.88) !important;
	color: var(--exp-login-text) !important;
}

body[data-path="login"][data-exp-login-theme="dark"] .login-content.page-card {
	background:
		linear-gradient(180deg, rgba(65, 199, 238, 0.08), transparent 52px),
		var(--exp-login-panel) !important;
}

body[data-path="login"][data-exp-login-theme="dark"] .splash img {
	filter: drop-shadow(0 18px 36px rgba(0, 212, 255, 0.2));
}

@media (prefers-color-scheme: dark) {
	body[data-path="login"]:not([data-exp-login-theme="light"]) {
		--exp-login-bg: #070b16;
		--exp-login-bg-soft: #0a1020;
		--exp-login-panel: rgba(15, 23, 40, 0.9);
		--exp-login-panel-strong: #111c30;
		--exp-login-border: rgba(135, 190, 230, 0.18);
		--exp-login-text: #eef3ff;
		--exp-login-muted: #9ca8bd;
		--exp-login-page-logo: url("/assets/exp_theme/img/exp-login-logo-cyan.svg");
		--exp-login-splash-logo: url("/assets/exp_theme/img/exp-login-logo-white.png");
		--exp-login-shadow: 0 28px 80px rgba(0, 0, 0, 0.42);
	}

	body[data-path="login"]:not([data-exp-login-theme="light"]) .splash img {
		filter: drop-shadow(0 18px 36px rgba(0, 212, 255, 0.2));
	}

	body[data-path="login"]:not([data-exp-login-theme="light"]) .form-control,
	body[data-path="login"]:not([data-exp-login-theme="light"]) .btn.btn-default,
	body[data-path="login"]:not([data-exp-login-theme="light"]) .btn-login-option {
		background: rgba(17, 28, 48, 0.88) !important;
		color: var(--exp-login-text) !important;
	}

	body[data-path="login"]:not([data-exp-login-theme="light"]) .login-content.page-card {
		background:
			linear-gradient(180deg, rgba(65, 199, 238, 0.08), transparent 52px),
			var(--exp-login-panel) !important;
	}
}

@media (max-width: 900px) {
	body[data-path="login"] .page-content-wrapper {
		align-items: flex-start;
		padding-top: 28px;
	}

	body[data-path="login"] .exp-login-theme-toggle {
		right: 16px;
		top: 16px;
	}

	body[data-path="login"] .page_content {
		display: block;
		width: min(100%, 520px);
	}

	body[data-path="login"] .page_content::before {
		margin: 0 auto 20px;
		max-width: 220px;
		min-height: 0;
		width: min(48vw, 220px);
	}

	body[data-path="login"] .page_content > div {
		margin: 0 auto;
		transform: none;
	}
}

@media (max-width: 480px) {
	body[data-path="login"] .page-content-wrapper {
		padding-left: 14px;
		padding-right: 14px;
	}

	body[data-path="login"] .page_content {
		width: 100%;
	}

	body[data-path="login"] .page_content::before {
		margin-bottom: 16px;
		width: 156px;
	}

	body[data-path="login"] .login-content.page-card {
		padding: 22px;
	}
}
