/**
 * Lotus d'Or Newsletter & Ebooks — styles publics par défaut (Étape 9).
 *
 * Portée : uniquement les éléments préfixés ".lon-" générés par les
 * shortcodes publics des Étapes 6/7 (formulaire d'inscription,
 * désinscription, demande RGPD, blocs ebooks).
 *
 * Conçu pour être surchargé facilement par le thème actif :
 *   - toutes les couleurs/espacements passent par des variables CSS
 *     "--lon-*" déclarées sur :root, à redéfinir dans le thème pour
 *     adapter l'habillage sans toucher à ce fichier ;
 *   - sélecteurs à une seule classe (faible spécificité) ;
 *   - aucun !important, sauf le strict minimum documenté ci-dessous ;
 *   - la police héritée du thème (font-family: inherit) plutôt
 *     qu'imposée par le plugin.
 */

/* ------------------------------------------------------------------
 * 1. Jetons de design (à surcharger depuis le thème si besoin)
 * ------------------------------------------------------------------ */
:root {
	/* Palette — inspirée du lotus doré : or chaud, vert feuille, fond crème. */
	--lon-color-ink: #2a2722;
	--lon-color-muted: #6b6458;
	--lon-color-gold: #c49a3a;
	--lon-color-gold-dark: #9c7a28;
	--lon-color-leaf: #4b6b57;
	--lon-color-leaf-dark: #395245;
	--lon-color-cream: #fbf8f1;
	--lon-color-surface: #ffffff;
	--lon-color-border: #e4dcc8;
	--lon-color-error: #a8453a;
	--lon-color-error-bg: #fbeceA;

	/* Rayons, espacements, transitions. */
	--lon-radius-sm: 6px;
	--lon-radius-md: 12px;
	--lon-space-1: 0.5rem;
	--lon-space-2: 1rem;
	--lon-space-3: 1.5rem;
	--lon-space-4: 2rem;
	--lon-transition: 180ms ease;

	/* Typographie : hérite du thème par défaut, surcharger si besoin. */
	--lon-font: inherit;
}

/* ------------------------------------------------------------------
 * 2. Réinitialisation locale (limitée aux éléments du plugin)
 * ------------------------------------------------------------------ */
.lon-form,
.lon-form *,
.lon-ebook-grid,
.lon-ebook-grid *,
.lon-message {
	box-sizing: border-box;
}

/* ------------------------------------------------------------------
 * 3. Formulaires (inscription, désinscription, demande RGPD)
 * ------------------------------------------------------------------ */
.lon-form {
	font-family: var(--lon-font);
	color: var(--lon-color-ink);
	max-width: 32rem;
	display: flex;
	flex-direction: column;
	gap: var(--lon-space-3);
}

.lon-field {
	display: flex;
	flex-direction: column;
	gap: var(--lon-space-1);
}

.lon-label {
	font-weight: 600;
	font-size: 0.95rem;
}

.lon-label .lon-optional {
	font-weight: 400;
	color: var(--lon-color-muted);
	font-size: 0.85em;
}

.lon-input,
.lon-textarea,
.lon-select {
	font-family: var(--lon-font);
	font-size: 1rem;
	color: var(--lon-color-ink);
	background-color: var(--lon-color-surface);
	border: 1px solid var(--lon-color-border);
	border-radius: var(--lon-radius-sm);
	padding: 0.65em 0.85em;
	width: 100%;
	transition: border-color var(--lon-transition), box-shadow var(--lon-transition);
}

.lon-textarea {
	min-height: 6rem;
	resize: vertical;
}

.lon-input::placeholder,
.lon-textarea::placeholder {
	color: var(--lon-color-muted);
	opacity: 0.8;
}

.lon-input:hover,
.lon-textarea:hover,
.lon-select:hover {
	border-color: var(--lon-color-gold-dark);
}

/* Halo doré discret au focus clavier — signature visuelle du formulaire. */
.lon-input:focus-visible,
.lon-textarea:focus-visible,
.lon-select:focus-visible {
	outline: none;
	border-color: var(--lon-color-gold-dark);
	box-shadow: 0 0 0 3px rgba(196, 154, 58, 0.28);
}

.lon-field-error .lon-input,
.lon-field-error .lon-textarea,
.lon-field-error .lon-select {
	border-color: var(--lon-color-error);
}

.lon-field-error-text {
	color: var(--lon-color-error);
	font-size: 0.85rem;
}

/* --- Case de consentement RGPD : case personnalisée plus visible --- */
.lon-checkbox-wrap {
	display: flex;
	align-items: flex-start;
	gap: var(--lon-space-1);
	cursor: pointer;
}

.lon-checkbox-wrap input[type='checkbox'] {
	appearance: none;
	-webkit-appearance: none;
	flex: 0 0 auto;
	width: 1.2rem;
	height: 1.2rem;
	margin-top: 0.15rem;
	border: 1px solid var(--lon-color-border);
	border-radius: 4px;
	background-color: var(--lon-color-surface);
	position: relative;
	cursor: pointer;
	transition: background-color var(--lon-transition), border-color var(--lon-transition);
}

.lon-checkbox-wrap input[type='checkbox']:checked {
	background-color: var(--lon-color-gold);
	border-color: var(--lon-color-gold-dark);
}

