/**
 * Styles du mini-formulaire OTP Supra-Z.
 *
 * Palette : rouge #bd2d39, noir #1a1a1a, blanc #ffffff, gris #f5f5f5
 *
 * @package Sz_Smsv
 * @since   1.0.0
 */

/* ── Conteneur principal ─────────────────────────────────────────────────── */

.sz-smsv-otp-wrap {
	margin: 1.5rem 0;
	padding: 1.5rem;
	border: 2px solid #bd2d39;
	border-radius: 6px;
	background: #fff;
	font-family: inherit;
	max-width: 480px;
}

/* ── En-tête ─────────────────────────────────────────────────────────────── */

.sz-smsv-otp-header {
	margin-bottom: 1.25rem;
}

.sz-smsv-sent-msg {
	margin: 0 0 0.5rem;
	font-size: 0.95rem;
	color: #1a1a1a;
}

.sz-smsv-sent-msg strong {
	color: #bd2d39;
}

.sz-smsv-timer {
	margin: 0;
	font-size: 0.85rem;
	color: #555;
}

.sz-smsv-countdown {
	font-weight: 700;
	color: #bd2d39;
}

.sz-smsv-countdown.sz-smsv-expired {
	color: #888;
}

/* ── Corps du formulaire ─────────────────────────────────────────────────── */

.sz-smsv-otp-body {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.sz-smsv-label {
	display: block;
	margin-bottom: 0.5rem;
	font-size: 0.9rem;
	font-weight: 600;
	color: #1a1a1a;
}

.sz-smsv-input-row {
	display: flex;
	gap: 0.5rem;
	align-items: stretch;
}

/* ── Champ de saisie du code ─────────────────────────────────────────────── */

.sz-smsv-code-input {
	flex: 1;
	min-width: 0;
	padding: 0.6rem 0.75rem;
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
	text-align: center;
	border: 2px solid #ccc;
	border-radius: 4px;
	color: #1a1a1a;
	background: #f9f9f9;
	transition: border-color 0.2s ease;
	-webkit-appearance: none;
	appearance: none;
}

.sz-smsv-code-input:focus {
	outline: none;
	border-color: #bd2d39;
	background: #fff;
}

.sz-smsv-code-input.sz-smsv-input-error {
	border-color: #bd2d39;
	background: #fff5f5;
}

.sz-smsv-code-input.sz-smsv-input-success {
	border-color: #2e7d32;
	background: #f1f8f1;
}

.sz-smsv-code-input:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* ── Bouton Valider ──────────────────────────────────────────────────────── */

.sz-smsv-btn-verify {
	flex-shrink: 0;
	padding: 0.6rem 1.25rem;
	font-size: 0.95rem;
	font-weight: 600;
	color: #fff;
	background: #bd2d39;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.2s ease, opacity 0.2s ease;
	white-space: nowrap;
}

.sz-smsv-btn-verify:hover:not(:disabled) {
	background: #9e2530;
}

.sz-smsv-btn-verify:focus {
	outline: 2px solid #bd2d39;
	outline-offset: 2px;
}

.sz-smsv-btn-verify:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.sz-smsv-btn-verify.sz-smsv-loading {
	opacity: 0.7;
}

/* ── Messages de retour ──────────────────────────────────────────────────── */

.sz-smsv-msg {
	min-height: 1.4rem;
	font-size: 0.9rem;
	line-height: 1.4;
}

.sz-smsv-msg:empty {
	display: none;
}

.sz-smsv-msg.sz-smsv-msg-error {
	padding: 0.5rem 0.75rem;
	color: #721c24;
	background: #f8d7da;
	border: 1px solid #f5c6cb;
	border-radius: 4px;
}

.sz-smsv-msg.sz-smsv-msg-success {
	padding: 0.5rem 0.75rem;
	color: #155724;
	background: #d4edda;
	border: 1px solid #c3e6cb;
	border-radius: 4px;
}

.sz-smsv-msg.sz-smsv-msg-info {
	padding: 0.5rem 0.75rem;
	color: #0c5460;
	background: #d1ecf1;
	border: 1px solid #bee5eb;
	border-radius: 4px;
}

/* ── Lien Renvoyer ───────────────────────────────────────────────────────── */

.sz-smsv-resend-wrap {
	margin: 0;
	font-size: 0.85rem;
	color: #555;
}

.sz-smsv-btn-resend {
	color: #bd2d39;
	text-decoration: underline;
	cursor: pointer;
}

.sz-smsv-btn-resend:hover {
	color: #9e2530;
}

.sz-smsv-btn-resend.sz-smsv-loading,
.sz-smsv-btn-resend:disabled {
	color: #888;
	pointer-events: none;
	text-decoration: none;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 400px) {
	.sz-smsv-input-row {
		flex-direction: column;
	}

	.sz-smsv-btn-verify {
		width: 100%;
		padding: 0.75rem;
	}
}
