/* ============================================================
   Gravart — Performance overrides
   Loaded LAST. Tames the heaviest GPU/CPU effects without
   sacrificing the visual identity.
   ============================================================ */

/* ---- 1. Custom cursor : désactivé partout ---- */
.cursor-dot, .cursor-ring { display: none !important; }
html, body, button, a, input, textarea, select, [role="button"] { cursor: auto; }
a, button, [role="button"] { cursor: pointer; }

/* ---- 2. Backdrop-filter : suppression globale, fallback en couleur opaque ---- */
* , *::before, *::after {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.nav.scrolled {
  background: rgba(244, 239, 230, 0.96) !important;
}
.nav.over-dark.scrolled {
  background: rgba(20, 16, 12, 0.94) !important;
  color: var(--bone);
}
.svc-slide-tag,
.cat-badge,
.article-cover-caption {
  background: rgba(14, 10, 7, 0.85) !important;
}

/* ---- 3. Hero halos : on les garde visibles mais on stoppe l'animation ----
   (l'animation faisait re-compositer un blur(42px) en boucle = très coûteux) */
.hero-halo,
.halo-1, .halo-2, .halo-3 {
  animation: none !important;
  will-change: auto;
}

/* ---- 4. Grain : conservé seulement sur le hero, retiré ailleurs ---- */
.products .grain::before,
.products-section .grain::before,
.services-section.grain::before,
.cta.grain::before,
.about.grain::before,
.process.grain::before,
.testimonials.grain::before,
.contact.grain::before,
.footer.grain::before,
.article-hero.grain::before,
.article-cta.grain::before,
.related.grain::before {
  display: none !important;
}

/* ---- 5. mix-blend-mode : retiré (force le navigateur à passer hors GPU) ---- */
.grain::before { mix-blend-mode: normal !important; }

/* ---- 6. Trust marquee : ribbon plus marqué + compact ---- */
.trust-bar {
  background: var(--bone-2, #efe7d6) !important;
  border-top: 2px solid var(--ink) !important;
  border-bottom: 2px solid var(--ink) !important;
  padding: 18px 0 !important;
  box-shadow: inset 0 1px 0 rgba(20,16,12,0.06), inset 0 -1px 0 rgba(20,16,12,0.06);
}
.trust-track {
  animation-duration: 60s !important;
  gap: 28px !important;
  align-items: center !important;   /* centre verticalement items + séparateurs */
}
.trust-item {
  font-size: clamp(1.05rem, 1.8vw, 1.45rem) !important;
  gap: 12px !important;
  font-weight: 300;
  align-items: center !important;
}
/* Tiret en lieu et place du dot — centré verticalement */
.trust-sep {
  width: auto !important;
  height: auto !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  color: var(--brass) !important;
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(1.05rem, 1.8vw, 1.45rem);
  line-height: 1;
  flex-shrink: 0;
}
.trust-sep::before {
  content: '/';
  display: inline-block;
  transform: translateY(-1px);     /* compense le décalage optique du tiret */
}
.paused-offscreen .trust-track,
.paused-offscreen .track-right,
.paused-offscreen .track-left { animation-play-state: paused !important; }

/* ---- 6b. Containment : isole les repaints des cartes ---- */
.strip-card,
.svc-slide,
.testi-card,
.blog-card,
.process-step,
.product-card,
.gallery-tile {
  contain: layout paint;
}
.products-row,
.trust-bar { contain: layout paint; }

/* ---- 7. Pulse de la "live dot" : conservé mais discret ---- */

/* ---- 8. Réduction des animations longues sur transition: all ----
   (le `transition: all` force le navigateur à observer toutes les propriétés) */
.nav { transition: padding 0.3s var(--ease), background 0.3s var(--ease) !important; }
.svc-slide,
.strip-card,
.process-step,
.testi-card,
.blog-card,
.contact-info-row,
.btn,
.svc-arr,
.svc-dot,
.product-card,
.faq-q {
  transition: transform 0.3s var(--ease), background 0.3s var(--ease), border-color 0.3s var(--ease), color 0.2s var(--ease), opacity 0.3s var(--ease) !important;
}

/* ---- 9. content-visibility : retiré (causait des blancs visuels au scroll rapide,
       surtout mobile, car le rendu était différé jusqu'à l'entrée dans le viewport) ---- */

/* ---- 9b. Reveal animation : durée raccourcie pour ressenti plus snappy ---- */
.reveal {
  transition: opacity 0.6s var(--ease, cubic-bezier(.2,.7,.2,1)),
              transform 0.6s var(--ease, cubic-bezier(.2,.7,.2,1)) !important;
}
.mask-reveal > span {
  transition: transform 0.7s var(--ease, cubic-bezier(.2,.7,.2,1)) !important;
}
/* On garde les delays existants mais on les compacte */
.reveal-d1 { transition-delay: 0.06s !important; }
.reveal-d2 { transition-delay: 0.12s !important; }
.reveal-d3 { transition-delay: 0.18s !important; }
.reveal-d4 { transition-delay: 0.24s !important; }

/* ============================================================
   PAGE HEROES — pattern unifié (services, bar à gravure, blog)
   ============================================================ */
.page-hero {
  background: var(--ink) !important;
  color: var(--bone);
  padding: 160px 0 90px !important;
  border-bottom: 1px solid var(--line-inv-soft);
  position: relative; overflow: hidden;
}
.page-hero .grain.grain-light::before,
.page-hero.grain::before { display: none !important; }

.page-hero .page-hero-grid,
.page-hero .blog-hero-grid {
  display: grid !important;
  grid-template-columns: 1.15fr 1fr;
  gap: 70px !important;
  align-items: end !important;
}
.page-hero .page-hero-left,
.page-hero .blog-hero-left {
  display: flex; flex-direction: column; gap: 22px;
}
.page-hero .page-hero-left .t-eyebrow,
.page-hero .blog-hero-left .t-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brass-soft);
}

