/* ============================================================
   MA BULLE BIEN-ÊTRE — CSS Global
   Kadence — Apparence — Personnaliser — CSS additionnel
   Sections :
     1. Fonts (déclarées dans CSS additionnel)
     2. Variables globales
     3. Typographie & base site
     4. Boutons site
     5. Sections, cartes, liens, header, footer, formulaires
     6. Responsive site
     ── LMS Calme Durable ──────────────────────────────────────
     7. Switcher RAG
     8. Leçons standard & jalons
     9. Pages hub (Mon Suivi)
    10. Timeline jalons (Résultats & Jalons)
   ============================================================ */


/* ─────────────────────────────────────────────────────────────
   1. FONTS
   ───────────────────────────────────────────────────────────── */
/* Les @font-face (Cormorant Garamond + Nunito Sans) sont déclarés dans
   Kadence → CSS additionnel, chargé sur TOUTES les pages (y compris LMS). */


/* ─────────────────────────────────────────────────────────────
   2. VARIABLES GLOBALES
   Site (--mbb-*) + LMS Calme Durable (--sage, --cream…)
   ───────────────────────────────────────────────────────────── */
:root {
  /* — Site Ma Bulle Bien-Être — */
  --mbb-taupe:        #8b7355;
  --mbb-taupe-clair:  #c9a090;
  --mbb-sauge:        #8fa68c;
  --mbb-texte:        #2c2420;
  --mbb-texte-2:      #a8948a;
  --mbb-fond:         #faf8f5;
  --mbb-fond-alt:     #f0ebe3;
  --mbb-fond-carte:   #e4d8cc;
  --mbb-blanc:        #ffffff;
  --mbb-fonce:        #4a3830;
  --mbb-radius:       8px;
  --mbb-radius-btn:   50px;
  --mbb-shadow:       0 2px 12px rgba(139, 115, 85, 0.10);

  /* — LMS Calme Durable — */
  --sage:         #4A7C6F;
  --sage-light:   #e8f0ee;
  --sage-mid:     #c5d9d4;
  --cream:        #FAF8F5;
  --charcoal:     #2C2C2A;
  --muted:        #7A7A74;
  --red-bg:       #FDECEA;
  --red-accent:   #C0392B;
  --orange-bg:    #FFF3E0;
  --orange-accent:#D4691E;
  --green-bg:     #EBF5F0;
  --green-accent: #2E7D52;
  --border:       #E2DDD6;
  --radius:       12px;
}


/* ─────────────────────────────────────────────────────────────
   3. TYPOGRAPHIE & BASE SITE
   ───────────────────────────────────────────────────────────── */
body {
  color: var(--mbb-texte);
  background-color: var(--mbb-fond);
  line-height: 1.75;
}
h1, h2, h3, h4 { color: var(--mbb-taupe); line-height: 1.3; }
h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
p  { max-width: 70ch; }


/* ─────────────────────────────────────────────────────────────
   4. BOUTONS SITE
   ───────────────────────────────────────────────────────────── */
.wp-block-button__link,
.kb-btn,
a.button,
.wc-block-components-button,
.single_add_to_cart_button {
  background-color: var(--mbb-taupe) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: var(--mbb-radius-btn) !important;
  padding: 0.85em 2em !important;
  font-weight: 600 !important;
  letter-spacing: 0.03em !important;
  text-decoration: none !important;
  transition: background-color 0.25s ease, transform 0.15s ease !important;
  display: inline-block;
}
.wp-block-button__link:hover,
.kb-btn:hover,
a.button:hover {
  background-color: var(--mbb-taupe-clair) !important;
  transform: translateY(-2px) !important;
}
/* Bouton outline (secondaire) */
.wp-block-button.is-style-outline .wp-block-button__link {
  background-color: transparent !important;
  border: 2px solid var(--mbb-taupe) !important;
  color: var(--mbb-taupe) !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background-color: var(--mbb-taupe) !important;
  color: #ffffff !important;
}


/* ─────────────────────────────────────────────────────────────
   5. SECTIONS · CARTES · LIENS · HEADER · FOOTER · FORMULAIRES
   ───────────────────────────────────────────────────────────── */
.wp-block-group, .kb-section { border-radius: var(--mbb-radius); }

.kb-post-loop-wrap article,
.wc-block-grid__product {
  background-color: var(--mbb-fond-carte);
  border-radius: var(--mbb-radius);
  box-shadow: var(--mbb-shadow);
  transition: box-shadow 0.25s ease;
}
.kb-post-loop-wrap article:hover,
.wc-block-grid__product:hover { box-shadow: 0 6px 24px rgba(139, 115, 85, 0.18); }

a { color: var(--mbb-taupe); text-decoration: none; transition: color 0.2s ease; }
a:hover { color: var(--mbb-taupe-clair); }

