/*
Theme Name: Kaydara Digital
Theme URI: https://kaydaradigital.com
Description: Thème enfant GeneratePress pour Kaydara Digital — maintenance, sécurité et continuité de sites WordPress. Charte de marque pilotée par theme.json (palette 6 couleurs, Sora/Inter auto-hébergées, échelle d'espacement). Une marque de Kaydara Group SARLU.
Author: Omar Sana Ouattara
Author URI: https://kaydaradigital.com
Template: generatepress
Version: 0.1.0
Requires at least: 6.6
Requires PHP: 8.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kaydara-digital
*/

/*
 * NOTE D'ARCHITECTURE
 * -------------------
 * 95 % du style est dans theme.json (couleurs, typo, espacements, boutons, liens).
 * Ce fichier ne contient QUE ce que theme.json ne sait pas exprimer pour un thème
 * CLASSIQUE comme GeneratePress :
 *   1. le forçage des polices côté front-end (cf. angle mort « GP free / theme.json ») ;
 *   2. l'accessibilité (focus visible, skip-link, prefers-reduced-motion) ;
 *   3. quelques garde-fous de lisibilité sur fond bleu nuit.
 * Les jetons sont disponibles en variables CSS générées par theme.json :
 *   --wp--preset--color--bleu-nuit | --ambre | --emeraude | --papier | --encre | --ardoise
 *   --wp--preset--font-family--sora | --inter
 *   --wp--preset--spacing--xs … --2xl
 */

/* 1. FORÇAGE TYPO -----------------------------------------------------------
 * GeneratePress (classique) pilote la typo du front via le Customizer, PAS via
 * theme.json. theme.json ne touche que l'éditeur de blocs. On force donc nos
 * polices ici pour garantir l'application côté visiteur, quel que soit le
 * réglage GP. À FAIRE en parallèle : Customizer → Typographie → "System Stack"
 * (évite que GP injecte une autre police après nous). */
body,
button,
input,
select,
textarea {
	font-family: var(--wp--preset--font-family--inter, system-ui, -apple-system, "Segoe UI", sans-serif);
}

h1, h2, h3, h4, h5, h6,
.site-title,
.entry-title {
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
}

/* 2. ACCESSIBILITÉ ----------------------------------------------------------
 * Focus visible en émeraude (signal d'action/sécurité de la marque). */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
	outline: 2px solid var(--wp--preset--color--emeraude, #128A6E);
	outline-offset: 2px;
	border-radius: 2px;
}

/* Skip-link réellement caché jusqu'au focus clavier. */
.skip-link {
	position: absolute;
	left: -9999px;
}
.skip-link:focus {
	left: 1rem;
	top: 1rem;
	z-index: 100000;
	padding: 0.75rem 1rem;
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4);
}

/* Respect de prefers-reduced-motion : filet de sécurité global.
 * (Le mouvement « maison » sera piloté par IntersectionObserver + cette règle.) */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* 3. LISIBILITÉ SUR FOND SOMBRE --------------------------------------------
 * Sur les bandeaux bleu nuit, le lien émeraude par défaut manque de contraste.
 * On le passe en papier souligné (ambre au survol, accent rare de la charte). */