/* Titres harmonisés */
.page-hero h1,
.page-hero .blog-hero-title {
  font-family: var(--display) !important;
  font-weight: 200 !important;
  font-size: clamp(2.8rem, 8vw, 7rem) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.038em !important;
  color: var(--bone) !important;
  margin: 0 !important;
  max-width: none !important;
}
.page-hero h1 em,
.page-hero .blog-hero-title em {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--brass-soft) !important;
}

/* Colonne droite */
.page-hero .page-hero-right,
.page-hero .blog-hero-right {
  display: flex; flex-direction: column; gap: 26px;
  padding-bottom: 6px;
  max-width: 38ch;
}
.page-hero .page-hero-lead,
.page-hero .page-hero-right p,
.page-hero .blog-hero-right p {
  font-family: var(--sans) !important;
  font-style: normal !important;
  font-size: 1.02rem !important;
  line-height: 1.6 !important;
  color: var(--bone) !important;
  opacity: 0.86 !important;
  margin: 0 !important;
}

/* Page Services : grille rééquilibrée — titre plus large à gauche */
.page-hero-services .page-hero-grid {
  grid-template-columns: 1.35fr 1fr !important;
  gap: 80px !important;
}
.page-hero-services .page-hero-right {
  max-width: 100%;
  padding-left: 0;
}

/* Liste d'ancres : titre + flèche collée au texte */
.page-services-anchors {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  border-top: 1px solid var(--line-inv-soft);
}
.page-services-anchors li { border-bottom: 1px solid var(--line-inv-soft); }
.page-services-anchors a {
  display: flex;
  align-items: center;
  justify-content: flex-start;       /* texte + flèche groupés à gauche */
  gap: 14px;
  padding: 18px 0;
  text-decoration: none;
  font-family: var(--display);
  font-weight: 300;
  font-size: 1.25rem;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--bone);
  transition: padding-left 0.35s var(--ease), color 0.35s var(--ease);
}
.page-services-anchors a::after {
  content: '→';
  font-family: var(--sans);
  font-size: 16px;
  color: var(--brass);
  flex-shrink: 0;
  transition: transform 0.35s var(--ease), color 0.35s var(--ease);
}
.page-services-anchors a:hover { padding-left: 10px; color: var(--brass-soft); }
.page-services-anchors a:hover::after { transform: translateX(8px); color: var(--bone); }