.site-header { background-color: #ffffff; box-shadow: 0 1px 8px rgba(139, 115, 85, 0.08); }

.site-footer { background-color: var(--mbb-fond-alt); color: var(--mbb-texte-2); font-size: 0.9rem; }
.site-footer a { color: var(--mbb-taupe-clair); }

input[type="text"],
input[type="email"],
textarea,
select {
  border: 1.5px solid var(--mbb-fond-carte) !important;
  border-radius: var(--mbb-radius) !important;
  background-color: #ffffff !important;
  color: var(--mbb-texte) !important;
  padding: 0.6em 1em !important;
  transition: border-color 0.2s ease !important;
}
input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  border-color: var(--mbb-taupe) !important;
  outline: none !important;
}


/* ─────────────────────────────────────────────────────────────
   6. RESPONSIVE SITE
   ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  h1 { font-size: 1.7rem; }
  h2 { font-size: 1.4rem; }
  .wp-block-button__link, .kb-btn { width: 100%; text-align: center; }
}


/* ═════════════════════════════════════════════════════════════
   LMS CALME DURABLE
   Toutes les classes sont scopées (.cd-lesson-wrapper,
   .hub-wrapper, .rag-*…) — aucun conflit avec le site.
   ═════════════════════════════════════════════════════════════ */


/* ─────────────────────────────────────────────────────────────
   7. SWITCHER RAG (fixe, coin supérieur droit)
   ───────────────────────────────────────────────────────────── */
.rag-switcher {
  position: fixed; top: 20px; right: 20px; z-index: 9999;
  background: white; border: 1px solid var(--border);
  border-radius: 50px; padding: 6px 10px;
  display: flex; gap: 6px; align-items: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.rag-switcher span {
  font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--muted); margin-right: 4px;
}
.rag-btn {
  width: 28px; height: 28px; border-radius: 50%; border: none;
  cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.15s, box-shadow 0.15s; opacity: 0.5;
}
.rag-btn:hover { transform: scale(1.1); opacity: 1; }
.rag-btn.active { opacity: 1; box-shadow: 0 0 0 2px white, 0 0 0 4px currentColor; }
.rag-btn.rouge  { background: var(--red-bg);    color: var(--red-accent); }
.rag-btn.orange { background: var(--orange-bg); color: var(--orange-accent); }
.rag-btn.vert   { background: var(--green-bg);  color: var(--green-accent); }


/* ─────────────────────────────────────────────────────────────
   8. LEÇONS STANDARD & JALONS (.cd-lesson-wrapper)
   ───────────────────────────────────────────────────────────── */
.cd-lesson-wrapper {
  max-width: 780px; margin: 0 auto; padding: 40px 24px 80px;
  font-family: 'Nunito Sans', sans-serif; font-weight: 300;
  line-height: 1.7; color: var(--charcoal);
}

/* En-tête */
.lesson-header {
  margin-bottom: 36px; padding-bottom: 28px;
  border-bottom: 1px solid var(--border);
}
.lesson-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.meta-pill {
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 4px 12px;
  border-radius: 50px; background: var(--sage-light); color: var(--sage);
}
.rag-badge {
  font-size: 11px; font-weight: 500; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 4px 14px;
  border-radius: 50px; transition: all 0.3s ease;
}
.rag-badge.rouge  { background: var(--red-bg);    color: var(--red-accent); }
.rag-badge.orange { background: var(--orange-bg); color: var(--orange-accent); }
.rag-badge.vert   { background: var(--green-bg);  color: var(--green-accent); }
.lesson-objective {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 18px; color: var(--muted); font-weight: 300;
}

/* Bandeau RAG */
.rag-banner {
  border-radius: var(--radius); padding: 16px 20px; margin-bottom: 32px;
  display: flex; align-items: flex-start; gap: 14px; transition: all 0.3s ease;
}
.rag-banner.rouge  { background: var(--red-bg);    border-left: 4px solid var(--red-accent); }
.rag-banner.orange { background: var(--orange-bg); border-left: 4px solid var(--orange-accent); }
.rag-banner.vert   { background: var(--green-bg);  border-left: 4px solid var(--green-accent); }
.rag-banner .icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.rag-banner .rag-text { font-size: 14px; line-height: 1.6; }
.rag-banner .rag-text strong { display: block; font-weight: 500; margin-bottom: 2px; }
.rag-text.rouge  strong { color: var(--red-accent); }
.rag-text.orange strong { color: var(--orange-accent); }
.rag-text.vert   strong { color: var(--green-accent); }

/* Audio */
.audio-section {
  background: white; border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px; margin-bottom: 32px;
}
.audio-label {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--muted); margin-bottom: 12px; font-weight: 500;
}
.audio-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 400; color: var(--charcoal); margin-bottom: 16px;
}

/* Contenu principal */
.cd-content-section { margin-bottom: 32px; }
.section-label {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--sage); font-weight: 500; margin-bottom: 10px;
}
.cd-lesson-wrapper .content-text { font-size: 15px; line-height: 1.8; color: var(--charcoal); }

