/* =========================================================================
   Cfet, le magazine des entrepreneurs
   Design : magazine business premium, encre de nuit + or, Playfair + Inter
   ========================================================================= */

:root {
  --encre:        #0A1324;
  --ardoise-fonce:#1E293B;
  --ardoise:      #334155;
  --brume:        #F5F7FA;
  --blanc:        #FFFFFF;
  --or:           #D4AF37;
  --or-clair:     #E4C76A;
  --or-sombre:    #B8962E;

  --texte:        #1F2733;
  --texte-doux:   #5A6678;
  --texte-clair:  rgba(255,255,255,.78);

  --bordure:      rgba(10,19,36,.10);
  --ombre-portee: 0 18px 50px rgba(10,19,36,.16);

  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --large: 1180px;
  --etroit: 760px;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--sans);
  font-size: 18px;
  line-height: 1.7;
  color: var(--texte);
  background: var(--blanc);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--or-sombre); text-decoration: none; }
a:hover { color: var(--or); }

h1, h2, h3, h4 { font-family: var(--serif); font-weight: 700; line-height: 1.18; color: var(--encre); margin: 0 0 .5em; }

:focus-visible { outline: 3px solid var(--or); outline-offset: 2px; }

.container { width: 100%; max-width: var(--large); margin-inline: auto; padding-inline: 22px; }

/* ===== Boutons ===== */
.bouton-or {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--sans); font-weight: 600; font-size: .98rem;
  padding: .72em 1.4em; border: 0; border-radius: 2px; cursor: pointer;
  background: var(--or); color: var(--encre);
  letter-spacing: .01em; transition: background .18s, transform .18s;
}
.bouton-or:hover { background: var(--or-clair); color: var(--encre); transform: translateY(-1px); }
.bouton-or::after { content: "→"; font-weight: 400; }

.bouton-cadre {
  display: inline-flex; align-items: center; gap: .5em;
  font-weight: 600; font-size: .98rem; padding: .72em 1.4em;
  border: 1px solid rgba(255,255,255,.5); border-radius: 2px;
  color: var(--blanc); background: transparent; transition: border-color .18s, background .18s;
}
.bouton-cadre:hover { border-color: var(--or); color: var(--blanc); background: rgba(212,175,55,.12); }

/* =========================================================================
   En-tête
   ========================================================================= */
.barre-haut {
  position: sticky; top: 0; z-index: 50;
  background: var(--encre); color: var(--blanc);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.barre-haut-int {
  max-width: var(--large); margin-inline: auto; padding: 0 22px;
  height: 76px; display: flex; align-items: center; gap: 28px;
}
.marque { display: flex; align-items: baseline; gap: 2px; color: var(--blanc); }
.marque-nom {
  font-family: var(--serif); font-weight: 800; font-size: 1.7rem;
  letter-spacing: .04em; color: var(--blanc); text-transform: uppercase;
}
.marque-point { width: 7px; height: 7px; border-radius: 50%; background: var(--or); align-self: flex-end; margin-bottom: 6px; }
.marque-base { display: none; font-family: var(--sans); font-size: .72rem; color: var(--texte-clair); letter-spacing: .12em; text-transform: uppercase; margin-left: 8px; }

.menu-rubriques { display: flex; align-items: center; gap: 26px; margin-right: auto; }
.menu-rubriques a {
  color: rgba(255,255,255,.86); font-size: .95rem; font-weight: 500;
  position: relative; padding: 6px 0; transition: color .15s;
}
.menu-rubriques a:hover { color: var(--blanc); }
.menu-rubriques a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px;
  background: var(--or); transition: width .2s;
}
.menu-rubriques a:hover::after { width: 100%; }

.barre-haut-actions { display: flex; align-items: center; gap: 14px; }
.bouton-recherche {
  display: grid; place-items: center; width: 40px; height: 40px;
  background: transparent; border: 1px solid rgba(255,255,255,.18); border-radius: 50%;
  color: var(--blanc); cursor: pointer; transition: border-color .15s, background .15s;
}
.bouton-recherche:hover { border-color: var(--or); background: rgba(255,255,255,.06); }