/* Mobile */
@media (max-width: 900px) {
  .page-hero-services .page-hero-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
  .page-hero-services .page-hero-right { padding-left: 0; }
  .page-services-anchors a { font-size: 1.1rem; }
}

/* Bar à gravure : grille 1fr 1fr avec image cohérente */
.page-hero.page-hero-bag .bag-hero-grid {
  grid-template-columns: 1fr 1fr !important;
  align-items: center !important;
  gap: 70px !important;
}
.page-hero-bag .page-hero-left { gap: 22px; }
.page-hero-bag .hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 6px; }
.page-hero-bag .bag-hero-vis {
  position: relative;
  border: 1px solid var(--line-inv-soft);
}
.page-hero-bag .bag-hero-vis img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  aspect-ratio: 4 / 3;
}
.page-hero-bag .bag-hero-meta {
  position: absolute;
  bottom: 14px; left: 14px; right: 14px;
  display: flex; justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bone);
  pointer-events: none;
}

/* Mobile */
@media (max-width: 900px) {
  .page-hero { padding: 120px 0 60px !important; }
  .page-hero .page-hero-grid,
  .page-hero .blog-hero-grid,
  .page-hero.page-hero-bag .bag-hero-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
    align-items: start !important;
  }
  .page-hero h1, .page-hero .blog-hero-title { font-size: clamp(2.4rem, 11vw, 3.6rem) !important; }
  .page-hero .page-hero-right,
  .page-hero .blog-hero-right { max-width: 100%; }
}

/* ============================================================
   Hero — refonte 2 lignes + harmonie colonne droite
   ============================================================ */

/* Hero section : ancre les stats en bas, met le contenu en flex column */
.hero {
  display: flex !important;
  flex-direction: column;
  min-height: 92vh;
}
.hero > .wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* Grille hero : titre à gauche, colonne droite poussée à droite et centrée verticalement */
.hero-grid {
  grid-template-columns: 1fr minmax(280px, 360px) !important;
  gap: 120px !important;
  align-items: center !important;     /* centrage vertical */
  justify-items: stretch !important;
  padding: 140px 0 60px !important;
  flex: 1;
}
.hero-right {
  justify-self: end !important;        /* colle à droite */
  align-self: center !important;
  width: 100%;
  padding-bottom: 0 !important;
}

/* Stats poussés en bas de la section */
.hero-stats {
  margin-top: auto !important;
  padding: 28px 0 36px !important;
}

@media (max-width: 1024px) {
  .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
    padding: 120px 0 40px !important;
  }
  .hero-right { justify-self: stretch !important; align-self: stretch !important; }
  .hero-title.hero-title-2l {
    font-size: clamp(3.4rem, 13vw, 6rem) !important;   /* mobile : titre largement plus gros */
    line-height: 0.95 !important;
  }
  .hero-title.hero-title-2l .line-2 { margin-left: 0; }
}
@media (max-width: 600px) {
  .hero-title.hero-title-2l {
    font-size: clamp(3rem, 15vw, 4.6rem) !important;
  }
}

/* Titre 2 lignes : on resserre le tracking et on ajuste le clamp pour
   éviter le pavé visuel quand on supprime une ligne */
.hero-title.hero-title-2l {
  font-size: clamp(3.2rem, 9.4vw, 8.6rem) !important;
  line-height: 0.92 !important;
  letter-spacing: -0.04em !important;
  margin-bottom: 0 !important;
}
.hero-title.hero-title-2l .line { padding-bottom: 0.08em; margin-bottom: -0.08em; }
.hero-title.hero-title-2l .line-2 { margin-left: 0.55em; }    /* léger décalage stylistique */

