/* =================================================================
   EN CROISSANCE : Design system
   Barlow Condensed (titres) + Source Serif 4 (lecture)
   Ambiance : data journal, dense, structuré, voix éditoriale forte
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800&family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;0,8..60,700;1,8..60,400&display=swap');

/* ── Variables ─────────────────────────────────────────── */
:root {
  --ec-fond:        #fbf9f4;
  --ec-fond-alt:    #f0ede6;
  --ec-texte:       #1c1c1c;
  --ec-second:      #737368;
  --ec-rouge:       #c40d1e;
  --ec-ambre:       #c87800;
  --ec-bord:        #dbd8d0;
  --ec-bord-forte:  #a8a49c;
  --ec-lien:        #1a4a7a;
  --ec-blanc:       #ffffff;

  --ec-creation:    #5b21b6;
  --ec-finance:     #1a4a7a;
  --ec-marketing:   #9d1e5c;
  --ec-commercial:  #1a5e3a;
  --ec-management:  #7c2d12;
  --ec-digital:     #0e5984;

  --titre-font:  'Barlow Condensed', sans-serif;
  --lecture-font:'Source Serif 4', Georgia, serif;
  --rayon:       3px;
  --larg-texte:  760px;
  --larg-site:   1180px;
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--lecture-font);
  font-size: 18px;
  line-height: 1.75;
  color: var(--ec-texte);
  background: var(--ec-fond);
  font-optical-sizing: auto;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; }

/* ── Utilitaires ───────────────────────────────────────── */
.ec-conteneur { max-width:var(--larg-site); margin:0 auto; padding:0 28px; }
.ec-conteneur-etroit { max-width:780px; }
.ec-titre-page { font-family:var(--titre-font); font-size:2.2rem; font-weight:700; color:var(--ec-texte); margin:0 0 28px; }
.ec-conteneur-etroit h2 { font-family:var(--titre-font); font-size:1.3rem; font-weight:700; color:var(--ec-texte); margin:28px 0 10px; }
.ec-conteneur-etroit p { font-family:var(--lecture-font); line-height:1.75; margin:0 0 16px; }
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; }

/* ── Navigation principale ─────────────────────────────── */
.ec-nav-site {
  background: var(--ec-texte);
  position: sticky;
  top: 0;
  z-index: 100;
}
.ec-nav-interieur {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  gap: 20px;
}
.ec-nav-marque {
  font-family: var(--titre-font);
  font-weight: 800;
  font-size: 1.5rem;
  letter-spacing: -.01em;
  color: var(--ec-blanc);
  text-transform: uppercase;
  flex-shrink: 0;
}
.ec-nav-marque span { color: var(--ec-rouge); }
.ec-nav-liens {
  display: flex;
  gap: 0;
  align-items: center;
}
.ec-nav-liens li a {
  font-family: var(--titre-font);
  font-size: .9375rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  padding: 0 14px;
  height: 56px;
  display: flex;
  align-items: center;
  border-bottom: 3px solid transparent;
  transition: color .2s, border-color .2s;
}
.ec-nav-liens li a:hover,
.ec-nav-liens li a.actif {
  color: #fff;
  border-bottom-color: var(--ec-rouge);
}
.ec-nav-burger {
  display:none;
  background:none; border:none;
  color:#fff; font-size:1.25rem;
  cursor:pointer; padding:8px;
}

