/*
Theme Name:   Hello Child — Cabinet Profi
Theme URI:    https://cabinet-profi.fr/
Description:  Thème enfant Hello Elementor pour la refonte stratégique Cabinet Profi. Design system custom, tokens CSS, typo Jost + Fraunces, palette bleu nuit + or.
Author:       Crealab
Author URI:   https://cabinet-profi.fr/
Template:     hello-elementor
Version:      1.0.0
License:      GNU General Public License v3 or later
License URI:  https://www.gnu.org/licenses/gpl-3.0.html
Text Domain:  hello-child
*/

/* === 1. FONTS === */
/* Jost (titres + corps) et Fraunces (citations éditoriales). Chargées via functions.php avec preconnect + display=swap. Déclarations locales ci-dessous pour auto-hébergement futur (phase 2 perf). */
@font-face { font-family: "Jost"; font-style: normal; font-weight: 400; font-display: swap; src: local("Jost"); }
@font-face { font-family: "Jost"; font-style: normal; font-weight: 500; font-display: swap; src: local("Jost Medium"); }
@font-face { font-family: "Jost"; font-style: normal; font-weight: 600; font-display: swap; src: local("Jost SemiBold"); }
@font-face { font-family: "Jost"; font-style: normal; font-weight: 700; font-display: swap; src: local("Jost Bold"); }
@font-face { font-family: "Fraunces"; font-style: italic; font-weight: 400; font-display: swap; src: local("Fraunces Italic"); }

/* === 2. VARIABLES CSS === */
:root {
  /* 2.1 Palette neutres (fond & structure) */
  --color-bg: #0B1628;                     /* Fond principal — bleu nuit profond */
  --color-bg-alt: #0F1E3A;                 /* Fond alternatif sections */
  --color-surface: #17294A;                /* Cartes, encarts, blocs élevés */
  --color-surface-hi: #1F3460;             /* Surface hover */
  --color-border: #233659;                 /* Bordures discrètes */
  --color-border-strong: #3A4F7A;          /* Bordures contrastées */

  /* 2.2 Palette texte */
  --color-text: #F5F1E8;                   /* Crème principale (AAA 15.2:1 sur bg) */
  --color-text-muted: #9AA9C2;             /* Texte secondaire (AAA 7.1:1) */
  --color-text-dim: #6B7F9E;               /* Texte très discret, mentions légales */
  --color-text-inverse: #0B1628;           /* Texte sur fond clair */

  /* 2.3 Accents marque */
  --color-accent: #C9A961;                 /* Or signature (version raffinée) */
  --color-accent-strong: #B8943D;          /* Or hover / focus */
  --color-accent-soft: #EBDFB8;            /* Or très clair pour backgrounds subtils */
  --color-accent-on: #0B1628;              /* Texte sur fond or (ratio 12:1) */

  /* 2.4 Sémantiques UI */
  --color-success: #4ADE80;
  --color-warning: #FBBF24;
  --color-danger: #F87171;
  --color-info: #60A5FA;

  /* 2.5 Typo familles */
  --font-sans: "Jost", -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-serif: "Fraunces", Georgia, "Times New Roman", serif;
  --font-mono: ui-monospace, "SF Mono", Menlo, Monaco, Consolas, monospace;

  /* 2.6 Typo scale fluide (clamp min, pref, max) */
  --fs-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);       /* 12→14 */
  --fs-sm: clamp(0.875rem, 0.8rem + 0.375vw, 1rem);          /* 14→16 */
  --fs-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);          /* 16→18 */
  --fs-lg: clamp(1.125rem, 1rem + 0.625vw, 1.375rem);        /* 18→22 */
  --fs-xl: clamp(1.5rem, 1.2rem + 1.5vw, 2rem);              /* 24→32 */
  --fs-2xl: clamp(2rem, 1.5rem + 2.5vw, 3rem);               /* 32→48 */
  --fs-3xl: clamp(2.5rem, 1.8rem + 3.5vw, 4rem);             /* 40→64 */
  --fs-4xl: clamp(3rem, 2rem + 5vw, 5.5rem);                 /* 48→88 */

  /* 2.7 Typo — hauteurs de ligne et graisses */
  --lh-tight: 1.1;
  --lh-snug: 1.3;
  --lh-normal: 1.6;
  --lh-relaxed: 1.75;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-wider: 0.1em;

  /* 2.8 Espacement (échelle 4/8) */
  --sp-0: 0;
  --sp-1: 0.25rem;                         /* 4 */
  --sp-2: 0.5rem;                          /* 8 */
  --sp-3: 0.75rem;                         /* 12 */
  --sp-4: 1rem;                            /* 16 */
  --sp-5: 1.5rem;                          /* 24 */
  --sp-6: 2rem;                            /* 32 */
  --sp-7: 3rem;                            /* 48 */
  --sp-8: 4rem;                            /* 64 */
  --sp-9: 6rem;                            /* 96 */
  --sp-10: 8rem;                           /* 128 */

  /* 2.9 Rayons */
  --radius-none: 0;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --radius-full: 9999px;

  /* 2.10 Ombres (adaptées au fond sombre) */
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.35);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.4);
  --shadow-accent: 0 8px 24px rgba(201,169,97,0.25);

  /* 2.11 Layout */
  --container-max: 1240px;
  --container-wide: 1440px;
  --container-narrow: 760px;
  --header-h: 84px;
  --gutter: clamp(1rem, 3vw, 2rem);

  /* 2.12 Transitions */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --dur-fast: 150ms;
  --dur-base: 250ms;
  --dur-slow: 400ms;

  /* 2.13 Z-index scale */
  --z-base: 0;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-header: 300;
  --z-modal: 400;
  --z-popup: 500;
  --z-toast: 600;
}

