/************************************************************
 * SINGLE POST – MODERN CLEAN CSS (LUXE / EPURÉ) – FINAL (STABLE)
 * - 100% natif (aucun .wp-block-table, aucun ajout de class)
 * - Conserve l’esthétique (shadows, spacing, cards)
 * - Texte justifié
 * - Tables:
 *    - Desktop: table FULL WIDTH (colonnes s’étirent)
 *    - Mobile / manque de place: scroll horizontal sur le tableau
 *    - THEAD en secondary
 *    - Pas de bordures entre lignes, zebra + hover
 * - Strong: adouci (pas de gros paquets, pas surlignage agressif)
 * - Titres: couleur texte (pas de bleu/primary), H2 plus petit, pas de ::after
 ************************************************************/

/* ------------------------- BASE LAYOUT ------------------------- */

body.single-post .site-main {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.single.single--post.single--fullwidth {
  padding-top: 7.5rem !important;
  scroll-margin-top: 7.5rem !important;
  background: var(--e-global-color-cad7ef2) !important;
}

/* Force base modern system font for the whole single */
.single.single--post.single--fullwidth,
.single.single--post.single--fullwidth * {
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif !important;
}

/* ------------------------- HERO ------------------------- */

.single-hero--fullwidth {
  padding: 1.1rem 0 0.7rem !important;
}

.single-hero__inner {
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 4vw !important;
}

.single-hero__title {
  margin: 0 0 0.75rem !important;
  font-size: clamp(1.8rem, 2.2vw, 2rem) !important;
  line-height: 1.12 !important;
  letter-spacing: -0.03em !important;
  color: var(--e-global-color-text) !important;
}

.single-hero__title::after {
  display: none;
}

.single-hero__pills {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.55rem !important;
}

/* ------------------------- PILLS ------------------------- */

.single-pill {
  display: inline-flex !important;
  align-items: center !important;
  padding: 0.38rem 0.78rem !important;
  border-radius: 999px !important;
  font-size: 0.86rem !important;
  font-weight: 650 !important;
  letter-spacing: 0.01em !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.single-pill--primary {
  background: rgba(106, 0, 244, 0.08) !important;
  border-color: rgba(106, 0, 244, 0.22) !important;
  color: var(--e-global-color-secondary) !important;
}

.single-pill--secondary {
  background: rgba(106, 0, 244, 0.06) !important;
  border-color: rgba(106, 0, 244, 0.18) !important;
  color: var(--e-global-color-secondary) !important;
}

/* ------------------------- TOP MEDIA / META ------------------------- */

.single-top {
  padding: 0.2rem 0 1.1rem !important;
}

.single-top__inner {
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 4vw !important;

  display: grid !important;
  grid-template-columns: minmax(0, 0.62fr) minmax(0, 0.38fr) !important;
  gap: 1.1rem !important;
  align-items: start !important;
}

/* Prevent grid children overflow (tables/images/long words) */
.single-top__inner > * {
  min-width: 0 !important;
}

/* Featured image */
.single-featured {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  max-height: 460px !important;

  background: var(--e-global-color-cad7ef2) !important;
  overflow: hidden !important;

  border-radius: 14px !important;
  border: 1px solid rgba(119, 119, 119, 0.22) !important;

  box-shadow:
    0 10px 20px rgba(73, 70, 70, 0.08),
    0 25px 55px rgba(73, 70, 70, 0.10) !important;
}

.single-featured img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.single-featured--placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(119, 119, 119, 0.06) !important;
  color: var(--e-global-color-accent) !important;
  font-size: 0.95rem !important;
}

/* Meta: compact */
.single-meta {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.45rem !important;
}

.single-meta-row {
  display: grid !important;
  grid-template-columns: 18px auto 1fr !important;
  gap: 0.55rem !important;
  align-items: center !important;

  padding: 0.48rem 0 !important;
  border-bottom: 1px solid rgba(119, 119, 119, 0.18) !important;
  font-size: 0.96rem !important;
  color: var(--e-global-color-accent) !important;
}

.single-meta-row:last-child {
  border-bottom: none !important;
}

.single-icon {
  width: 18px !important;
  height: 18px !important;
  color: var(--e-global-color-secondary) !important;
}

.single-meta-label {
  font-weight: 700 !important;
  color: var(--e-global-color-text) !important;
}

.single-meta-value {
  text-align: right !important;
  font-weight: 550 !important;
  color: var(--e-global-color-text) !important;
  opacity: 0.95 !important;
}

/* Tags block */
.single-meta-tags-block {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.45rem !important;
  padding-top: 0.15rem !important;
}

.single-meta-tags-title {
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
}

.single-meta-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.45rem !important;
}

/* ------------------------- CONTENT + RIGHT COLUMN ------------------------- */