/* ── HOME : bande éditoriale ───────────────────────────── */
.ec-bandeau-editorial {
  background: var(--ec-texte);
  color: var(--ec-blanc);
  padding: 60px 0 52px;
  border-bottom: 3px solid var(--ec-rouge);
}
.ec-bandeau-interieur {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 56px;
  align-items: start;
}
.ec-bandeau-surtitre {
  font-family: var(--titre-font);
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ec-rouge);
  margin-bottom: 12px;
}
.ec-bandeau-titre {
  font-family: var(--titre-font);
  font-size: 3.25rem;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  margin-bottom: 20px;
}
.ec-bandeau-intro {
  font-family: var(--lecture-font);
  font-size: 1.0625rem;
  line-height: 1.8;
  color: rgba(255,255,255,.65);
  margin-bottom: 28px;
  max-width: 560px;
}
.ec-bandeau-chiffres {
  display: flex;
  gap: 36px;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 24px;
  margin-top: 4px;
}
.ec-chiffre-val {
  font-family: var(--titre-font);
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--ec-ambre);
  line-height: 1;
}
.ec-chiffre-lib {
  font-family: var(--lecture-font);
  font-size: .8125rem;
  color: rgba(255,255,255,.45);
  margin-top: 3px;
}
.ec-bandeau-rubriques { display:flex; flex-direction:column; gap:8px; }
.ec-rubrique-lien {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-left: 3px solid transparent;
  color: rgba(255,255,255,.5);
  font-family: var(--titre-font);
  font-size: .9375rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: border-color .2s, color .2s, background .2s;
}
.ec-rubrique-lien:hover {
  color: #fff;
  background: rgba(255,255,255,.05);
}
.ec-rubrique-lien-nb { font-size:.75rem; opacity:.45; }

/* ── Barre rubriques (séparatrice) ─────────────────────── */
.ec-barre-rubriques {
  background: var(--ec-fond-alt);
  border-bottom: 1px solid var(--ec-bord);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.ec-barre-rubriques-liste {
  display: flex;
  gap: 0;
  align-items: stretch;
  min-width: max-content;
}
.ec-barre-rubrique-item {
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ec-second);
  padding: 12px 20px;
  border-right: 1px solid var(--ec-bord);
  white-space: nowrap;
  transition: color .2s, background .2s;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ec-barre-rubrique-item:hover { color:var(--ec-texte); background: var(--ec-blanc); }
.ec-barre-rubrique-puce { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ── Section À la une ──────────────────────────────────── */
.ec-section-une { padding: 52px 0 0; }
.ec-section-titre-ligne {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 28px;
}
.ec-section-titre-label {
  font-family: var(--titre-font);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ec-rouge);
}
.ec-section-titre-ligne::after {
  content: '';
  flex:1;
  height: 1px;
  background: var(--ec-bord);
}

/* Article vedette */
.ec-article-vedette {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--ec-bord);
  border-left: 4px solid var(--ec-rouge);
  background: var(--ec-blanc);
  transition: box-shadow .2s;
}
.ec-article-vedette:hover { box-shadow: 4px 4px 0 var(--ec-rouge); }
.ec-vedette-corps { padding: 36px 36px 36px 32px; }
.ec-vedette-second { padding: 36px; border-left: 1px solid var(--ec-bord); display:flex; flex-direction:column; justify-content:center; }
.ec-rubrique-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  padding: 3px 10px;
  margin-bottom: 14px;
}
.ec-vedette-titre {
  font-family: var(--titre-font);
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin-bottom: 14px;
}
.ec-article-vedette:hover .ec-vedette-titre { color: var(--ec-rouge); }
.ec-vedette-desc {
  font-family: var(--lecture-font);
  font-size: .9375rem;
  color: var(--ec-second);
  line-height: 1.7;
  margin-bottom: 20px;
}
.ec-vedette-meta {
  font-family: var(--titre-font);
  font-size: .8125rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #999;
}
.ec-vedette-lire {
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ec-rouge);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
}
.ec-vedette-lire svg { transition: transform .2s; }
.ec-article-vedette:hover .ec-vedette-lire svg { transform: translateX(4px); }
.ec-vedette-img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
  border: 1px solid var(--ec-bord);
  margin-bottom: 24px;
}

