/* maiCalculus Login Portal — matches the maicalculus.com theme tokens. */
.mc-login {
	--mc-brand: #0800c2;
	--mc-brand-hover: #06009b;
	--mc-brand-light: #4d6fff;
	--mc-brand-tint: #b5b3ed;
	--mc-brand-focus: rgba(8, 0, 194, 0.18);
	--mc-fg: #151515;
	--mc-muted: #6c757d;
	--mc-border: #dddedc;
	--mc-input-bg: #ffffff;
	--mc-suffix-bg: #f2f2f2;
	--mc-error: #d63384;

	box-sizing: border-box;
	width: 100%;
	max-width: 480px;
	margin: 0 auto;
	color: var(--mc-fg);
	font-family: brockmannRegular, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.mc-login *,
.mc-login *::before,
.mc-login *::after {
	box-sizing: border-box;
}

.mc-login__form {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin: 0;
}

.mc-login__label {
	font-family: brockmannSemiBold, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--mc-fg);
}

.mc-login__input-group {
	display: flex;
	align-items: stretch;
	height: 52px;
	border: 1px solid var(--mc-border);
	border-radius: 8px;
	overflow: hidden;
	background: var(--mc-input-bg);
	transition: border-color 150ms ease, box-shadow 150ms ease;
}

.mc-login__input-group:focus-within {
	border-color: var(--mc-brand);
	box-shadow: 0 0 0 4px var(--mc-brand-focus);
}

.mc-login__input {
	flex: 1 1 auto;
	min-width: 0;
	border: none;
	outline: none;
	background: transparent;
	padding: 0 16px;
	font-family: inherit;
	font-size: 16px;
	color: var(--mc-fg);
	letter-spacing: 0.005em;
}

.mc-login__input::placeholder {
	color: #a8adb3;
}

.mc-login__suffix {
	display: inline-flex;
	align-items: center;
	padding: 0 16px;
	background: var(--mc-suffix-bg);
	color: var(--mc-muted);
	font-size: 14px;
	border-left: 1px solid var(--mc-border);
	white-space: nowrap;
}

.mc-login__error {
	margin: 0;
	font-size: 13px;
	color: var(--mc-error);
	letter-spacing: 0.005em;
}

.mc-login__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 52px;
	margin-top: 6px;
	padding: 0 28px;
	color: #ffffff;
	background: linear-gradient(96deg, var(--mc-brand) 57.95%, var(--mc-brand-light) 97.31%);
	border: 0;
	border-radius: 8px;
	font-family: brockmannSemiBold, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: filter 150ms ease, transform 150ms ease, box-shadow 150ms ease, opacity 150ms ease;
	box-shadow: 0 10px 24px -12px rgba(8, 0, 194, 0.55);
}

.mc-login__button:hover:not(:disabled) {
	filter: brightness(1.05);
	transform: translateY(-1px);
	box-shadow: 0 14px 28px -12px rgba(8, 0, 194, 0.6);
}

.mc-login__button:active:not(:disabled) {
	transform: translateY(0);
	filter: brightness(0.98);
}

.mc-login__button:focus-visible {
	outline: none;
	box-shadow: 0 0 0 4px var(--mc-brand-focus), 0 10px 24px -12px rgba(8, 0, 194, 0.55);
}

.mc-login__button:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	box-shadow: none;
}