/* === 3. RESET === */
/* Reset moderne minimal, inspiré Andy Bell + Josh Comeau. Ne touche pas à ce que Elementor gère déjà. */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; -moz-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
html:focus-within { scroll-behavior: smooth; }
body { min-height: 100vh; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; line-height: var(--lh-normal); font-family: var(--font-sans); font-size: var(--fs-base); font-weight: var(--fw-regular); color: var(--color-text); background-color: var(--color-bg); }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-sans); font-weight: var(--fw-semibold); line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); color: var(--color-text); }
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }
h5 { font-size: var(--fs-base); font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: var(--tracking-wider); }
h6 { font-size: var(--fs-sm); font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: var(--tracking-wider); }
a { color: var(--color-accent); text-decoration-color: transparent; text-underline-offset: 0.2em; transition: color var(--dur-fast) var(--ease), text-decoration-color var(--dur-fast) var(--ease); }
a:hover { color: var(--color-accent-strong); text-decoration: underline; text-decoration-color: currentColor; }
a:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; border-radius: var(--radius-sm); }
ul, ol { padding-left: var(--sp-5); }
ul[role="list"], ol[role="list"] { list-style: none; padding: 0; }
button { cursor: pointer; background: none; border: none; }
::selection { background: var(--color-accent); color: var(--color-accent-on); }
hr { border: 0; border-top: 1px solid var(--color-border); margin: var(--sp-6) 0; }
@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; } }

/* === 4. DEV TOOLS === */
/* Outils visibles uniquement en environnement de dev. Activés via la classe .dev-mode ajoutée sur <body> dans functions.php si WP_DEBUG est actif. À retirer en prod. */
body.dev-mode::before { content: "DEV " attr(data-viewport); position: fixed; top: 0; left: 0; z-index: var(--z-toast); padding: 4px 10px; font-family: var(--font-mono); font-size: 11px; font-weight: var(--fw-bold); color: #000; background: #FBBF24; border-bottom-right-radius: var(--radius-sm); pointer-events: none; }
body.dev-mode.dev-grid main::before { content: ""; position: fixed; inset: 0; z-index: var(--z-toast); background: linear-gradient(to right, rgba(201,169,97,0.08) 1px, transparent 1px); background-size: calc((100vw - 2 * var(--gutter)) / 12) 100%; background-position: var(--gutter) 0; pointer-events: none; }
body.dev-mode .debug-outline * { outline: 1px solid rgba(201,169,97,0.3); }
@media (min-width: 480px) { body.dev-mode { --dev-vp: "XS 480+"; } }
@media (min-width: 640px) { body.dev-mode { --dev-vp: "SM 640+"; } }
@media (min-width: 768px) { body.dev-mode { --dev-vp: "MD 768+"; } }
@media (min-width: 1024px) { body.dev-mode { --dev-vp: "LG 1024+"; } }
@media (min-width: 1280px) { body.dev-mode { --dev-vp: "XL 1280+"; } }
@media (min-width: 1536px) { body.dev-mode { --dev-vp: "2XL 1536+"; } }

/* === 5. LAYOUT & THEMES === */
/* 5.1 Container fluide */
.container { width: 100%; max-width: var(--container-max); margin-inline: auto; padding-inline: var(--gutter); }
.container--wide { max-width: var(--container-wide); }
.container--narrow { max-width: var(--container-narrow); }
.container--full { max-width: none; }

/* 5.2 Stack vertical automatique (spacing utility) */
.stack > * + * { margin-top: var(--stack-space, var(--sp-4)); }
.stack-sm { --stack-space: var(--sp-2); }
.stack-md { --stack-space: var(--sp-4); }
.stack-lg { --stack-space: var(--sp-6); }
.stack-xl { --stack-space: var(--sp-8); }

/* 5.3 Grilles utilitaires */
.grid { display: grid; gap: var(--grid-gap, var(--sp-5)); }
.grid-2 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)); }
.grid-3 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr)); }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr)); }