/* Colonne droite : on pose une vraie hiérarchie verticale */
.hero-right {
  gap: 22px !important;
  padding-bottom: 14px !important;
  max-width: 36ch;
}
.hero-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brass-soft);
  display: block;
  margin-bottom: -8px; /* serre le rapport eyebrow → lead */
}
.hero-lead {
  font-size: 1.12rem !important;
  line-height: 1.6 !important;
  max-width: 36ch !important;
  color: var(--bone) !important;
  opacity: 0.9;
}
.hero-actions { gap: 12px !important; margin-top: 8px; }
.hero-title.hero-title-2l {
  font-size: clamp(2.8rem, 8.4vw, 7.6rem) !important;
}
.hero-tag {
  align-self: flex-start;
  margin-top: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* Mobile : tout centré, ordre logique conservé */
@media (max-width: 900px) {
  .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
    padding: 110px 0 60px !important;
    align-items: start !important;
  }
  .hero-title.hero-title-2l .line-2 { margin-left: 0; }
  .hero-right { max-width: 100%; }
}

/* ============================================================
   Blog index (home.php) — harmonisation typo & visuel
   ============================================================ */

.blog-page-hero {
  background: var(--ink);
  color: var(--bone);
  padding: 160px 0 90px !important;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--line-inv-soft);
}

.blog-hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 80px;
  align-items: end;
}
.blog-hero-left { display: flex; flex-direction: column; gap: 22px; }
.blog-hero-left .t-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brass-soft);
}
.blog-hero-title {
  font-family: var(--display);
  font-weight: 200;
  font-size: clamp(3.2rem, 9.4vw, 8.6rem) !important;
  line-height: 0.92 !important;
  letter-spacing: -0.04em !important;
  color: var(--bone);
  margin: 0;
}
.blog-hero-title em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--brass-soft);
}

.blog-hero-right {
  display: flex; flex-direction: column;
  gap: 28px;
  padding-bottom: 12px;
  max-width: 38ch;
}
.blog-hero-lead {
  font-family: var(--sans);
  font-size: 1.04rem;
  line-height: 1.6;
  color: var(--bone);
  opacity: 0.86;
  margin: 0;
}
.blog-hero-meta {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  border-top: 1px solid var(--line-inv-soft);
  padding-top: 22px;
}
.blog-hero-meta li {
  display: flex; flex-direction: column; gap: 6px;
}
.blog-hero-meta .k {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-inv-3);
}
.blog-hero-meta .v {
  font-family: var(--display);
  font-weight: 200;
  font-size: 1.6rem;
  color: var(--bone);
  letter-spacing: -0.01em;
}

/* Filter chips */
.blog-page-hero .blog-cats {
  margin-top: 60px;
  padding-top: 28px;
  border-top: 1px solid var(--line-inv-soft);
  display: flex; flex-wrap: wrap; gap: 10px;
}
.blog-page-hero .blog-cats .cat {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: transparent;
  border: 1px solid var(--line-inv-soft);
  border-radius: 999px;
  padding: 9px 16px;
  cursor: pointer;
  transition: background 0.25s var(--ease), color 0.25s var(--ease), border-color 0.25s var(--ease);
}
.blog-page-hero .blog-cats .cat:hover { border-color: var(--brass); color: var(--brass-soft); }
.blog-page-hero .blog-cats .cat.active {
  background: var(--brass);
  color: var(--ink);
  border-color: var(--brass);
}