/* Colonnes */
.columns-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 36px; }
@media (max-width: 580px) { .columns-grid { grid-template-columns: 1fr; } }
.col-card { background: white; border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; }
.col-card h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px; font-weight: 500; color: var(--charcoal);
  margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.action-list { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.action-list li { font-size: 14px; display: flex; align-items: flex-start; gap: 10px; line-height: 1.5; }
.action-list li::before { content: "›"; color: var(--sage); font-size: 16px; font-weight: 500; flex-shrink: 0; margin-top: 1px; }
.rag-row { display: flex; align-items: flex-start; gap: 8px; font-size: 14px; line-height: 1.5; margin-bottom: 10px; }
.rag-row:last-child { margin-bottom: 0; }
.rag-row .dot { font-size: 16px; flex-shrink: 0; }

/* Check-in standard */
.checkin-section { margin-bottom: 36px; display: flex; flex-direction: column; gap: 12px; }
.checkin-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); font-weight: 500; }
.btn-checkin {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px; border-radius: var(--radius);
  font-family: 'Nunito Sans', sans-serif; font-size: 14px;
  font-weight: 400; text-decoration: none; cursor: pointer;
  border: none; transition: all 0.2s; align-self: flex-start;
}
.btn-primary { background: var(--sage); color: white; }
.btn-primary:hover { background: #3a6259; }
.btn-outline { background: transparent; color: var(--sage); border: 1.5px solid var(--sage); }
.btn-outline:hover { background: var(--sage-light); }
.checkin-note { font-size: 12px; color: var(--muted); font-style: italic; margin-top: -4px; }

/* Check-in jalon */
.jalon-checkin {
  background: var(--sage-light); border: 1px solid var(--sage-mid);
  border-radius: var(--radius); padding: 20px 22px;
  display: flex; align-items: center; gap: 16px; margin-bottom: 36px;
}
.jalon-icon { font-size: 28px; flex-shrink: 0; }
.jalon-text h4 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px; font-weight: 500; color: var(--sage); margin-bottom: 4px;
}
.jalon-text p { font-size: 13px; color: var(--muted); line-height: 1.5; margin-bottom: 12px; }

/* Critères de validation pilier */
.jalon-criteria {
  display: flex; flex-direction: column; gap: 10px;
  margin: 16px 0 14px;
}
.criteria-item {
  display: flex; align-items: flex-start; gap: 12px;
  background: white; border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
  cursor: pointer; transition: border-color 0.2s, background 0.2s;
  font-size: 14px; line-height: 1.5; color: var(--charcoal);
  user-select: none;
}
.criteria-item:hover { border-color: var(--sage-mid); }
.criteria-item.criteria-checked {
  background: var(--sage-light); border-color: var(--sage-mid);
}
.criteria-checkbox { display: none; }
.criteria-check {
  font-size: 17px; flex-shrink: 0; margin-top: 0px;
  line-height: 1; min-width: 20px; text-align: center;
}
.criteria-label { flex: 1; }
.criteria-note {
  font-size: 12px; color: var(--muted);
  font-style: italic; line-height: 1.6;
  padding: 10px 14px;
  background: var(--cream); border-radius: 8px;
  border-left: 3px solid var(--sage-mid);
}

/* Ce qui vient ensuite (bloc final jalon) */
.jalon-next-section {
  background: white; border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px 22px;
  border-left: 4px solid var(--sage);
}
.jalon-next-section .section-label { margin-bottom: 8px; }

/* Navigation leçon */
.lesson-nav {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 28px; border-top: 1px solid var(--border); gap: 12px; flex-wrap: wrap;
}
.nav-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-radius: var(--radius);
  background: white; border: 1px solid var(--border);
  font-family: 'Nunito Sans', sans-serif; font-size: 13px;
  color: var(--charcoal); cursor: pointer; text-decoration: none; transition: all 0.2s;
}
.nav-btn:hover { border-color: var(--sage); color: var(--sage); }
.mark-done {
  font-size: 13px; color: var(--muted);
  display: flex; align-items: center; gap: 6px;
  cursor: pointer; transition: color 0.2s;
  background: none; border: none; font-family: 'Nunito Sans', sans-serif;
}
.mark-done:hover { color: var(--green-accent); }
.mark-done .check-circle {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1.5px solid currentColor;
  display: flex; align-items: center; justify-content: center; font-size: 10px;
}


/* ─────────────────────────────────────────────────────────────
   9. PAGES HUB — MON SUIVI (.hub-wrapper)
   Semaine en cours · Check-in · Résultats & Jalons
   ───────────────────────────────────────────────────────────── */
.hub-wrapper {
  max-width: 780px; margin: 0 auto; padding: 12px 24px 24px;
  font-family: 'Nunito Sans', sans-serif; font-weight: 300;
  line-height: 1.7; color: var(--charcoal);
}

