/* ===============================
   Single Article – layout stable (SINGLE-POST.PHP)
   =============================== */

/* ===== Conteneurs / tokens de base ===== */
:root{
  --container: 1200px;
  --container-lg: 1200px;
}
.home-section.container{
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(12px, 2vw, 20px);
}


/* Conteneur article maîtrisé */
.jeu-video-container{
  max-width: var(--container-lg);
  margin: 0 auto;
  padding: clamp(16px,2vw,32px);
  font-family: system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
/* Fallbacks locaux (héritent du thème si présent) */
.single-article{
  --bg: #ffffff;
  --bg-soft: #f7f8fb;
  --border: rgba(0,0,0,.12);
  --text: #0b1220;
  --text-soft: #64748b;
  --primary: #2563eb;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 8px 24px rgba(0,0,0,.10);
  --shadow-sm: 0 4px 14px rgba(0,0,0,.08);
  --shadow-xs: 0 2px 8px rgba(0,0,0,.06);

  /* impose le mode clair dans la zone article */
  color-scheme: light;
  background: var(--bg);
  color: var(--text);
}

/* ===== Rythme global & titres ===== */
.single-article .article-hero{
  margin-bottom: clamp(14px, 2.2vw, 22px);
  row-gap: clamp(10px, 2.2vw, 18px);
}
.single-article .home-title,
.single-article h1{
  font-size: clamp(1.6rem, 4vw, 2rem);
  line-height: 1.15;
  margin: .25rem 0 .55rem;
}
.single-article h2{
  font-size: clamp(1.4rem, 3.6vw, 1.5rem);
  line-height: 1.2;
  margin: .9rem 0 .7rem;
}
.single-article h3{
  font-size: clamp(1rem, 3.2vw, 1.25rem);
  line-height: 1.25;
  margin: .8rem 0 .6rem;
}
.single-article .article-summary{ margin-top: clamp(10px, 1.8vw, 16px); }
.single-article .article-toc{ margin-top: clamp(8px, 1.6vw, 12px); }

/* Largeur de la zone contenu (bureau) */
@media (min-width:1200px){
  .single-article .article-body{ max-width: var(--container); }
  .single-article .article-content{ max-width: none; }
}
@media (min-width:992px){
  .single-article .home-title{ font-size: clamp(1.8rem, 2.4vw, 2.4rem); }
}

/* ===============================
   Layout 2 colonnes (70 / 30) – FIX
   =============================== */
.single-article .article-columns{
  display: grid;
  grid-template-columns: 1fr;                 /* mobile */
  gap: var(--gap, 24px);
  margin-block: clamp(16px, 3vw, 28px);
  align-items: start;                         /* évite l’étirement vertical */
  grid-auto-rows: auto;                       /* rows à la hauteur du contenu */
}

.single-article .article-col-main{
  min-width: 0;                               /* évite overflow du contenu */
  align-self: start;                           /* ne pas s’étirer */
}

.single-article .article-col-side{
  align-self: start;                           /* ne pas s’étirer */
  display: grid;
  grid-auto-rows: max-content;                 /* chaque widget à sa hauteur */
  gap: clamp(12px, 1.6vw, 16px);
  /* Par défaut (mobile / tablette), pas de sticky */
  position: static;
  top: auto;
}

/* Bureau : grille 70/30 + sticky propre sur la colonne droite */
@media (min-width: 992px){
  .single-article .article-columns{
    grid-template-columns: 70% 30%;
  }
  .single-article .article-col-side{
    position: sticky;
    top: clamp(72px, 8vh, 120px);             /* sous le header si fixé */
  }
}
/* <<< attention : media-query fermée ici */










/* ========================================
   Colonne droite intelligente (sidebar article)
   ======================================== */
.article-col-side{
  display:grid;
  gap: clamp(12px, 1.6vw, 16px);
}

/* Blocs de la colonne droite (hauteur = contenu) */
.article-col-side .widget-box{
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 1rem 1.25rem;
}
.article-col-side .widget-box + .widget-box{ margin-top: 0; }
.article-col-side .widget-box * { max-width: 100%; }


.article-col-side .widget-box h3{
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0 0 .75rem;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  padding-bottom: .35rem;
}

/* ==== Réseaux sociaux ==== */
.article-col-side .widget-social .social-links{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .5rem;
  margin: 0; padding: 0; list-style: none;
}
.article-col-side .widget-social .social-links li{ margin: 0; }
.article-col-side .widget-social .social-btn{
  display: grid; place-items: center;
  height: 44px; border-radius: 10px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  text-decoration: none;
  color: var(--text);
  transition: transform .12s ease, box-shadow .12s ease, border-color .15s ease;
}
.article-col-side .widget-social .social-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow);
  border-color: var(--primary);
  color: var(--primary);
}
.article-col-side .widget-social .social-btn svg{
  width: 20px; height: 20px; display: block;
}