/* 5.4 Sections thématiques */
.section { padding-block: clamp(3rem, 8vw, 6rem); }
.section--dark { background-color: var(--color-bg); color: var(--color-text); }
.section--darker { background-color: var(--color-bg-alt); color: var(--color-text); }
.section--surface { background-color: var(--color-surface); color: var(--color-text); }
.section--accent { background-color: var(--color-accent); color: var(--color-accent-on); }
.section--accent h1, .section--accent h2, .section--accent h3, .section--accent h4 { color: var(--color-accent-on); }

/* 5.5 Thème clair ponctuel (certains blocs légaux ou formulaires) */
.theme-light { --color-bg: #FFFFFF; --color-bg-alt: #F8F6F0; --color-surface: #F2EFE6; --color-text: #0B1628; --color-text-muted: #475569; --color-border: #E2DED1; background-color: var(--color-bg); color: var(--color-text); }
.theme-light h1, .theme-light h2, .theme-light h3, .theme-light h4 { color: var(--color-text); }
.theme-light a { color: var(--color-accent-strong); }

/* 5.6 Accessibilité utilitaires */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; top: -100px; left: var(--sp-4); z-index: var(--z-toast); padding: var(--sp-3) var(--sp-4); background: var(--color-accent); color: var(--color-accent-on); font-weight: var(--fw-semibold); border-radius: var(--radius-md); text-decoration: none; transition: top var(--dur-base) var(--ease); }
.skip-link:focus { top: var(--sp-4); }
.visually-hidden:not(:focus):not(:active) { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

/* 5.7 Header sticky de base (surchargé par Elementor Theme Builder si besoin) */
.site-header { position: sticky; top: 0; z-index: var(--z-header); min-height: var(--header-h); background-color: rgba(11,22,40,0.92); backdrop-filter: saturate(180%) blur(12px); -webkit-backdrop-filter: saturate(180%) blur(12px); border-bottom: 1px solid var(--color-border); }
body.scroll .site-header { background-color: rgba(11,22,40,0.98); box-shadow: var(--shadow-md); }

/* === 6. COMPOSANTS UI === */
/* 6.1 Boutons — trois variantes : primary (or plein), secondary (outline), ghost */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-5); min-height: 48px; font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); letter-spacing: var(--tracking-wide); text-transform: uppercase; text-decoration: none; border: 2px solid transparent; border-radius: var(--radius-md); cursor: pointer; transition: background-color var(--dur-base) var(--ease), color var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur-base) var(--ease); }
.btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; }
.btn:active { transform: translateY(1px); }
.btn--primary { background-color: var(--color-accent); color: var(--color-accent-on); border-color: var(--color-accent); box-shadow: var(--shadow-accent); }
.btn--primary:hover { background-color: var(--color-accent-strong); border-color: var(--color-accent-strong); color: var(--color-accent-on); text-decoration: none; }
.btn--secondary { background-color: transparent; color: var(--color-accent); border-color: var(--color-accent); }
.btn--secondary:hover { background-color: var(--color-accent); color: var(--color-accent-on); text-decoration: none; }
.btn--ghost { background-color: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn--ghost:hover { background-color: var(--color-surface); border-color: var(--color-border-strong); color: var(--color-text); text-decoration: none; }
.btn--lg { min-height: 56px; padding: var(--sp-4) var(--sp-6); font-size: var(--fs-base); }
.btn--sm { min-height: 40px; padding: var(--sp-2) var(--sp-4); font-size: var(--fs-xs); }
.btn--block { display: flex; width: 100%; }

/* 6.2 Cartes */
.card { position: relative; padding: var(--sp-6); background-color: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); transition: transform var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease); }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--color-accent); }
.card__title { margin-bottom: var(--sp-3); font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-text); }
.card__text { color: var(--color-text-muted); line-height: var(--lh-relaxed); }
.card--elevated { box-shadow: var(--shadow-md); }
.card--flat { background-color: transparent; border-color: var(--color-border); }
.card--accent { background-color: var(--color-accent); color: var(--color-accent-on); border-color: var(--color-accent); }
.card--accent .card__title, .card--accent .card__text { color: var(--color-accent-on); }