.declic-menu { display: none; width: 42px; height: 40px; background: transparent; border: 0; cursor: pointer; padding: 9px 8px; }
.declic-menu span { display: block; height: 2px; background: var(--blanc); border-radius: 2px; transition: transform .25s, opacity .2s; }
.declic-menu span + span { margin-top: 5px; }
.declic-menu[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.declic-menu[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.declic-menu[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.volet-recherche {
  display: none; gap: 12px; background: var(--ardoise-fonce);
  padding: 16px 22px; max-width: var(--large); margin-inline: auto;
}
.volet-recherche.ouvert { display: flex; }
.volet-recherche input {
  flex: 1; padding: .7em 1em; border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.05); color: var(--blanc); border-radius: 2px; font-size: 1rem;
}
.volet-recherche input::placeholder { color: rgba(255,255,255,.5); }

/* =========================================================================
   Accueil : Tribune (une éditoriale)
   ========================================================================= */
.tribune-une {
  position: relative; color: var(--blanc); overflow: hidden;
  background:
    radial-gradient(1200px 480px at 88% -10%, rgba(212,175,55,.28), transparent 60%),
    radial-gradient(800px 400px at 10% 120%, rgba(91,141,239,.12), transparent 55%),
    linear-gradient(160deg, #0c1730 0%, var(--encre) 55%, #070d1c 100%);
}
.tribune-une::after {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 100% 38px; opacity: .5; pointer-events: none;
}
.tribune-une-int { position: relative; max-width: 880px; margin-inline: auto; padding: 92px 22px 96px; }
.surtitre {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: .76rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  color: var(--or); margin-bottom: 22px;
}
.surtitre::before { content: ""; width: 34px; height: 1px; background: var(--or); }
.tribune-une h1 { font-size: clamp(2.1rem, 5.4vw, 3.9rem); color: var(--blanc); margin: 0 0 .35em; letter-spacing: -.01em; overflow-wrap: break-word; }
.tribune-une-chapo { font-size: 1.18rem; line-height: 1.65; color: var(--texte-clair); max-width: 620px; margin: 0 0 34px; }
.tribune-une-actions { display: flex; flex-wrap: wrap; gap: 14px; }

/* ===== Bandeau rubriques ===== */
.bandeau-rubriques { background: var(--brume); border-bottom: 1px solid var(--bordure); }
.bandeau-rubriques-int {
  max-width: var(--large); margin-inline: auto; padding: 6px 22px;
  display: grid; grid-template-columns: repeat(6, minmax(0, 1fr));
}
.vignette-rubrique-nom, .vignette-rubrique-desc { overflow-wrap: break-word; max-width: 100%; }
.vignette-rubrique {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px;
  padding: 22px 12px; color: var(--encre); border-right: 1px solid var(--bordure);
  transition: background .15s;
}
.vignette-rubrique:last-child { border-right: 0; }
.vignette-rubrique:hover { background: rgba(212,175,55,.07); color: var(--encre); }
.vignette-rubrique-pastille { width: 30px; height: 30px; border-radius: 50%; background: var(--accent, var(--or)); opacity: .9; box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent, var(--or)) 16%, transparent); }
.vignette-rubrique-nom { font-family: var(--serif); font-weight: 700; font-size: 1rem; }
.vignette-rubrique-desc { font-size: .78rem; color: var(--texte-doux); }

/* =========================================================================
   Sections génériques
   ========================================================================= */
.section-une-int, .section-derniers-int { max-width: var(--large); margin-inline: auto; padding: 64px 22px; }
.titre-rang { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 34px; }
.titre-rang h2 { position: relative; font-size: 2rem; margin: 0; padding-bottom: 14px; }
.titre-rang h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 56px; height: 3px; background: var(--or); }
.lien-fleche { font-family: var(--sans); font-size: .92rem; font-weight: 600; color: var(--ardoise); white-space: nowrap; }
.lien-fleche:hover { color: var(--or-sombre); }