/* ==== Carte compacte (post/jeu) ==== */
.article-col-side .widget-card{
  display: flex; align-items: center; gap: .75rem;
  text-decoration: none; color: inherit;
  padding: .45rem 0;
}
.article-col-side .widget-card-thumb{
  flex: 0 0 60px; width: 60px; height: 60px;
  border-radius: var(--radius-sm);
  overflow: hidden; background: var(--bg-soft);
  box-shadow: var(--shadow-xs) inset;
}
.article-col-side .widget-card-thumb img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.article-col-side .widget-card-body{
  display:flex; flex-direction:column; gap:.25rem; min-width:0;
}
.article-col-side .widget-card-title{
  font-size:.92rem; font-weight:600; line-height:1.3; color:var(--text);
  overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
}
.article-col-side .widget-card-meta{
  font-size:.8rem; color:var(--text-soft);
}

/* ==== Articles liés : Liste (desktop/tablette) vs Carrousel (mobile) ==== */
.article-col-side .related-list{ display: grid; gap: .35rem; }
.article-col-side .related-carousel{ display: none; } /* masqué par défaut */

@media (max-width: 768px){
  .article-col-side .related-list{ display: none; }
  .article-col-side .related-carousel{ display: block; }
}

/* Carrousel mobile – s’appuie sur tes classes globales .carousel* */
.article-col-side .related-carousel.carousel{
  position: relative;
}
.article-col-side .related-carousel .carousel-track{
  display:flex; gap:.6rem; overflow-x:auto; -webkit-overflow-scrolling:touch;
  scroll-snap-type: x proximity; padding-block: 2px;
}
.article-col-side .related-carousel .carousel-item{
  flex: 0 0 72%; max-width: 72%;
  scroll-snap-align: start; contain: layout paint;
}
@media (max-width: 420px){
  .article-col-side .related-carousel .carousel-item{ flex-basis: 84%; max-width: 84%; }
}
.article-col-side .related-carousel .card.card--compact{
  display: grid; grid-template-columns: 110px 1fr; gap: .6rem;
  border:1px solid var(--border); border-radius: var(--radius);
  background: var(--bg); text-decoration: none;
  box-shadow: var(--shadow-sm); overflow: hidden;
}
.article-col-side .related-carousel .card__thumb{
  aspect-ratio: 4/3; background: var(--bg-soft);
}
.article-col-side .related-carousel .card__thumb img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.article-col-side .related-carousel .card__body{ padding: .6rem .6rem .6rem 0; }
.article-col-side .related-carousel .card__title{
  font-size:.95rem; margin:.1rem 0 .25rem; color: var(--text);
  overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
}
.article-col-side .related-carousel .card__meta{
  font-size:.82rem; color: var(--text-soft);
}
.article-col-side .related-carousel .carousel-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:32px; height:32px; line-height:30px; text-align:center;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  border:1px solid var(--border); border-radius:999px; z-index:2;
}
.article-col-side .related-carousel .carousel-nav.prev{ left:.25rem; }
.article-col-side .related-carousel .carousel-nav.next{ right:.25rem; }

/* ==== Liste de jeux associés ==== */
.article-col-side .widget-related-games .widget-game-list{
  list-style:none; margin:0; padding:0; display:grid; gap:.35rem;
}

/* ==== CTA Newsletter/Inscription ==== */
.article-col-side .widget-cta{
  text-align:center; background:var(--bg-soft);
  border:1px solid var(--border); border-radius:var(--radius);
  padding: 1rem;
}
.article-col-side .widget-cta p{
  margin:0 0 .75rem; color: var(--text-soft);
}
.article-col-side .widget-cta .btn-primary{
  display:inline-block; padding:.6rem 1rem; border-radius: var(--radius-sm);
  background: var(--primary); color:#fff; font-weight:600; text-decoration:none; border:0;
  transition: transform .15s ease, box-shadow .15s ease;
}
.article-col-side .widget-cta .btn-primary:hover{
  transform: translateY(-2px); box-shadow: var(--shadow);
}

