/* =================================================================
   CHRISTOPHE LLAMAS COACHING — Design system
   Charte réelle de la marque : rouge #BE1622, blanc, noir.
   Typographie sans-serif système (Helvetica / Arial), logo noir.
   Titre d'accueil en rouge italique. Toutes les couleurs en variables.
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Palette — rouge de marque + noir + blanc */
  --ink:#1A1A1A;          /* noir de marque — texte, logo, UI sombre */
  --ink-2:#3A3A3A;        /* gris très foncé secondaire */
  --bone:#F4F4F5;         /* gris très clair — surfaces douces */
  --bone-2:#E9E9EB;       /* gris clair — chips, sous-nav */
  --paper:#FFFFFF;        /* blanc — cartes, fond */
  --flame:#BE1622;        /* ROUGE de marque — accent principal */
  --flame-2:#9C121C;      /* rouge foncé (hover) */
  --ember:#D81E2B;        /* rouge clair secondaire (dégradés/accents) */
  --aqua:#A8141F;         /* rouge profond (remplace l'ancien accent froid) */
  --aqua-2:#BE1622;       /* rouge */
  --brass:#A8141F;        /* rouge profond (distinctions / palmarès) */
  --stone:#6B6B6B;        /* gris — texte secondaire */
  --line:rgba(0,0,0,.12);
  --line-soft:rgba(0,0,0,.07);

  /* Sémantique */
  --bg:var(--paper);
  --fg:var(--ink);
  --muted:var(--stone);
  --accent:var(--flame);

  /* Type — sans-serif système (vraie typo du site) */
  --display:'Helvetica Neue',Helvetica,Arial,'Trebuchet MS',sans-serif;
  --sans:'Helvetica Neue',Helvetica,Arial,sans-serif;

  /* Échelle fluide */
  --step--1:clamp(.82rem,.78rem + .2vw,.92rem);
  --step-0:clamp(1rem,.95rem + .25vw,1.12rem);
  --step-1:clamp(1.2rem,1.1rem + .5vw,1.45rem);
  --step-2:clamp(1.5rem,1.3rem + 1vw,2rem);
  --step-3:clamp(2rem,1.6rem + 2vw,3.1rem);
  --step-4:clamp(2.7rem,2rem + 3.4vw,4.6rem);
  --step-5:clamp(3.4rem,2.2rem + 5.6vw,6.8rem);

  /* Espace / forme */
  --container:1200px;
  --container-wide:1360px;
  --gutter:clamp(20px,5vw,64px);
  --radius:4px;
  --radius-lg:14px;
  --shadow:0 1px 2px rgba(0,0,0,.05),0 12px 30px -14px rgba(0,0,0,.16);
  --shadow-lg:0 28px 64px -30px rgba(0,0,0,.35);
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--sans);
  font-size:var(--step-0);
  line-height:1.62;
  color:var(--fg);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none;padding:0}