/* En-tête hub */
.hub-header { margin-bottom: 28px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.hub-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.hub-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  font-weight: 400; color: var(--charcoal);
  line-height: 1.25; margin: 0 0 6px;
}
.hub-subtitle {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic; font-size: 18px; color: var(--green-accent); font-weight: 300;
  max-width: none !important;
}
.hub-rag-badge {
  font-size: 11px; font-weight: 500; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 4px 14px; border-radius: 50px; display: none;
}
.hub-rag-badge.rouge  { background: var(--red-bg);    color: var(--red-accent); }
.hub-rag-badge.orange { background: var(--orange-bg); color: var(--orange-accent); }
.hub-rag-badge.vert   { background: var(--green-bg);  color: var(--green-accent); }
.hub-section { margin-bottom: 32px; }

/* ─────────────────────────────────────────────────────────────
   SKIP-TO-FORM (bouton "Aller au check-in" sous le sous-titre)
   ───────────────────────────────────────────────────────────── */
.hub-skip-to-form {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 0px;
  padding: 8px 18px;
  font-family: 'Nunito Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--sage, #4A7C6F);
  /*background: transparent;*/
  /*border: 1.5px solid var(--sage, #4A7C6F);*/
  background: var(--sage-light, #e8f0ee);
  border: 1.5px solid var(--sage, #4A7C6F);

  border-radius: 50px;
  text-decoration: none;
  transition: all 0.2s ease;
  letter-spacing: 0.02em;
}
.hub-skip-to-form:hover {
  /* background: var(--sage-light, #e8f0ee);*/
  /*color: var(--sage, #4A7C6F); */
  background: transparent;
  color: var(--sage, #4A7C6F);
  text-decoration: none;
}

/* Variante "encart titre du formulaire" — sans bouton */
.hub-checkin-section--titre {
  margin-bottom: 0 !important;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: none;
}
.hub-checkin-section--titre .hub-checkin-body p {
  margin-bottom: 0;
}

/* Petit décalage pour l'ancre (pour ne pas être collée au menu si sticky) */
#checkin {
  scroll-margin-top: 24px;
}

/* Variante du wrapper en bas (pour resserrer la note rassurante au formulaire) */
.hub-wrapper--bottom {
  margin-top: 24px;
}

/* Labels et blocs */
.section-label-hub {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--sage); font-weight: 500; margin-bottom: 4px;
}
.content-block { margin-bottom: 32px; }
.hub-wrapper .content-text { font-size: 15px; line-height: 1.8; color: var(--charcoal); margin-top: 10px; }

/* Étapes */
.steps-section { margin-bottom: 36px; }
.steps-list { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.step-item {
  display: flex; align-items: flex-start; gap: 14px;
  background: white; border: 1px solid var(--border); border-radius: 12px; padding: 14px 18px;
}
.step-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--sage-light); color: var(--sage);
  font-size: 12px; font-weight: 500; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.step-text { font-size: 14px; line-height: 1.6; padding-top: 3px; }
.step-text strong { font-weight: 500; }
.step-lost {
  background: var(--sage-light); border-radius: 12px; padding: 12px 18px;
  font-size: 13px; color: var(--sage); margin-top: 6px; text-align: center;
}
.step-lost strong { font-weight: 500; }

/* Cartes RAG mode */
.rag-mode-section { margin-bottom: 36px; }
.rag-mode-cards { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.rag-mode-card {
  border-radius: 12px; padding: 16px 18px;
  display: flex; align-items: flex-start; gap: 12px;
  border: 1px solid transparent;
  transition: opacity 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
.rag-mode-card.rouge  { background: var(--red-bg);    border-color: rgba(192,57,43,0.15); }
.rag-mode-card.orange { background: var(--orange-bg); border-color: rgba(212,105,30,0.15); }
.rag-mode-card.vert   { background: var(--green-bg);  border-color: rgba(46,125,82,0.15); }
.rag-mode-icon { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.rag-mode-body { font-size: 14px; line-height: 1.5; }
.rag-mode-body strong { display: block; font-weight: 500; margin-bottom: 2px; font-size: 13px; letter-spacing: 0.03em; }
.rag-mode-card.rouge  .rag-mode-body strong { color: var(--red-accent); }
.rag-mode-card.orange .rag-mode-body strong { color: var(--orange-accent); }
.rag-mode-card.vert   .rag-mode-body strong { color: var(--green-accent); }
.rag-mode-cond   { font-size: 12px; color: var(--muted); margin-bottom: 4px; font-style: italic; }
.rag-mode-action { font-size: 14px; }
.rag-mode-label-hint {
  font-size: 11px; font-style: italic; color: var(--muted);
  margin-left: 6px; font-weight: 300; text-transform: none; letter-spacing: 0;
}
.rag-doute { font-size: 12px; text-align: center; color: var(--muted); margin-top: 8px; font-style: italic; }
.rag-mode-section.has-rag .rag-mode-card        { opacity: 0.35; transform: scale(0.985); }
.rag-mode-section.has-rag .rag-mode-card.active { opacity: 1; transform: scale(1); box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.rag-mode-section.has-rag .rag-mode-card.rouge.active  { border-color: var(--red-accent); }
.rag-mode-section.has-rag .rag-mode-card.orange.active { border-color: var(--orange-accent); }
.rag-mode-section.has-rag .rag-mode-card.vert.active   { border-color: var(--green-accent); }


/* Toggle détail — cartes RAG (page 1-0 Semaine en cours) */
.rag-toggle-btn {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 10px; padding: 4px 10px;
  font-size: 12px; font-family: 'Nunito Sans', sans-serif;
  color: var(--muted); background: none;
  border: 1px solid var(--border);
  border-radius: 20px; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.rag-toggle-btn:hover { color: var(--charcoal); border-color: var(--charcoal); }
.rag-toggle-arrow { font-size: 10px; transition: transform 0.2s; display: inline-block; }
.rag-toggle-btn[aria-expanded="true"] .rag-toggle-arrow { transform: rotate(180deg); }
.rag-toggle-btn[aria-expanded="true"] { color: var(--sage); border-color: var(--sage); }
.rag-detail {
  margin-top: 12px; padding: 12px 14px;
  background: rgba(255,255,255,0.6);
  border-radius: 8px; border: 1px solid var(--border);
}
.rag-detail-objectif {
  font-size: 12px; font-weight: 600; color: var(--sage); margin-bottom: 6px;
}
.rag-detail-label {
  font-size: 13px; color: var(--charcoal); margin-bottom: 6px; line-height: 1.5;
}
.rag-detail-list {
  margin: 0 0 8px 0; padding-left: 18px;
  font-size: 13px; color: var(--charcoal); line-height: 1.8;
}
.rag-detail-list li { margin: 0; }
.rag-detail-win {
  font-size: 12px; font-weight: 500; margin-top: 8px; padding: 6px 10px; border-radius: 6px;
}
.rag-detail-win.rouge { background: var(--red-bg);   color: var(--red-accent); }
.rag-detail-win.vert  { background: var(--green-bg); color: var(--green-accent); }
/* Neutralise display:block sur les strong à l'intérieur des blocs détail */
.rag-detail-label strong { display: inline; color: inherit; font-weight: 600; }

/* Raccourcis */
.shortcuts-section { margin-bottom: 36px; }
.shortcuts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
@media (max-width: 520px) { .shortcuts-grid { grid-template-columns: 1fr; } }
.shortcut-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px; border-radius: 12px;
  background: white; border: 1px solid var(--border);
  text-decoration: none; color: var(--charcoal);
  font-size: 13px; font-family: 'Nunito Sans', sans-serif;
  font-weight: 400; transition: all 0.2s; line-height: 1.4;
}
.shortcut-btn:hover { border-color: var(--sage); color: var(--sage); background: var(--sage-light); }
.shortcut-icon { font-size: 18px; flex-shrink: 0; }
.shortcut-optional { font-size: 11px; color: var(--muted); display: block; font-style: italic; }

/* Bloc check-in hub */
.hub-checkin-section {
  background: var(--sage-light); border: 1px solid var(--sage-mid);
  border-radius: 12px; padding: 24px 22px; margin-bottom: 36px;
  display: flex; align-items: center; gap: 20px;
}
@media (max-width: 520px) { .hub-checkin-section { flex-direction: column; align-items: flex-start; } }
.hub-checkin-icon { font-size: 30px; flex-shrink: 0; }
.hub-checkin-body { flex: 1; }
.hub-checkin-body h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 500; color: var(--sage); margin-bottom: 4px;
}
.hub-checkin-body p { font-size: 13px; color: var(--muted); margin-bottom: 14px; }
.btn-hub-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: 12px;
  background: var(--sage); color: white;
  font-family: 'Nunito Sans', sans-serif; font-size: 14px;
  font-weight: 400; text-decoration: none; transition: background 0.2s; border: none; cursor: pointer;
}
.btn-hub-primary:hover { background: #3a6259; }

/* Bouton outline hub */
.btn-hub-outline {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 10px;
  background: transparent; color: var(--sage); border: 1.5px solid var(--sage-mid);
  font-family: 'Nunito Sans', sans-serif; font-size: 13px;
  font-weight: 400; text-decoration: none; transition: all 0.2s; cursor: pointer;
}
.btn-hub-outline:hover { background: white; border-color: var(--sage); }
.btn-hub-outline-done { background: white; }

/* SOS urgence */
.sos-section {
  background: white; border: 1px solid var(--border);
  border-radius: 12px; padding: 20px 22px; margin-bottom: 36px;
  border-left: 4px solid var(--red-accent);
}
.sos-steps { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.sos-step  { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.5; }
.sos-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--red-bg); color: var(--red-accent);
  font-size: 11px; font-weight: 500; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}

/* Rappel / Note */
.reminder-section {
  background: var(--cream); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 36px;
  display: flex; align-items: flex-start; gap: 12px;
}
.reminder-icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.reminder-text { font-size: 13px; color: var(--muted); font-style: italic; line-height: 1.6; margin: 0; }

/* Variante stackée (semaine en cours) */
.reminder-section.reminder-stack {
  flex-direction: column; gap: 14px; align-items: stretch;
}
.reminder-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: 21px; font-weight: 400; font-style: italic;
  color: var(--charcoal); line-height: 1.4; margin: 0;
}
.reminder-pills {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.reminder-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'Nunito Sans', sans-serif; font-size: 12px; font-weight: 400; font-style: normal;
  padding: 5px 13px; border-radius: 50px; white-space: nowrap;
}
.pill-green  { background: var(--green-bg);  color: var(--green-accent); border: 1px solid rgba(46,125,82,0.2); }
.pill-orange { background: var(--orange-bg); color: var(--orange-accent); border: 1px solid rgba(212,105,30,0.2); }
.pill-red    { background: var(--red-bg);    color: var(--red-accent);   border: 1px solid rgba(192,57,43,0.2); }

.reminder-section.centered { text-align: center; display: block; padding: 20px 22px; }

/* Footer liens hub */
.hub-footer-links {
  padding-top: 28px; border-top: 1px solid var(--border);
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: center;
}

/* ─────────────────────────────────────────────────────────────
   OVERRIDES LIFTERLMS / KADENCE
   Harmonisation visuelle avec la palette Calme Durable
   ───────────────────────────────────────────────────────────── */

/* Masquer le H1 titre injecté (remplacé par nos meta-pills) */
.single-lesson .entry-title,
.single-llms_quiz .entry-title {
  display: none !important;
}

/* Bouton favori (cœur) — harmonisation couleur */
.llms-lesson-like .llms-svg-icon { color: var(--sage) !important; }
.llms-lesson-liked .llms-svg-icon { color: var(--red-accent) !important; }

/* "Retourner à" — discret */
.llms-parent-course-link {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  color: var(--muted) !important;
  margin-bottom: 0 !important;
}
.llms-parent-course-link a {
  color: var(--sage) !important;
  text-decoration: none !important;
}
.llms-parent-course-link a:hover { text-decoration: underline !important; }

/* Bouton "Marquer comme terminé" — forme uniquement (couleur via Simple Branding) */
.llms-button-primary,
button.llms-field-button {
  border-radius: 12px !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  padding: 14px 32px !important;
  letter-spacing: 0.02em !important;
  box-shadow: none !important;
  border: none !important;
  transition: background 0.2s, opacity 0.2s !important;
}
.llms-button-primary:hover,
button.llms-field-button:hover {
  opacity: 0.88 !important;
  transform: none !important;
}

/* Espace au-dessus du bouton */
.llms-mark-complete,
.llms-mark-complete-wrapper,
.llms-lesson-complete-wrapper,
form.llms-mark-complete { margin-top: 16px !important; padding-top: 0 !important; }

/* Navigation bas de page (Retours au programme / Chapitre suivant) */
.llms-course-navigation {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  margin-top: 12px !important;
}
.llms-course-navigation .llms-lesson-preview {
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  transition: border-color 0.2s !important;
}
.llms-course-navigation .llms-lesson-preview:hover {
  border-color: var(--sage) !important;
}
.llms-course-navigation .llms-lesson-link {
  display: block !important;
  padding: 16px 18px !important;
  text-decoration: none !important;
  color: inherit !important;
}
/* Labels "RETOURS AU PROGRAMME" / "CHAPITRE SUIVANT" */
.llms-course-navigation .llms-pre-text,
.llms-course-navigation h6.llms-pre-text {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--muted) !important;
  display: block !important;
  margin-bottom: 6px !important;
}
/* Titre de la leçon dans la nav */
.llms-course-navigation .llms-lesson-title,
.llms-course-navigation h5.llms-lesson-title {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: var(--charcoal) !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}
.llms-course-navigation .llms-lesson-preview:hover .llms-lesson-title,
.llms-course-navigation .llms-lesson-preview:hover h5.llms-lesson-title {
  color: var(--sage) !important;
}
/* Supprimer le séparateur vertical central */
.llms-course-navigation .llms-course-nav + .llms-course-nav::before {
  display: none !important;
}
.footer-link {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--muted); text-decoration: none;
  padding: 6px 12px; border-radius: 50px;
  background: white; border: 1px solid var(--border); transition: all 0.2s;
}
.footer-link:hover { border-color: var(--sage); color: var(--sage); }