/* ==== Petites touches responsives ==== */
@media (max-width: 991px){
  .article-col-side{ margin-top: 1.5rem; }
}
































/* ===============================
   HERO (cover + galerie)
   =============================== */
.single-article .article-hero__cover{
  border-radius: var(--radius);
  overflow: hidden;
  background:#0f0f10;
  margin:0;
  height: clamp(560px, 42vh, 800px);
  position:relative;
  z-index:0;
}
.single-article .article-hero__cover img{
  width:100%; height:100%; object-fit:cover; object-position:center; display:block;
}
@media (max-width:520px){
  .single-article .article-hero__cover{ height:auto; aspect-ratio:16/9; max-height:46vh; }
}

/* Galerie thumbstrip */
.single-article .gallery-carousel.thumbstrip{
  --thumb-gap: clamp(6px, 1vw, 10px);
  margin-top: clamp(8px, 1.4vw, 12px);
  position:relative;
}
.single-article .gallery-carousel.thumbstrip .carousel-track{
  display:flex; gap:var(--thumb-gap); align-items:stretch;
  overflow-x:auto; scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch;
  padding-block:2px;
}
.single-article .gallery-carousel.thumbstrip .carousel-item{
  flex:0 0 calc((100% - (var(--thumb-gap)*3))/4.5);
  scroll-snap-align:start; contain:layout paint;
  min-width:64px; max-width:160px;
}
.single-article .gallery-carousel.thumbstrip .lg-item{
  display:block; position:relative; aspect-ratio:1/1;
  border-radius:var(--radius-sm); overflow:hidden;
  background:var(--bg-soft); box-shadow:var(--shadow-xs);
}
.single-article .gallery-carousel.thumbstrip .lg-item>img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.single-article .gallery-carousel.thumbstrip .carousel-nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:32px; height:32px; line-height:30px; text-align:center;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  border:1px solid var(--border); border-radius:999px;
}
.single-article .gallery-carousel.thumbstrip .carousel-nav.prev{ left:.25rem; }
.single-article .gallery-carousel.thumbstrip .carousel-nav.next{ right:.25rem; }
@media (max-width:360px){
  .single-article .gallery-carousel.thumbstrip .carousel-item{ min-width:56px; }
}

/* ===============================
   Chips méta (date, auteur, etc.)
   =============================== */
.single-article .jeu-meta-chips{
  display:flex; flex-wrap:wrap; align-items:center; gap:.5rem .6rem;
}
.single-article .jeu-meta-chips .chip{
  display:inline-flex; align-items:center; gap:.45rem;
  height:34px; padding:0 .75rem; border-radius:999px; line-height:1;
  background:var(--bg); border:1px solid var(--border);
}
.single-article .jeu-meta-chips .chip a{
  text-decoration:none; color:inherit; border-bottom:1px solid transparent;
}
.single-article .jeu-meta-chips .chip a:hover{ border-color:var(--primary); }
.single-article .chip-sponsor{ background:var(--bg-soft); border:1px solid var(--border); color:var(--text); }
.jeu-meta-chips .chip .chip-avatar{ width:20px; height:20px; border-radius:999px; object-fit:cover; display:inline-block; }
.jeu-meta-chips .chip .icon{ width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.8; opacity:.9; flex:0 0 16px; }
.jeu-meta-chips .chip-date .icon{ opacity:.95; }
.jeu-meta-chips .is-updated{ background:var(--bg-soft); border:1px solid var(--border); }
.jeu-meta-chips .chip-sponsor .icon{ stroke-width:1.6; }
.jeu-meta-chips .chip-cat:not(:first-of-type) .icon{ display:none; }

/* ===============================
   Sommaire (ToC)
   =============================== */
.single-article .article-toc{
  background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1rem 1.25rem;
  margin:clamp(16px,2vw,28px) 0;
  box-shadow:var(--shadow-xs);
}
.single-article .toc-title{ margin-bottom: 1rem; font-size:1.1rem; font-weight:600; color:var(--text); }
.single-article .toc-list{ list-style:none; margin:0; padding:0; display:grid; gap:.5rem; }
.single-article .toc-list li a{
  display:block; padding:.4rem .6rem; border-radius:var(--radius-sm);
  color:var(--text-soft); text-decoration:none;
  transition: background .15s ease, color .15s ease, padding-left .15s ease;
}
.single-article .toc-list li a:hover,
.single-article .toc-list li a.is-active{
  background:var(--bg); color:var(--primary);
  border-left:3px solid var(--primary);
  padding-left:.5rem;
}