input,textarea,select{font:inherit}
:focus-visible{outline:2.5px solid var(--flame);outline-offset:3px;border-radius:2px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container.wide{max-width:var(--container-wide)}
.container.narrow{max-width:820px}
.section{padding-block:clamp(36px,4.5vw,72px)}
.section.tight{padding-block:clamp(40px,5vw,72px)}
.section--ink{background:var(--ink);color:#fff}
.section--ink .muted{color:rgba(255,255,255,.62)}
.section--ink p{color:rgba(255,255,255,.82)}
.section--paper{background:var(--paper)}

/* ---------- Typo helpers ---------- */
.display{font-family:var(--display);font-weight:700;line-height:1;letter-spacing:-.015em}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.06;letter-spacing:-.01em}
.h-xl{font-size:var(--step-5)}
.h-lg{font-size:var(--step-4)}
.h-md{font-size:var(--step-3)}
.h-sm{font-size:var(--step-2)}
p{max-width:68ch}
.lead{font-size:var(--step-1);line-height:1.5;color:var(--ink-2)}
.muted{color:var(--muted)}
.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--flame);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{display:none}
.eyebrow.aqua{color:var(--aqua-2)}.eyebrow.aqua::before{background:var(--aqua-2)}
.eyebrow.brass{color:var(--brass)}.eyebrow.brass::before{background:var(--brass)}
.eyebrow.center{justify-content:center}
.eyebrow.no-rule::before{display:none}
.serif-em{font-style:italic;font-weight:600}
.underline-flame{
  background:linear-gradient(transparent 62%,rgba(190,22,34,.22) 0);
  padding:0 .05em;
}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--flame);
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  padding:.92em 1.5em;border-radius:var(--radius);
  font-family:var(--sans);font-weight:700;font-size:.96rem;letter-spacing:.01em;
  background:var(--b);color:#fff;border:1.5px solid var(--b);
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),color .25s var(--ease);
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em}
.btn:hover{background:var(--flame-2);border-color:var(--flame-2);transform:translateY(-2px);box-shadow:0 14px 26px -12px rgba(190,22,34,.55)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{background:var(--ink);border-color:var(--ink);color:#fff;box-shadow:none}
.btn--on-ink{background:var(--flame);border-color:var(--flame)}
.btn--ghost-on-ink{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn--ghost-on-ink:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--lg{padding:1.05em 1.9em;font-size:1.02rem}
.btn--block{display:flex;width:100%}
.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;font-weight:700;color:var(--ink);
  border-bottom:2px solid var(--flame);padding-bottom:2px;transition:gap .25s var(--ease),color .2s
}
.link-arrow:hover{gap:.85em;color:var(--flame)}
.link-arrow svg{width:.95em;height:.95em;transition:transform .25s var(--ease)}
.link-arrow:hover svg{transform:translateX(3px)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:200;
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:saturate(1.2) blur(14px);
  border-bottom:1px solid var(--line-soft);
  transition:background .3s,box-shadow .3s,border-color .3s;
}
.site-header.scrolled{background:color-mix(in srgb,var(--paper) 97%,transparent);box-shadow:0 8px 26px -20px rgba(0,0,0,.4)}
.nav{display:flex;align-items:center;gap:1.4rem;height:74px}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0;margin-right:auto}
.brand img{height:44px;width:auto}
.brand .brand-name{font-family:var(--display);font-weight:700;font-size:1.02rem;line-height:1;letter-spacing:-.01em}
.brand .brand-name small{display:block;font-family:var(--sans);font-weight:700;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--flame);margin-top:.3em}
.nav-links{display:flex;align-items:center;gap:.2rem}
.nav-links > li{position:relative}
.nav-links a,.nav-links .nav-trigger{
  display:inline-flex;align-items:center;gap:.35em;padding:.6em .8em;border-radius:var(--radius);
  font-weight:600;font-size:.92rem;color:var(--ink);transition:color .2s,background .2s;white-space:nowrap;
}
.nav-links a:hover,.nav-links .nav-trigger:hover{color:var(--flame)}
.nav-links a.is-active{color:var(--flame)}
.nav-links a.is-active::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.35em;height:2px;background:var(--flame)}
.nav-trigger svg{width:.7em;height:.7em;transition:transform .25s}
.has-drop:hover .nav-trigger svg,.has-drop:focus-within .nav-trigger svg{transform:rotate(180deg)}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:248px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.22s var(--ease);
}
.has-drop:hover .dropdown,.has-drop:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:.62em .8em;border-radius:8px;font-size:.9rem}
.dropdown a:hover{background:var(--bone);color:var(--flame)}
.nav-cta{margin-left:.6rem}
.nav-toggle{display:none;width:46px;height:46px;border-radius:10px;border:1px solid var(--line);align-items:center;justify-content:center}
.nav-toggle span{position:relative;width:20px;height:2px;background:var(--ink);transition:.25s}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:.25s}
.nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
body.menu-open .nav-toggle span{background:transparent}
body.menu-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
body.menu-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero (accueil) — fond blanc, titre rouge italique ---------- */
.hero{position:relative;background:var(--paper);color:var(--ink);overflow:hidden;isolation:isolate}
.hero::after{ /* halo rouge très subtil */
  content:"";position:absolute;z-index:-1;width:55vw;height:55vw;right:-14vw;top:-20vw;border-radius:50%;
  background:radial-gradient(circle,rgba(190,22,34,.10),transparent 68%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center;
  padding-block:clamp(40px,5.5vw,84px)}
.hero .eyebrow{color:var(--flame)}.hero .eyebrow::before{background:var(--flame)}
.hero h1{font-size:clamp(2rem,1.5rem + 2.4vw,3.4rem);margin:.32em 0 .5em;color:var(--flame);font-style:italic}
.hero .lead{color:var(--ink-2);max-width:46ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero-figure{position:relative}
.hero-figure img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/5}
.hero-badge{
  position:absolute;left:-18px;bottom:26px;background:var(--flame);color:#fff;border-radius:var(--radius-lg);
  padding:1rem 1.2rem;box-shadow:var(--shadow-lg);max-width:240px;transform:rotate(-2deg)
}
.hero-badge .big{font-family:var(--display);font-weight:700;font-size:1.7rem;line-height:1;display:block}
.hero-badge .small{font-size:.78rem;font-weight:600;letter-spacing:.04em;opacity:.95;margin-top:.3em}

/* Bandeau de stats sous le hero */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.stat-strip .stat{padding:clamp(18px,3vw,30px) var(--gutter);border-right:1px solid var(--line)}
.stat-strip .stat:last-child{border-right:none}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,1.2rem+2.4vw,3.1rem);line-height:1;color:var(--flame)}
.stat .lbl{display:block;margin-top:.5em;font-size:.82rem;letter-spacing:.04em;color:var(--muted);max-width:22ch}