.lon-checkbox-wrap input[type='checkbox']:checked::after {
	content: '';
	position: absolute;
	left: 0.32rem;
	top: 0.1rem;
	width: 0.32rem;
	height: 0.62rem;
	border: solid var(--lon-color-surface);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.lon-checkbox-wrap input[type='checkbox']:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(196, 154, 58, 0.28);
}

.lon-checkbox-label {
	font-size: 0.92rem;
	color: var(--lon-color-muted);
	line-height: 1.4;
}

.lon-checkbox-label a {
	color: var(--lon-color-leaf-dark);
	text-decoration: underline;
}

/* ------------------------------------------------------------------
 * 4. Boutons
 * ------------------------------------------------------------------ */
.lon-btn {
	font-family: var(--lon-font);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1;
	border: 1px solid transparent;
	border-radius: var(--lon-radius-sm);
	padding: 0.75em 1.5em;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	transition: transform var(--lon-transition), box-shadow var(--lon-transition), background-color var(--lon-transition);
}

.lon-btn-primary {
	color: #fff;
	background: linear-gradient(135deg, var(--lon-color-gold), var(--lon-color-gold-dark));
}

.lon-btn-primary:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(156, 122, 40, 0.32);
}

.lon-btn-secondary {
	color: var(--lon-color-leaf-dark);
	background-color: var(--lon-color-cream);
	border-color: var(--lon-color-border);
}

.lon-btn-secondary:hover {
	border-color: var(--lon-color-leaf);
}

.lon-btn:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(196, 154, 58, 0.35);
}

.lon-btn[disabled],
.lon-btn.lon-is-loading {
	cursor: not-allowed;
	opacity: 0.75;
	transform: none !important; /* Empêche tout effet de survol pendant l'envoi en cours. */
}

/* Indicateur de chargement affiché pendant les appels AJAX du plugin. */
.lon-spinner {
	width: 1em;
	height: 1em;
	border: 2px solid rgba(255, 255, 255, 0.45);
	border-top-color: #fff;
	border-radius: 50%;
	display: none;
	animation: lon-spin 700ms linear infinite;
}

.lon-btn.lon-is-loading .lon-spinner {
	display: inline-block;
}

.lon-btn.lon-is-loading .lon-btn-label {
	opacity: 0.85;
}

@keyframes lon-spin {
	to {
		transform: rotate(360deg);
	}
}

/* ------------------------------------------------------------------
 * 5. Messages (succès, erreur, info, double opt-in)
 * ------------------------------------------------------------------ */
.lon-message {
	font-family: var(--lon-font);
	border-radius: var(--lon-radius-sm);
	padding: var(--lon-space-2) var(--lon-space-2);
	font-size: 0.95rem;
	line-height: 1.5;
	border: 1px solid transparent;
}

.lon-message--success {
	color: var(--lon-color-leaf-dark);
	background-color: #eef3ee;
	border-color: var(--lon-color-leaf);
}

.lon-message--error {
	color: var(--lon-color-error);
	background-color: var(--lon-color-error-bg);
	border-color: var(--lon-color-error);
}

.lon-message--info,
.lon-double-optin-notice {
	color: var(--lon-color-ink);
	background-color: var(--lon-color-cream);
	border-color: var(--lon-color-border);
}

/* ------------------------------------------------------------------
 * 6. Blocs ebooks
 * ------------------------------------------------------------------ */
.lon-ebook-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--lon-space-3);
}

.lon-ebook-card {
	font-family: var(--lon-font);
	background-color: var(--lon-color-surface);
	border: 1px solid var(--lon-color-border);
	border-radius: var(--lon-radius-md);
	padding: var(--lon-space-3);
	display: flex;
	flex-direction: column;
	gap: var(--lon-space-1);
	transition: box-shadow var(--lon-transition), transform var(--lon-transition);
}

.lon-ebook-card:hover {
	box-shadow: 0 10px 24px rgba(42, 39, 34, 0.08);
	transform: translateY(-2px);
}

.lon-ebook-card__cover {
	width: 100%;
	border-radius: var(--lon-radius-sm);
	margin-bottom: var(--lon-space-1);
}

.lon-ebook-card__title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--lon-color-ink);
	margin: 0;
}

.lon-ebook-card__excerpt {
	color: var(--lon-color-muted);
	font-size: 0.92rem;
	line-height: 1.5;
	margin: 0;
}

.lon-ebook-card__btn {
	align-self: flex-start;
	margin-top: var(--lon-space-1);
}

/* ------------------------------------------------------------------
 * 7. Responsive
 * ------------------------------------------------------------------ */
@media (min-width: 700px) {
	.lon-ebook-grid {
		grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
	}
}

@media (max-width: 480px) {
	.lon-btn {
		width: 100%;
	}
}

/* ------------------------------------------------------------------
 * 8. Préférences d'accessibilité
 * ------------------------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
	.lon-btn-primary:hover,
	.lon-ebook-card:hover {
		transform: none;
	}

	.lon-input,
	.lon-textarea,
	.lon-select,
	.lon-btn,
	.lon-ebook-card {
		transition: none;
	}

	/* Le spinner reste animé : il signale un état réel d'attente réseau,
	   pas un effet décoratif. */
}