/* ===============================
   Médias dans le contenu
   =============================== */
.single-article .entry-content{ color:var(--text); }
.single-article .entry-content a{
  color:var(--primary); text-decoration:none;
  border-bottom:1px solid color-mix(in oklab, var(--primary) 30%, transparent);
}
.single-article .entry-content a:hover{ border-bottom-color: currentColor; }

.single-article .entry-content img,
.single-article .entry-content video{
  max-width:100%; height:auto; display:block; border-radius:var(--radius-sm);
}
.single-article .entry-content figure{ margin:clamp(.6rem,2vw,1rem) 0; }
.single-article .entry-content figure>img{ width:100%; height:auto; }
.single-article .entry-content figcaption{ font-size:.9rem; color:var(--text-soft); text-align:center; margin-top:.35rem; }

/* Alignements WP */
.single-article .entry-content .alignnone,
.single-article .entry-content .aligncenter,
.single-article .entry-content .alignleft,
.single-article .entry-content .alignright{
  display:block; margin:clamp(.5rem,2vw,1rem) auto; float:none; max-width:100%;
}
@media (min-width:700px){
  .single-article .entry-content .alignleft{ float:left; margin:.25rem 1rem .75rem 0; max-width:calc(50% - .75rem); }
  .single-article .entry-content .alignright{ float:right; margin:.25rem 0 .75rem 1rem; max-width:calc(50% - .75rem); }
}

/* Embeds vidéo responsives */
.single-article .entry-content iframe,
.single-article .entry-content embed,
.single-article .entry-content object{ max-width:100%; display:block; border:0; }
.single-article .entry-content .wp-block-embed__wrapper,
.single-article .entry-content .wp-block-video,
.single-article .entry-content .is-type-video{
  position:relative; width:100%; aspect-ratio:16/9; overflow:hidden; border-radius:var(--radius-sm);
}
.single-article .entry-content .wp-block-embed__wrapper iframe,
.single-article .entry-content .wp-block-video video{ position:absolute; inset:0; width:100%; height:100%; }

/* ===============================
   Partage
   =============================== */
.single-article .article-share .jeu-sites{ gap:.45rem .55rem; }
.single-article .article-share .jeu-sites a{
  padding:.4rem .65rem; font-size:.95rem; line-height:1; white-space:nowrap;
}
@media (max-width:380px){
  .single-article .article-share .jeu-sites a{ font-size:.9rem; padding:.38rem .6rem; }
}

/* ===============================
   Commentaires – liste + formulaire
   =============================== */