/* ===== À la une : vedette + classement ===== */
.section-une-grille { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr); gap: 44px; align-items: start; }

.feuillet-vedette { display: flex; flex-direction: column; }
.feuillet-vedette-visuel { position: relative; display: block; border-radius: 3px; overflow: hidden; aspect-ratio: 16/10; background: var(--brume); }
.feuillet-vedette-visuel img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.feuillet-vedette:hover .feuillet-vedette-visuel img { transform: scale(1.04); }
.feuillet-vedette-corps { padding-top: 22px; }
.feuillet-vedette-corps h3 { font-size: 1.85rem; line-height: 1.2; margin: 14px 0 .4em; }
.feuillet-vedette-corps h3 a { color: var(--encre); }
.feuillet-vedette-corps h3 a:hover { color: var(--or-sombre); }
.feuillet-vedette-corps p { color: var(--texte-doux); margin: 0 0 14px; }

.feuillet-rubrique {
  display: inline-block; font-family: var(--sans); font-size: .72rem; font-weight: 700;
  letter-spacing: .11em; text-transform: uppercase; color: var(--encre);
  background: var(--accent, var(--or)); padding: .42em .9em; border-radius: 2px;
}
a.feuillet-rubrique:hover { color: var(--encre); filter: brightness(1.05); }

.classement-une { list-style: none; margin: 0; padding: 0; counter-reset: rang; }
.classement-une .rang { display: grid; grid-template-columns: 96px 1fr; gap: 16px; padding: 18px 0; border-top: 1px solid var(--bordure); }
.classement-une .rang:first-child { border-top: 0; padding-top: 0; }
.rang-visuel { display: block; border-radius: 3px; overflow: hidden; aspect-ratio: 4/3; background: var(--brume); }
.rang-visuel img { width: 100%; height: 100%; object-fit: cover; }
.rang-corps { display: flex; flex-direction: column; gap: 4px; }
.rang-num { font-family: var(--serif); font-weight: 800; font-size: 1.05rem; color: var(--or); line-height: 1; }
.rang-rubrique { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--texte-doux); }
.rang-corps h4 { font-size: 1.06rem; line-height: 1.3; margin: 0; }
.rang-corps h4 a { color: var(--encre); }
.rang-corps h4 a:hover { color: var(--or-sombre); }

/* ===== Derniers articles ===== */
.section-derniers { background: var(--brume); }
.grille-feuillets { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 30px; }

.feuillet { display: flex; flex-direction: column; background: var(--blanc); border: 1px solid var(--bordure); border-radius: 3px; overflow: hidden; transition: box-shadow .2s, transform .2s; }
.feuillet:hover { box-shadow: var(--ombre-portee); transform: translateY(-3px); }
.feuillet-visuel { display: block; aspect-ratio: 16/10; background: var(--brume); overflow: hidden; }
.feuillet-visuel img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s; }
.feuillet:hover .feuillet-visuel img { transform: scale(1.05); }
.feuillet-corps { display: flex; flex-direction: column; gap: 10px; padding: 20px 22px 22px; flex: 1; }
.feuillet-titre { font-size: 1.22rem; line-height: 1.28; margin: 4px 0 0; }
.feuillet-titre a { color: var(--encre); }
.feuillet-titre a:hover { color: var(--or-sombre); }
.feuillet-extrait { font-size: .95rem; color: var(--texte-doux); margin: 0; flex: 1; }
.feuillet-meta { font-size: .82rem; color: var(--texte-doux); letter-spacing: .02em; }