/* Featured article — harmonisé avec les cartes home */
.blog-featured-wrap { background: var(--bone); padding: 100px 0 60px; }
.featured-article {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  background: var(--bone-2);
  text-decoration: none;
  color: var(--ink);
  border: 1px solid var(--line);
  overflow: hidden;
  transition: transform 0.5s var(--ease), border-color 0.3s var(--ease);
}
.featured-article:hover { border-color: var(--brass); }
.featured-article .fa-image {
  position: relative; aspect-ratio: 4/3; overflow: hidden;
  background: var(--bone-3, #e8e0d2);
}
.featured-article .fa-image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.1s var(--ease);
}
.featured-article:hover .fa-image img { transform: scale(1.04); }
.featured-article .fa-image .tag {
  position: absolute;
  top: 18px; left: 18px;
  background: var(--ink); color: var(--bone);
  padding: 6px 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.featured-article .fa-text {
  padding: 50px 50px 50px;
  display: flex; flex-direction: column;
  gap: 16px;
  justify-content: center;
}
.featured-article .fa-text .t-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brass);
}
.featured-article .fa-text h2 {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}
.featured-article .fa-text h2 em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--brass-deep);
}
.featured-article .fa-text p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.65;
  color: var(--fg-2);
  margin: 0;
}
.featured-article .fa-meta {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.featured-article .fa-meta .dot {
  width: 3px; height: 3px; border-radius: 50%; background: var(--brass);
}
.featured-article .fa-text .btn { align-self: flex-start; margin-top: 6px; }

/* ============================================================
   Vignette d'article — style éditorial unifié
   (s'applique à .blog-card sur la home/blog ET .related-card
    dans la section "articles similaires" des single)
   ============================================================ */

.blog-grid-wrap { background: var(--bone); padding: 60px 0 120px; }
.blog-grid-wrap .blog-grid,
.blog-preview .blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px 22px;
  counter-reset: blog-card;
}

/* ---- Card frame ---- */
.blog-grid-wrap .blog-card,
.blog-preview .blog-card,
.related-grid .related-card {
  display: flex;
  flex-direction: column;
  background: var(--bone);
  border: 1px solid var(--line);
  text-decoration: none;
  color: var(--ink);
  position: relative;
  overflow: hidden;
  counter-increment: blog-card;
  transition: border-color 0.45s var(--ease), transform 0.45s var(--ease);
}
.blog-grid-wrap .blog-card:hover,
.blog-preview .blog-card:hover,
.related-grid .related-card:hover {
  border-color: var(--ink);
  transform: translateY(-3px);
}

/* ---- Image (16:10 = plus compacte que 4:3) ---- */
.blog-grid-wrap .blog-card .blog-img-wrap,
.blog-preview .blog-card .blog-img-wrap,
.related-grid .related-card .rc-img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: radial-gradient(120% 80% at 50% 30%, #f1ebe1 0%, #e8e0d2 60%, #ddd2bf 100%);
  position: relative;
}
.blog-grid-wrap .blog-card .blog-img-wrap img,
.blog-preview .blog-card .blog-img-wrap img,
.related-grid .related-card .rc-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.1s var(--ease);
  display: block;
}
.blog-grid-wrap .blog-card:hover .blog-img-wrap img,
.blog-preview .blog-card:hover .blog-img-wrap img,
.related-grid .related-card:hover .rc-img img { transform: scale(1.04); }

/* ---- Numéro "01" + meta line (compacts) ---- */
.blog-grid-wrap .blog-card .blog-meta,
.blog-preview .blog-card .blog-meta {
  padding: 14px 16px 0;
  display: flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-3);
  position: relative;
}
.blog-grid-wrap .blog-card .blog-meta::before,
.blog-preview .blog-card .blog-meta::before {
  content: counter(blog-card, decimal-leading-zero);
  font-family: var(--display);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0;
  color: var(--brass);
  padding-right: 10px;
  margin-right: 4px;
  border-right: 1px solid var(--line);
  line-height: 1;
}
.blog-grid-wrap .blog-card .blog-meta .cat,
.blog-preview .blog-card .blog-meta .cat { color: var(--brass); }
.blog-grid-wrap .blog-card .blog-meta .sep,
.blog-preview .blog-card .blog-meta .sep {
  width: 3px; height: 3px; border-radius: 50%; background: var(--brass);
  flex-shrink: 0;
}