/* 6.3 Badges / Étiquettes */
.badge { display: inline-flex; align-items: center; gap: var(--sp-1); padding: var(--sp-1) var(--sp-3); font-size: var(--fs-xs); font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: var(--tracking-wider); border-radius: var(--radius-full); background-color: var(--color-surface); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.badge--accent { background-color: var(--color-accent-soft); color: var(--color-accent-on); border-color: var(--color-accent); }
.badge--success { background-color: rgba(74,222,128,0.12); color: var(--color-success); border-color: rgba(74,222,128,0.4); }
.badge--warning { background-color: rgba(251,191,36,0.12); color: var(--color-warning); border-color: rgba(251,191,36,0.4); }
.badge--danger { background-color: rgba(248,113,113,0.12); color: var(--color-danger); border-color: rgba(248,113,113,0.4); }

/* 6.4 Citations éditoriales (utilisées sur la page EEAT) */
.quote { position: relative; padding: var(--sp-6) var(--sp-7); font-family: var(--font-serif); font-style: italic; font-size: var(--fs-xl); line-height: var(--lh-snug); color: var(--color-text); border-left: 4px solid var(--color-accent); }
.quote::before { content: "“"; position: absolute; top: var(--sp-3); left: var(--sp-4); font-family: var(--font-serif); font-size: 4rem; line-height: 1; color: var(--color-accent); opacity: 0.4; pointer-events: none; }
.quote cite { display: block; margin-top: var(--sp-4); font-family: var(--font-sans); font-style: normal; font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: var(--tracking-wider); }
.quote cite::before { content: "— "; }

/* 6.5 Proof bar (UMIH, ORIAS, années d'expérience — affichée en haut de page) */
.proof-bar { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--sp-5) var(--sp-7); padding: var(--sp-4) var(--sp-5); background-color: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.proof-bar__item { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-sm); color: var(--color-text-muted); }
.proof-bar__item strong { color: var(--color-text); font-weight: var(--fw-semibold); }
.proof-bar__sep { width: 1px; height: 24px; background-color: var(--color-border); }
@media (max-width: 640px) { .proof-bar__sep { display: none; } }

/* 6.6 Silo entry card (les 3 portes d'entrée de la home aiguilleur) */
.silo-entry { position: relative; display: flex; flex-direction: column; gap: var(--sp-4); padding: var(--sp-7); background-color: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); overflow: hidden; transition: transform var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease), background-color var(--dur-base) var(--ease); }
.silo-entry::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(201,169,97,0) 0%, rgba(201,169,97,0.06) 100%); opacity: 0; transition: opacity var(--dur-base) var(--ease); pointer-events: none; }
.silo-entry:hover { transform: translateY(-6px); border-color: var(--color-accent); background-color: var(--color-surface-hi); }
.silo-entry:hover::after { opacity: 1; }
.silo-entry__icon { width: 56px; height: 56px; padding: var(--sp-3); color: var(--color-accent); background-color: rgba(201,169,97,0.1); border-radius: var(--radius-lg); }
.silo-entry__title { font-size: var(--fs-xl); font-weight: var(--fw-semibold); color: var(--color-text); }
.silo-entry__desc { font-size: var(--fs-base); color: var(--color-text-muted); line-height: var(--lh-relaxed); }
.silo-entry__cta { margin-top: auto; padding-top: var(--sp-4); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-accent); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.silo-entry__cta::after { content: " →"; transition: transform var(--dur-base) var(--ease); display: inline-block; }
.silo-entry:hover .silo-entry__cta::after { transform: translateX(4px); }