/* ===== Bandeau repères (chiffres) ===== */
.bandeau-reperes { position: relative; color: var(--blanc); background: var(--ardoise-fonce); overflow: hidden; }
.bandeau-reperes::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(700px 300px at 85% 50%, rgba(212,175,55,.16), transparent 60%);
}
.bandeau-reperes-int { position: relative; max-width: var(--large); margin-inline: auto; padding: 58px 22px; }
.bandeau-reperes-titre { color: var(--blanc); font-size: 1.7rem; margin-bottom: 30px; }
.bandeau-reperes-titre::after { content: ""; display: block; width: 50px; height: 3px; background: var(--or); margin-top: 12px; }
.bandeau-reperes-grille { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.repere { padding-left: 20px; border-left: 1px solid rgba(255,255,255,.16); }
.repere-chiffre { display: block; font-family: var(--serif); font-weight: 800; font-size: 2.6rem; color: var(--or); line-height: 1; margin-bottom: 8px; }
.repere-libelle { font-size: .9rem; color: var(--texte-clair); }

/* =========================================================================
   Pied
   ========================================================================= */
.pied { background: var(--encre); color: var(--texte-clair); }
.pied-int { max-width: var(--large); margin-inline: auto; padding: 64px 22px 40px; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.pied-marque .marque-nom--clair { font-family: var(--serif); font-weight: 800; font-size: 1.6rem; color: var(--blanc); text-transform: uppercase; letter-spacing: .04em; display: inline-flex; align-items: baseline; }
.pied-marque .marque-nom--clair .marque-point { margin-left: 3px; margin-bottom: 5px; }
.pied-marque p { margin: 16px 0 0; font-size: .95rem; max-width: 320px; line-height: 1.6; }
.pied-col h3 { color: var(--blanc); font-family: var(--sans); font-size: .82rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 18px; }
.pied-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.pied-col a { color: var(--texte-clair); font-size: .95rem; }
.pied-col a:hover { color: var(--or); }
.pied-bas { border-top: 1px solid rgba(255,255,255,.08); }
.pied-bas p { max-width: var(--large); margin-inline: auto; padding: 22px; font-size: .85rem; color: rgba(255,255,255,.5); }

/* =========================================================================
   Fil d'Ariane
   ========================================================================= */
.fil-int { max-width: var(--large); margin-inline: auto; padding: 22px 22px 0; }
.fil ol { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin: 0; padding: 0; font-size: .85rem; color: var(--texte-doux); }
.fil li { display: flex; align-items: center; gap: 8px; }
.fil li:not(:last-child)::after { content: "›"; color: var(--texte-doux); opacity: .6; }
.fil a { color: var(--texte-doux); }
.fil a:hover { color: var(--or-sombre); }
.fil-actuel span { color: var(--encre); font-weight: 600; }

/* =========================================================================
   Article
   ========================================================================= */
.page-article { max-width: var(--large); margin-inline: auto; padding: 26px 22px 70px; }
.article-entete { max-width: 820px; margin: 0 auto 26px; text-align: center; }
.article-entete .feuillet-rubrique { margin-bottom: 18px; }
.article-entete h1 { font-size: clamp(2rem, 4.4vw, 3rem); margin: 0 0 .35em; }
.article-meta { display: inline-flex; align-items: center; gap: 12px; font-size: .9rem; color: var(--texte-doux); }
.point-sep { width: 4px; height: 4px; border-radius: 50%; background: var(--or); }

.article-visuel { margin: 0 0 40px; border-radius: 4px; overflow: hidden; max-width: 980px; margin-inline: auto; }
.article-visuel img { width: 100%; height: auto; }

.article-grille { display: grid; grid-template-columns: minmax(0, 1fr) 312px; gap: 56px; align-items: start; max-width: 1040px; margin-inline: auto; }

/* Corps rédactionnel */
.article-corps { font-size: 1.075rem; line-height: 1.85; color: var(--texte); max-width: 760px; overflow-wrap: break-word; }
.article-corps > *:first-child { margin-top: 0; }
.article-corps p { margin: 0 0 1.3em; }
.article-corps h2 { font-size: 1.72rem; margin: 1.9em 0 .6em; padding-top: .2em; }
.article-corps h2::after { content: ""; display: block; width: 46px; height: 3px; background: var(--or); margin-top: .45em; }
.article-corps h3 { font-size: 1.32rem; margin: 1.6em 0 .5em; }
.article-corps h4 { font-size: 1.08rem; margin: 1.4em 0 .4em; }
.article-corps a { color: var(--or-sombre); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.article-corps a:hover { color: var(--or); }
.article-corps ul, .article-corps ol { margin: 0 0 1.4em; padding-left: 1.4em; }
.article-corps li { margin-bottom: .55em; }
.article-corps ul li::marker { color: var(--or-sombre); }
.article-corps ol li::marker { color: var(--or-sombre); font-weight: 700; }
.article-corps img { border-radius: 4px; margin: 1em 0; }
.article-corps figure { margin: 1.8em 0; }
.article-corps figure img { margin: 0 auto; }
.article-corps figcaption { font-size: .85rem; color: var(--texte-doux); text-align: center; margin-top: .6em; }
.article-corps blockquote {
  margin: 1.8em 0; padding: 4px 0 4px 26px; border-left: 3px solid var(--or);
  font-family: var(--serif); font-size: 1.3rem; font-style: italic; color: var(--ardoise);
}
.article-corps blockquote p { margin-bottom: .4em; }
.article-corps table { width: 100%; border-collapse: collapse; margin: 1.8em 0; font-size: .96rem; }
.article-corps th, .article-corps td { padding: 12px 16px; border: 1px solid var(--bordure); text-align: left; vertical-align: top; }
.article-corps thead th, .article-corps tr:first-child th { background: var(--encre); color: var(--blanc); font-family: var(--sans); font-weight: 600; }
.article-corps tbody tr:nth-child(even) { background: var(--brume); }
.article-corps hr { border: 0; height: 1px; background: var(--bordure); margin: 2.4em 0; }
.article-corps strong { color: var(--encre); }
.article-corps pre { overflow-x: auto; background: var(--brume); padding: 16px; border-radius: 4px; font-size: .9rem; }
/* Tableaux scrollables horizontalement sur petit écran */
.tableau-defile { overflow-x: auto; margin: 1.8em 0; -webkit-overflow-scrolling: touch; }
.tableau-defile table { margin: 0; min-width: 460px; }

/* Alignements WordPress + légendes */
.article-corps .aligncenter, .article-corps figure.aligncenter { margin-left: auto; margin-right: auto; text-align: center; }
.article-corps .alignright { float: right; margin: .4em 0 1em 1.6em; max-width: 50%; }
.article-corps .alignleft { float: left; margin: .4em 1.6em 1em 0; max-width: 50%; }
.article-corps p[style*="center"] { text-align: center; }
.article-corps .wp-caption { max-width: 100%; }
.article-corps .wp-caption-text { font-size: .85rem; color: var(--texte-doux); text-align: center; }

/* iFrames responsives */
.cadre-video { position: relative; width: 100%; padding-top: 56.25%; margin: 1.8em 0; border-radius: 4px; overflow: hidden; background: var(--encre); }
.cadre-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* Colonne latérale (maillage) */
.colonne-laterale { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 30px; }
.bloc-lateral { background: var(--brume); border: 1px solid var(--bordure); border-radius: 4px; padding: 22px; }
.bloc-lateral-titre { font-size: 1.05rem; margin: 0 0 16px; padding-bottom: 12px; border-bottom: 1px solid var(--bordure); }
.bloc-lateral-liste { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.bloc-lateral-liste a { display: grid; grid-template-columns: 64px 1fr; gap: 12px; align-items: center; color: var(--encre); }
.bloc-lateral-liste img { width: 64px; height: 48px; object-fit: cover; border-radius: 3px; }
.bloc-lateral-liste span { font-size: .9rem; line-height: 1.35; font-weight: 500; }
.bloc-lateral-liste a:hover span { color: var(--or-sombre); }
.bloc-lateral-rubriques { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.bloc-lateral-rubriques a { display: flex; align-items: center; gap: 10px; padding: 8px 0; color: var(--ardoise); font-size: .95rem; font-weight: 500; border-bottom: 1px solid var(--bordure); }
.bloc-lateral-rubriques li:last-child a { border-bottom: 0; }
.bloc-lateral-rubriques a:hover { color: var(--or-sombre); }
.bloc-lateral-rubriques .puce { width: 9px; height: 9px; border-radius: 50%; background: var(--accent, var(--or)); }
.bloc-lateral-rubriques em { margin-left: auto; font-style: normal; font-size: .82rem; color: var(--texte-doux); }

.section-lire-aussi { background: var(--blanc); border-top: 1px solid var(--bordure); }

/* =========================================================================
   Archives (blog, rubriques, recherche)
   ========================================================================= */
.entete-archive { background: var(--brume); border-bottom: 1px solid var(--bordure); }
.entete-archive-int { max-width: var(--large); margin-inline: auto; padding: 52px 22px; }
.entete-archive h1 { font-size: clamp(2rem, 4vw, 2.8rem); margin: 0 0 .25em; }
.entete-archive p { color: var(--texte-doux); margin: 0; font-size: 1.05rem; }
.entete-rubrique { background: var(--encre); color: var(--blanc); border-bottom: 0; position: relative; overflow: hidden; }
.entete-rubrique::before { content: ""; position: absolute; inset: 0; background: radial-gradient(600px 260px at 90% 0%, color-mix(in srgb, var(--accent, var(--or)) 30%, transparent), transparent 60%); }
.entete-rubrique .entete-archive-int { position: relative; }
.entete-rubrique h1 { color: var(--blanc); }
.entete-rubrique p { color: var(--texte-clair); }
.entete-rubrique-tag { display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--accent, var(--or)); margin-bottom: 14px; }

.zone-liste { max-width: var(--large); margin-inline: auto; padding: 50px 22px 70px; }
.vide { color: var(--texte-doux); text-align: center; padding: 40px 0; }

.recherche-bloc { display: flex; gap: 12px; margin-top: 18px; max-width: 560px; }
.recherche-bloc input { flex: 1; padding: .8em 1em; border: 1px solid var(--bordure); border-radius: 2px; font-size: 1rem; }

/* Grille rubriques (pavés) */
.grille-rubriques { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pave-rubrique { display: flex; flex-direction: column; gap: 10px; padding: 30px 26px; background: var(--blanc); border: 1px solid var(--bordure); border-top: 3px solid var(--accent, var(--or)); border-radius: 3px; color: var(--encre); transition: box-shadow .2s, transform .2s; }
.pave-rubrique:hover { box-shadow: var(--ombre-portee); transform: translateY(-3px); color: var(--encre); }
.pave-rubrique-pastille { width: 34px; height: 34px; border-radius: 50%; background: var(--accent, var(--or)); opacity: .9; }
.pave-rubrique h2 { font-size: 1.4rem; margin: 6px 0 0; }
.pave-rubrique-nb { font-size: .85rem; font-weight: 600; color: var(--or-sombre); }
.pave-rubrique-dernier { font-size: .9rem; color: var(--texte-doux); line-height: 1.4; }

/* =========================================================================
   Pages statiques / contact
   ========================================================================= */
.page-statique { max-width: var(--etroit); margin-inline: auto; padding: 30px 22px 70px; }
.page-statique-entete { margin-bottom: 30px; }
.page-statique-entete h1 { font-size: clamp(1.9rem, 4vw, 2.6rem); }
.page-statique-entete p { color: var(--texte-doux); font-size: 1.08rem; margin: 0; }
.page-statique-corps { max-width: none; }

.formulaire-contact { display: flex; flex-direction: column; gap: 18px; }
.formulaire-contact label { display: flex; flex-direction: column; gap: 7px; font-weight: 600; font-size: .92rem; color: var(--encre); }
.formulaire-contact input, .formulaire-contact textarea { padding: .75em 1em; border: 1px solid var(--bordure); border-radius: 2px; font-size: 1rem; font-family: var(--sans); background: var(--blanc); }
.formulaire-contact input:focus, .formulaire-contact textarea:focus { border-color: var(--or); outline: none; }
.formulaire-contact .bouton-or { align-self: flex-start; }
.champ-piege { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.message-ok { background: #ecf7ec; border: 1px solid #bfe3bf; color: #2f6b2f; padding: 18px 22px; border-radius: 3px; margin-bottom: 20px; }
.message-erreur { background: #fdeceb; border: 1px solid #f1c3bf; color: #a53b30; padding: 14px 18px; border-radius: 3px; margin-bottom: 18px; }

/* =========================================================================
   Pagination
   ========================================================================= */
.pagination { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-top: 50px; }
.page-lien { display: grid; place-items: center; min-width: 44px; height: 44px; padding: 0 14px; border: 1px solid var(--bordure); border-radius: 2px; color: var(--ardoise); font-weight: 600; font-size: .92rem; background: var(--blanc); }
.page-lien:hover { border-color: var(--or); color: var(--or-sombre); }
.page-actuelle { background: var(--encre); border-color: var(--encre); color: var(--blanc); }
.page-actuelle:hover { color: var(--blanc); }
.page-ellipse { display: grid; place-items: center; min-width: 30px; height: 44px; color: var(--texte-doux); }

/* =========================================================================
   404
   ========================================================================= */
.zone-404 { padding: 90px 22px; text-align: center; }
.zone-404-int { max-width: 560px; margin-inline: auto; }
.code-404 { display: block; font-family: var(--serif); font-weight: 800; font-size: 6rem; line-height: 1; color: var(--or); margin-bottom: 12px; }
.zone-404 h1 { font-size: 1.9rem; margin-bottom: 12px; }
.zone-404 p { color: var(--texte-doux); margin-bottom: 30px; }
.zone-404-suggestions { margin-top: 46px; }
.zone-404-suggestions h2 { font-size: 1rem; font-family: var(--sans); color: var(--texte-doux); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 14px; }
.zone-404-suggestions ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.zone-404-suggestions a { color: var(--or-sombre); text-decoration: underline; }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 1080px) {
  .pied-int { grid-template-columns: 1fr 1fr 1fr; }
  .pied-marque { grid-column: 1 / -1; }
}
/* En-tête : passage en menu déroulant dès que les 6 rubriques ne tiennent plus */
@media (max-width: 960px) {
  .menu-rubriques {
    display: none; position: absolute; top: 76px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--encre); padding: 8px 22px 18px; border-top: 1px solid rgba(255,255,255,.08);
  }
  .menu-rubriques.ouvert { display: flex; }
  .menu-rubriques a { padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
  .menu-rubriques a::after { display: none; }
  .declic-menu { display: block; }
}
@media (max-width: 920px) {
  .section-une-grille { grid-template-columns: 1fr; gap: 40px; }
  .article-grille { grid-template-columns: 1fr; gap: 44px; }
  .colonne-laterale { position: static; }
  .grille-feuillets { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grille-rubriques { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .bandeau-rubriques-int { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .vignette-rubrique:nth-child(3n) { border-right: 0; }
}
@media (max-width: 760px) {
  body { font-size: 17px; }
  .barre-haut-actions .bouton-or { display: none; }
  .bandeau-reperes-grille { grid-template-columns: repeat(2, 1fr); gap: 30px 20px; }
  .pied-int { grid-template-columns: 1fr 1fr; }
  .tribune-une-int { padding: 64px 22px 68px; }
  .titre-rang { flex-direction: column; gap: 6px; }
  .classement-une .rang { grid-template-columns: 80px 1fr; }
  .recherche-bloc, .volet-recherche { flex-direction: column; }
  .article-corps .alignleft, .article-corps .alignright { float: none; margin: 1em auto; max-width: 100%; }
  .surtitre { font-size: .66rem; letter-spacing: .1em; flex-wrap: wrap; }
  .surtitre::before { width: 26px; }
}
@media (max-width: 560px) {
  .bandeau-rubriques-int { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .vignette-rubrique { border-right: 0 !important; border-bottom: 1px solid var(--bordure); padding: 18px 10px; }
  .vignette-rubrique:nth-child(odd) { border-right: 1px solid var(--bordure) !important; }
  .vignette-rubrique-nom { font-size: .92rem; }
}
@media (max-width: 460px) {
  .grille-feuillets, .grille-rubriques { grid-template-columns: 1fr; }
  .pied-int { grid-template-columns: 1fr; }
  .marque-nom { font-size: 1.45rem; }
}