/* ---------- Generic section header ---------- */
.section-head{max-width:760px;margin-bottom:clamp(32px,5vw,64px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:var(--step-3);margin-top:.28em}
.section-head p{margin-top:1rem;color:var(--muted)}
.section-head.center p{margin-inline:auto}
.section-head--mini{margin-bottom:clamp(18px,2.6vw,30px)}

/* ---------- Intro letter (accueil) ---------- */
.letter{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,64px);align-items:start}
.letter-figure{position:sticky;top:96px}
.letter-figure img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%}
.letter-figure figcaption{margin-top:.9rem;font-size:.84rem;color:var(--muted)}
.letter-body > * + *{margin-top:1.1rem}
.letter-body .lead{margin-bottom:.4rem}
.letter-body .dropcap::first-letter{
  font-family:var(--display);font-weight:700;float:left;font-size:3.4em;line-height:.74;
  padding:.06em .14em 0 0;color:var(--flame)
}
.signature{font-style:italic;font-weight:600;font-size:1.5rem;color:var(--ink);margin-top:1.4rem}
.wiki-link{font-size:.92rem}

/* ---------- Method (3 piliers + macrocycles) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem 1.5rem;position:relative;overflow:hidden}
.pillar .pic{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--flame);letter-spacing:.04em}
.pillar h3{font-size:1.3rem;margin:.6rem 0 .5rem}
.pillar p{font-size:.96rem;color:var(--muted)}
.pillar::after{content:"";position:absolute;inset:auto -30% -40% auto;width:140px;height:140px;border-radius:50%;background:rgba(190,22,34,.06)}

.cycle-list{counter-reset:c;display:grid;gap:.4rem}
.cycle-list li{display:flex;gap:1rem;align-items:baseline;padding:1rem 0;border-bottom:1px solid var(--line)}
.cycle-list li::before{counter-increment:c;content:counter(c,decimal-leading-zero);font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--brass);min-width:1.6em}
.cycle-list strong{font-weight:700}

/* ---------- Pricing packs ---------- */
.packs{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.5vw,20px);align-items:stretch}
.pack{
  display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:1.7rem 1.5rem;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s
}
.pack:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.pack--featured{background:var(--flame);color:#fff;border-color:var(--flame)}
.pack--featured .pack-price .amount{color:#fff}
.pack--featured .pack-price .per,.pack--featured .pack-price .sub{color:rgba(255,255,255,.82)}
.pack--featured .pack-feat li{color:rgba(255,255,255,.92)}
.pack--featured .pack-feat li::before{color:#fff}
.pack--featured .pack-ideal{background:rgba(255,255,255,.14);color:rgba(255,255,255,.92)}
.pack--featured .pack-ideal b{color:#fff}
.pack-flag{position:absolute;top:-12px;left:1.5rem;background:var(--ink);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.4em .8em;border-radius:40px}
.pack-rank{font-family:var(--display);font-weight:700;font-size:.92rem;color:var(--flame);letter-spacing:.06em}
.pack--featured .pack-rank{color:rgba(255,255,255,.9)}
.pack h3{font-size:1.32rem;margin:.25rem 0 .1rem;letter-spacing:-.01em}
.pack-tag{font-size:.86rem;color:var(--muted);min-height:2.4em}
.pack--featured .pack-tag{color:rgba(255,255,255,.85)}
.pack-price{margin:1rem 0;display:flex;align-items:baseline;gap:.35em;flex-wrap:wrap}
.pack-price .amount{font-family:var(--display);font-weight:700;font-size:2.2rem;line-height:1;color:var(--ink)}
.pack-price .per{font-size:.86rem;color:var(--muted);font-weight:600}
.pack-price .sub{flex-basis:100%;font-size:.8rem;color:var(--muted)}
.pack-feat{display:grid;gap:.55rem;margin:.4rem 0 1.3rem;font-size:.92rem}
.pack-feat li{position:relative;padding-left:1.5em;color:var(--ink)}
.pack-feat li::before{content:"›";position:absolute;left:0;top:-.05em;color:var(--flame);font-weight:700;font-size:1.15em}
.pack-ideal{margin-top:auto;background:var(--bone);border-radius:10px;padding:.85rem 1rem;font-size:.82rem;color:var(--ink-2);line-height:1.45}
.pack-ideal b{color:var(--flame)}

.principles{display:flex;flex-wrap:wrap;gap:.6rem}
.principle-chip{background:var(--bone-2);border-radius:40px;padding:.55em 1.1em;font-weight:700;font-size:.86rem;letter-spacing:.04em}
.principle-chip span{color:var(--flame)}

/* ---------- Feature list (coaching à distance) ---------- */
.feature-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
.feature-list{display:grid;gap:1.1rem}
.feature-list li{display:flex;gap:1rem}
.feature-list .ic{flex-shrink:0;width:42px;height:42px;border-radius:11px;background:rgba(190,22,34,.12);color:var(--flame);display:flex;align-items:center;justify-content:center}
.feature-list .ic svg{width:20px;height:20px}
.feature-list h4{font-family:var(--sans);font-weight:700;font-size:1.02rem;margin-bottom:.15rem}
.feature-list p{font-size:.92rem;color:var(--muted)}
.tech-logos{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.tech-logos span{font-size:.8rem;font-weight:600;color:var(--ink-2);background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:.4em .9em}

/* ---------- Testimonials ---------- */
.tmt-grid{columns:3;column-gap:clamp(16px,2vw,24px)}
.tmt{
  break-inside:avoid;margin-bottom:clamp(16px,2vw,24px);background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem 1.45rem;
}
.tmt .quote-mark{font-family:var(--display);font-weight:700;font-size:2.4rem;line-height:.4;color:var(--flame);display:block;height:.5em}
.tmt p{font-size:.95rem;color:var(--ink-2);max-width:none}
.tmt .who{display:flex;align-items:center;gap:.7rem;margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--line-soft)}
.tmt .avatar{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;flex-shrink:0}
.tmt .name{font-weight:700;font-size:.92rem;line-height:1.2}
.tmt .date{font-size:.78rem;color:var(--muted)}
.tmt .name a{border-bottom:1px solid var(--line)}
.tmt-collapsed{max-height:none}
/* Avis : repli avec dégradé + bouton « voir tous les avis » */
.reviews-collapse{position:relative;overflow:hidden;max-height:1000px}
.reviews-collapse.is-open{max-height:none}
.reviews-collapse::after{content:"";position:absolute;left:0;right:0;bottom:0;height:260px;background:linear-gradient(rgba(255,255,255,0),var(--paper));pointer-events:none}
.reviews-collapse.is-open::after{display:none}
.reviews-more{text-align:center;margin-top:1.6rem}
[hidden]{display:none !important}

/* Bloc avis Google + lien */
.review-cta{
  display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;justify-content:space-between;
  background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2.4rem);
}
.review-cta .stars{color:var(--flame);font-size:1.4rem;letter-spacing:.1em}

/* Accueil — aperçus « Avis » & « Résultats » */
.center-actions{text-align:center;margin-top:clamp(28px,4vw,46px)}
.center-wrap{display:flex;justify-content:center}
.google-rating{
  display:inline-flex;align-items:center;gap:.55rem;flex-wrap:wrap;justify-content:center;
  background:var(--paper);border:1px solid var(--line);border-radius:40px;
  padding:.55rem 1.2rem;margin-bottom:2rem;font-weight:700;font-size:.95rem;color:var(--ink);
  transition:border-color .2s,box-shadow .2s
}
.google-rating:hover{border-color:var(--ink);box-shadow:var(--shadow)}
.google-rating .gr-num{font-family:var(--display);font-size:1.18rem;line-height:1}
.google-rating .gr-stars{color:#F4B400;letter-spacing:.05em;font-size:1.05rem}
.google-rating .gr-meta{color:var(--muted);font-weight:600;font-size:.86rem}
.home-tmt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.home-tmt-grid .tmt{margin-bottom:0}
.home-tmt-grid .tmt p{display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
@media (max-width:1080px){.home-tmt-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.home-tmt-grid{grid-template-columns:1fr}}

/* ---------- Comment form ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.4rem)}
.form-row{display:grid;gap:1.1rem}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field label{display:block;font-weight:700;font-size:.88rem;margin-bottom:.4rem}
.field .req{color:var(--flame)}
.field input,.field textarea{
  width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:10px;background:var(--bone);
  transition:border-color .2s,background .2s;color:var(--ink)
}
.field input:focus,.field textarea:focus{border-color:var(--flame);background:var(--paper);outline:none}
.field .hint{font-size:.78rem;color:var(--muted);margin-top:.35rem}
.captcha-box{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.captcha-box img{border:1px solid var(--line);border-radius:8px}

/* ---------- Results ---------- */
.result-toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;align-items:center}
.chip{
  border:1.5px solid var(--line);background:var(--paper);border-radius:40px;padding:.5em 1.05em;
  font-weight:700;font-size:.85rem;color:var(--ink-2);transition:.2s var(--ease)
}
.chip:hover{border-color:var(--ink)}
.chip.is-active{background:var(--flame);color:#fff;border-color:var(--flame)}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.result-card{
  display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)
}
.result-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.result-card .ph{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--bone-2)}
.result-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.result-card:hover .ph img{transform:scale(1.04)}
.result-card .date-pill{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.04em;padding:.4em .7em;border-radius:30px}
.result-card .rc-body{padding:1.3rem 1.35rem 1.5rem;display:flex;flex-direction:column;flex:1}
.result-card h3{font-size:1.12rem;line-height:1.18;margin-bottom:.6rem}
.result-card .rc-text{font-size:.9rem;color:var(--muted);max-width:none}
.result-card .rc-text.clamp{display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.rc-toggle{margin-top:.9rem;align-self:flex-start;font-weight:700;font-size:.85rem;color:var(--flame);border-bottom:1.5px solid currentColor;padding-bottom:1px}
.year-tag{grid-column:1/-1;display:flex;align-items:center;gap:1rem;margin-top:1rem}
.year-tag h3{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--ink)}
.year-tag::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- Books ---------- */
.books{display:grid;gap:clamp(28px,5vw,64px)}
.book{display:grid;grid-template-columns:300px 1fr;gap:clamp(24px,4vw,52px);align-items:center}
.book:nth-child(even){grid-template-columns:1fr 300px}
.book:nth-child(even) .book-cover{order:2}
.book-cover{position:relative}
.book-cover img{width:100%;border-radius:8px;box-shadow:var(--shadow-lg)}
.book-cover::before{content:"";position:absolute;inset:auto -16px -16px 16px;background:rgba(190,22,34,.10);border-radius:12px;z-index:-1}
.book-body h3{font-size:var(--step-2);margin-bottom:.4rem}
.book-body .lang-pill{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--flame);background:rgba(190,22,34,.10);padding:.35em .8em;border-radius:30px;margin-bottom:.8rem}
.book-body p{color:var(--ink-2)}
.book-body .meta-list{font-size:.84rem;color:var(--muted);margin:1rem 0;line-height:1.9}
.book-body .actions{margin-top:1.3rem}

/* ---------- Timeline (palmarès / news) ---------- */
.timeline{position:relative;display:grid;gap:0;margin-top:1rem}
.timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--flame),#6E0E15)}
.tl-item{position:relative;padding:0 0 2.4rem 2.6rem}
.tl-item::before{content:"";position:absolute;left:0;top:6px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--flame)}
.tl-item .year{font-family:var(--display);font-weight:700;font-size:1.6rem;color:var(--ink);line-height:1;margin-bottom:.6rem}
.tl-item h3{font-family:var(--sans);font-weight:700;font-size:1.05rem;margin-bottom:.3rem}
.tl-item p{font-size:.95rem;color:var(--ink-2)}
.tl-item .hl{color:var(--flame);font-weight:700}
.tl-item .medal{display:inline-flex;align-items:center;gap:.4em;font-weight:700;color:var(--brass);font-size:.92rem}

