/**
 * Login / Signup modal - styles from reference docs/log-sign-up.js
 * Colors: #a855f7, #3b82f6, #38bdf8, #4ade80, #ec4899, #818cf8
 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap');

.login-signup-modal-overlay {
	position: fixed;
	inset: 0;
	z-index: 1050;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(4px);
	animation: loginSignupFadeIn 0.25s ease;
}
.login-signup-modal-overlay[aria-hidden="false"] {
	display: flex;
}

@keyframes loginSignupFadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}

@keyframes loginSignupContentFadeIn {
	from { opacity: 0; transform: translateY(18px); }
	to { opacity: 1; transform: translateY(0); }
}

.login-signup-modal-box {
	width: 400px;
	max-width: 95vw;
	max-height: 90vh;
	overflow-y: auto;
	background: linear-gradient(145deg, rgba(22, 18, 40, 0.95), rgba(18, 20, 36, 0.97));
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 22px;
	box-shadow: 0 8px 50px rgba(0, 0, 0, 0.5);
	padding: 32px 28px 28px;
	position: relative;
	animation: loginSignupContentFadeIn 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	font-family: 'DM Sans', sans-serif;
}

.login-signup-modal-close {
	position: absolute;
	top: 16px;
	right: 18px;
	background: none;
	border: none;
	color: rgba(255, 255, 255, 0.4);
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	padding: 0;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.login-signup-modal-close:hover {
	color: rgba(255, 255, 255, 0.7);
}

.login-signup-modal-content {
	min-height: 120px;
}

/* Headings and text */
.login-signup-modal-content .lsm-title {
	color: #fff;
	margin: 0;
	font-size: 22px;
	font-weight: 700;
}
.login-signup-modal-content .lsm-subtitle {
	color: rgba(255, 255, 255, 0.45);
	font-size: 13px;
	margin: 6px 0 0;
}
.login-signup-modal-content .lsm-head-icon {
	width: 52px;
	height: 52px;
	border-radius: 16px;
	background: linear-gradient(135deg, #a855f7, #3b82f6);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 14px;
	font-size: 24px;
}
.login-signup-modal-content .lsm-head-icon.forgot {
	background: linear-gradient(135deg, #38bdf8, #3b82f6);
}
.login-signup-modal-content .lsm-head-icon.success {
	background: linear-gradient(135deg, #4ade80, #3b82f6);
}
.login-signup-modal-content .lsm-text-center {
	text-align: center;
	margin-bottom: 24px;
}

/* Inputs - reference style */
.login-signup-modal-content .lsm-input-wrap {
	position: relative;
	margin-bottom: 14px;
}
.login-signup-modal-content .lsm-input,
.login-signup-modal-content .lsm-input-with-icon {
	width: 100%;
	padding: 13px 16px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 12px;
	color: #fff;
	font-size: 14px;
	outline: none;
	transition: border 0.25s, box-shadow 0.25s;
	box-sizing: border-box;
	font-family: 'DM Sans', sans-serif;
}
.login-signup-modal-content .lsm-input-with-icon {
	padding-left: 42px;
}
.login-signup-modal-content .lsm-input::placeholder {
	color: rgba(255, 255, 255, 0.4);
}
.login-signup-modal-content .lsm-input:focus,
.login-signup-modal-content .lsm-input-with-icon:focus {
	border-color: #a855f7;
	box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.2);
}
.login-signup-modal-content .lsm-input-icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 18px;
	opacity: 0.5;
	pointer-events: none;
}

/* Buttons */
.login-signup-modal-content .lsm-btn {
	width: 100%;
	padding: 13px;
	border-radius: 12px;
	border: none;
	color: #fff;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: transform 0.15s;
	font-family: 'DM Sans', sans-serif;
	margin-bottom: 0;
}
.login-signup-modal-content .lsm-btn-primary {
	background: linear-gradient(135deg, #a855f7, #3b82f6);
	box-shadow: 0 4px 18px rgba(168, 85, 247, 0.35);
}
.login-signup-modal-content .lsm-btn-primary:active {
	transform: scale(0.97);
}
.login-signup-modal-content .lsm-btn-forgot {
	background: linear-gradient(135deg, #38bdf8, #3b82f6);
	box-shadow: 0 4px 18px rgba(56, 189, 248, 0.35);
}
.login-signup-modal-content .lsm-btn-secondary {
	width: 100%;
	margin-top: 10px;
	padding: 10px;
	border-radius: 10px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: transparent;
	color: rgba(255, 255, 255, 0.55);
	font-size: 13px;
	cursor: pointer;
	font-family: 'DM Sans', sans-serif;
}
.login-signup-modal-content .lsm-btn-secondary:hover {
	color: rgba(255, 255, 255, 0.8);
}
.login-signup-modal-content .lsm-btn-success {
	background: linear-gradient(135deg, #4ade80, #3b82f6);
	box-shadow: 0 4px 18px rgba(74, 222, 128, 0.35);
}

/* Links */
.login-signup-modal-content .lsm-link {
	color: #38bdf8;
	font-size: 13px;
	cursor: pointer;
	background: none;
	border: none;
	padding: 0;
	font-family: inherit;
}
.login-signup-modal-content .lsm-link:hover {
	text-decoration: underline;
}
.login-signup-modal-content .lsm-link-purple {
	color: #a855f7;
	font-weight: 600;
}

/* OR divider */
.login-signup-modal-content .lsm-divider {
	display: flex;
	align-items: center;
	margin: 18px 0 16px;
	gap: 10px;
}
.login-signup-modal-content .lsm-divider-line {
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.18));
}
.login-signup-modal-content .lsm-divider-text {
	color: rgba(255, 255, 255, 0.38);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 1.8px;
	background: rgba(255, 255, 255, 0.06);
	padding: 5px 14px;
	border-radius: 20px;
	border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Error message */
.login-signup-modal-content .lsm-error {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px 12px;
	border-radius: 10px;
	margin-bottom: 10px;
	background: rgba(239, 68, 68, 0.12);
	border: 1px solid rgba(239, 68, 68, 0.3);
	color: #f87171;
	font-size: 13px;
}
.login-signup-modal-content .lsm-error.hidden {
	display: none;
}

.login-signup-modal-content .lsm-divider.hidden {
	display: none;
}

/* Any element with .hidden inside modal (e.g. password mismatch message) */
.login-signup-modal-content .hidden {
	display: none !important;
}

/* Footer link row */
.login-signup-modal-content .lsm-footer-row {
	text-align: center;
	margin-top: 18px;
}
.login-signup-modal-content .lsm-footer-row span:first-child {
	color: rgba(255, 255, 255, 0.45);
	font-size: 13px;
}

/* Right-align block (e.g. Forgot password link) */
.login-signup-modal-content .lsm-right {
	text-align: right;
	margin-bottom: 16px;
	margin-top: -6px;
}

/* Signup: step bar (reference style) - single line, no wrap */
.login-signup-modal-content .lsm-step-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	margin-bottom: 28px;
	flex-wrap: nowrap;
	min-width: 0;
}
.login-signup-modal-content .lsm-step-bar-item {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}
.login-signup-modal-content .lsm-step-dot {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-weight: 700;
	font-size: 11px;
	transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
	flex-shrink: 0;
}
.login-signup-modal-content .lsm-step-dot-active {
	width: 28px;
	height: 28px;
	font-size: 11px;
	border: 2px solid rgba(255, 255, 255, 0.3);
}
.login-signup-modal-content .lsm-step-connector {
	width: 18px;
	height: 2px;
	border-radius: 2px;
	transition: background 0.4s;
	flex-shrink: 0;
}
.login-signup-modal-content .lsm-signup-step-label {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	margin-bottom: 6px;
	text-align: center;
}

/* Signup: password strength */
.login-signup-modal-content .lsm-password-strength {
	margin-bottom: 14px;
}
.login-signup-modal-content .lsm-password-strength.hidden {
	display: none !important;
}
/* Forgot new password: strength label and bar use inline colors; ensure no dark override */
.login-signup-modal-content #lsm-forgot-strength-label {
	color: inherit;
}

/* Signup: OTP digit inputs */
.login-signup-modal-content .lsm-otp-row {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-bottom: 18px;
}
.login-signup-modal-content .lsm-otp-digit {
	width: 42px;
	height: 50px;
	text-align: center;
	font-size: 22px;
	font-weight: 700;
	background: rgba(255, 255, 255, 0.07);
	border: 2px solid rgba(255, 255, 255, 0.15);
	border-radius: 10px;
	color: #fff;
	outline: none;
	transition: border 0.2s, box-shadow 0.2s;
	box-sizing: border-box;
}
.login-signup-modal-content .lsm-otp-digit:focus {
	border-color: #a855f7;
	box-shadow: 0 0 10px rgba(168, 85, 247, 0.3);
}

/* Signup: checkbox (WhatsApp) */
.login-signup-modal-content .lsm-checkbox-wrap {
	display: flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	margin-bottom: 12px;
	color: rgba(255, 255, 255, 0.7);
	font-size: 13px;
}
.login-signup-modal-content .lsm-checkbox-wrap input {
	width: 22px;
	height: 22px;
	accent-color: #a855f7;
}

/* Signup: select (state, education) */
.login-signup-modal-content .lsm-select {
	appearance: none;
	cursor: pointer;
	color: #fff;
}
.login-signup-modal-content .lsm-select option {
	background: #1a1a2e;
	color: #fff;
}

/* Signup: exam tags */
.login-signup-modal-content .lsm-exam-tags {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 4px;
	margin-bottom: 10px;
	max-height: 200px;
	overflow-y: auto;
}
.login-signup-modal-content .lsm-exam-tag {
	display: inline-flex;
	align-items: center;
	padding: 7px 14px;
	border-radius: 20px;
	border: 1.5px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	color: rgba(255, 255, 255, 0.6);
	font-size: 13px;
	cursor: pointer;
	transition: all 0.2s;
	font-family: 'DM Sans', sans-serif;
}
.login-signup-modal-content .lsm-exam-tag:hover {
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.8);
}
.login-signup-modal-content .lsm-exam-tag-selected {
	box-shadow: 0 0 10px rgba(168, 85, 247, 0.2);
}

/* Signup: email-only CTA button */
.login-signup-modal-content .lsm-btn-signup-email {
	background: linear-gradient(135deg, rgba(168, 85, 247, 0.2), rgba(59, 130, 246, 0.2));
	border: 1px solid rgba(255, 255, 255, 0.14);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-bottom: 20px;
}
.login-signup-modal-content .lsm-btn-signup-email:hover {
	opacity: 0.95;
}
.login-signup-modal-content .lsm-btn-finish {
	background: linear-gradient(135deg, #ec4899, #a855f7, #4ade80);
	box-shadow: 0 4px 20px rgba(236, 72, 153, 0.4);
	font-weight: 700;
}
.login-signup-modal-content .lsm-btn-finish:active {
	transform: scale(0.97);
}
