@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800&display=swap');

:root {
	--operion-primary: #6d329e;
	--operion-primary-2: #5d2c91;
	--operion-accent: #7b3db2;
	--operion-dark: #3b1762;
	--operion-text: #1f1729;
	--operion-muted: #6e6280;
	--operion-card-bg: rgba(255, 255, 255, 0.94);
	--operion-input-bg: rgba(248, 245, 251, 0.96);
	--operion-shadow: 0 28px 70px rgba(60, 28, 94, 0.18);
}

html,
body {
	width: 100%;
	min-height: 100%;
	height: 100%;
	overflow-x: hidden !important;
}

body,
input,
button,
select,
textarea,
.navbar,
.page-card,
.card,
a,
span,
div,
label {
	font-family: "Cairo", sans-serif !important;
}

body {
	margin: 0 !important;
	color: var(--operion-text) !important;
	background-color: #f8f3ff !important;
	background-image:
		radial-gradient(circle at 10% 12%, rgba(109, 50, 158, 0.20), transparent 28%),
		radial-gradient(circle at 92% 82%, rgba(109, 50, 158, 0.13), transparent 30%),
		linear-gradient(135deg, #efe5fb 0%, #fbf8ff 48%, #f3e9ff 100%) !important;
	background-size: cover !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;
	position: relative;
}

body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	background:
		linear-gradient(90deg, rgba(109, 50, 158, 0.12) 0%, rgba(109, 50, 158, 0.04) 38%, transparent 39%),
		radial-gradient(circle at 5% 0%, rgba(255,255,255,0.42), transparent 34%),
		radial-gradient(circle at 100% 100%, rgba(109, 50, 158, 0.08), transparent 28%);
}

body::after {
	content: "";
	position: fixed;
	left: -16vw;
	top: -12vh;
	width: 62vw;
	height: 124vh;
	background:
		linear-gradient(135deg, rgba(109, 50, 158, 0.42), rgba(255,255,255,0.08));
	border-radius: 0 52% 52% 0;
	pointer-events: none;
	z-index: 0;
	filter: blur(0.2px);
}

/* Hide default Frappe header/footer */
.navbar,
.navbar-light,
.web-footer,
footer,
.page-footer,
.footer,
.website-footer,
.page-breadcrumbs,
.breadcrumbs {
	display: none !important;
}

.page-container,
.website-statistics,
.page_content,
#page-login,
.for-login,
.for-login .page-content,
.for-login .page-card-container {
	position: relative;
	z-index: 2;
}