/* News cards */
.news-list{display:grid;gap:clamp(20px,3vw,34px)}
.news-year{font-family:var(--display);font-weight:700;font-size:var(--step-2);color:var(--ink);margin:2.4rem 0 .4rem;display:flex;align-items:center;gap:1rem}
.news-year::after{content:"";flex:1;height:2px;background:var(--line)}
.news-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.news-card .nc-pad{padding:clamp(1.3rem,2.5vw,2rem)}
.news-card .nc-date{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--flame)}
.news-card h3{font-size:1.3rem;margin:.5rem 0 .8rem;line-height:1.2}
.news-card p{color:var(--ink-2);font-size:.96rem}
.video-frame{position:relative;aspect-ratio:16/9;background:var(--ink)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.press-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-top:1.2rem}
.press-grid a{display:block;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--paper);transition:transform .3s var(--ease),box-shadow .3s}
.press-grid a:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.press-grid img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* ---------- Partners ---------- */
.partners{display:grid;gap:clamp(20px,3vw,32px)}
.partner{display:grid;grid-template-columns:220px 1fr;gap:clamp(20px,3vw,40px);align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2.2rem)}
.partner-logo{display:flex;align-items:center;justify-content:center;background:var(--bone);border-radius:12px;padding:1.2rem;min-height:140px}
.partner-logo img{max-height:120px;width:auto}
.partner h3{font-size:1.5rem;margin-bottom:.7rem}
.partner p{color:var(--ink-2);font-size:.96rem}
.partner .actions{margin-top:1.1rem}