/* Variante related-card : cat-pill compacte */
.related-grid .related-card .rc-cat {
  display: inline-block;
  margin: 14px 16px 0;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  padding: 5px 10px;
  border: 1px solid var(--brass);
  border-radius: 999px;
  align-self: flex-start;
  background: transparent !important;
}

/* ---- Title (gras, compact) ---- */
.blog-grid-wrap .blog-card h3,
.blog-preview .blog-card h3,
.related-grid .related-card h4 {
  padding: 8px 16px 0;
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.08rem;
  line-height: 1.22;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
  transition: color 0.4s var(--ease);
}
.blog-grid-wrap .blog-card h3 em,
.blog-preview .blog-card h3 em,
.related-grid .related-card h4 em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--brass-deep);
}
.blog-grid-wrap .blog-card:hover h3,
.blog-preview .blog-card:hover h3,
.related-grid .related-card:hover h4 { color: var(--brass-deep); }

/* ---- Excerpt (compact, max 2 lignes affichées) ---- */
.blog-grid-wrap .blog-card p,
.blog-preview .blog-card p {
  padding: 8px 16px 14px;
  font-family: var(--sans);
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--fg-2);
  margin: 0;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Related card meta */
.related-grid .related-card .rc-meta {
  margin-top: auto;
  padding: 10px 16px 12px;
  display: flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-3);
  border-top: 1px solid var(--line);
}
.related-grid .related-card .rc-meta .dot {
  width: 3px; height: 3px; border-radius: 50%; background: var(--brass);
}

/* ---- "Lire l'article →" en bas (blog-card, compact) ---- */
.blog-grid-wrap .blog-card .blog-readmore,
.blog-preview .blog-card .blog-readmore {
  margin-top: 0;
  padding: 10px 16px 12px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-deep);
  transition: background 0.4s var(--ease), color 0.4s var(--ease);
}
.blog-grid-wrap .blog-card .blog-readmore::after,
.blog-preview .blog-card .blog-readmore::after {
  content: '→';
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 0;
  transition: transform 0.45s var(--ease);
  transform: translateX(0);
}
.blog-grid-wrap .blog-card:hover .blog-readmore,
.blog-preview .blog-card:hover .blog-readmore {
  background: var(--ink);
  color: var(--bone);
}
.blog-grid-wrap .blog-card:hover .blog-readmore::after,
.blog-preview .blog-card:hover .blog-readmore::after { transform: translateX(6px); }

/* Mobile */
@media (max-width: 1024px) {
  .blog-grid-wrap .blog-grid,
  .blog-preview .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
}
@media (max-width: 700px) {
  .blog-grid-wrap .blog-grid,
  .blog-preview .blog-grid { grid-template-columns: 1fr; gap: 22px; }
  .blog-grid-wrap .blog-card h3,
  .blog-preview .blog-card h3,
  .related-grid .related-card h4 { font-size: 1.2rem; }
}

@media (max-width: 1024px) {
  .blog-grid-wrap .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-article { grid-template-columns: 1fr; }
  .featured-article .fa-text { padding: 40px 28px; }
}
@media (max-width: 700px) {
  .blog-page-hero { padding: 120px 0 60px !important; }
  .blog-hero-grid { grid-template-columns: 1fr; gap: 32px; align-items: start; }
  .blog-hero-meta { grid-template-columns: 1fr 1fr; }
  .blog-hero-right { max-width: 100%; }
  .blog-grid-wrap .blog-grid { grid-template-columns: 1fr; gap: 36px; }
  .blog-page-hero .blog-cats { margin-top: 40px; }
}

/* ============================================================
   Règle typo : serif italique réservé aux mots/courtes phrases.
   Tout texte long (paragraphes, leads, témoignages) → Inter Tight.
   Les <em> à l'intérieur restent serif (accent voulu).
   ============================================================ */