.has-bleu-nuit-background-color a:where(:not(.wp-element-button)) {
	color: var(--wp--preset--color--papier, #FBF9F4);
	text-decoration: underline;
}
.has-bleu-nuit-background-color a:where(:not(.wp-element-button)):hover {
	color: var(--wp--preset--color--ambre, #D98E2B);
}

/* Sélection de texte aux couleurs de la marque. */
::selection {
	background: var(--wp--preset--color--ambre, #D98E2B);
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
}

/* 4. EN-TÊTE — LOCKUP DE MARQUE --------------------------------------------
 * Injecté par inc/header-footer.php (filtre generate_logo_output).
 * Pensé pour un en-tête sur fond CLAIR (papier). Si tu passes l'en-tête en
 * bleu nuit, inverse : KAYDARA en papier, garde DIGITAL en ambre. */
.kd-lockup__link {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	text-decoration: none;
}
.kd-lockup__mark {
	display: inline-grid;
	place-items: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 8px;
	background: var(--wp--preset--color--ambre, #D98E2B);
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
	font-size: 1.25rem;
	line-height: 1;
}
.kd-lockup__word {
	display: inline-flex;
	gap: 0.35ch;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
	font-size: 1.15rem;
	letter-spacing: 0.02em;
}
.kd-lockup__word strong { color: var(--wp--preset--color--bleu-nuit, #0F2A43); font-weight: 700; }
.kd-lockup__word span   { color: var(--wp--preset--color--ambre, #D98E2B); font-weight: 700; }

/* 5. EN-TÊTE — CTA PERSISTANT ----------------------------------------------
 * Bouton émeraude injecté dans generate_menu_bar_items (desktop + mobile).
 * !important sur la couleur : prime sur les styles de lien de GP et notre
 * règle « lien sur fond sombre ». */
.kd-nav-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.6rem 1.1rem;
	border-radius: 6px;
	background: var(--wp--preset--color--emeraude, #128A6E);
	color: var(--wp--preset--color--papier, #FBF9F4) !important;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1;
	white-space: nowrap;
	text-decoration: none;
	transition: background-color 0.15s ease;
}
.kd-nav-cta:hover,
.kd-nav-cta:focus {
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4) !important;
}
.kd-nav-cta__short { display: none; }

/* Libellé court sur mobile pour éviter le débordement de la barre. */
@media (max-width: 768px) {
	.kd-nav-cta { padding: 0.5rem 0.8rem; font-size: 0.85rem; }
	.kd-nav-cta__full  { display: none; }
	.kd-nav-cta__short { display: inline; }
}

/* 6. PIED DE PAGE -----------------------------------------------------------
 * Rendu par generate_copyright. La couleur du texte hérite de la barre de
 * pied de page configurée dans le Customizer (souvent foncée). */
.kd-footer-bottom { text-align: center; }
.kd-footer-nav {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	justify-content: center;
	margin: 0 0 0.75rem;
	padding: 0;
}
.kd-footer-nav a { color: inherit; text-decoration: none; }
.kd-footer-nav a:hover { text-decoration: underline; }
.kd-footer-mention { margin: 0; opacity: 0.85; font-size: 0.9rem; }

/* 7. (OPTIONNEL) EN-TÊTE COLLANT EN CSS PUR --------------------------------
 * GP free n'a pas de sticky nav (réservé à GP Premium / Menu Plus). Pour un
 * en-tête qui suit le scroll, décommente ce bloc. À tester : selon ta config
 * d'en-tête GP, ajuste le sélecteur (.site-header) et surveille les décalages.
 *
 * .site-header {
 *     position: sticky;
 *     top: 0;
 *     z-index: 100;
 * }
 */

/* 8. CARTE RÉALISATION ------------------------------------------------------
 * Markup unique du Post Template (pattern « Grille de réalisations »).
 * Les champs sont remplis par Block Bindings (core/post-meta). */
.kd-card {
	height: 100%;
	background: #ffffff;
	border: 1px solid rgba(27, 43, 54, 0.10); /* encre à 10 % */
	border-radius: 12px;
	overflow: hidden;
	transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.kd-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(15, 42, 67, 0.12); /* bleu nuit diffus */
	border-color: rgba(27, 43, 54, 0.18);
}

/* Média : ratio constant pour des cartes homogènes. */
.kd-card__media { margin: 0; }
.kd-card__media img {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

/* Corps : colonne, l'accroche pousse la stack et le lien vers le bas. */
.kd-card__body {
	padding: var(--wp--preset--spacing--md, 1.25rem);
	height: 100%;
	gap: 0.6rem;
}

/* Pastille de type : bleu nuit, pour ne PAS consommer l'émeraude
 * (réservée à l'action/sécurité par la charte). */
.kd-card__badge {
	align-self: flex-start;
	margin: 0;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
/* Si le champ kd_badge est vide, on masque la pastille (pas de pilule fantôme). */
.kd-card__badge:empty { display: none; }

.kd-card__title { margin: 0; }
.kd-card__title a {
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	text-decoration: none;
}
.kd-card__title a:hover { text-decoration: underline; }

.kd-card__accroche {
	margin: 0;
	flex: 1 1 auto; /* occupe l'espace → aligne le bas des cartes */
	color: var(--wp--preset--color--encre, #1C2B36);
}

.kd-card__stack {
	margin: 0;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}

.kd-card__more {
	margin: 0;
	color: var(--wp--preset--color--emeraude, #128A6E);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
}
.kd-card__more:hover { text-decoration: underline; }

/* 9. EN-TÊTE — MASQUER LE TITRE DE SITE GP (doublon du lockup) -------------
 * Notre lockup de marque (.site-logo, injecté par inc/header-footer.php) tient
 * lieu d'identité visuelle. GP affiche en plus le titre de site et le slogan :
 * on les masque pour éviter le doublon « KAYDARA DIGITAL » + « kaydaradigital.com ».
 * Le titre reste dans le DOM (lien d'accueil) ; le lockup porte déjà l'aria-label. */
.site-header .main-title,
.site-header .site-title,
.site-header .site-description {
	display: none;
}

/* 10. FICHE DÉTAILLÉE — étude de cas ---------------------------------------
 * Injectée dans le contenu par inc/single-realisation.php (single du CPT).
 * Masque le « byline » GP (date/auteur) qui n'a pas de sens pour un portfolio. */
.single-realisation .entry-meta { display: none; }

.kd-case__badge {
	display: inline-block;
	margin: 0 0 0.5rem;
	padding: 0.25rem 0.7rem;
	border-radius: 999px;
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.kd-case__badge:empty { display: none; }

.kd-case__lead {
	margin: 0.25rem 0 1.5rem;
	font-size: var(--wp--preset--font-size--lg, 1.5rem);
	line-height: 1.4;
	color: var(--wp--preset--color--encre, #1C2B36);
}

.kd-case__media { margin: 0 0 2rem; }
.kd-case__media img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 12px;
}

.kd-case__client {
	margin: 0 0 1.5rem;
	font-size: 0.95rem;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}
.kd-case__client span {
	margin-right: 0.4rem;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.kd-case__sections {
	display: grid;
	gap: 1.75rem;
	margin: 2rem 0;
}
.kd-case__section h2 { margin: 0 0 0.4rem; font-size: var(--wp--preset--font-size--lg, 1.5rem); }
.kd-case__section p  { margin: 0 0 0.75rem; }

.kd-case__stack { margin: 2rem 0; }
.kd-case__stack h2 { margin: 0 0 0.75rem; font-size: var(--wp--preset--font-size--md, 1.125rem); }
.kd-case__stack ul {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0;
	padding: 0;
}
.kd-case__stack li {
	padding: 0.3rem 0.7rem;
	border: 1px solid rgba(27, 43, 54, 0.15);
	border-radius: 6px;
	background: #ffffff;
	font-size: 0.85rem;
	color: var(--wp--preset--color--encre, #1C2B36);
}

/* Bouton « Voir le site » : contour bleu nuit (secondaire, pas l'émeraude). */
.kd-case__link { margin: 1.5rem 0 0; }
.kd-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.6rem 1.1rem;
	border: 1.5px solid var(--wp--preset--color--bleu-nuit, #0F2A43);
	border-radius: 6px;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43) !important;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
}
.kd-btn:hover {
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4) !important;
}

/* Bandeau CTA de bas de fiche. */
.kd-case-cta {
	margin: 3rem 0 0;
	padding: 2rem;
	border-radius: 12px;
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4);
	text-align: center;
}
.kd-case-cta__title {
	margin: 0 0 0.5rem;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
	font-size: var(--wp--preset--font-size--lg, 1.5rem);
}
.kd-case-cta p { margin: 0 0 1rem; }
.kd-case-cta__btn {
	display: inline-block;
	padding: 0.7rem 1.4rem;
	border-radius: 6px;
	background: var(--wp--preset--color--emeraude, #128A6E);
	color: var(--wp--preset--color--papier, #FBF9F4) !important;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
	transition: background-color 0.15s ease;
}
.kd-case-cta__btn:hover { background: var(--wp--preset--color--ambre, #D98E2B); color: var(--wp--preset--color--bleu-nuit, #0F2A43) !important; }

/* 11. PATTERN — APERÇU DES 3 FORMULES --------------------------------------
 * Chrome des cartes en CSS (theme.json a color.custom:false → pas de blanc
 * « libre » via le sélecteur). Colonnes cœur : empilement mobile automatique,
 * hauteurs égales (align-items stretch). */
.kd-formules__grid { margin-top: var(--wp--preset--spacing--md, 2rem); align-items: stretch; }

.kd-formule {
	background: #ffffff;
	border: 1px solid rgba(27, 43, 54, 0.10);
	border-radius: 12px;
	padding: var(--wp--preset--spacing--md, 1.5rem);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	height: 100%;
}
.kd-formule h3 { margin: 0; }

.kd-formule__price {
	margin: 0;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 1.9rem;
	font-weight: 700;
	line-height: 1.1;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
}
.kd-formule__price span {
	display: block;
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}

.kd-formule__for {
	margin: 0 0 0.5rem;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}

.kd-formule__list { margin: 0 0 1rem; padding-left: 1.1rem; color: var(--wp--preset--color--encre, #1C2B36); }
.kd-formule__list li { margin: 0.25rem 0; }

/* Bouton collé en bas → alignement des CTA quel que soit le nombre de lignes. */
.kd-formule .wp-block-buttons { margin-top: auto; }

/* Carte recommandée (Business). */
.kd-formule--reco {
	position: relative;
	border: 2px solid var(--wp--preset--color--emeraude, #128A6E);
}
.kd-formule__reco-badge {
	position: absolute;
	top: -0.8rem;
	left: 50%;
	transform: translateX(-50%);
	margin: 0;
	padding: 0.2rem 0.8rem;
	border-radius: 999px;
	background: var(--wp--preset--color--emeraude, #128A6E);
	color: var(--wp--preset--color--papier, #FBF9F4);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	white-space: nowrap;
}

.kd-formules__more { margin-top: var(--wp--preset--spacing--sm, 1rem); }
.kd-formules__more a {
	color: var(--wp--preset--color--emeraude, #128A6E);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
}
.kd-formules__more a:hover { text-decoration: underline; }

/* 12. PATTERN — BLOC ENGAGEMENTS -------------------------------------------
 * La grille est gérée par le layout « grid » du groupe (WP) : on ne style
 * que les items. Coche émeraude = signal sécurité/état OK de la charte. */
.kd-engagement h3 {
	position: relative;
	margin: 0 0 0.35rem;
	padding-left: 1.6rem;
}
.kd-engagement h3::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--wp--preset--color--emeraude, #128A6E);
	font-weight: 700;
}
.kd-engagement p { margin: 0; color: var(--wp--preset--color--encre, #1C2B36); }

.kd-engagements__note { margin-top: var(--wp--preset--spacing--md, 2rem); color: var(--wp--preset--color--ardoise, #6B7A86); }

/* 13. PAGE D'ACCUEIL --------------------------------------------------------
 * Sur l'accueil, le héros porte le H1 → on masque le titre de page GP pour
 * éviter un double titre (le titre reste hors écran via display:none). */
.home .entry-header .entry-title { display: none; }

/* Héros (sur fond bleu nuit). */
.kd-hero__eyebrow {
	margin: 0;
	color: var(--wp--preset--color--ambre, #D98E2B);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}
.kd-hero__sub {
	max-width: 46rem;
	margin-inline: auto;
	opacity: 0.92;
}
.kd-hero__link { margin-top: 0.25rem; }
.kd-hero__proof {
	max-width: 44rem;
	margin-inline: auto;
	margin-top: var(--wp--preset--spacing--md, 2rem);
	opacity: 0.7;
}

/* Intros de section centrées. */
.kd-section-intro { max-width: 48rem; margin-inline: auto; }

/* Grilles 3 colonnes (constat / solutions) : cartes blanches + filet de couleur. */
.kd-grid-3 { margin-top: var(--wp--preset--spacing--sm, 1rem); }
.kd-feature {
	background: #ffffff;
	border: 1px solid rgba(27, 43, 54, 0.10);
	border-top: 3px solid var(--wp--preset--color--ardoise, #6B7A86);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--md, 1.5rem);
}
.kd-feature h3 { margin: 0 0 0.4rem; }
.kd-feature p  { margin: 0; color: var(--wp--preset--color--encre, #1C2B36); }
.kd-grid-3--constat   .kd-feature { border-top-color: var(--wp--preset--color--ambre, #D98E2B); }
.kd-grid-3--solutions .kd-feature { border-top-color: var(--wp--preset--color--emeraude, #128A6E); }

.kd-transition {
	margin-top: var(--wp--preset--spacing--md, 2rem);
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
}
.kd-creation { color: var(--wp--preset--color--ardoise, #6B7A86); }

/* Méthode : 4 étapes. */
.kd-steps { margin-top: var(--wp--preset--spacing--md, 2rem); }
.kd-step {
	background: #ffffff;
	border: 1px solid rgba(27, 43, 54, 0.10);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--md, 1.5rem);
}
.kd-step__num {
	display: inline-grid;
	place-items: center;
	width: 2.2rem;
	height: 2.2rem;
	margin: 0 0 0.6rem;
	border-radius: 8px;
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
	color: var(--wp--preset--color--papier, #FBF9F4);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
}
.kd-step h3 { margin: 0 0 0.4rem; }
.kd-step__deliv { margin: 0; font-size: 0.85rem; color: var(--wp--preset--color--ardoise, #6B7A86); }

/* Liens « → » de section. */
.kd-link { margin-top: var(--wp--preset--spacing--sm, 1rem); }
.kd-link a {
	color: var(--wp--preset--color--emeraude, #128A6E);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
}
.kd-link a:hover { text-decoration: underline; }

/* 14. PAGE — RÉSERVER UN AUDIT GRATUIT -------------------------------------
 * Page de conversion. Réutilise .kd-grid-3 / .kd-feature / .kd-steps / .kd-step
 * définis plus haut. */
.kd-audit-lead {
	margin: 0;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	line-height: 1.25;
}

.kd-whatsapp { margin-top: 0.25rem; }
.kd-whatsapp a {
	color: var(--wp--preset--color--emeraude, #128A6E);
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	text-decoration: none;
}
.kd-whatsapp a:hover { text-decoration: underline; }

.kd-receive {
	max-width: 40rem;
	margin: 1rem auto 0;
	padding-left: 1.1rem;
	color: var(--wp--preset--color--encre, #1C2B36);
}
.kd-receive li { margin: 0.35rem 0; }

/* Bandeau de réassurance (sobre, bordé). */
.kd-reassure {
	max-width: 52rem;
	margin: var(--wp--preset--spacing--md, 2rem) auto 0;
	padding: 0.9rem 1.25rem;
	border: 1px solid rgba(27, 43, 54, 0.15);
	border-radius: 10px;
	color: var(--wp--preset--color--ardoise, #6B7A86);
	font-size: 0.9rem;
}
.kd-check { color: var(--wp--preset--color--emeraude, #128A6E); font-weight: 700; }

/* Bloc formulaire. */
.kd-audit-form { max-width: 640px; }
.kd-form-note { color: var(--wp--preset--color--ardoise, #6B7A86); }
.kd-form-note a { color: var(--wp--preset--color--emeraude, #128A6E); }

/* Harmonisation légère de Fluent Forms aux couleurs de la marque.
 * Best-effort : selon la version de FF, ajuste les sélecteurs si besoin. */
.kd-audit-form .fluentform .ff-el-input--label label {
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
}
.kd-audit-form .fluentform .ff-el-form-control {
	border-radius: 6px;
	border: 1px solid rgba(27, 43, 54, 0.20);
}
.kd-audit-form .fluentform .ff-el-form-control:focus {
	border-color: var(--wp--preset--color--emeraude, #128A6E);
	box-shadow: 0 0 0 2px rgba(18, 138, 110, 0.15);
	outline: none;
}
.kd-audit-form .fluentform .ff-btn-submit {
	background: var(--wp--preset--color--emeraude, #128A6E);
	color: var(--wp--preset--color--papier, #FBF9F4);
	border: 0;
	border-radius: 6px;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 600;
	transition: background-color 0.15s ease;
}
.kd-audit-form .fluentform .ff-btn-submit:hover {
	background: var(--wp--preset--color--bleu-nuit, #0F2A43);
}

/* 15. PAGE — SERVICES & FORMULES -------------------------------------------
 * Tableau comparatif : défilement horizontal sur mobile plutôt qu'écrasement.
 * Colonne Business (3e) mise en avant. */
.kd-compare { overflow-x: auto; }
.kd-compare table {
	width: 100%;
	min-width: 620px; /* déclenche le scroll horizontal sous ~620px */
	border-collapse: collapse;
}
.kd-compare th,
.kd-compare td {
	padding: 0.7rem 0.9rem;
	text-align: center;
	border-bottom: 1px solid rgba(27, 43, 54, 0.10);
	vertical-align: top;
}
.kd-compare thead th {
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 1.05rem;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
	border-bottom-width: 2px;
}
/* Première colonne = libellés de ligne, alignés à gauche. */
.kd-compare th:first-child,
.kd-compare td:first-child {
	text-align: left;
	font-weight: 600;
	color: var(--wp--preset--color--encre, #1C2B36);
}
/* Mise en avant de la colonne Business (3e). */
.kd-compare th:nth-child(3),
.kd-compare td:nth-child(3) { background: rgba(18, 138, 110, 0.06); }
.kd-compare__reco {
	display: block;
	margin-top: 0.2rem;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--wp--preset--color--emeraude, #128A6E);
}

.kd-price-note { color: var(--wp--preset--color--ardoise, #6B7A86); }

/* Conditions. */
.kd-conditions {
	max-width: 46rem;
	margin-inline: auto;
	padding-left: 1.1rem;
	color: var(--wp--preset--color--encre, #1C2B36);
}
.kd-conditions li { margin: 0.4rem 0; }
.kd-conditions strong { color: var(--wp--preset--color--bleu-nuit, #0F2A43); }

/* Sous-section création (en retrait : panneau distinct, plus sobre). */
.kd-creation-block {
	max-width: 620px;
	margin-inline: auto;
	background: #ffffff;
	border: 1px solid rgba(27, 43, 54, 0.12);
	border-radius: 12px;
}
.kd-eyebrow {
	margin: 0;
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}
.kd-create-table table { width: 100%; border-collapse: collapse; }
.kd-create-table th,
.kd-create-table td {
	padding: 0.55rem 0.7rem;
	border-bottom: 1px solid rgba(27, 43, 54, 0.10);
	text-align: left;
}
.kd-create-table thead th {
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-size: 0.78rem;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ardoise, #6B7A86);
}
.kd-create-table td:last-child,
.kd-create-table th:last-child {
	text-align: right;
	white-space: nowrap;
}
.kd-create-table td:last-child {
	font-family: var(--wp--preset--font-family--sora, system-ui, sans-serif);
	font-weight: 700;
	color: var(--wp--preset--color--bleu-nuit, #0F2A43);
}