/* ---------- CTA band (rouge) ---------- */
.cta-band{position:relative;background:var(--flame);color:#fff;overflow:hidden;isolation:isolate}
.cta-band::after{content:"";position:absolute;z-index:-1;inset:auto -10% -60% auto;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 65%)}
.cta-band .inner{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(24px,4vw,48px);align-items:center;padding-block:clamp(36px,5vw,72px)}
.cta-band .eyebrow{color:#fff}.cta-band .eyebrow::before{background:#fff}
.cta-band h2{font-size:var(--step-4);color:#fff}
.cta-band p{color:rgba(255,255,255,.92);margin-top:.8rem}
.cta-actions{display:flex;flex-direction:column;gap:.9rem}
.cta-actions .btn{--b:var(--ink)}
.cta-actions .btn:hover{background:#000;border-color:#000}
.cta-actions .btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-actions .btn--ghost:hover{background:#fff;color:var(--flame);border-color:#fff}
.cta-contact{font-size:.92rem;color:rgba(255,255,255,.9)}
.cta-contact a{font-weight:700;border-bottom:1px solid rgba(255,255,255,.5)}

/* ---------- Page hero (sous-pages) — fond clair ---------- */
.page-hero{position:relative;background:var(--bone);color:var(--ink);overflow:hidden;isolation:isolate;border-bottom:1px solid var(--line-soft)}
.page-hero::after{content:"";position:absolute;z-index:-1;inset:-30% -20% auto auto;width:50vw;height:50vw;border-radius:50%;background:radial-gradient(circle,rgba(190,22,34,.08),transparent 68%)}
.page-hero .inner{padding-block:clamp(48px,7vw,92px)}
.page-hero img.cover{display:none}
.page-hero h1{font-size:var(--step-4);margin:.3em 0 .4em;color:var(--ink)}
.page-hero p{color:var(--ink-2);max-width:60ch}
.breadcrumb{display:flex;gap:.5em;align-items:center;font-size:.82rem;color:var(--muted);margin-bottom:1.2rem}
.breadcrumb a:hover{color:var(--flame)}
.breadcrumb span{opacity:.5}

/* Sub-nav (univers ultra) */
.subnav{position:sticky;top:74px;z-index:100;background:var(--bone-2);border-bottom:1px solid var(--line)}
.subnav .inner{display:flex;gap:.3rem;overflow-x:auto;padding-block:.7rem;scrollbar-width:none}
.subnav .inner::-webkit-scrollbar{display:none}
.subnav a{flex-shrink:0;padding:.5em 1em;border-radius:40px;font-weight:700;font-size:.86rem;color:var(--ink-2);transition:.2s}
.subnav a:hover{background:var(--paper)}
.subnav a.is-active{background:var(--flame);color:#fff}

/* Construction notice */
.construction{text-align:center;padding:clamp(3rem,8vw,6rem) 0}
.construction .ic{width:72px;height:72px;margin:0 auto 1.4rem;border-radius:50%;background:rgba(190,22,34,.10);color:var(--flame);display:flex;align-items:center;justify-content:center}
.construction .ic svg{width:34px;height:34px}
.construction h2{font-size:var(--step-3)}
.construction p{color:var(--muted);margin:.8rem auto 0}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,52px)}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.4rem)}
.contact-line{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.contact-line:last-child{border-bottom:none}
.contact-line .ic{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--bone);color:var(--flame);display:flex;align-items:center;justify-content:center}
.contact-line .ic svg{width:20px;height:20px}
.contact-line .k{display:block;margin-bottom:.12rem;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.contact-line .v{font-weight:700;font-size:1.05rem}
.contact-line .v a:hover{color:var(--flame)}
.legal h3{font-family:var(--sans);font-weight:700;font-size:1.05rem;margin:1.4rem 0 .4rem}
.legal p{font-size:.92rem;color:var(--ink-2)}

/* ---------- Footer — fond clair, logo noir visible ---------- */
.site-footer{background:var(--bone);color:var(--ink);padding-block:clamp(48px,6vw,80px) 2rem;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,4vw,56px);padding-bottom:2.6rem;border-bottom:1px solid var(--line)}
.footer-brand img{height:50px;margin-bottom:1rem}
.footer-brand p{color:var(--stone);font-size:.92rem;max-width:34ch}
.footer-col h4{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--flame);margin-bottom:1rem}
.footer-col ul{display:grid;gap:.6rem}
.footer-col a{color:var(--ink-2);font-size:.94rem;transition:color .2s}
.footer-col a:hover{color:var(--flame)}
.footer-contact li{color:var(--ink-2);font-size:.94rem;display:flex;gap:.6rem;margin-bottom:.6rem}
.footer-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;padding-top:1.8rem;font-size:.84rem;color:var(--muted)}
.footer-bottom a{border-bottom:1px solid var(--line)}
.footer-bottom a:hover{color:var(--flame)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto !important}
  html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-figure{max-width:460px}
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .stat-strip .stat:nth-child(2){border-right:none}
  .stat-strip .stat:nth-child(1),.stat-strip .stat:nth-child(2){border-bottom:1px solid var(--line)}
  .packs{grid-template-columns:repeat(2,1fr)}
  .tmt-grid{columns:2}
  .results-grid{grid-template-columns:repeat(2,1fr)}
  .letter{grid-template-columns:1fr}
  .letter-figure{position:relative;top:0;max-width:420px}
  .feature-split{grid-template-columns:1fr}
  .cta-band .inner{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:860px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .mobile-menu{
    position:fixed;inset:74px 0 0;z-index:190;background:var(--paper);
    transform:translateX(100%);transition:transform .35s var(--ease);
    overflow-y:auto;padding:1.4rem var(--gutter) 3rem;display:flex;flex-direction:column;gap:.2rem
  }
  body.menu-open .mobile-menu{transform:none}
  body.menu-open{overflow:hidden}
  .mobile-menu a{padding:.95em .4em;font-size:1.15rem;font-weight:600;border-bottom:1px solid var(--line-soft);font-family:var(--display)}
  .mobile-menu .sub{padding-left:1.1rem}
  .mobile-menu .sub a{font-size:1rem;font-family:var(--sans);color:var(--ink-2)}
  .mobile-menu .group-label{margin-top:1rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--flame);font-weight:700}
  .mobile-menu .btn{margin-top:1.4rem}
  .book,.book:nth-child(even){grid-template-columns:1fr}
  .book-cover{max-width:260px}
  .book:nth-child(even) .book-cover{order:0}
  .partner{grid-template-columns:1fr}
  .partner-logo{max-width:260px}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .packs{grid-template-columns:1fr}
  .tmt-grid{columns:1}
  .results-grid{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
  .hero-badge{left:0}
  :root{--gutter:20px}
}
.mobile-menu{display:none}
@media (max-width:860px){.mobile-menu{display:flex}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* =================================================================
   CONSENTEMENT COOKIES — habillage de tarteaucitron.js aux couleurs
   de la marque (rouge #BE1622, noir #1A1A1A, blanc). tarteaucitron
   injecte sa propre CSS au chargement ; on la surcharge ici avec une
   spécificité suffisante (#tarteaucitronRoot + !important). Les fichiers
   de la librairie (assets/tarteaucitron/) restent intacts.
   ================================================================= */
/* Typographie identique au site sur tout le module */
html body #tarteaucitronRoot,
html body #tarteaucitronRoot *{font-family:var(--sans)!important}

/* Bandeau : liseré rouge de marque + ombre, texte sombre, titres */
html body #tarteaucitronRoot #tarteaucitronAlertBig{
  border-top:4px solid var(--flame)!important;
  box-shadow:var(--shadow-lg)!important;
  border-radius:var(--radius-lg)!important;
}
html body #tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH1,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH2,
html body #tarteaucitronRoot #tarteaucitron .tarteaucitronH3{color:var(--ink)!important}

/* Liens (mentions légales…) en rouge de marque */
html body #tarteaucitronRoot #tarteaucitronAlertBig a,
html body #tarteaucitronRoot #tarteaucitronPrivacyUrl,
html body #tarteaucitronRoot #tarteaucitron a{color:var(--flame)!important}

/* « Tout accepter » / « Enregistrer » = rouge de marque (action principale) */
html body #tarteaucitronRoot #tarteaucitronPersonalize2,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronAllAllowed,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronSaveButton{
  background:var(--flame)!important;color:#fff!important;
  border:0!important;border-radius:var(--radius)!important;opacity:1!important;
}
html body #tarteaucitronRoot #tarteaucitronPersonalize2:hover,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronAllAllowed:hover,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronSaveButton:hover{background:var(--flame-2)!important}

/* « Tout refuser » = noir de marque, même importance visuelle (exigence CNIL) */
html body #tarteaucitronRoot #tarteaucitronAllDenied2,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronAllDenied{
  background:var(--ink)!important;color:#fff!important;
  border:0!important;border-radius:var(--radius)!important;opacity:1!important;
}
html body #tarteaucitronRoot #tarteaucitronAllDenied2:hover,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronAllDenied:hover{background:#000!important}