/* ── Liste analyses ─────────────────────────────────────── */
.ec-section-analyses { padding: 48px 0 64px; }
.ec-liste-analyses {
  border-top: 2px solid var(--ec-texte);
}
.ec-analyse-item {
  display: grid;
  grid-template-columns: 68px 110px 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid var(--ec-bord);
  transition: background .15s;
}
.ec-analyse-item:hover { background: var(--ec-fond-alt); margin: 0 -28px; padding: 22px 28px; }
.ec-analyse-gauche {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex-shrink: 0;
}
.ec-analyse-rubrique-etiquette {
  font-family: var(--titre-font);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  padding: 3px 8px;
  border-radius: 2px;
}
.ec-analyse-date { font-family: var(--titre-font); font-size: .7rem; letter-spacing:.04em; text-transform:uppercase; color:#aaa; }
.ec-analyse-corps { min-width:0; }
.ec-analyse-titre {
  font-family: var(--titre-font);
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  line-height: 1.2;
  margin-bottom: 6px;
}
.ec-analyse-item:hover .ec-analyse-titre { color: var(--ec-rouge); }
.ec-analyse-extrait {
  font-family: var(--lecture-font);
  font-size: .875rem;
  color: var(--ec-second);
  line-height: 1.6;
}
.ec-analyse-lecture {
  font-family: var(--titre-font);
  font-size: .75rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #bbb;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Vignettes dans les listes */
.ec-analyse-vignette {
  width: 68px;
  height: 68px;
  overflow: hidden;
  border: 1px solid var(--ec-bord);
  flex-shrink: 0;
  align-self: center;
}
.ec-analyse-vignette img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.ec-analyse-item:hover .ec-analyse-vignette img { transform: scale(1.07); }

.ec-rubrique-art-vignette {
  width: 96px;
  height: 96px;
  overflow: hidden;
  border: 1px solid var(--ec-bord);
  align-self: flex-start;
}
.ec-rubrique-art-vignette img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.ec-rubrique-art-item:hover .ec-rubrique-art-vignette img { transform: scale(1.07); }

/* Voir plus */
.ec-voir-plus {
  text-align: center;
  padding-top: 32px;
}
.ec-btn-voir-plus {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ec-texte);
  border: 2px solid var(--ec-texte);
  padding: 10px 24px;
  border-radius: 2px;
  transition: background .2s, color .2s;
}
.ec-btn-voir-plus:hover { background: var(--ec-texte); color: var(--ec-blanc); }

/* ── Section rubriques grille ───────────────────────────── */
.ec-section-rubriques { padding: 0 0 64px; }
.ec-grille-rubriques {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: var(--ec-bord);
  border: 1px solid var(--ec-bord);
}
.ec-rubrique-bloc {
  background: var(--ec-fond);
  padding: 28px 24px;
  transition: background .2s;
}
.ec-rubrique-bloc:hover { background: var(--ec-blanc); }
.ec-rubrique-bloc-nom {
  font-family: var(--titre-font);
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin-bottom: 6px;
  padding-bottom: 12px;
  border-bottom: 3px solid var(--ec-bord);
}
.ec-rubrique-bloc-articles { margin-top:14px; display:flex; flex-direction:column; gap:10px; }
.ec-rubrique-bloc-art-titre {
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--ec-second);
  line-height: 1.3;
  transition: color .2s;
}
.ec-rubrique-bloc:hover .ec-rubrique-bloc-art-titre { color: var(--ec-texte); }

/* ── ARTICLE : en-tête ──────────────────────────────────── */
.ec-fil-ariane {
  font-family: var(--titre-font);
  font-size: .8125rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ec-second);
  padding: 14px 0;
  border-bottom: 1px solid var(--ec-bord);
}
.ec-fil-ariane a { color: var(--ec-second); }
.ec-fil-ariane a:hover { color: var(--ec-rouge); }
.ec-fil-sep { margin: 0 10px; color: var(--ec-bord-forte); }

.ec-chapeau-article {
  padding: 44px 0 36px;
  border-bottom: 2px solid var(--ec-texte);
}
.ec-chapeau-rubrique-ligne {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 18px;
}
.ec-chapeau-rubrique {
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  padding: 4px 12px;
  border-radius: 2px;
}
.ec-chapeau-lecture {
  font-family: var(--titre-font);
  font-size: .75rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ec-second);
}
.ec-chapeau-titre {
  font-family: var(--titre-font);
  font-size: 2.75rem;
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin-bottom: 20px;
}
.ec-chapeau-intro {
  font-family: var(--lecture-font);
  font-size: 1.125rem;
  line-height: 1.75;
  color: var(--ec-second);
  max-width: 680px;
  margin-bottom: 20px;
  font-style: italic;
}
.ec-chapeau-meta {
  font-family: var(--titre-font);
  font-size: .8125rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #aaa;
  display: flex;
  gap: 16px;
  align-items: center;
}
.ec-chapeau-meta-sep { color: var(--ec-bord-forte); }