/* 6.7 Formulaires (base pour WPForms — surchargé par leur propre CSS mais on pose les fondations) */
.wpforms-field-label, label { display: block; margin-bottom: var(--sp-2); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text); }
.wpforms-field input[type="text"], .wpforms-field input[type="email"], .wpforms-field input[type="tel"], .wpforms-field textarea, .wpforms-field select, input[type="text"]:not(.btn), input[type="email"]:not(.btn), input[type="tel"]:not(.btn), textarea:not(.btn), select:not(.btn) { width: 100%; padding: var(--sp-3) var(--sp-4); font-family: var(--font-sans); font-size: var(--fs-base); color: var(--color-text); background-color: var(--color-bg-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); transition: border-color var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease); }
.wpforms-field input:focus, .wpforms-field textarea:focus, .wpforms-field select:focus, input:focus:not(.btn), textarea:focus:not(.btn), select:focus:not(.btn) { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(201,169,97,0.2); }
.wpforms-field input::placeholder, .wpforms-field textarea::placeholder { color: var(--color-text-dim); }
.wpforms-submit, .wpforms-submit-container button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: var(--sp-3) var(--sp-5); font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--color-accent-on); background-color: var(--color-accent); border: 2px solid var(--color-accent); border-radius: var(--radius-md); cursor: pointer; transition: background-color var(--dur-base) var(--ease); }
.wpforms-submit:hover, .wpforms-submit-container button:hover { background-color: var(--color-accent-strong); border-color: var(--color-accent-strong); }

/* 6.8 Breadcrumbs (fil d'Ariane, généré par Rank Math) */
.rank-math-breadcrumb { padding: var(--sp-3) 0; font-size: var(--fs-sm); color: var(--color-text-muted); }
.rank-math-breadcrumb a { color: var(--color-text-muted); text-decoration: none; }
.rank-math-breadcrumb a:hover { color: var(--color-accent); text-decoration: underline; }
.rank-math-breadcrumb .separator { margin-inline: var(--sp-2); color: var(--color-text-dim); }

/* 6.9 Tables (articles hub SGE — taux, chiffres) */
table { width: 100%; border-collapse: collapse; margin-block: var(--sp-5); font-size: var(--fs-sm); }
table th, table td { padding: var(--sp-3) var(--sp-4); text-align: left; border-bottom: 1px solid var(--color-border); }
table th { font-weight: var(--fw-semibold); color: var(--color-text); text-transform: uppercase; font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); background-color: var(--color-bg-alt); }
table tbody tr:hover { background-color: var(--color-surface); }

/* 6.10 Code inline & blocs (articles hub SGE) */
code { padding: 0.1em 0.4em; font-family: var(--font-mono); font-size: 0.9em; color: var(--color-accent); background-color: var(--color-bg-alt); border-radius: var(--radius-sm); }
pre { padding: var(--sp-4); overflow-x: auto; background-color: var(--color-bg-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); }
pre code { padding: 0; background: none; color: var(--color-text); }

/* 6.11 Article long-form (hub SGE, page expert) */
.prose { max-width: 72ch; font-size: var(--fs-base); line-height: var(--lh-relaxed); color: var(--color-text); }
.prose > * + * { margin-top: var(--sp-4); }
.prose h2 { margin-top: var(--sp-8); margin-bottom: var(--sp-3); font-size: var(--fs-xl); }
.prose h3 { margin-top: var(--sp-6); margin-bottom: var(--sp-2); font-size: var(--fs-lg); }
.prose a { color: var(--color-accent); text-decoration: underline; text-decoration-color: rgba(201,169,97,0.4); text-underline-offset: 0.2em; }
.prose a:hover { text-decoration-color: currentColor; }
.prose ul, .prose ol { padding-left: var(--sp-5); }
.prose li + li { margin-top: var(--sp-2); }
.prose blockquote { padding-left: var(--sp-5); border-left: 4px solid var(--color-accent); font-family: var(--font-serif); font-style: italic; color: var(--color-text-muted); }
.prose img { margin-block: var(--sp-5); border-radius: var(--radius-md); }

/* 6.12 Timeline (parcours Nathalie — page EEAT, rendu par le shortcode [expert_timeline]) */
.timeline { list-style: none; padding: 0; margin: 0; position: relative; }
.timeline::before { content: ""; position: absolute; top: 0; bottom: 0; left: 10px; width: 2px; background: linear-gradient(to bottom, var(--color-accent) 0%, var(--color-border) 100%); }
.timeline__item { position: relative; padding-left: var(--sp-7); padding-bottom: var(--sp-6); }
.timeline__item:last-child { padding-bottom: 0; }
.timeline__item::before { content: ""; position: absolute; top: 6px; left: 4px; width: 14px; height: 14px; background-color: var(--color-accent); border: 3px solid var(--color-bg); border-radius: var(--radius-full); box-shadow: 0 0 0 2px var(--color-accent); }
.timeline__year { display: inline-block; margin-bottom: var(--sp-2); padding: var(--sp-1) var(--sp-3); font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold); letter-spacing: var(--tracking-wider); color: var(--color-accent); background-color: rgba(201,169,97,0.1); border-radius: var(--radius-sm); }
.timeline__title { margin-bottom: var(--sp-2); font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--color-text); }
.timeline__desc { color: var(--color-text-muted); line-height: var(--lh-relaxed); }