.single-article .comments-section{
  background:var(--bg); border:1px solid var(--border);
  border-radius:var(--radius); padding:clamp(.9rem,1.6vw,1.25rem);
  box-shadow:var(--shadow-xs);
}
.single-article .comments-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:.75rem; margin-bottom:.9rem;
}
.single-article .comments-title{
  margin:0; line-height:1.2;
  font-size:clamp(1.1rem, 1.4vw + .7rem, 1.5rem);
}
.single-article .comment-list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:clamp(10px,1.2vw,14px);
}
.single-article .comment{ margin:0; }
.single-article .comment .comment-body{
  display:grid; grid-template-columns:44px 1fr; gap:.75rem;
  background:var(--bg-soft); border:1px solid var(--border);
  border-radius:var(--radius); padding:.75rem .85rem;
}
.single-article .comment .comment-author .avatar{
  grid-row:1 / span 2; width:44px; height:44px;
  border-radius:50%; object-fit:cover; display:block; box-shadow:var(--shadow-xs);
}
.single-article .comment .comment-author{
  display:flex; align-items:center; gap:.5rem; font-weight:600; color:var(--text);
}
.single-article .comment .comment-author .fn,
.single-article .comment .comment-author .url{
  color:var(--text); text-decoration:none; border-bottom:1px solid transparent;
}
.single-article .comment .comment-author .url:hover{ border-color:var(--primary); }
.single-article .comment .comment-metadata{
  margin:.15rem 0 .35rem; font-size:.9rem; color:var(--text-soft);
}
.single-article .comment .comment-metadata a{
  color:inherit; text-decoration:none; border-bottom:1px dotted transparent;
}
.single-article .comment .comment-metadata a:hover{
  color:var(--primary); border-bottom-color:var(--primary);
}
.single-article .comment .comment-content{ color:var(--text); }
.single-article .comment .comment-content p{ margin:.4rem 0; }
.single-article .comment .reply,
.single-article .comment .edit-link{ margin-top:.4rem; }
.single-article .comment .reply a,
.single-article .comment .edit-link a{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.35rem .6rem; border:1px solid var(--border); border-radius:999px;
  text-decoration:none; color:var(--text);
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.single-article .comment .reply a:hover,
.single-article .comment .edit-link a:hover{
  color:var(--primary); border-color:var(--primary); background:var(--bg);
}
.single-article .comment .comment-awaiting-moderation{
  display:inline-block; margin:.25rem 0 .4rem; font-size:.9rem; color:var(--text-soft);
}
.single-article .comment-list .children{
  list-style:none; margin:.6rem 0 0 2.25rem; padding:0;
  display:grid; gap:.6rem; border-left:2px solid var(--border);
}
@media (max-width:520px){
  .single-article .comment-list .children{ margin-left:1rem; }
}
.single-article .comments-pagination{
  display:flex; gap:.4rem; flex-wrap:wrap; justify-content:center; margin-top:.9rem;
}
.single-article .comments-pagination .page a,
.single-article .comments-pagination .page span{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:2rem; height:2rem; padding:0 .55rem;
  border:1px solid var(--border); border-radius:8px; text-decoration:none; color:var(--text);
}
.single-article .comments-pagination .current{
  background:var(--primary-50, var(--bg-soft));
  border-color:var(--primary); color:var(--primary);
}

/* Formulaire */
.single-article .comment-form-wrap{
  margin-top:clamp(14px, 2.5vw, 22px);
  background:var(--bg); border:1px solid var(--border);
  border-radius:var(--radius);
  padding:clamp(.9rem,1.6vw,1.2rem);
  box-shadow:var(--shadow-xs);
}
.single-article .comment-form .logged-in-as{
  margin-bottom:.6rem; font-size:.95rem;
}
.single-article .comment-form .logged-in-as a{
  color:var(--text); text-decoration:none; border-bottom:1px solid var(--border);
}
.single-article .comment-form .logged-in-as a:hover{
  border-bottom-color:var(--primary); color:var(--primary);
}
.single-article .comment-form .form-row{
  display:flex; flex-direction:column; gap:.35rem; margin-bottom:.75rem;
}
.single-article .comment-form label{ font-size:.92rem; color:var(--text-soft); }
.single-article .comment-form input[type="text"],
.single-article .comment-form input[type="email"],
.single-article .comment-form input[type="url"],
.single-article .comment-form textarea{
  width:100%; background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:calc(var(--radius) - 4px);
  padding:.6rem .7rem; color:var(--text);
  outline:none;
  transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.single-article .comment-form textarea{ resize:vertical; min-height:140px; }
.single-article .comment-form input:focus,
.single-article .comment-form textarea:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in oklab, var(--primary) 18%, transparent);
  background:var(--bg);
}
.single-article .comment-form .submit-row{
  display:flex; align-items:center; gap:.6rem; justify-content:flex-end; margin-top:.5rem;
}
.single-article .comment-form input[type="submit"],
.single-article .comment-form button[type="submit"]{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.55rem .95rem; border-radius:999px;
  border:1px solid var(--primary);
  background:var(--primary); color:#fff; cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, opacity .15s ease;
}
.single-article .comment-form input[type="submit"]:hover,
.single-article .comment-form button[type="submit"]{
  box-shadow:var(--shadow); transform:translateY(-1px);
}

/* Petits correctifs natifs WP */
.single-article .comment-notes{ display:none; }
.single-article .required{ color:var(--primary); }
.single-article .form-submit{ margin:0; }
.single-article .comment-form .cancel-comment-reply a{
  text-decoration:none; color:var(--text-soft);
}
.single-article .comment-form .cancel-comment-reply a:hover{ color:var(--primary); }

/* Accessibilité / motion */
@media (prefers-reduced-motion: reduce){
  .single-article .comment-form input[type="submit"],
  .single-article .comment-form button[type="submit"]{ transition:none; }
}

/* ===============================
   Jeu associé (carte)
   =============================== */