/* « Personnaliser » = contour discret sur fond blanc */
html body #tarteaucitronRoot #tarteaucitronCloseAlert,
html body #tarteaucitronRoot #tarteaucitronPersonalize{
  background:#fff!important;color:var(--ink)!important;
  border:1px solid var(--line)!important;border-radius:var(--radius)!important;
}

/* Bascules par service : choix actif plein (rouge=autorisé / noir=refusé),
   choix inactif en gris atténué — apparence pilotée explicitement */
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny{
  background:var(--bone-2)!important;color:var(--ink)!important;opacity:.55!important;
}
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsAllowed{border-color:var(--flame)!important}
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsDenied{border-color:var(--ink)!important}
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsAllowed .tarteaucitronAllow,
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices #tarteaucitronServices_mandatory .tarteaucitronLine button.tarteaucitronAllow{
  background:var(--flame)!important;color:#fff!important;opacity:1!important;
}
html body #tarteaucitronRoot #tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsDenied .tarteaucitronDeny{
  background:var(--ink)!important;color:#fff!important;opacity:1!important;
}

/* Pastille flottante en rouge (au cas où showIcon serait réactivé) */
html body #tarteaucitronRoot #tarteaucitronIcon #tarteaucitronManager{background:var(--flame)!important}

/* ===== Design C — encart compact en coin (mode popup) =====
   Carte flottante en bas à droite, en-tête icône+titre à gauche, puis texte,
   puis « Tout accepter » pleine largeur et « Tout refuser » / « Choisir »
   côte à côte. (#tarteaucitronRoot doublé = priorité sur la CSS de la lib.) */