/* 6.13 FAQ accordéon natif <details>/<summary> (zero JS, WCAG AA, rendu par [expert_faq]) */
.faq { display: flex; flex-direction: column; gap: var(--sp-3); }
.faq__item { background-color: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; transition: border-color var(--dur-base) var(--ease); }
.faq__item[open] { border-color: var(--color-accent); }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); padding: var(--sp-5) var(--sp-6); font-size: var(--fs-base); font-weight: var(--fw-semibold); color: var(--color-text); cursor: pointer; list-style: none; transition: background-color var(--dur-fast) var(--ease); }
.faq__item summary:hover { background-color: var(--color-surface-hi); }
.faq__item summary:focus-visible { outline: 2px solid var(--color-accent); outline-offset: -2px; }
.faq__q { flex: 1; }
.faq__item summary::after { content: "+"; flex-shrink: 0; width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-sans); font-size: var(--fs-xl); font-weight: var(--fw-regular); line-height: 1; color: var(--color-accent); background-color: rgba(201,169,97,0.1); border-radius: var(--radius-full); transition: transform var(--dur-base) var(--ease), background-color var(--dur-base) var(--ease); }
.faq__item[open] summary::after { content: "−"; transform: rotate(180deg); background-color: var(--color-accent); color: var(--color-accent-on); }
.faq__a { padding: 0 var(--sp-6) var(--sp-5); color: var(--color-text-muted); line-height: var(--lh-relaxed); }
.faq__a > * + * { margin-top: var(--sp-3); }

/* 6.14 Hero Expert (page EEAT — grid sur les wrappers de widgets Elementor) */
.hero-expert { position: relative; overflow: hidden; padding-block: clamp(4rem, 10vw, 8rem); min-height: clamp(520px, 80vh, 760px); display: flex; align-items: center; }
.hero-expert::before { content: ""; position: absolute; top: -20%; right: -10%; width: 60%; height: 120%; background: radial-gradient(ellipse at center, rgba(201,169,97,0.08) 0%, transparent 60%); pointer-events: none; z-index: 0; }
.hero-expert__grid { position: relative; z-index: 1; display: grid !important; grid-template-columns: 1.1fr 0.9fr; grid-template-areas: "title portrait" "baseline portrait" "chiffres portrait"; gap: var(--sp-5) var(--sp-8); align-items: center; width: 100%; max-width: var(--container-max); margin-inline: auto; padding-inline: var(--gutter); }
.hero-expert__title { grid-area: title; width: 100%; }
.hero-expert__title .elementor-heading-title { font-size: var(--fs-4xl); line-height: var(--lh-tight); letter-spacing: var(--tracking-tight); color: var(--color-text); margin: 0; font-weight: var(--fw-semibold); }
.hero-expert__baseline { grid-area: baseline; width: 100%; }
.hero-expert__baseline .hero-baseline { font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--color-text-muted); max-width: 52ch; margin: 0; }
.hero-expert__chiffres { grid-area: chiffres; justify-self: start; width: 100%; }
.hero-expert__media { grid-area: portrait; justify-self: end; width: 100%; display: flex; justify-content: flex-end; }
.hero-expert__media .hero-expert__portrait { width: 100%; max-width: 480px; aspect-ratio: 4/5; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
@media (max-width: 900px) { .hero-expert__grid { grid-template-columns: 1fr; grid-template-areas: "portrait" "title" "baseline" "chiffres"; gap: var(--sp-5); } .hero-expert__media { justify-self: center; justify-content: center; } .hero-expert__media .hero-expert__portrait { max-width: 320px; } .hero-expert__chiffres { justify-self: center; } }

/* 6.15 Footer */
.site-footer { padding-block: var(--sp-8) var(--sp-5); background-color: var(--color-bg-alt); border-top: 1px solid var(--color-border); color: var(--color-text-muted); font-size: var(--fs-sm); }
.site-footer a { color: var(--color-text-muted); }
.site-footer a:hover { color: var(--color-accent); }
.site-footer__bottom { padding-top: var(--sp-5); margin-top: var(--sp-6); border-top: 1px solid var(--color-border); text-align: center; color: var(--color-text-dim); font-size: var(--fs-xs); }