/* Grille 6 dimensions */
.dimensions-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 12px; }
@media (max-width: 480px) { .dimensions-grid { grid-template-columns: repeat(2, 1fr); } }
.dimension-item {
  display: flex; align-items: center; gap: 10px;
  background: white; border: 1px solid var(--border);
  border-radius: 12px; padding: 14px;
  font-size: 13px; color: var(--charcoal); font-weight: 400; line-height: 1.3;
}
.dimension-icon { font-size: 18px; flex-shrink: 0; }


/* ─────────────────────────────────────────────────────────────
   10. TIMELINE JALONS (page Mes résultats & jalons)
   ───────────────────────────────────────────────────────────── */
.jalon-timeline { position: relative; padding-left: 52px; margin-top: 14px; }
.timeline-line {
  position: absolute; left: 19px; top: 22px; bottom: 22px;
  width: 2px; background: var(--border); z-index: 0;
}
.jalon-item { position: relative; margin-bottom: 16px; }
.jalon-item:last-child { margin-bottom: 0; }

.jalon-dot {
  position: absolute; left: -52px; top: 14px;
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 500; letter-spacing: 0.03em;
  z-index: 1; flex-shrink: 0; font-family: 'Nunito Sans', sans-serif;
}
.dot-done       { background: var(--sage);     border: 2px solid var(--sage);         color: white; font-size: 14px; }
.dot-upcoming   { background: white;            border: 2px solid var(--border);       color: var(--muted); }
.dot-graduation { background: var(--green-bg);  border: 2px solid var(--green-accent); color: var(--green-accent); }