.single-article .jeu-section > a.card{
  display:grid; grid-template-columns:110px 1fr;
  gap:clamp(10px,1.6vw, var(--gap));
  align-items:center; padding:12px 14px;
  background:var(--bg-soft); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow-xs);
  text-decoration:none;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.single-article .jeu-section > a.card:hover{
  transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--primary);
}
.single-article .jeu-section > a.card .card__thumb{
  aspect-ratio:4/3; border-radius:var(--radius-sm);
  overflow:hidden; background:var(--bg); box-shadow:var(--shadow-xs) inset;
}
.single-article .jeu-section > a.card .card__thumb img{
  width:100%; height:100%; object-fit:cover; display:block;
}
@media (min-width:992px){
  .single-article .jeu-section > a.card{ grid-template-columns:150px 1fr; padding:14px 16px; }
}
@media (max-width:520px){
  .single-article .jeu-section > a.card{
    grid-template-columns:90px 1fr; padding:10px 12px; gap:.65rem;
  }
  .single-article .jeu-section > a.card .card__thumb{ aspect-ratio:1/1; max-height:90px; }
}



/* ===============================
   Sécurité anti-débordements
   =============================== */
.single-article, .single-article .entry-content{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* ===== Anti-dark global (thèmes forçant le sombre) ===== */
body.dark .single-article,
body.is-dark .single-article,
[data-theme="dark"] .single-article{
  color-scheme: light !important;
  --bg:#ffffff;
  --bg-soft:#f7f8fb;
  --border:rgba(0,0,0,.12);
  --text:#0b1220;
  --text-soft:#64748b;
}



/* ===== Prev/Next navigation ===== */
.prev-next-nav{ margin-top:clamp(24px,3vw,40px); }
.prev-next-grid{
  display:grid; gap:16px;
}
@media(min-width:768px){
  .prev-next-grid{ grid-template-columns:1fr 1fr; }
}

.nav-card{
  display:flex; align-items:center; gap:12px;
  background:var(--bg-soft); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow-xs);
  padding:12px; text-decoration:none; color:var(--text);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.nav-card:hover{
  transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--primary);
}
.nav-card.prev{ text-align:left; justify-content:flex-start; }
.nav-card.next{ text-align:right; justify-content:flex-end; }

.nav-arrow{
  font-size:1.6rem; font-weight:bold; color:var(--primary);
}
.nav-thumb{
  flex:0 0 80px; width:80px; height:60px;
  border-radius:var(--radius-sm); overflow:hidden;
  background:#e9eef5; box-shadow:var(--shadow-xs) inset;
}
.nav-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.nav-body{ flex:1 1 auto; min-width:0; display:flex; flex-direction:column; gap:4px; }
.nav-label{ font-size:.8rem; color:var(--text-soft); text-transform:uppercase; }
.nav-title-small{
  font-size:.95rem; line-height:1.3; margin:0; font-weight:600; color:var(--text);
  overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
}




/* ===== Jeux associés (carrousel) — bureau uniquement ===== */
.jeu-associe-carousel-desktop{ display:none; }
@media (min-width: 992px){
  .jeu-associe-carousel-desktop{ display:block; }
}

/* mise en page des cartes (même style que la sidebar, mais en carrousel) */
.games-carousel .carousel-track{
  display:flex; gap: clamp(10px, 1.6vw, 16px);
  overflow-x:auto; -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity;
  padding-block: 2px;
}
.games-carousel .carousel-item{
  scroll-snap-align:start; contain: layout paint;
  flex: 0 0 clamp(300px, 32%, 360px); /* ~3 cartes visibles sur large écran */
  max-width: clamp(300px, 32%, 360px);
}
.games-carousel .card.card--compact{
  display:grid; grid-template-columns: 130px 1fr; gap: .7rem;
  border:1px solid var(--border); border-radius: var(--radius);
  background: var(--bg); text-decoration: none; box-shadow: var(--shadow-sm);
  overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.games-carousel .card.card--compact:hover{
  transform: translateY(-2px); box-shadow: var(--shadow); border-color: var(--primary);
}
.games-carousel .card__thumb{ aspect-ratio: 4/3; background: var(--bg-soft); }
.games-carousel .card__thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.games-carousel .card__body{ padding: .7rem .8rem .7rem 0; }
.games-carousel .card__title{
  font-size: .98rem; margin:.1rem 0 .25rem; color: var(--text);
  overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
}
.games-carousel .card__meta{ font-size: .82rem; color: var(--text-soft); }

.games-carousel .carousel-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:32px; height:32px; line-height:30px; text-align:center;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  border:1px solid var(--border); border-radius:999px; z-index:2;
}
.games-carousel .carousel-nav.prev{ left:.25rem; }
.games-carousel .carousel-nav.next{ right:.25rem; }














/* ===== Sources & crédits – carte auteur + sources ===== */
.credits-section { margin-top: clamp(16px, 2.6vw, 28px); }