html body #tarteaucitronRoot#tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig{
  bottom:18px!important;top:auto!important;left:auto!important;right:18px!important;
  transform:none!important;max-width:330px!important;width:calc(100% - 32px)!important;min-width:0!important;
  border-radius:var(--radius-lg)!important;padding:20px!important;
  display:flex!important;flex-wrap:wrap!important;gap:8px!important;align-items:stretch;
}
/* pas de pastille ::before en popup (l'icône ⚡ est placée dans le texte) */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig::before{display:none!important}

/* En-tête (icône + titre) puis phrase, alignés à gauche */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert{
  flex:0 0 100%!important;text-align:left!important;padding:0!important;margin:0 0 6px!important;font-size:13.5px!important;
}
html body #tarteaucitronRoot #tarteaucitronAlertBig .cll-head{display:flex;align-items:center;gap:10px;margin-bottom:9px}
html body #tarteaucitronRoot #tarteaucitronAlertBig .cll-ico{
  width:38px;height:38px;border-radius:50%;background:#fff;border:2px solid var(--flame);
  display:flex;align-items:center;justify-content:center;font-size:19px;line-height:1;flex:none;
}
html body #tarteaucitronRoot #tarteaucitronAlertBig .cll-tac-title{
  display:inline!important;font-size:17px!important;font-weight:700!important;color:var(--ink)!important;
  margin:0!important;letter-spacing:-.01em;text-align:left!important;
}
html body #tarteaucitronRoot #tarteaucitronAlertBig .cll-txt{display:block;color:var(--ink-2);font-size:13.5px;line-height:1.45;font-weight:400!important}

/* Boutons : même police / padding / arrondi que la maquette */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronPersonalize2,
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronAllDenied2,
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronCloseAlert{
  font-size:13px!important;font-weight:700!important;padding:10px 16px!important;border-radius:6px!important;
  margin:0!important;box-sizing:border-box!important;width:auto!important;text-align:center!important;line-height:1.2!important;
}
/* « Tout accepter » occupe toute la largeur */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronPersonalize2{flex:0 0 100%!important}
/* « Tout refuser » et « Choisir » se partagent la ligne du dessous */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronAllDenied2,
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronCloseAlert{flex:1 1 0!important}
/* lien « Politique de confidentialité » masqué du bandeau (accessible via Choisir + pied de page) */
html body #tarteaucitronRoot.tarteaucitronSize-popup #tarteaucitronAlertBig #tarteaucitronPrivacyUrl{display:none!important}