/* ── ARTICLE : zone lecture ─────────────────────────────── */
.ec-lecture-zone { padding: 52px 0 80px; }
.ec-lecture-grille {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 56px;
  align-items: start;
}
.ec-marge-sommaire { position: sticky; top: 76px; }
.ec-sommaire-titre {
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ec-second);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--ec-rouge);
}
.ec-sommaire-liste { list-style:none; }
.ec-sommaire-item {
  padding: 6px 0;
  border-bottom: 1px solid var(--ec-bord);
}
.ec-sommaire-lien {
  font-family: var(--titre-font);
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--ec-second);
  line-height: 1.3;
  transition: color .2s;
}
.ec-sommaire-lien:hover, .ec-sommaire-lien.actif { color: var(--ec-rouge); }
.ec-sommaire-articles {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--ec-bord);
}
.ec-sommaire-articles-titre {
  font-family: var(--titre-font);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #bbb;
  margin-bottom: 12px;
}
.ec-lien-article-lie {
  display: block;
  font-family: var(--titre-font);
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--ec-second);
  padding: 8px 0;
  border-bottom: 1px solid var(--ec-bord);
  line-height: 1.3;
  transition: color .2s;
}
.ec-lien-article-lie:hover { color: var(--ec-rouge); }

/* Corps de l'article */
.ec-lecture-corps { min-width:0; }
.ec-lecture-corps h2 {
  font-family: var(--titre-font);
  font-size: 1.625rem;
  font-weight: 800;
  letter-spacing: .01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin: 48px 0 18px;
  padding-top: 20px;
  border-top: 2px solid var(--ec-texte);
  line-height: 1.2;
}
.ec-lecture-corps h2:first-child { margin-top: 0; }
.ec-lecture-corps h3 {
  font-family: var(--titre-font);
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin: 30px 0 12px;
}
.ec-lecture-corps p {
  font-family: var(--lecture-font);
  font-size: 1rem;
  line-height: 1.85;
  color: var(--ec-texte);
  margin-bottom: 20px;
}
.ec-lecture-corps ul, .ec-lecture-corps ol {
  margin-bottom: 20px;
  padding-left: 0;
  list-style: none;
}
.ec-lecture-corps ul li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
  font-size: 1rem;
  line-height: 1.75;
}
.ec-lecture-corps ul li::before {
  content: '›';
  position: absolute;
  left: 0;
  color: var(--ec-rouge);
  font-weight: 700;
}
.ec-lecture-corps ol { counter-reset: ec-list; }
.ec-lecture-corps ol li {
  counter-increment: ec-list;
  padding-left: 32px;
  margin-bottom: 10px;
  font-size: 1rem;
  line-height: 1.75;
  position: relative;
}
.ec-lecture-corps ol li::before {
  content: counter(ec-list);
  position: absolute;
  left: 0;
  font-family: var(--titre-font);
  font-weight: 800;
  font-size: .875rem;
  color: var(--ec-blanc);
  background: var(--ec-rouge);
  width: 22px; height:22px;
  display: flex; align-items:center; justify-content:center;
  border-radius: 2px;
  top: 2px;
}
.ec-lecture-corps strong { font-weight: 700; color: var(--ec-texte); }
.ec-lecture-corps a { color: var(--ec-lien); text-decoration: underline; text-decoration-thickness:1px; }
.ec-lecture-corps a:hover { color: var(--ec-rouge); }
.ec-lecture-corps em { font-style:italic; }

/* ── Encadrés ──────────────────────────────────────────── */
.ec-encadre {
  margin: 32px 0;
  padding: 0;
}
.ec-encadre-entete {
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ec-encadre-corps { padding: 18px 20px; font-size: .9375rem; }
.ec-encadre-corps p { margin-bottom: 10px; font-size:.9375rem; }
.ec-encadre-corps p:last-child { margin-bottom: 0; }
.ec-encadre-corps ul { margin-bottom:8px; }
.ec-encadre-corps ul li { font-size:.9375rem; }

.ec-encadre-donnee {
  border: 2px solid var(--ec-texte);
}
.ec-encadre-donnee .ec-encadre-entete {
  background: var(--ec-texte);
  color: var(--ec-ambre);
}
.ec-encadre-donnee .ec-encadre-corps {
  background: var(--ec-fond);
}
.ec-chiffre-fort {
  font-family: var(--titre-font);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--ec-ambre);
  line-height: 1;
  margin-bottom: 4px;
}