.single-content {
  padding: 0.55rem 0 2.6rem !important;
}

.single-content__inner {
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 4vw !important;
}

.single-content-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px) !important;
  gap: 2.1rem !important;
  align-items: start !important;
}

.single-content-grid > * {
  min-width: 0 !important;
}

.single-article {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  max-width: 100% !important;
}

/* Sticky right column for desktop */
.single-aside {
  position: sticky !important;
  top: 8.5rem !important;
}

/* Contact box */
.single-contact {
  border: 1px solid rgba(119, 119, 119, 0.22) !important;
  border-radius: 14px !important;
  background: transparent !important;

  padding: 1.1rem 1.05rem 1.15rem !important;

  box-shadow:
    0 10px 20px rgba(73, 70, 70, 0.06),
    0 25px 55px rgba(73, 70, 70, 0.08) !important;
}

.single-contact__kicker {
  font-size: 0.8rem !important;
  font-weight: 750 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--e-global-color-accent) !important;
  margin: 0 0 0.45rem !important;
}

.single-contact__title {
  margin: 0 0 0.45rem !important;
  font-size: 1.25rem !important;
  font-weight: 850 !important;
  letter-spacing: -0.02em !important;
  color: var(--e-global-color-text) !important;
}

.single-contact__text {
  margin: 0 0 0.95rem !important;
  font-size: 1rem !important;
  line-height: 1.65 !important;
  color: var(--e-global-color-text) !important;
  opacity: 0.92 !important;
}

.single-contact__btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 46px !important;

  border-radius: 12px !important;
  border: 1px solid rgba(106, 0, 244, 0.35) !important;

  text-decoration: none !important;
  font-size: 0.98rem !important;
  font-weight: 750 !important;

  color: var(--e-global-color-cad7ef2) !important;
  background: var(--e-global-color-secondary) !important;

  transition: transform 0.2s ease-out, opacity 0.2s ease-out, box-shadow 0.2s ease-out !important;
}

.single-contact__btn:hover {
  transform: translate3d(0, -2px, 0) !important;
  opacity: 0.96 !important;
  box-shadow: 0 12px 28px rgba(73, 70, 70, 0.12) !important;
}

/* ------------------------- TYPOGRAPHY (JUSTIFY) ------------------------- */

.single-article p,
.single-article ul,
.single-article ol,
.single-article li {
  font-size: 1.12rem !important;
  line-height: 1.68 !important;
  color: var(--e-global-color-text) !important;

  text-align: justify !important;
  text-justify: inter-word !important;
  hyphens: auto !important;
}

.single-article p,
.single-article ul,
.single-article ol {
  margin: 0 0 0.95rem !important;
  padding: 0 !important;
}

.single-article ul,
.single-article ol {
  padding-left: 1.35rem !important;
}

.single-article li {
  margin: 0.28rem 0 !important;
  line-height: 1.62 !important;
}

/* Styled markers */
.single-article ul ::marker {
  color: var(--e-global-color-secondary) !important;
  font-size: 1.05em !important;
}

.single-article ol ::marker {
  color: var(--e-global-color-secondary) !important;
  font-weight: 850 !important;
}

/* Links understated */
.single-article a {
  color: var(--e-global-color-secondary) !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(106, 0, 244, 0.35) !important;
  padding-bottom: 2px !important;
}

.single-article a:hover {
  border-bottom-color: rgba(106, 0, 244, 0.60) !important;
}

/* STRONG: adouci, luxe discret (pas bloc, pas surlignage) */
.single-article strong,
.single-article b {
  font-weight: 700 !important;
  color: var(--e-global-color-text) !important;
  background: transparent !important;
  padding: 0 0.08em !important;

  /* micro accent doux */
  box-shadow: inset 0 -0.55em 0 rgba(106, 0, 244, 0.12) !important;

  box-decoration-break: clone !important;
  -webkit-box-decoration-break: clone !important;
}

/* ------------------------- ELEMENTOR BUTTONS (SINGLE ARTICLE) ------------------------- */

.single-article .elementor-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.45rem !important;

  padding: 0.65rem 1.25rem !important;
  min-height: 46px !important;

  font-family: inherit !important;
  font-size: 0.95rem !important;
  font-weight: 780 !important;
  letter-spacing: 0.01em !important;

  color: #ffffff !important;
  background: var(--e-global-color-secondary) !important;

  border: 1px solid rgba(106, 0, 244, 0.45) !important;
  border-radius: 12px !important;

  text-decoration: none !important;
  white-space: nowrap !important;

  transition:
    transform 0.18s ease-out,
    box-shadow 0.18s ease-out,
    opacity 0.18s ease-out !important;
}