.credit-card{
  display:grid; grid-template-columns:72px 1fr; gap:12px;
  background: var(--bg); border:1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-xs);
  padding: 12px 14px; align-items: center; margin-bottom: 12px;
}
.credit-avatar-wrap{ width:72px; height:72px; border-radius: 16px; overflow:hidden; background: var(--bg-soft); display:grid; place-items:center; }
.credit-avatar { width:72px; height:72px; border-radius: 16px; display:block; object-fit: cover; }
.credit-avatar-fallback{
  width: 48px; height: 48px; border-radius: 50%; display:grid; place-items:center;
  background: var(--bg); border:1px solid var(--border); font-weight:700; color: var(--text);
}
.credit-body{ min-width:0; }
.credit-name{ margin:.1rem 0 .1rem; font-size:1.05rem; line-height:1.2; }
.credit-name a{ color: var(--text); text-decoration:none; border-bottom:1px solid transparent; }
.credit-name a:hover{ border-bottom-color: var(--primary); }
.credit-role{ margin:.1rem 0 .35rem; color: var(--text-soft); font-size:.92rem; }
.credit-stats{ margin:0; color: var(--text-soft); font-size:.92rem; }
.credit-stats .stat strong{ color: var(--text); }
.credit-stats .sep{ margin:0 .4rem; opacity:.6; }

/* Liste des sources */
.source-list{ list-style:none; margin:0; padding:0; display:grid; gap:.5rem; }
.source-item{ margin:0; }
.source-card{
  display:grid; grid-template-columns:36px 1fr; gap:.6rem; align-items:center;
  background: var(--bg); border:1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-xs);
  padding:.55rem .65rem; text-decoration:none; color: var(--text);
  transition: transform .12s ease, box-shadow .12s ease, border-color .15s ease;
}
.source-card:hover{ transform: translateY(-1px); box-shadow: var(--shadow); border-color: var(--primary); }