.jalon-card {
  background: white; border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px; transition: border-color 0.2s;
}
.jalon-card:hover    { border-color: var(--sage-mid); }
.jalon-card-done     { background: var(--sage-light); border-color: var(--sage-mid); }
.jalon-card-final    { background: var(--green-bg);   border-color: rgba(46,125,82,0.2); }

.jalon-card-header   { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.jalon-card-tag      { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); font-weight: 500; margin-bottom: 4px; }
.jalon-card-title    { font-family: 'Cormorant Garamond', serif; font-size: 19px; font-weight: 500; color: var(--charcoal); margin: 0; }

.jalon-status-badge  { font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.07em; padding: 3px 10px; border-radius: 50px; white-space: nowrap; flex-shrink: 0; }
.badge-done          { background: var(--sage);     color: white; }
.badge-upcoming      { background: var(--cream);    color: var(--muted);        border: 1px solid var(--border); }
.badge-graduation    { background: var(--green-bg); color: var(--green-accent); border: 1px solid rgba(46,125,82,0.3); }

.jalon-card-desc     { font-size: 13px; color: var(--muted); line-height: 1.6; margin-bottom: 14px; }
.jalon-card-desc em  { font-style: italic; color: var(--charcoal); }

@media (max-width: 480px) {
  .jalon-card-header  { flex-direction: column; }
  .jalon-status-badge { align-self: flex-start; }
}