/* Hover élégant */
.single-article .elementor-button:hover {
  transform: translate3d(0, -2px, 0) !important;
  opacity: 0.96 !important;
  box-shadow:
    0 10px 22px rgba(73, 70, 70, 0.12),
    0 22px 45px rgba(73, 70, 70, 0.14) !important;
}

/* Active (click) */
.single-article .elementor-button:active {
  transform: translate3d(0, 0, 0) !important;
  box-shadow:
    0 4px 10px rgba(73, 70, 70, 0.18) !important;
}

/* Focus clavier (accessibilité propre) */
.single-article .elementor-button:focus-visible {
  outline: none !important;
  box-shadow:
    0 0 0 3px rgba(106, 0, 244, 0.35),
    0 8px 20px rgba(73, 70, 70, 0.14) !important;
}

/* ------------------------- HEADINGS H1 → H6 ------------------------- */

.single-article h1,
.single-article h2,
.single-article h3,
.single-article h4,
.single-article h5,
.single-article h6 {
  all: unset !important;
  display: block !important;

  font-family: inherit !important;
  color: var(--e-global-color-text) !important;

  font-weight: 880 !important;
  letter-spacing: -0.02em !important;

  margin: 0 !important;
  padding: 0 !important;
}

.single-article h1 {
  font-size: clamp(2rem, 3vw, 2.6rem) !important;
  line-height: 1.12 !important;
  margin: 2.2rem 0 0.85rem !important;
  padding: 0 0 0.45rem !important;
  border-bottom: 1px solid rgba(119, 119, 119, 0.18) !important;
}

.single-article h1::after {
  content: "" !important;
  display: block !important;
  width: 86px !important;
  height: 3px !important;
  margin: 0.75rem 0 0 !important;
  background: var(--e-global-color-secondary) !important;
  border-radius: 999px !important;
}

/* H2 smaller + kill ::after externe */
.single-article h2 {
  font-size: clamp(1.22rem, 1.6vw, 1.45rem) !important;
  line-height: 1.25 !important;
  margin: 1.65rem 0 0.6rem !important;
  padding: 0 0 0.25rem !important;
  border-bottom: 1px solid rgba(119, 119, 119, 0.14) !important;
}

.single-article h2::after {
  content: none !important;
  display: none !important;
}

.single-article h3 {
  font-size: clamp(1.22rem, 1.55vw, 1.42rem) !important;
  line-height: 1.25 !important;
  margin: 1.35rem 0 0.5rem !important;
  padding: 0 0 0 0.85rem !important;
  position: relative !important;
}

.single-article h3::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.22em !important;
  width: 3px !important;
  height: 0.92em !important;
  background: rgba(106, 0, 244, 0.65) !important;
  border-radius: 999px !important;
}

.single-article h4,
.single-article h5,
.single-article h6 {
  margin: 1.05rem 0 0.45rem !important;
  padding: 0 !important;
}

.single-article h4 {
  font-size: 1.12rem !important;
  line-height: 1.3 !important;
  font-weight: 850 !important;
}

.single-article h5 {
  font-size: 1.02rem !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
}

.single-article h6 {
  font-size: 0.96rem !important;
  line-height: 1.35 !important;
  font-weight: 780 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  opacity: 0.95 !important;
}

/* ------------------------- TABLES (DESKTOP FULL WIDTH + MOBILE SCROLL) ------------------------- */
/*
  Problèmes corrigés :
  - PC: les colonnes doivent s’étirer -> table reste une table (width:100%)
  - Responsive: quand ça dépasse -> on active scroll seulement sur breakpoints
    (sans wrapper HTML, c’est le compromis fiable ET propre)
*/

.single-article table {
  width: 100% !important;
  max-width: 100% !important;

  /* Desktop: vraie table -> colonnes s’étirent */
  display: table !important;
  table-layout: auto !important;

  border-collapse: separate !important;
  border-spacing: 0 !important;

  border: 1px solid rgba(119, 119, 119, 0.32) !important;
  background: rgba(255, 255, 255, 0.14) !important;

  margin: 1.35rem 0 1.8rem !important;
}

/* Header */
.single-article table thead th {
  background: var(--e-global-color-secondary) !important;
  color: #ffffff !important;

  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
  white-space: nowrap !important;

  padding: 0.82rem 0.95rem !important;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.18) !important;
}

/* Cells: no inner borders */
.single-article table th,
.single-article table td {
  border: none !important;

  padding: 0.78rem 0.95rem !important;
  text-align: left !important;
  vertical-align: middle !important;

  font-size: 1.01rem !important;
  line-height: 1.55 !important;
  color: var(--e-global-color-text) !important;

  background: transparent !important;
}

/* Zebra + hover */
.single-article table tbody tr:nth-child(odd) td {
  background: rgba(119, 119, 119, 0.015) !important;
}

