
  <style>
  :root {
    --ink:       #111;
    --ink-2:     #2a2724;
    --muted:     #767676;
    --line:      rgba(0,0,0,.09);
    --paper:     #fff;
    --soft:      #f8f7f5;
    --blush:     #c4786a;
    --blush-lt:  #f7ece9;
    --blush-md:  #d9948a;
    --blush-pale:#fdf3f1;
    --rose-deep: #9e4f43;
    --serif:     'Cormorant Garamond', Georgia, serif;
    --sans:      'DM Sans', system-ui, sans-serif;
    --sh:        0 4px 20px rgba(0,0,0,.07);
  }
  *, *::before, *::after { box-sizing: border-box; }
  body { font-family: var(--sans); background: var(--soft); color: var(--ink); }
  a { color: inherit; }

  /* ── HERO ── */
  .s1-hero {
    background: var(--blush-pale);
    border-bottom: 1px solid rgba(196,120,106,.15);
    padding: 60px 0 52px;
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .s1-hero::before {
    content: '';
    position: absolute;
    width: 500px; height: 500px;
    border-radius: 50%;
    border: 1px solid rgba(196,120,106,.12);
    top: -200px; right: -100px;
    pointer-events: none;
  }
  .s1-hero::after {
    content: '';
    position: absolute;
    width: 300px; height: 300px;
    border-radius: 50%;
    border: 1px solid rgba(196,120,106,.08);
    bottom: -150px; left: -50px;
    pointer-events: none;
  }
  .s1-nav { font-family: var(--sans); font-size: .55rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--blush); margin-bottom: 16px; display: flex; align-items: center; justify-content: center; gap: 12px; }
  .s1-nav-sep { opacity: .4; }
  .s1-mois { font-family: var(--serif); font-size: clamp(.85rem, 1.5vw, 1rem); font-style: italic; color: var(--muted); margin-bottom: 8px; }
  .s1-title { font-family: var(--serif); font-size: clamp(2.2rem, 5.5vw, 4rem); font-weight: 300; color: var(--ink); line-height: 1.1; margin-bottom: 20px; letter-spacing: -.01em; }
  .s1-title em { font-style: italic; color: var(--blush); }
  .s1-sep { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 20px; }
  .s1-sep-line { width: 40px; height: 1px; background: var(--blush-md); opacity: .5; }
  .s1-sep-dot  { width: 5px; height: 5px; border-radius: 50%; background: var(--blush); }
  .s1-intro { font-family: var(--serif); font-size: clamp(1rem, 1.5vw, 1.15rem); font-style: italic; color: var(--muted); max-width: 60ch; margin: 0 auto 24px; line-height: 1.7; }
  .s1-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; }
  .s1-badge { display: inline-flex; align-items: center; gap: 5px; padding: 5px 14px; border-radius: 100px; font-family: var(--sans); font-size: .58rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; background: rgba(196,120,106,.1); color: var(--rose-deep); border: 1px solid rgba(196,120,106,.2); }

  /* ── LAYOUT ── */
  .s1-layout { display: grid; grid-template-columns: 1fr 300px; gap: 48px; padding: 48px 0 60px; align-items: start; }
  @media (max-width: 900px) { .s1-layout { grid-template-columns: 1fr; } }

  /* ── CONTENU ── */
  .s1-body { min-width: 0; }

  /* Image héro article */
  .s1-img-wrap { position: relative; margin-bottom: 36px; border-radius: 2px; overflow: hidden; }
  .s1-img-wrap img { width: 100%; display: block; }
  .s1-img-caption { font-family: var(--sans); font-size: .62rem; color: var(--muted); text-align: center; margin-top: 8px; font-style: italic; }

  /* Sections */
  .s1-section { margin-bottom: 36px; }
  .s1-section-kicker { font-family: var(--sans); font-size: .52rem; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--blush); margin-bottom: 10px; }
  .s1-section-title { font-family: var(--serif); font-size: clamp(1.4rem, 2.5vw, 1.9rem); font-weight: 400; color: var(--ink); margin-bottom: 16px; line-height: 1.2; }
  .s1-section-title::after { content: ''; display: block; width: 28px; height: 2px; background: var(--blush-md); margin-top: 10px; }
  .s1-p { font-family: Georgia, var(--serif); font-size: clamp(.92rem, 1.2vw, 1rem); line-height: 1.85; color: var(--ink-2); margin-bottom: 16px; }
  .s1-p:last-child { margin-bottom: 0; }

  /* Encart rose */
  .s1-encart { background: var(--blush-pale); border-left: 3px solid var(--blush-md); padding: 20px 22px; margin: 28px 0; border-radius: 0 4px 4px 0; }
  .s1-encart-title { font-family: var(--serif); font-size: 1.05rem; font-weight: 600; color: var(--ink); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
  .s1-encart p { font-family: Georgia, var(--serif); font-size: .92rem; line-height: 1.75; color: var(--ink-2); margin: 0; }

.s1-expert { background: #fff; border: 1px solid var(--ink); border-left: 4px solid var(--ink); padding: 28px 26px; margin: 32px 0; position: relative; }
.s1-expert::before { content: '"'; font-family: var(--serif); font-size: 6rem; line-height: .6; color: rgba(0,0,0,.06); position: absolute; top: 16px; left: 18px; }
.s1-expert-label { font-family: var(--sans); font-size: .5rem; font-weight: 700; letter-spacing: .24em; text-transform: uppercase; color: var(--blush); margin-bottom: 12px; }
.s1-expert-quote { font-family: var(--serif); font-size: clamp(1rem, 1.6vw, 1.2rem); font-style: italic; font-weight: 300; color: var(--ink-2); line-height: 1.65; margin-bottom: 14px; position: relative; }
.s1-expert-author { font-family: var(--sans); font-size: .65rem; color: var(--muted); }

  /* Témoignage */
  .s1-temoignage { background: var(--paper); border: 1px solid var(--line); padding: 24px; margin: 32px 0; position: relative; }
  .s1-temo-label { font-family: var(--sans); font-size: .5rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--blush); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
  .s1-temo-label::before { content: ''; width: 20px; height: 1px; background: var(--blush-md); }
  .s1-temo-text { font-family: var(--serif); font-size: clamp(.95rem, 1.3vw, 1.1rem); font-style: italic; color: var(--ink-2); line-height: 1.7; margin-bottom: 12px; }
  .s1-temo-author { font-family: var(--sans); font-size: .62rem; color: var(--muted); }
  .s1-temo-avatar { display: inline-flex; align-items: center; gap: 8px; }
  .s1-temo-initiales { width: 30px; height: 30px; border-radius: 50%; background: var(--blush-lt); display: inline-flex; align-items: center; justify-content: center; font-family: var(--sans); font-size: .62rem; font-weight: 600; color: var(--blush); }

  /* Check list */
  .s1-checklist { list-style: none; padding: 0; margin: 16px 0; }
  .s1-checklist li { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--line); font-family: Georgia, var(--serif); font-size: .92rem; color: var(--ink-2); line-height: 1.6; }
  .s1-checklist li:last-child { border-bottom: none; }
  .s1-checklist-dot { width: 18px; height: 18px; border-radius: 50%; background: var(--blush-lt); border: 1px solid var(--blush-md); flex-shrink: 0; margin-top: 2px; display: flex; align-items: center; justify-content: center; }
  .s1-checklist-dot i { font-size: .55rem; color: var(--blush); }

  /* Navigation semaines */
  .s1-nav-sem { display: flex; gap: 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin: 36px 0; }
  .s1-nav-sem a { flex: 1; display: flex; align-items: center; gap: 10px; padding: 16px 14px; text-decoration: none; color: var(--muted); font-family: var(--sans); font-size: .65rem; font-weight: 500; transition: color .15s, background .15s; }
  .s1-nav-sem a:hover { color: var(--ink); background: var(--blush-pale); }
  .s1-nav-sem a:first-child { border-right: 1px solid var(--line); }
  .s1-nav-sem-label { font-family: var(--sans); font-size: .5rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--blush); display: block; margin-bottom: 3px; }
  .s1-nav-sem-title { font-family: var(--serif); font-size: .95rem; font-weight: 400; color: var(--ink); }

  /* Voir aussi */
  .s1-voir-aussi { background: var(--blush-pale); border: 1px solid rgba(196,120,106,.15); padding: 20px; margin: 28px 0; }
  .s1-voir-aussi-title { font-family: var(--sans); font-size: .52rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--blush); margin-bottom: 12px; }
  .s1-voir-aussi ul { list-style: none; padding: 0; margin: 0; }
  .s1-voir-aussi li { padding: 6px 0; border-bottom: 1px solid rgba(196,120,106,.1); }
  .s1-voir-aussi li:last-child { border-bottom: none; }
  .s1-voir-aussi a { font-family: Georgia, var(--serif); font-size: .9rem; color: var(--ink-2); text-decoration: none; display: flex; align-items: center; gap: 8px; transition: color .15s; }
  .s1-voir-aussi a:hover { color: var(--blush); }
  .s1-voir-aussi a i { font-size: .6rem; color: var(--blush); flex-shrink: 0; }

  /* SIDEBAR */
  .s1-sidebar { position: sticky; top: 80px; }
  @media (max-width: 900px) { .s1-sidebar { position: static; border-top: 1px solid var(--line); padding-top: 28px; margin-top: 8px; } }

  .s1-sidebar-widget { background: var(--paper); border: 1px solid var(--line); padding: 20px; margin-bottom: 16px; }
  .s1-sidebar-widget-title { font-family: var(--sans); font-size: .52rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--ink); padding-bottom: 10px; border-bottom: 2px solid var(--ink); margin-bottom: 14px; }

  /* Chiffres clés sidebar */
  .s1-chiffre { text-align: center; padding: 12px 0; border-bottom: 1px solid var(--line); }
  .s1-chiffre:last-child { border-bottom: none; }
  .s1-chiffre-n { font-family: var(--serif); font-size: 2.2rem; font-weight: 300; color: var(--blush); line-height: 1; }
  .s1-chiffre-l { font-family: var(--sans); font-size: .58rem; color: var(--muted); margin-top: 3px; letter-spacing: .06em; text-transform: uppercase; }

  /* Semaines sidebar */
  .s1-sem-mini { display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; }
  .s1-sem-cell { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-family: var(--sans); font-size: .62rem; font-weight: 500; border: 1px solid var(--line); color: var(--muted); text-decoration: none; transition: all .15s; }
  .s1-sem-cell:hover { border-color: var(--blush-md); color: var(--blush); }
  .s1-sem-cell.actif { background: var(--blush); color: #fff; border-color: var(--blush); }

  /* BREADCRUMB */
  .bcrumb { font-family: var(--sans); font-size: .62rem; font-weight: 500; letter-spacing: .07em; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 20px 0 0; }
  .bcrumb a { color: var(--muted); text-decoration: none; transition: color .14s; }
  .bcrumb a:hover { color: var(--blush); }
  .bcrumb-sep { opacity: .3; }