/* ─────────────────────────────────────────────────────────────
   11. SIDEBAR — COURSE OUTLINE (barre latérale programmes)
   Cible : .wp-block-llms-course-syllabus
   ───────────────────────────────────────────────────────────── */

/* Wrapper global */
.wp-block-llms-course-syllabus .llms-syllabus-wrapper {
  font-family: 'Nunito Sans', sans-serif;
  font-weight: 300;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Titre de section (MON SUIVI, BIENVENUE & DIAGNOSTIC…) */
.wp-block-llms-course-syllabus .llms-section-title {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--sage) !important;
  margin: 8px 0 4px !important;
  padding: 0 !important;
  border: none !important;
}
.wp-block-llms-course-syllabus .llms-course-wrap:first-child .llms-section-title {
  margin-top: 0 !important;
}
/* Espacement entre sections — supprimer tout espace et liseré */
.wp-block-llms-course-syllabus .llms-course-wrap {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Chaque leçon */
.wp-block-llms-course-syllabus .llms-lesson-preview {
  background: white;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 4px;
  transition: border-color 0.2s ease;
}
.wp-block-llms-course-syllabus .llms-lesson-preview:hover {
  border-color: var(--sage-mid);
}

/* Leçon active (current) */
.wp-block-llms-course-syllabus .llms-lesson-preview.current-lesson {
  background: var(--sage-light);
  border-color: var(--sage-mid);
}

/* Leçon complétée */
.wp-block-llms-course-syllabus .llms-lesson-preview.is-complete {
  background: white;
  border-color: var(--border);
  opacity: 0.75;
}

/* Lien — padding minimal */
.wp-block-llms-course-syllabus .llms-lesson-link,
.wp-block-llms-course-syllabus .llms-lesson-link * {
  box-sizing: border-box !important;
}
.wp-block-llms-course-syllabus .llms-lesson-link {
  display: block !important;
  padding: 6px 10px !important;
  text-decoration: none !important;
  color: inherit !important;
  min-height: 0 !important;
}

/* Layout interne : titre à gauche, compteur + icône à droite sur une ligne */
.wp-block-llms-course-syllabus .course-information {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 6px !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
.wp-block-llms-course-syllabus .llms-main {
  flex: 1 !important;
  min-width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* Compteur et icône sur une seule ligne */
.wp-block-llms-course-syllabus .llms-extra {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 5px !important;
  flex-shrink: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
  width: auto !important;
}

/* Titre leçon — une seule ligne, tronqué si trop long */
.wp-block-llms-course-syllabus .llms-lesson-title {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--charcoal) !important;
  margin: 0 !important;
  line-height: 1.3 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.wp-block-llms-course-syllabus .current-lesson .llms-lesson-title {
  color: var(--sage) !important;
  font-weight: 500 !important;
}
.wp-block-llms-course-syllabus .is-complete .llms-lesson-title {
  color: var(--muted) !important;
}

/* Compteur "1 sur 3" */
.wp-block-llms-course-syllabus .llms-lesson-counter {
  font-size: 10px !important;
  color: var(--muted) !important;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

/* Icône check */
.wp-block-llms-course-syllabus .llms-lesson-complete .fa {
  font-size: 13px !important;
  color: var(--border) !important;
}
.wp-block-llms-course-syllabus .is-complete .llms-lesson-complete .fa {
  color: var(--sage) !important;
}
.wp-block-llms-course-syllabus .current-lesson .llms-lesson-complete .fa {
  color: var(--sage-mid) !important;
}

/* Supprimer les .clear superflus */
.wp-block-llms-course-syllabus .clear { display: none; }

/* Force suppression espace inter-sections — spécificité maximale */
#block-41 .llms-course-wrap,
.widget .llms-course-wrap,
.llms-syllabus-wrapper .llms-course-wrap {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
#block-41 .llms-syllabus-wrapper,
.widget .llms-syllabus-wrapper {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* ─────────────────────────────────────────────────────────────
   12. LIFTERLMS — Completion + bas de page
   ───────────────────────────────────────────────────────────── */

/* Réduction espace bas de page + liseré de fin */
.cd-lesson-wrapper {
  padding-bottom: 40px !important;
  border-bottom: 1px solid var(--border) !important;
  margin-bottom: 8px !important;
}

/* Wrapper centré */
.llms-lesson-button-wrapper {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 24px 0 4px !important;
  font-size: 0 !important; /* masque le texte brut "Chapitre terminé" */
  font-family: 'Nunito Sans', sans-serif !important;
}

/* Badge vert — UNIQUEMENT quand le chapitre est terminé
   (= quand llms-incomplete-lesson-form est présent dans le wrapper) */
.llms-lesson-button-wrapper:has(.llms-incomplete-lesson-form)::before {
  content: "✓  Chapitre terminé" !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--green-accent) !important;
  background: var(--green-bg) !important;
  border: 1.5px solid rgba(46, 125, 82, 0.25) !important;
  border-radius: 50px !important;
  padding: 10px 28px !important;
  display: inline-block !important;
  letter-spacing: 0.02em !important;
}

/* Bouton "Marquer comme terminé" (chapitre pas encore fait) */
.llms-lesson-button-wrapper:not(:has(.llms-incomplete-lesson-form)) .llms-button-action,
.llms-lesson-button-wrapper:not(:has(.llms-incomplete-lesson-form)) button[name="mark_complete"] {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: white !important;
  background: var(--sage) !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 12px 32px !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
  letter-spacing: 0.03em !important;
}
.llms-lesson-button-wrapper:not(:has(.llms-incomplete-lesson-form)) .llms-button-action:hover,
.llms-lesson-button-wrapper:not(:has(.llms-incomplete-lesson-form)) button[name="mark_complete"]:hover {
  background: #3a6259 !important;
}

/* Bouton "Marquer incomplet" — discret, souligné */
#llms_mark_incomplete,
.llms-incomplete-lesson-form .llms-button-secondary {
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--muted) !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 2px 0 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: color 0.2s ease, border-color 0.2s ease !important;
}
#llms_mark_incomplete:hover,
.llms-incomplete-lesson-form .llms-button-secondary:hover {
  color: var(--charcoal) !important;
  border-bottom-color: var(--charcoal) !important;
  background: transparent !important;
}

/* Nettoyage */
.llms-incomplete-lesson-form .llms-cols-last { display: contents !important; }
.llms-incomplete-lesson-form .clear { display: none !important; }}


/* ─────────────────────────────────────────────────────────────
   11. SIDEBAR — SECTIONS COLLAPSIBLES
   ───────────────────────────────────────────────────────────── */
.cd-toggle-arrow {
  font-size: 10px;
  color: var(--muted);
  transition: transform 0.25s ease;
  margin-left: auto;
  display: inline-block;
  flex-shrink: 0;
}
.llms-course-wrap .llms-section-title {
  display: flex !important;
  align-items: center !important;
  gap: 6px;
}
.llms-course-wrap.cd-collapsed .cd-toggle-arrow {
  transform: rotate(-90deg);
}
.cd-lessons-wrap {
  overflow: hidden;
  max-height: 2000px;
  transition: max-height 0.35s ease;
}
.llms-course-wrap.cd-collapsed .cd-lessons-wrap {
  max-height: 0 !important;
}