.t-lead,
.footer-about p,
.products-foot p,
.about-content .lead,
.about-content p,
.testi-text,
.cta p,
.contact-left .lead,
.contact-left p,
.page-hero-lead p,
.page-hero-sub p,
.svc-text .lead,
.svc-text p,
.blog-hero .lead,
.blog-hero p,
.blog-featured p,
.featured-article .fa-text p,
.blog-card p,
.process-step p,
.about-value-text,
.svc-slide-body p,
.contact-form-foot,
.hero-lead,
.blog-hero-lead,
.faq-a,
.section-head .sub,
p.lead, p.t-body, p.sub {
  font-family: var(--sans) !important;
  font-style: normal !important;
}

/* Les accents italiques imbriqués restent serif */
.t-lead em,
.footer-about p em,
.about-content .lead em,
.about-content p em,
.testi-text em,
.cta p em,
.contact-left .lead em,
.page-hero-lead p em,
.svc-text .lead em,
.blog-hero .lead em,
.blog-featured p em,
.featured-article .fa-text p em,
.blog-card p em,
.hero-lead em,
.blog-hero-lead em {
  font-family: var(--serif) !important;
  font-style: italic !important;
}

/* ============================================================
   Article single — cover plus mesurée + colonne lisible centrée
   ============================================================ */

/* Cover plus contenue (l'original 560 px, ratio variable, écrasait l'écran) */
.article-cover {
  max-height: 380px !important;
  aspect-ratio: 21 / 9;
}
.article-cover img {
  max-height: 380px !important;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 700px) {
  .article-cover { max-height: 240px !important; aspect-ratio: 16/10; }
  .article-cover img { max-height: 240px !important; }
}

/* Colonne de lecture : élargie un peu et centrage forcé */
.article-wrap { padding: 70px 24px 100px !important; }
.article-wrap > .article-col,
.article-wrap .article-col {
  max-width: 820px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: 100% !important;
  float: none !important;
}
.article-wrap .article-content { width: 100%; }

/* Les blocs spéciaux (callout, spec-table, num-list, product, cta-inline)
   doivent occuper toute la largeur de la colonne sans dépasser */
.article-content .article-callout,
.article-content .article-spec-table,
.article-content .article-num-list,
.article-content .article-product,
.article-content .article-cta-inline {
  width: 100%;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box;
}

/* Listes dans l'article : assure l'alignement et la largeur */
.article-content ul, .article-content ol {
  width: 100%;
  padding-left: 0;
}

/* Sécurité : si wpautop a tout de même injecté des <p> vides ou autour de commentaires */
.article-content > p:empty { display: none; }

/* ============================================================
   Section Contact — typographie renforcée (lisibilité)
   ============================================================ */

/* Colonne gauche : EMAIL / TÉL. / INSTA / LIEU */
.contact-info-row .k {
  font-size: 11px !important;
  letter-spacing: 0.18em !important;
  font-weight: 600 !important;
  color: var(--fg-2) !important;
}
.contact-info-row .v {
  font-size: 1.18rem !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
  letter-spacing: -0.005em !important;
  font-family: var(--sans) !important;
}

/* Colonne droite : labels + champs du formulaire */
.field label {
  font-size: 11.5px !important;
  letter-spacing: 0.18em !important;
  font-weight: 600 !important;
  color: var(--fg-2) !important;
}
.field input,
.field textarea,
.field select {
  font-size: 1.05rem !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
}
.field input::placeholder,
.field textarea::placeholder {
  color: var(--fg-3) !important;
  font-weight: 400 !important;
}

/* ---- 10. Respect des préférences utilisateur (accessibilité + perf) ---- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.05ms !important;
    scroll-behavior: auto !important;
  }
  .hero-halo, .halo-1, .halo-2, .halo-3,
  .trust-track,
  .track-right, .track-left {
    animation: none !important;
  }
}