.ec-encadre-essentiel {
  border-left: 4px solid var(--ec-rouge);
  background: var(--ec-fond-alt);
}
.ec-encadre-essentiel .ec-encadre-entete { color: var(--ec-rouge); background: transparent; padding-left:20px; }
.ec-encadre-essentiel .ec-encadre-corps { padding-left:20px; }

.ec-encadre-attention {
  border: 1px solid #e8d88a;
  background: #fffbeb;
}
.ec-encadre-attention .ec-encadre-entete { color: #92400e; background: transparent; }

.ec-encadres-chiffres {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0;
  border: 2px solid var(--ec-texte);
  margin: 32px 0;
}
.ec-chiffre-item {
  text-align: center;
  padding: 24px 16px;
  border-right: 1px solid var(--ec-bord);
}
.ec-chiffre-item:last-child { border-right:none; }
.ec-chiffre-item-val {
  font-family: var(--titre-font);
  font-size: 2rem;
  font-weight: 800;
  color: var(--ec-texte);
  line-height: 1;
}
.ec-chiffre-item-lib { font-family: var(--lecture-font); font-size: .8125rem; color: var(--ec-second); margin-top: 6px; }

/* Tableau */
.ec-lecture-corps .ec-tableau-analyse {
  width: 100%;
  border-collapse: collapse;
  margin: 28px 0;
  font-size: .9rem;
  border: 1px solid var(--ec-bord);
}
.ec-tableau-analyse thead tr { background: var(--ec-texte); }
.ec-tableau-analyse th {
  padding: 11px 16px;
  text-align: left;
  font-family: var(--titre-font);
  font-weight: 700;
  font-size: .8125rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ec-blanc);
}
.ec-tableau-analyse td { padding: 11px 16px; border-bottom: 1px solid var(--ec-bord); font-family: var(--lecture-font); font-size: .9rem; line-height:1.5; }
.ec-tableau-analyse tbody tr:hover { background: var(--ec-fond-alt); }
.ec-tableau-analyse .td-oui { color: var(--ec-commercial); font-weight:700; }
.ec-tableau-analyse .td-non { color: var(--ec-rouge); font-weight:700; }

/* Étapes */
.ec-etapes { margin: 28px 0; }
.ec-etape-item {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--ec-bord);
}
.ec-etape-item:last-child { border-bottom:none; }
.ec-etape-num {
  font-family: var(--titre-font);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--ec-rouge);
  line-height: 1.6;
}
.ec-etape-texte p { margin-bottom:6px; }
.ec-etape-label {
  font-family: var(--titre-font);
  font-size: .9375rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--ec-texte);
  margin-bottom: 4px;
}

/* Image carrée dans le corps de l'article */
.ec-img-article {
  float: right;
  width: 220px;
  height: 220px;
  object-fit: cover;
  margin: 0 0 24px 32px;
  border: 1px solid var(--ec-bord);
  display: block;
}

/* Figure SVG */
.ec-figure-analyse {
  margin: 32px 0;
  border: 1px solid var(--ec-bord);
}
.ec-figure-analyse img { max-width:100%; height:auto; }