.page-content,
.page_content,
#page-login,
main.container,
.container {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Main desktop layout */
.for-login,
.for-login .page-card-container {
	width: 100% !important;
	max-width: 100% !important;
	min-height: 100vh !important;
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	align-items: center !important;
	padding: 56px 8vw !important;
	box-sizing: border-box !important;
}

/* Brand side through page-card-head */
.for-login .page-card-head {
	grid-column: 1 !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	text-align: center !important;
	min-height: 460px !important;
	padding: 20px !important;
	margin: 0 !important;
	position: relative !important;
}

.for-login .page-card-head::after {
	content: "";
	width: 270px;
	height: 190px;
	margin-top: 34px;
	display: block;
	background:
		linear-gradient(180deg, rgba(255,255,255,0.60), rgba(109,50,158,0.12));
	border-radius: 34px;
	box-shadow: 0 24px 60px rgba(109, 50, 158, 0.14);
	opacity: 0.8;
}

.page-card-head img,
.page-card .app-logo,
.page-card .brand-logo,
.page-card .login-content .app-logo {
	display: block !important;
	margin: 0 auto 26px auto !important;
	max-height: 118px !important;
	max-width: 150px !important;
	border-radius: 18px !important;
}

.page-card-head h4,
.page-card-head h5,
.page-card-head .h4 {
	text-align: center !important;
	color: var(--operion-primary-2) !important;
	font-size: 30px !important;
	line-height: 1.35 !important;
	font-weight: 800 !important;
	margin: 0 auto 16px !important;
	max-width: 520px !important;
}

/* Login card side */
.page-card,
.card,
.for-login .page-card,
.for-login .login-content.page-card {
	grid-column: 2 !important;
	width: 100% !important;
	max-width: 560px !important;
	min-width: 0 !important;
	margin: 0 0 0 auto !important;
	border-radius: 24px !important;
	border: 1px solid rgba(109, 50, 158, 0.08) !important;
	background: var(--operion-card-bg) !important;
	box-shadow: var(--operion-shadow) !important;
	padding: 42px 46px !important;
	box-sizing: border-box !important;
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}

.page-card .page-card-body,
.page-card .login-content,
.page-card .sign-up-content,
.page-card form {
	background: transparent !important;
	border: 0 !important;
	box-shadow: none !important;
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
}

.form-group,
.page-card .form-group,
.page-card .email-field,
.page-card .password-field {
	width: 100% !important;
	margin-bottom: 20px !important;
	position: relative !important;
}

.form-control,
.page-card .form-control,
.page-card input[type="text"],
.page-card input[type="email"],
.page-card input[type="password"] {
	width: 100% !important;
	max-width: 100% !important;
	min-height: 56px !important;
	height: 56px !important;
	border-radius: 14px !important;
	background: var(--operion-input-bg) !important;
	border: 1px solid rgba(109, 50, 158, 0.13) !important;
	box-shadow: none !important;
	color: var(--operion-text) !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	padding-left: 58px !important;
	padding-right: 18px !important;
	box-sizing: border-box !important;
}

.form-control::placeholder,
.page-card input::placeholder {
	color: #90889e !important;
	opacity: 1 !important;
}

.form-control:focus,
.page-card .form-control:focus,
.page-card input:focus {
	border-color: rgba(109, 50, 158, 0.38) !important;
	box-shadow: 0 0 0 4px rgba(109, 50, 158, 0.10) !important;
	background: #fff !important;
}

.for-login .page-card .page-card-body .field-icon,
.for-forgot .page-card .page-card-body .field-icon,
.for-login-with-email-link .page-card .page-card-body .field-icon,
.for-signup .page-card .page-card-body .field-icon,
.for-email-login .page-card .page-card-body .field-icon {
	position: absolute !important;
	left: 18px !important;
	right: auto !important;
	top: 17px !important;
	width: 22px !important;
	height: 22px !important;
	fill: var(--operion-primary) !important;
	color: var(--operion-primary) !important;
	z-index: 3 !important;
}

.for-login .page-card .page-card-body .email-field .toggle-password,
.for-login .page-card .page-card-body .password-field .toggle-password,
.for-forgot .page-card .page-card-body .email-field .toggle-password,
.for-forgot .page-card .page-card-body .password-field .toggle-password,
.for-login-with-email-link .page-card .page-card-body .email-field .toggle-password,
.for-login-with-email-link .page-card .page-card-body .password-field .toggle-password,
.for-signup .page-card .page-card-body .email-field .toggle-password,
.for-signup .page-card .page-card-body .password-field .toggle-password,
.for-email-login .page-card .page-card-body .email-field .toggle-password,
.for-email-login .page-card .page-card-body .password-field .toggle-password {
	top: 17px !important;
	right: 18px !important;
	left: auto !important;
	color: var(--operion-primary-2) !important;
	font-size: 15px !important;
	z-index: 4 !important;
}

.page-card .forgot-password-message,
.page-card .forgot-password-message a,
.for-login .forgot-password-message,
.for-login .forgot-password-message a {
	display: block !important;
	text-align: right !important;
	font-size: 16px !important;
	font-weight: 500 !important;
	margin: 6px 0 24px !important;
	color: var(--operion-primary-2) !important;
}

button,
.btn,
.btn-primary,
.page-card .btn-primary,
.page-card button.btn-primary,
.page-card .btn-login {
	width: 100% !important;
	min-height: 58px !important;
	height: 58px !important;
	border: none !important;
	border-radius: 14px !important;
	background: linear-gradient(90deg, var(--operion-primary), var(--operion-primary-2)) !important;
	color: #fff !important;
	font-size: 17px !important;
	font-weight: 800 !important;
	font-family: "Cairo", sans-serif !important;
	box-shadow: 0 16px 34px rgba(93, 44, 145, 0.24) !important;
	transition: all 0.2s ease !important;
}

button:hover,
.btn:hover,
.btn-primary:hover,
.page-card .btn-primary:hover,
.page-card button.btn-primary:hover,
.page-card .btn-login:hover {
	transform: translateY(-1px) !important;
	box-shadow: 0 20px 40px rgba(93, 44, 145, 0.28) !important;
	background: linear-gradient(90deg, var(--operion-accent), var(--operion-primary-2)) !important;
}

a,
.page-card a,
.form-footer a,
.page-card-head h4,
.page-card .forgot-password-message,
.page-card .sign-up-message {
	color: var(--operion-primary-2) !important;
	font-family: "Cairo", sans-serif !important;
}

a:hover,
.page-card a:hover,
.form-footer a:hover {
	color: var(--operion-accent) !important;
	text-decoration: none !important;
}

.for-login .page-card .page-card-actions,
.for-login .page-card .sign-up-message,
.for-login .page-card .login-divider {
	background: transparent !important;
	border: 0 !important;
}

/* Desktop footer */
.for-login::after {
	content: "© 2025 Operion For Smart Solutions. All rights reserved.";
	position: fixed;
	left: 50%;
	bottom: 28px;
	transform: translateX(-50%);
	color: rgba(65, 49, 82, 0.58);
	font-size: 14px;
	font-weight: 500;
	z-index: 5;
}

/* Tablet */
@media (max-width: 960px) {
	body {
		background-image:
			radial-gradient(circle at 12% 10%, rgba(109, 50, 158, 0.13), transparent 32%),
			radial-gradient(circle at 88% 88%, rgba(109, 50, 158, 0.12), transparent 30%),
			linear-gradient(160deg, #faf7ff 0%, #f3e8ff 100%) !important;
		background-attachment: scroll !important;
	}

	body::after {
		display: none !important;
	}

	.for-login,
	.for-login .page-card-container {
		display: flex !important;
		flex-direction: column !important;
		align-items: center !important;
		justify-content: flex-start !important;
		min-height: 100vh !important;
		width: 100% !important;
		padding: 54px 22px 110px !important;
		box-sizing: border-box !important;
	}

	.for-login .page-card-head {
		display: flex !important;
		min-height: auto !important;
		width: 100% !important;
		padding: 0 !important;
		margin: 0 auto 30px !important;
	}

	.for-login .page-card-head::after {
		display: none !important;
	}

	.page-card-head img,
	.page-card .app-logo,
	.page-card .brand-logo,
	.page-card .login-content .app-logo {
		max-height: 104px !important;
		max-width: 128px !important;
		margin-bottom: 22px !important;
	}

	.page-card-head h4,
	.page-card-head h5,
	.page-card-head .h4 {
		font-size: 31px !important;
		line-height: 1.35 !important;
		max-width: 520px !important;
		margin-bottom: 0 !important;
	}

	.page-card,
	.card,
	.for-login .page-card,
	.for-login .login-content.page-card {
		width: 100% !important;
		max-width: 620px !important;
		margin: 0 auto !important;
		padding: 38px 34px !important;
		border-radius: 28px !important;
		background: rgba(255, 255, 255, 0.94) !important;
		box-shadow: 0 26px 64px rgba(70, 34, 100, 0.16) !important;
	}

	.form-control,
	.page-card .form-control,
	.page-card input[type="text"],
	.page-card input[type="email"],
	.page-card input[type="password"] {
		min-height: 58px !important;
		height: 58px !important;
		border-radius: 15px !important;
		font-size: 17px !important;
		padding-left: 58px !important;
	}

	button,
	.btn,
	.btn-primary,
	.page-card .btn-primary,
	.page-card button.btn-primary,
	.page-card .btn-login {
		min-height: 58px !important;
		height: 58px !important;
		border-radius: 15px !important;
		font-size: 17px !important;
	}

	.page-card .forgot-password-message,
	.page-card .forgot-password-message a,
	.for-login .forgot-password-message,
	.for-login .forgot-password-message a {
		text-align: right !important;
		font-size: 17px !important;
		margin: 8px 0 24px !important;
	}

	.for-login::after {
		content: "© 2025 Operion For Smart Solutions. All rights reserved.";
		position: relative;
		left: auto;
		bottom: auto;
		transform: none;
		margin-top: 38px;
		text-align: center;
		font-size: 14px;
		line-height: 1.6;
	}
}

/* Mobile */
@media (max-width: 576px) {
	.for-login,
	.for-login .page-card-container {
		padding: 44px 18px 86px !important;
	}

	.page-card-head img,
	.page-card .app-logo,
	.page-card .brand-logo,
	.page-card .login-content .app-logo {
		max-height: 92px !important;
		max-width: 112px !important;
		margin-bottom: 20px !important;
	}

	.page-card-head h4,
	.page-card-head h5,
	.page-card-head .h4 {
		font-size: 27px !important;
		line-height: 1.35 !important;
		max-width: 360px !important;
	}

	.page-card,
	.card,
	.for-login .page-card,
	.for-login .login-content.page-card {
		max-width: 100% !important;
		padding: 32px 22px !important;
		border-radius: 26px !important;
	}

	.form-group,
	.page-card .form-group,
	.page-card .email-field,
	.page-card .password-field {
		margin-bottom: 16px !important;
	}

	.form-control,
	.page-card .form-control,
	.page-card input[type="text"],
	.page-card input[type="email"],
	.page-card input[type="password"] {
		min-height: 54px !important;
		height: 54px !important;
		border-radius: 14px !important;
		font-size: 16px !important;
		padding-left: 54px !important;
		padding-right: 16px !important;
	}

	.for-login .page-card .page-card-body .field-icon,
	.for-forgot .page-card .page-card-body .field-icon,
	.for-login-with-email-link .page-card .page-card-body .field-icon,
	.for-signup .page-card .page-card-body .field-icon,
	.for-email-login .page-card .page-card-body .field-icon {
		left: 17px !important;
		top: 16px !important;
		width: 21px !important;
		height: 21px !important;
	}

	.for-login .page-card .page-card-body .email-field .toggle-password,
	.for-login .page-card .page-card-body .password-field .toggle-password,
	.for-forgot .page-card .page-card-body .email-field .toggle-password,
	.for-forgot .page-card .page-card-body .password-field .toggle-password,
	.for-login-with-email-link .page-card .page-card-body .email-field .toggle-password,
	.for-login-with-email-link .page-card .page-card-body .password-field .toggle-password,
	.for-signup .page-card .page-card-body .email-field .toggle-password,
	.for-signup .page-card .page-card-body .password-field .toggle-password,
	.for-email-login .page-card .page-card-body .email-field .toggle-password,
	.for-email-login .page-card .page-card-body .password-field .toggle-password {
		top: 16px !important;
		right: 16px !important;
		font-size: 15px !important;
	}

	.page-card .forgot-password-message,
	.page-card .forgot-password-message a,
	.for-login .forgot-password-message,
	.for-login .forgot-password-message a {
		font-size: 16px !important;
		margin: 8px 0 20px !important;
	}

	button,
	.btn,
	.btn-primary,
	.page-card .btn-primary,
	.page-card button.btn-primary,
	.page-card .btn-login {
		min-height: 54px !important;
		height: 54px !important;
		border-radius: 14px !important;
		font-size: 16px !important;
	}

	.for-login::after {
		font-size: 13px;
		max-width: 280px;
	}
}

/* Very small mobile */
@media (max-width: 400px) {
	.for-login,
	.for-login .page-card-container {
		padding: 34px 14px 76px !important;
	}

	.page-card-head img,
	.page-card .app-logo,
	.page-card .brand-logo,
	.page-card .login-content .app-logo {
		max-height: 78px !important;
		max-width: 96px !important;
	}

	.page-card-head h4,
	.page-card-head h5,
	.page-card-head .h4 {
		font-size: 23px !important;
	}

	.page-card,
	.card,
	.for-login .page-card,
	.for-login .login-content.page-card {
		padding: 28px 18px !important;
		border-radius: 22px !important;
	}

	.form-control,
	.page-card .form-control,
	.page-card input[type="text"],
	.page-card input[type="email"],
	.page-card input[type="password"],
	button,
	.btn,
	.btn-primary,
	.page-card .btn-primary,
	.page-card button.btn-primary,
	.page-card .btn-login {
		min-height: 50px !important;
		height: 50px !important;
		font-size: 15px !important;
	}
}
