/* Admin login 2FA — flat layout, same outer shell as admin auth/login (.auth_box is 350px in admin.css). */

.auth_body .auth_fields_container {
	max-width: 350px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

/* Intro and errors under the page title */
.auth_box .auth_login_2fa_intro {
	margin: 0 0 16px;
	padding: 0;
	color: #3f3f3f;
	font-size: 14px;
	line-height: 1.45;
	text-align: center;
}

.auth_box .auth_login_2fa_error {
	color: #c62828;
	font-size: 14px;
	text-align: center;
	margin: 0 0 12px;
}

/* otp_start: factor list */
.auth_box .auth_login_2fa_options {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0 0 20px;
	padding: 0;
}

.auth_box .auth_login_2fa_card {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 12px;
	min-height: 52px;
	box-sizing: border-box;
	border: 1px solid #dcdcdc;
	border-radius: 3px;
	padding: 8px 12px;
	cursor: pointer;
	background: #fff;
}

.auth_box .auth_login_2fa_card:hover {
	border-color: #bfbfbf;
}

.auth_box .auth_login_2fa_radio {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	margin: 0;
	accent-color: #1976d2;
	cursor: pointer;
}

.auth_box .auth_login_2fa_card_icon {
	flex: 0 0 auto;
	width: 22px;
	text-align: center;
	color: #3f3f3f;
	font-size: 16px;
	line-height: 1;
}

.auth_box .auth_login_2fa_card_body {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	flex: 1 1 auto;
	min-width: 0;
	text-align: left;
}

.auth_box .auth_login_2fa_card_title,
.auth_box .auth_login_2fa_card_masked {
	font-size: 14px;
	line-height: 1.35;
	color: #3f3f3f;
}

.auth_box .auth_login_2fa_actions {
	text-align: right;
	margin: 0;
	padding: 0;
}

.auth_box .otp_start_next_button {
	min-width: 120px;
}

.auth_box .otp_start_form {
	margin: 0;
	padding: 0;
}

/* otp_email / otp_phone: verify + resend */
.auth_box .otp_verify_intro {
	margin: 0 0 16px;
	padding: 0;
	color: #3f3f3f;
	font-size: 14px;
	line-height: 1.45;
}

.auth_box .otp_verify_form {
	margin: 0;
	padding: 0;
	width: 100%;
	box-sizing: border-box;
}

.auth_box .otp_verify_field {
	margin-bottom: 16px;
}

.auth_box .otp_verify_label {
	display: block;
	font-size: 14px;
	font-weight: 500;
	margin-bottom: 6px;
	color: #5f5f5f;
}

.auth_box .otp_verify_otp_input {
	display: block;
	width: 100%;
	box-sizing: border-box;
	font-size: 16px;
	padding: 8px 10px;
	border: 1px solid #dcdcdc;
	border-radius: 3px;
	background: #fff;
	color: #3f3f3f;
}

.auth_box .otp_verify_otp_input::placeholder {
	color: #9ca3af;
}

.auth_box .otp_verify_button_row {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 10px;
	align-items: stretch;
	margin-top: 8px;
}

.auth_box .otp_verify_button_row .otp_verify_btn_primary,
.auth_box .otp_verify_button_row .otp_verify_btn_secondary {
	flex: 1 1 120px;
	min-height: 38px;
	box-sizing: border-box;
	font-size: 14px;
	border-radius: 3px;
	cursor: pointer;
}

.auth_box .otp_verify_btn_secondary {
	border: 1px solid #dcdcdc;
	background: #f5f5f5;
	color: #3f3f3f;
}

.auth_box .otp_verify_btn_secondary:hover {
	background: #ebebeb;
}

@media (max-width: 373px) {
	.auth_body .auth_fields_container {
		max-width: 100%;
		padding-left: 12px;
		padding-right: 12px;
		box-sizing: border-box;
	}

	.auth_body .auth_box {
		width: 100% !important;
		max-width: 100%;
	}

	.auth_fields_header {
		padding-bottom: 20px;
	}
}

@media (max-width: 1279px) {
	.auth_fields_header {
		padding-bottom: 25px;
	}
}