/* ── PAGE RUBRIQUE ──────────────────────────────────────── */
.ec-rubrique-entete {
  padding: 44px 0 32px;
  border-bottom: 2px solid var(--ec-texte);
}
.ec-rubrique-entete-etiquette {
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  padding: 4px 14px;
  border-radius: 2px;
  margin-bottom: 16px;
  display: inline-block;
}
.ec-rubrique-entete-titre {
  font-family: var(--titre-font);
  font-size: 2.25rem;
  font-weight: 800;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin-bottom: 10px;
}
.ec-rubrique-entete-desc {
  font-family: var(--lecture-font);
  font-size: 1rem;
  color: var(--ec-second);
  max-width: 640px;
  line-height: 1.7;
}
.ec-rubrique-articles { padding: 48px 0 72px; }
.ec-rubrique-liste { border-top: 2px solid var(--ec-texte); }
.ec-rubrique-art-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: 32px;
  align-items: start;
  padding: 28px 0;
  border-bottom: 1px solid var(--ec-bord);
  transition: background .15s;
}
.ec-rubrique-art-item:hover { background: var(--ec-fond-alt); margin: 0 -28px; padding: 28px 28px; }
.ec-rubrique-art-titre {
  font-family: var(--titre-font);
  font-size: 1.375rem;
  font-weight: 800;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-texte);
  margin-bottom: 10px;
  line-height: 1.15;
}
.ec-rubrique-art-item:hover .ec-rubrique-art-titre { color: var(--ec-rouge); }
.ec-rubrique-art-desc {
  font-family: var(--lecture-font);
  font-size: .9375rem;
  color: var(--ec-second);
  line-height: 1.65;
  margin-bottom: 12px;
}
.ec-rubrique-art-meta { font-family: var(--titre-font); font-size: .75rem; letter-spacing:.05em; text-transform:uppercase; color:#bbb; }
.ec-rubrique-art-droite { display:flex; flex-direction:column; align-items:flex-end; gap:12px; flex-shrink:0; }
.ec-rubrique-art-lecture { font-family:var(--titre-font); font-size:.75rem; letter-spacing:.06em; text-transform:uppercase; color:#ccc; white-space:nowrap; }
.ec-lire-art {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--titre-font);
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ec-rouge);
  white-space: nowrap;
}
.ec-lire-art svg { transition: transform .2s; }
.ec-rubrique-art-item:hover .ec-lire-art svg { transform:translateX(4px); }

/* ── Mentions légales ───────────────────────────────────── */
.ec-mentions-zone {
  max-width: 760px;
  margin: 0 auto;
  padding: 60px 28px 80px;
}
.ec-mentions-zone h1 { font-family:var(--titre-font); font-size:2rem; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; color:var(--ec-texte); margin-bottom:32px; padding-bottom:16px; border-bottom:2px solid var(--ec-texte); }
.ec-mentions-zone h2 { font-family:var(--titre-font); font-size:1.125rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; color:var(--ec-texte); margin:28px 0 10px; }
.ec-mentions-zone p { font-family:var(--lecture-font); font-size:1rem; line-height:1.8; color:var(--ec-texte); margin-bottom:14px; }