.source-avatar{
  width:36px; height:36px; border-radius: 10px; display:grid; place-items:center;
  background: var(--bg-soft); border:1px solid var(--border); font-weight:700; color: var(--text);
}
.source-body{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.source-label{ font-size:.96rem; font-weight:600; line-height:1.3; color: var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.source-host{ font-size:.86rem; color: var(--text-soft); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Responsive */
@media (max-width:520px){
  .credit-card{ grid-template-columns:56px 1fr; }
  .credit-avatar-wrap{ width:56px; height:56px; border-radius:12px; }
  .credit-avatar{ width:56px; height:56px; border-radius:12px; }
}


/* === PATCH anti-overflow — Colonne droite (sidebar) === */

/* 1) La grille doit autoriser le shrink des 2 colonnes */
@media (min-width: 992px){
  .single-article .article-columns{
    /* au lieu de 70% 30% qui peut dépasser avec le gap/padding */
    grid-template-columns: minmax(0, 1fr) minmax(260px, 34%);
  }
}

/* 2) La colonne droite elle-même ne doit jamais forcer la largeur */
.single-article .article-col-side{
  min-width: 0;        /* indispensable en grid */
  max-width: 100%;
  overflow: hidden;    /* on clippe la colonne, pas le contenu scrolleur interne */
  box-sizing: border-box;
}

/* 3) Les widgets internes ne peuvent pas élargir la colonne */
.article-col-side .widget-box,
.article-col-side .widget-card,
.article-col-side .related-carousel,
.article-col-side .related-list{
  min-width: 0;
  max-width: 100%;
}

/* 4) Médias dans la sidebar 100% safe */
.article-col-side img,
.article-col-side video,
.article-col-side iframe,
.article-col-side embed,
.article-col-side object{
  max-width: 100% !important;
  height: auto;
  display: block;
}

/* 5) Carrousel de la sidebar : le track scrolle, la colonne ne déborde pas */
.article-col-side .related-carousel{
  overflow: hidden; /* évite la barre de scroll horizontale globale */
  position: relative;
}
.article-col-side .related-carousel .carousel-track{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  padding-inline: 6px; /* garde les boutons/nav à l'intérieur */
}
.article-col-side .related-carousel .carousel-item{
  min-width: 0; /* autorise le clamp correct */
}

/* 6) Boutons de nav du carrousel : ne sortent pas du container */
.article-col-side .related-carousel .carousel-nav{
  /* contrainte douce dans la boîte */
  inset-inline-start: 4px;
  inset-inline-end: 4px;
}

/* 7) Titres/URLs trop longs dans les cartes de la sidebar */
.article-col-side .widget-card-title,
.article-col-side .related-carousel .card__title{
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  word-break: break-word;
}

/* 8) Très petit viewport : resserrer les espacements */
@media (max-width: 380px){
  .article-col-side{ gap: 10px; }
  .article-col-side .related-carousel .card.card--compact{ grid-template-columns: 100px 1fr; }
}










/* ===========================
   Commentaires – PixiPlace
   =========================== */
.comments-section {
  --c-primary: var(--brand, #2563eb); /* bleu du site si défini */
  --c-text: var(--text, #0f172a);
  --c-muted: var(--muted, #64748b);
  --c-border: var(--border, #e5e7eb);
  --radius-lg: var(--radius-lg, 14px);
  --gap: 1rem;
}

/* Liste propre, sans puces */
.comment-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Carte commentaire : avatar + contenu */
.comment-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--gap);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  background: #fff;
  padding: 1rem;
}

/* Avatar (utilise l'<img> générée) */
.comment-card__avatar .credit-avatar {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  object-fit: cover;
  display: block;
  box-shadow: 0 1px 0 rgba(15,23,42,.04);
}

/* En-tête : auteur + date */
.comment-card__head {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .25rem;
}
.comment-card__author a,
.comment-card__author {
  font-weight: 700;
  color: var(--c-primary);
  text-decoration: none;
}
.comment-card__author a:hover,
.comment-card__author a:focus {
  text-decoration: underline;
}
.comment-card__date {
  color: var(--c-muted);
  font-size: .85rem;
  background: #f1f5f9;
  border-radius: 999px;
  padding: .2rem .6rem;
}

/* Corps du commentaire */
.comment-card__content {
  color: var(--c-text);
  line-height: 1.6;
  margin-top: .25rem;
}

/* Pied : actions */
.comment-card__foot {
  margin-top: .5rem;
}
.comment-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

/* Boutons (vignettes harmonisées avec .btn existant) */
.comment-actions .btn,
.comment-actions a.comment-reply-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 600;
  font-size: .9rem;
  padding: .4rem .8rem;
  border-radius: 999px;
  border: 1px solid var(--c-primary);
  color: var(--c-primary);
  background: #fff;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.comment-actions .btn:hover,
.comment-actions a.comment-reply-link:hover,
.comment-actions .btn:focus-visible,
.comment-actions a.comment-reply-link:focus-visible {
  background: var(--c-primary);
  color: #fff;
  text-decoration: none;
}

/* Lien "Modifier" si généré sans .btn */
.comment-actions a.comment-edit-link {
  display: inline-flex;
  align-items: center;
  font-weight: 600;
  font-size: .9rem;
  padding: .4rem .8rem;
  border-radius: 999px;
  border: 1px solid var(--c-primary);
  color: var(--c-primary);
  background: #fff;
}
.comment-actions a.comment-edit-link:hover,
.comment-actions a.comment-edit-link:focus-visible {
  background: var(--c-primary);
  color: #fff;
}

/* état "En attente" */
.comment-card__content .chip {
  display: inline-block;
  margin-top: .4rem;
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: .2rem .6rem;
  font-size: .85rem;
}

/* Indentation des réponses imbriquées */
.comment-list .children {
  list-style: none;
  margin: .75rem 0 0 3.25rem; /* espace = largeur avatar + gap */
  padding: 0;
}
.comment-list .children .comment-card {
  background: #fcfdff;
}

/* Formulaire : garder l’harmonie visuelle */
.comment-form-wrap {
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  background: #fff;
  padding: 1rem;
}
.comment-form .form-row + .form-row { margin-top: .75rem; }
.comment-form label { font-weight: 600; color: var(--c-muted); }

/* Bouton Publier = primaire */
.comment-form .submit-row button,
.comment-form .submit-row input[type="submit"] {
  border-radius: 999px;
  padding: .55rem 1.1rem;
}

/* Titre et head */
.comments-head .comments-title {
  font-size: 1.25rem;
  font-weight: 800;
}

/* Liens par défaut dans la zone commentaires : bleu harmonisé */
.comments-section a { color: var(--c-primary); }
.comments-section a:hover { text-decoration: underline; }

/* Mobile tweaks */
@media (max-width: 480px){
  .comment-card { grid-template-columns: 48px 1fr; }
  .comment-card__avatar .credit-avatar { width: 48px; height: 48px; }
  .comment-list .children { margin-left: 2.75rem; }
}