.single-article table tbody tr:nth-child(even) td {
  background: rgba(106, 0, 244, 0.040) !important;
}

.single-article table tbody tr:hover td {
  background: rgba(106, 0, 244, 0.060) !important;
}

/* Responsive: scroll horizontal si manque de place */
@media (max-width: 1024px) {
  .single-article table {
    display: block !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;

    /* déclenche le scroll si colonnes nombreuses */
    width: 100% !important;
  }

  /* Empêche certains thèmes de casser le rendu en “block” */
  .single-article table thead,
  .single-article table tbody,
  .single-article table tfoot,
  .single-article table tr,
  .single-article table th,
  .single-article table td {
    display: revert !important;
  }

  /* Astuce: si le tableau a beaucoup de colonnes,
     il garde une largeur naturelle et scroll */
  .single-article table {
    min-width: 100% !important;
  }

  .single-article table thead th,
  .single-article table th,
  .single-article table td {
    white-space: nowrap !important;
  }
}

/* ------------------------- RELATED POSTS ------------------------- */

.single-related {
  padding: 0 0 3.1rem !important;
}

.single-related__inner {
  width: 100% !important;
  margin: 0 auto !important;
  padding: 0 4vw !important;
}

.single-related__head {
  margin-bottom: 1rem !important;
}

.single-related__title {
  margin: 0 !important;
  display: inline !important;

  font-size: clamp(1.35rem, 2.2vw, 1.75rem) !important;
  line-height: 1.15 !important;

  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  color: var(--e-global-color-text) !important;

  /* Style similaire au "gras" : accent doux secondary, pas un gros surlignage */
  padding: 0 0.14em !important;
  box-shadow: inset 0 -0.62em 0 rgba(106, 0, 244, 0.14) !important;

  box-decoration-break: clone !important;
  -webkit-box-decoration-break: clone !important;
}

.single-related-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 1.2rem !important;
}

.single-related-card {
  background: var(--e-global-color-cad7ef2) !important;
  border: 1px solid rgba(119, 119, 119, 0.22) !important;
  box-shadow:
    0 10px 20px rgba(73, 70, 70, 0.08),
    0 25px 55px rgba(73, 70, 70, 0.10) !important;
  overflow: hidden !important;
  min-height: 300px !important;
  transition:
    transform 0.25s ease-out,
    box-shadow 0.25s ease-out,
    border-color 0.25s ease-out !important;
}

.single-related-card__link {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  text-decoration: none !important;
  color: inherit !important;
}

.single-related-card:hover {
  transform: translate3d(0, -6px, 0) !important;
  border-color: rgba(106, 0, 244, 0.26) !important;
  box-shadow:
    0 16px 28px rgba(73, 70, 70, 0.10),
    0 30px 60px rgba(73, 70, 70, 0.14) !important;
}

.single-related-card__thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  background: rgba(119, 119, 119, 0.06) !important;
}

.single-related-card__thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.5s ease-out !important;
}

.single-related-card:hover .single-related-card__thumb img {
  transform: scale(1.06) !important;
}

.single-related-card__placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--e-global-color-accent) !important;
  font-size: 0.9rem !important;
  height: 100% !important;
}

.single-related-card__body {
  padding: 0.95rem 1rem 1.05rem !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
}

.single-related-card__meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.4rem !important;
  align-items: center !important;
  font-size: 0.86rem !important;
  color: var(--e-global-color-accent) !important;
}

.single-related-card__title {
  margin: 0 !important;
  font-size: 1.08rem !important;
  line-height: 1.35 !important;
  color: var(--e-global-color-text) !important;
}

.single-related-card__excerpt {
  margin: 0.1rem 0 0.25rem !important;
  font-size: 0.98rem !important;
  color: var(--e-global-color-text) !important;
  line-height: 1.55 !important;
  text-align: justify !important;
  hyphens: auto !important;
}

.single-related-card__readmore {
  margin-top: auto !important;
  font-size: 0.92rem !important;
  font-weight: 650 !important;
  color: var(--e-global-color-secondary) !important;
}

/* ------------------------- RESPONSIVE ------------------------- */

@media (max-width: 1024px) {
  .single-top__inner {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 1rem !important;
  }

  .single-featured {
    max-height: 420px !important;
  }

  .single-related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .single-content-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 1.4rem !important;
  }

  .single-aside {
    position: static !important;
  }

  .single-meta-value {
    text-align: left !important;
  }
}

@media (max-width: 640px) {
  .single-hero__inner,
  .single-top__inner,
  .single-content__inner,
  .single-related__inner {
    padding: 0 1.1rem !important;
  }

  .single-related-grid {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .single-article table thead th,
  .single-article table th,
  .single-article table td {
    padding: 0.72rem 0.82rem !important;
    font-size: 0.98rem !important;
  }
}