/* ── 404 ────────────────────────────────────────────────── */
.ec-404-zone { text-align:center; padding:80px 28px 48px; }
.ec-404-code { font-family:var(--titre-font); font-size:7rem; font-weight:800; color:var(--ec-bord); line-height:1; }
.ec-404-zone h1 { font-family:var(--titre-font); font-size:1.5rem; font-weight:800; text-transform:uppercase; color:var(--ec-texte); margin:16px 0 10px; }
.ec-404-zone p { font-family:var(--lecture-font); color:var(--ec-second); margin-bottom:28px; max-width:480px; margin-left:auto; margin-right:auto; }
.ec-404-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: var(--ec-texte);
  color: var(--ec-blanc);
  padding: 12px 28px;
  border-radius: 2px;
  transition: background .2s;
}
.ec-404-btn:hover { background: var(--ec-rouge); }
.ec-404-rubriques { padding: 40px 0 16px; }
.ec-404-cats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin-top: 8px;
}
.ec-404-cat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ec-texte);
  padding: 14px 16px;
  background: var(--ec-blanc);
  border: 1px solid var(--ec-bord);
  border-top: 3px solid transparent;
  transition: border-color .2s, background .2s;
}
.ec-404-cat-item:hover { background: var(--ec-fond-alt); }
.ec-404-suggestions { padding: 32px 0 80px; }
.ec-404-arts {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
  margin-top: 8px;
}
.ec-404-art-item {
  display: flex;
  gap: 16px;
  padding: 16px;
  background: var(--ec-blanc);
  border: 1px solid var(--ec-bord);
  border-left: 3px solid var(--ec-bord);
  transition: border-left-color .2s;
  align-items: flex-start;
}
.ec-404-art-item:hover { border-left-color: var(--ec-rouge); }
.ec-404-art-vignette { width:64px; height:64px; overflow:hidden; flex-shrink:0; }
.ec-404-art-vignette img { width:100%; height:100%; object-fit:cover; display:block; }
.ec-404-art-corps { min-width:0; display:flex; flex-direction:column; gap:6px; }
.ec-404-art-titre {
  font-family: var(--titre-font);
  font-size: .875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--ec-texte);
  line-height: 1.25;
}
.ec-404-art-item:hover .ec-404-art-titre { color: var(--ec-rouge); }
.ec-404-art-meta { font-family:var(--titre-font); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:#bbb; }
@media (max-width:768px) {
  .ec-404-cats { grid-template-columns:1fr 1fr; }
  .ec-404-arts { grid-template-columns:1fr; }
}

/* ── Footer ─────────────────────────────────────────────── */
.ec-pied-site {
  background: var(--ec-texte);
  color: rgba(255,255,255,.45);
  border-top: 3px solid var(--ec-rouge);
}
.ec-pied-haut {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr;
  gap: 48px;
  padding: 52px 0 48px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ec-pied-marque-nom {
  font-family: var(--titre-font);
  font-size: 1.375rem;
  font-weight: 800;
  letter-spacing: -.01em;
  text-transform: uppercase;
  color: var(--ec-blanc);
  margin-bottom: 12px;
}
.ec-pied-marque-nom span { color: var(--ec-rouge); }
.ec-pied-marque-desc { font-family:var(--lecture-font); font-size:.875rem; line-height:1.75; color:rgba(255,255,255,.4); }
.ec-pied-col-titre {
  font-family: var(--titre-font);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  margin-bottom: 16px;
}
.ec-pied-col-liens { display:flex; flex-direction:column; gap:8px; }
.ec-pied-col-liens a { font-family:var(--lecture-font); font-size:.875rem; color:rgba(255,255,255,.45); transition:color .2s; }
.ec-pied-col-liens a:hover { color: var(--ec-blanc); }
.ec-pied-bas {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  font-family: var(--titre-font);
  font-size: .75rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.ec-pied-bas-liens { display:flex; gap:20px; }
.ec-pied-bas-liens a { color:rgba(255,255,255,.3); transition:color .2s; }
.ec-pied-bas-liens a:hover { color:rgba(255,255,255,.7); }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .ec-bandeau-interieur { grid-template-columns:1fr; }
  .ec-bandeau-rubriques { display:none; }
  .ec-lecture-grille { grid-template-columns:1fr; }
  .ec-marge-sommaire { display:none; }
  .ec-grille-rubriques { grid-template-columns:1fr 1fr; }
  .ec-pied-haut { grid-template-columns:1fr 1fr; }
}
@media (max-width: 768px) {
  body { font-size:17px; }
  .ec-bandeau-titre { font-size:2.25rem; }
  .ec-chapeau-titre { font-size:1.875rem; }
  .ec-article-vedette { grid-template-columns:1fr; }
  .ec-vedette-second { border-left:none; border-top:1px solid var(--ec-bord); }
  .ec-analyse-item { grid-template-columns:1fr; gap:8px; }
  .ec-analyse-lecture { display:none; }
  .ec-grille-rubriques { grid-template-columns:1fr; }
  .ec-nav-liens { display:none; }
  .ec-nav-burger { display:block; }
  .ec-nav-liens.ouvert {
    display:flex; flex-direction:column;
    position:absolute; top:56px; left:0; right:0;
    background:var(--ec-texte);
    padding:16px 28px;
    gap:4px;
    z-index:99;
  }
  .ec-nav-liens.ouvert li a { height:auto; padding:10px 0; border-bottom:1px solid rgba(255,255,255,.08); }
  .ec-rubrique-art-item { grid-template-columns:1fr; }
  .ec-rubrique-art-droite { flex-direction:row; align-items:center; }
  .ec-analyse-vignette { display:none; }
  .ec-rubrique-art-vignette { display:none; }
  .ec-img-article { float:none; width:100%; height:180px; margin:0 0 20px; }
  .ec-pied-haut { grid-template-columns:1fr; gap:28px; }
  .ec-pied-bas { flex-direction:column; gap:10px; text-align:center; }
}
@media (max-width:480px) {
  .ec-bandeau-titre { font-size:1.75rem; }
  .ec-chapeau-titre { font-size:1.5rem; }
  .ec-conteneur { padding:0 16px; }
  .ec-encadres-chiffres { grid-template-columns:1fr 1fr; }
}
