/* =============================================================
   Manga Print — Pack visuel Japan FM
   Surcharge ciblée du thème enfant GeneratePerf.
   Convention : préfixe .mp- pour les composants neufs, override
   limité aux variables racines + classes GeneratePress connues.
   ============================================================= */

/* -- 1. Variables racines (override) ------------------------- */

:root {
  --mp-paper: #F5F1E8;
  --mp-paper-2: #EAE3D2;
  --mp-ink: #1A1A1A;
  --mp-red: #C8102E;
  --mp-red-2: #E4232A;
  /* Override des variables GeneratePress consommées par le parent */
  --accent: #C8102E;
  --base: #F5F1E8;
  --base-2: #EAE3D2;
  --base-3: #1A1A1A;
  --contrast: #1A1A1A;
  --contrast-2: #444;
}

/* === GARDE-FOU LISIBILITÉ ===
   L'option Customizer GeneratePress peut définir #page (et autres wrappers)
   en sombre. Nos textes sont en encre noire — donc noir sur sombre = invisible.
   On force la palette papier crème sur TOUS les wrappers possibles. */
html,
body,
#page,
#page.site,
#page.grid-container,
#page.container,
.site,
.site-content,
.inside-content,
.content-area,
.inside-article,
.entry-content,
article.post,
article.page {
  background-color: var(--mp-paper) !important;
}

/* Texte du contenu : encre noire forcée pour qu'aucune option Customizer
   ne le rende illisible. */
.entry-title,
.entry-content,
.entry-content p,
.entry-content li,
.entry-content blockquote,
.entry-content figcaption,
.entry-meta,
.post-meta,
.author-box,
.comments-area,
.widget-area .widget {
  color: var(--mp-ink) !important;
}

body {
  background-image: repeating-linear-gradient(45deg, rgba(26,26,26,.025) 0 1px, transparent 1px 6px);
}

/* Le main container max-width du parent peut écraser nos sections.
   On force pleine largeur uniquement sur la home. */
.home #page.grid-container,
.home #page.container {
  max-width: none !important;
  padding: 0 !important;
}

/* Sur les pages single/archive : conserver une largeur lisible mais
   garder le fond crème. */
.single #page.grid-container,
.archive #page.grid-container,
.page #page.grid-container {
  background: var(--mp-paper) !important;
}

/* -- 2. Typos globales --------------------------------------- */

h1, h2, h3, h4, h5, h6,
.entry-title,
.widget-title,
.site-footer h2 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: -.01em;
  line-height: .95;
}

.mp-pop {
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  letter-spacing: .04em;
}

/* -- 3. Header / nav (restyle agressif du header GP parent) -- */

.site-header {
  background: var(--mp-paper) !important;
  border-bottom: 6px double var(--mp-ink) !important;
  padding: 12px 0 !important;
}
.site-header .inside-header {
  background: var(--mp-paper) !important;
  display: flex;
  align-items: center;
  gap: 32px;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 32px !important;
}
/* Logo : si custom logo PNG uploadé, le redimensionner correctement */
.site-logo,
.header-image {
  max-height: 60px !important;
  width: auto !important;
}
.site-logo img,
.header-image.is-logo-image {
  max-height: 60px !important;
  height: 60px !important;
  width: auto !important;
  object-fit: contain;
}
.main-title a,
.site-title a {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase;
  letter-spacing: -.02em;
  color: var(--mp-ink) !important;
  font-size: 32px !important;
}

/* === Menu navigation DESKTOP — version raffinée ===
   Plus de fond noir agressif ni de bandeaux rouges épais.
   Fond papier crème continu avec le header, items encre,
   accent rouge subtil au hover/actif (filet 2px sous l'item). */
.main-navigation,
.main-navigation .inside-navigation {
  background: var(--mp-paper) !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  padding: 0 !important;
}
.main-navigation .menu,
.main-navigation .main-nav > ul {
  background: transparent !important;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  max-width: 1320px;
  margin: 0 auto !important;
}
.main-navigation .menu > li,
.main-navigation .main-nav > ul > li {
  background: transparent !important;
}
.main-navigation .menu li a,
.main-navigation .main-nav ul li a {
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  font-size: 15px !important;
  padding: 14px 22px !important;
  background: transparent !important;
  line-height: 1 !important;
  position: relative;
  transition: color .15s !important;
}
/* Filet rouge fin qui apparaît au hover (animation slide) */
.main-navigation .menu li a::after,
.main-navigation .main-nav ul li a::after {
  content: "";
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 8px;
  height: 2px;
  background: var(--mp-red);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .2s ease-out;
}
.main-navigation .menu li a:hover,
.main-navigation .menu li.current-menu-item > a,
.main-navigation .menu li.current-menu-ancestor > a,
.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li.current-menu-item > a {
  color: var(--mp-red) !important;
  background: transparent !important;
}
.main-navigation .menu li a:hover::after,
.main-navigation .menu li.current-menu-item > a::after,
.main-navigation .menu li.current-menu-ancestor > a::after {
  transform: scaleX(1);
}

/* Sous-menu déroulant */
.main-navigation .sub-menu,
.main-navigation ul ul {
  background: var(--mp-paper) !important;
  border: 2px solid var(--mp-ink) !important;
  box-shadow: 5px 5px 0 var(--mp-ink) !important;
  padding: 8px 0 !important;
}
.main-navigation .sub-menu li a {
  font-size: 13px !important;
  padding: 10px 18px !important;
  letter-spacing: .1em !important;
}
.main-navigation .sub-menu li a::after {
  display: none !important;
}
.main-navigation .sub-menu li a:hover {
  background: var(--mp-red) !important;
  color: var(--mp-paper) !important;
}

/* Cacher éventuels marquee résiduels (en cache navigateur) */
.mp-marquee { display: none !important; }

/* -- 4. Wrapper home ----------------------------------------- */

/* Force full-bleed même si encapsulé dans un container GP étroit */
.mp-home { max-width: none !important; width: 100%; padding: 0 !important; }
.mp-home > section,
.mp-home > div.mp-marquee {
  position: relative;
  left: 50%;
  right: 50%;
  width: 100vw;
  margin-left: -50vw;
  margin-right: -50vw;
  max-width: 100vw;
  box-sizing: border-box;
}
/* Évite la scrollbar horizontale (technique full-bleed 100vw + margin négative).
   overflow-x: clip ne casse pas position:sticky ni les containing blocks.
   Limité à la home pour ne pas affecter d'autres pages. */
body.home { overflow-x: clip; }

.mp-wrap { max-width: 1320px; margin: 0 auto; padding: 0 32px; box-sizing: border-box; }

/* Marquee top home */
.mp-marquee {
  background: linear-gradient(90deg, var(--mp-red), var(--mp-ink), var(--mp-red));
  color: var(--mp-paper);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .05em;
  padding: 8px 0;
  overflow: hidden;
  white-space: nowrap;
  border-bottom: 3px solid var(--mp-ink);
}
.mp-marquee .mp-track {
  display: inline-block;
  white-space: nowrap;
  animation: mp-marquee 50s linear infinite;
  will-change: transform;
}
.mp-marquee .mp-track span { margin: 0 32px; }
/* Le contenu est dupliqué 2x dans le PHP — on translate de -50% pour
   un loop parfaitement continu. */
@keyframes mp-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
  .mp-marquee .mp-track { animation: none; }
}

/* Topbar (home) */
.mp-topbar {
  background: var(--mp-ink);
  color: var(--mp-paper);
  padding: 6px 0;
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.mp-topbar .mp-wrap { display: flex; justify-content: space-between; align-items: center; }

/* -- 5. Hero "Une planche" home ------------------------------ */

.mp-hero { padding: 40px 0 56px; }
.mp-hero .mp-wrap {
  position: relative;
}
/* Titre "À la une" au-dessus du hero, style en-tête de magazine */
.mp-hero-heading {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(28px, 3.4vw, 42px) !important;
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin: 0 0 20px !important;
  padding-bottom: 8px;
  position: relative;
  border-bottom: 4px solid var(--mp-ink);
  color: var(--mp-ink) !important;
}
.mp-hero-heading::before {
  content: "★ ";
  color: var(--mp-red);
}
.mp-hero-heading::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 80px;
  height: 4px;
  background: var(--mp-red);
}
/* La grille des panels (déplacée dans .mp-hero-grid) */
.mp-hero-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
  position: relative;
}

.mp-panel {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 6px 6px 0 var(--mp-ink);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--mp-ink);
  transition: transform .15s, box-shadow .15s;
}
.mp-panel:hover {
  transform: translate(-2px,-2px);
  box-shadow: 8px 8px 0 var(--mp-ink);
}

.mp-panel.mp-1 { grid-column: 1; grid-row: 1 / span 2; }
.mp-panel.mp-2 { grid-column: 2; grid-row: 1; background: var(--mp-paper-2); }
.mp-panel.mp-3 { grid-column: 3; grid-row: 1; background: var(--mp-ink); color: var(--mp-paper); border-color: var(--mp-red); }
.mp-panel.mp-4 { grid-column: 2 / span 2; grid-row: 2; flex-direction: row; }

.mp-panel .mp-img {
  overflow: hidden;
  position: relative;
}
.mp-panel.mp-1 .mp-img { aspect-ratio: 16/10; border-bottom: 3px solid var(--mp-ink); }
.mp-panel.mp-1 .mp-img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-radial-gradient(circle at 30% 30%, rgba(0,0,0,.07) 0 1px, transparent 2px 4px);
  mix-blend-mode: multiply;
  pointer-events: none;
}
.mp-panel .mp-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

.mp-panel.mp-4 .mp-img { width: 45%; aspect-ratio: 1; border-right: 3px solid var(--mp-ink); flex-shrink: 0; }
.mp-panel.mp-4 .mp-body { flex: 1; padding: 20px; }

.mp-panel .mp-body { padding: 24px; }
.mp-panel.mp-2 .mp-body, .mp-panel.mp-3 .mp-body { padding: 22px; flex: 1; display: flex; flex-direction: column; justify-content: space-between; }

.mp-kicker {
  display: inline-block;
  background: var(--mp-red);
  color: var(--mp-paper);
  padding: 4px 10px;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: .15em;
  font-size: 13px;
  margin-bottom: 14px;
  text-decoration: none;
}
.mp-panel.mp-3 .mp-kicker { background: var(--mp-red-2); }

.mp-panel h2,
.mp-panel h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  margin: 0 0 12px;
  line-height: .98;
}
.mp-panel.mp-1 h2,
.mp-panel.mp-1 h3 {
  font-size: clamp(28px, 3.4vw, 44px);
}
.mp-panel.mp-2 h3,
.mp-panel.mp-3 h3,
.mp-panel.mp-4 h3 {
  font-size: 22px;
}

.mp-panel .mp-num {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 56px;
  line-height: 1;
  color: var(--mp-red);
  display: block;
}
.mp-panel.mp-3 .mp-num { color: var(--mp-red-2); }

.mp-panel p.mp-dek {
  font-size: 16px;
  line-height: 1.55;
  margin: 0 0 16px;
  font-family: Georgia, "Times New Roman", serif;
}
.mp-panel .mp-byline {
  font-style: italic;
  font-size: 13px;
  color: var(--contrast-2);
  border-top: 2px dotted var(--mp-ink);
  padding-top: 10px;
  margin-top: auto;
}

/* Bulle "BANG !" */
.mp-bubble {
  position: absolute;
  top: -16px;
  right: -10px;
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  border-radius: 50% / 60%;
  padding: 14px 22px;
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  font-size: 28px;
  color: var(--mp-red);
  transform: rotate(-6deg);
  box-shadow: 5px 5px 0 var(--mp-ink);
  z-index: 3;
  pointer-events: none;
}

/* -- 6. Section rails (home Animés / Mangas) ----------------- */

.mp-rail { padding: 50px 0; border-top: 6px double var(--mp-ink); }

.mp-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 28px;
  flex-wrap: wrap;
  gap: 20px;
}
.mp-section-head h2 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: clamp(40px, 5vw, 64px);
  text-transform: uppercase;
  letter-spacing: -.02em;
  line-height: .9;
  position: relative;
  margin: 0;
}
.mp-section-head h2 sup {
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  font-size: 22px;
  color: var(--mp-red);
  text-transform: none;
  letter-spacing: .05em;
  margin-left: 12px;
  vertical-align: super;
}
.mp-section-head h2::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 80px;
  height: 6px;
  background: var(--mp-red);
}
/* mp-stat-right retiré (UX - inutile en home).
   .mp-h-link et .mp-see-all à la place. */
.mp-h-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 4px solid var(--mp-red);
  padding-bottom: 4px;
}
.mp-h-link:hover { color: var(--mp-red); }
.mp-section-head .mp-see-all {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: .12em;
  padding: 8px 16px;
  border: 2px solid var(--mp-ink);
  background: var(--mp-paper);
  color: var(--mp-ink);
  text-decoration: none;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.mp-section-head .mp-see-all:hover { background: var(--mp-ink); color: var(--mp-paper); }

/* ==== CAROUSEL "Plus lus de la semaine" ==== */

.mp-popular { background: var(--mp-paper-2); }

.mp-carousel {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 8px 8px 24px;
  margin: 0 -8px;
  scrollbar-color: var(--mp-red) var(--mp-paper);
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
  outline: none;
}
.mp-carousel:focus-visible { outline: 3px solid var(--mp-red); outline-offset: 2px; }

.mp-carousel::-webkit-scrollbar { height: 8px; }
.mp-carousel::-webkit-scrollbar-track { background: var(--mp-paper); border: 1px solid var(--mp-ink); }
.mp-carousel::-webkit-scrollbar-thumb { background: var(--mp-red); border: 1px solid var(--mp-ink); }

.mp-carousel-item {
  flex: 0 0 280px;
  scroll-snap-align: start;
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--mp-ink);
  transition: transform .15s, box-shadow .15s;
  position: relative;
}
.mp-carousel-item:hover {
  transform: translate(-2px,-2px);
  box-shadow: 7px 7px 0 var(--mp-red);
}
.mp-carousel-item .mp-rank {
  position: absolute;
  top: -16px;
  left: -16px;
  width: 56px;
  height: 56px;
  background: var(--mp-red);
  border: 3px solid var(--mp-ink);
  display: grid;
  place-items: center;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 26px;
  color: var(--mp-paper);
  z-index: 2;
  transform: rotate(-6deg);
  box-shadow: 3px 3px 0 var(--mp-ink);
}
.mp-carousel-item .mp-img {
  aspect-ratio: 16/10;
  overflow: hidden;
  border-bottom: 3px solid var(--mp-ink);
}
.mp-carousel-item .mp-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.mp-carousel-item .mp-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mp-carousel-item .mp-cat {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--mp-red);
}
.mp-carousel-item h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
  margin: 0;
}

.mp-subcats {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 2px dotted var(--mp-ink);
}
.mp-subcats a {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: .1em;
  padding: 6px 14px;
  border: 2px solid var(--mp-ink);
  background: var(--mp-paper);
  color: var(--mp-ink);
  text-decoration: none;
  transition: background .15s, color .15s;
}
.mp-subcats a:hover { background: var(--mp-ink); color: var(--mp-paper); }
.mp-subcats a.mp-on { background: var(--mp-red); border-color: var(--mp-red); color: var(--mp-paper); }

.mp-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.mp-case {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
  display: flex;
  flex-direction: column;
  transition: transform .15s, box-shadow .15s;
  text-decoration: none;
  color: var(--mp-ink);
}
.mp-case:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--mp-ink); }

.mp-case .mp-img { aspect-ratio: 4/3; overflow: hidden; border-bottom: 3px solid var(--mp-ink); }
.mp-case .mp-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

.mp-case .mp-body { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.mp-case .mp-cat {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--mp-red);
  text-decoration: none;
}
.mp-case h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 19px;
  line-height: 1.05;
  text-transform: uppercase;
  margin: 0;
}
.mp-case .mp-foot {
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px dotted var(--mp-ink);
  font-size: 11px;
  font-style: italic;
  display: flex;
  justify-content: space-between;
}

/* -- 7. Duo Voyage / Déco home ------------------------------- */

.mp-duo { padding: 50px 0; border-top: 6px double var(--mp-ink); background: var(--mp-paper-2); }
.mp-duo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.mp-duo-block .mp-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 20px; padding-bottom: 12px; border-bottom: 3px solid var(--mp-ink);
}
.mp-duo-block .mp-head h2 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 42px; text-transform: uppercase; line-height: .9; margin: 0;
}
.mp-duo-block .mp-more {
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  font-size: 18px; color: var(--mp-red); text-decoration: none;
}
.mp-feat-d {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 6px 6px 0 var(--mp-ink);
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: var(--mp-ink);
}
.mp-feat-d .mp-img { aspect-ratio: 16/9; overflow: hidden; border-bottom: 3px solid var(--mp-ink); }
.mp-feat-d .mp-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mp-feat-d .mp-body { padding: 20px; }
.mp-feat-d h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 24px; text-transform: uppercase; line-height: 1; margin: 0 0 10px;
}
.mp-feat-d p { font-size: 14px; line-height: 1.55; margin: 0; }

.mp-duo-list { margin-top: 16px; display: flex; flex-direction: column; gap: 8px; }
.mp-duo-list a {
  display: flex; gap: 12px; padding: 10px;
  background: var(--mp-paper); border: 2px solid var(--mp-ink);
  font-size: 14px; align-items: center; text-decoration: none; color: var(--mp-ink);
}
.mp-duo-list a:hover { background: var(--mp-ink); color: var(--mp-paper); }
.mp-duo-list a span {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  color: var(--mp-red); font-size: 22px; flex-shrink: 0;
}

/* -- 8. Hero catégorie (archive) ----------------------------- */

/* Variante COMPACTE (par défaut, page 1) — plus court, plus tassé */
.mp-cat-cover-compact {
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
  padding: 32px 40px;
  border: 4px double var(--mp-paper);
  outline: 3px solid var(--mp-ink);
  position: relative;
  overflow: hidden;
  margin: 24px 0 32px;
  display: block;
}
.mp-cat-cover-compact h1 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(40px, 6vw, 72px) !important;
  line-height: .9 !important;
  text-transform: uppercase;
  letter-spacing: -.02em;
  margin: 0 0 12px;
  color: var(--mp-paper) !important;
}
.mp-cat-cover-compact h1 small {
  display: block;
  font-size: .22em;
  letter-spacing: .25em;
  color: var(--mp-red-2);
  margin-bottom: 8px;
  font-weight: 400;
  text-transform: uppercase;
}
.mp-cat-cover-compact .mp-intro {
  font-size: 16px;
  line-height: 1.6;
  max-width: 720px;
  margin: 12px 0 18px;
  font-family: Georgia, "Times New Roman", serif;
  color: var(--mp-paper) !important;
}
.mp-cat-cover-compact .mp-intro p { margin: 0 0 10px; color: var(--mp-paper) !important; }
.mp-cat-cover-compact .mp-subcats {
  margin: 16px 0 0;
  padding: 0;
  border: 0;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.mp-cat-cover-compact .mp-subcats a {
  background: transparent;
  border: 2px solid var(--mp-paper);
  color: var(--mp-paper);
  padding: 6px 14px;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 12px;
  letter-spacing: .1em;
  text-decoration: none;
}
.mp-cat-cover-compact .mp-subcats a:hover,
.mp-cat-cover-compact .mp-subcats a.mp-on {
  background: var(--mp-red);
  border-color: var(--mp-red);
  color: var(--mp-paper);
}

/* Variante MINI (pages 2+) — juste le H1 */
.mp-cat-cover-mini {
  padding: 20px 24px;
  margin: 16px 0 24px;
  background: var(--mp-paper-2);
  border: 2px solid var(--mp-ink);
}
.mp-cat-cover-mini h1 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: clamp(28px, 4vw, 44px);
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin: 0;
  color: var(--mp-ink) !important;
  line-height: 1;
}
.mp-cat-cover-mini h1 small {
  font-size: .5em;
  color: var(--mp-red);
  font-weight: 400;
}

/* Séparateur "Tous les articles" entre la featured-row et le loop */
.mp-section-title {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(28px, 3.4vw, 42px) !important;
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin: 40px 0 24px !important;
  padding-bottom: 8px;
  border-bottom: 4px solid var(--mp-ink);
  position: relative;
  color: var(--mp-ink) !important;
}
.mp-section-title::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 80px;
  height: 4px;
  background: var(--mp-red);
}

/* ANCIEN .mp-cat-cover sans suffixe (plus utilisé mais garde-fou) */
.mp-cat-cover {
  background: var(--mp-ink);
  color: var(--mp-paper);
  padding: 50px 40px;
  border: 6px double var(--mp-paper);
  outline: 3px solid var(--mp-ink);
  position: relative;
  overflow: hidden;
  margin: 32px 0 40px;
}
.mp-cat-cover::before {
  content: "VOL.";
  position: absolute; top: 24px; left: 30px;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 14px; letter-spacing: .3em; color: var(--mp-red-2);
}
.mp-cat-cover::after {
  content: attr(data-issue);
  position: absolute; top: 24px; right: 30px;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 14px; letter-spacing: .3em; color: var(--mp-red-2);
}
.mp-cat-cover .mp-jp {
  position: absolute; bottom: 30px; right: 40px;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 60px; color: rgba(255,255,255,.06); line-height: 1;
  writing-mode: vertical-rl;
  pointer-events: none;
}
.mp-cat-cover h1 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: clamp(48px, 9vw, 120px);
  line-height: .85;
  text-transform: uppercase;
  letter-spacing: -.02em;
  margin: 32px 0 20px;
  color: var(--mp-paper);
}
.mp-cat-cover h1 small {
  display: block;
  font-size: .18em;
  letter-spacing: .3em;
  color: var(--mp-red-2);
  margin-bottom: 16px;
  font-weight: 400;
}
.mp-cat-cover .mp-intro {
  font-size: 17px;
  line-height: 1.6;
  max-width: 680px;
  margin-bottom: 24px;
  font-family: Georgia, "Times New Roman", serif;
}
.mp-cat-cover .mp-stats {
  display: flex; gap: 48px;
  padding-top: 20px;
  border-top: 2px solid var(--mp-red);
  flex-wrap: wrap;
}
.mp-cat-cover .mp-stats .mp-n {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 36px; color: var(--mp-red-2); line-height: 1;
}
.mp-cat-cover .mp-stats .mp-l {
  font-size: 11px; text-transform: uppercase; letter-spacing: .15em;
  margin-top: 4px; color: var(--mp-paper);
}

/* TOC sous-thèmes */
.mp-toc {
  background: var(--mp-paper-2);
  border: 3px solid var(--mp-ink);
  padding: 24px;
  margin: 0 0 40px;
}
.mp-toc h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 22px;
  text-transform: uppercase;
  margin: 0 0 16px;
  border-bottom: 3px solid var(--mp-ink);
  padding-bottom: 8px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
}
.mp-toc h3 small {
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  font-size: 14px;
  color: var(--mp-red);
  text-transform: none;
  letter-spacing: .05em;
  font-weight: 400;
}
.mp-toc-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.mp-toc-list li { margin: 0; padding: 0; }
.mp-toc-list li::marker { content: ""; }
.mp-toc-list a {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dotted var(--mp-ink);
  font-size: 14px;
  text-decoration: none;
  color: var(--mp-ink);
}
.mp-toc-list a:hover { color: var(--mp-red); }
.mp-toc-list a strong {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 16px;
  font-weight: 400;
}
.mp-toc-list a span {
  color: var(--mp-red);
  font-size: 13px;
  font-style: italic;
}

/* Featured row archive (article épinglé + side) */
.mp-feat-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 24px;
  margin-bottom: 40px;
}
.mp-feat-big {
  position: relative;
  border: 3px solid var(--mp-ink);
  box-shadow: 8px 8px 0 var(--mp-red);
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: var(--mp-paper);
}
.mp-feat-big img { width: 100%; height: 100%; object-fit: cover; display: block; aspect-ratio: 16/10; }
.mp-feat-big .mp-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 40%, transparent 70%);
  padding: 32px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.mp-feat-big h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: clamp(22px, 3vw, 36px);
  line-height: 1;
  text-transform: uppercase;
  margin: 12px 0 0;
  color: var(--mp-paper);
}
.mp-feat-side { display: flex; flex-direction: column; gap: 16px; }

/* -- 9. FAQ catégorie ---------------------------------------- */

.mp-faq {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 6px 6px 0 var(--mp-ink);
  padding: 32px;
  margin: 40px 0;
}
.mp-faq h2 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 28px;
  text-transform: uppercase;
  margin: 0 0 20px;
  border-bottom: 3px solid var(--mp-red);
  padding-bottom: 8px;
}
.mp-faq details {
  padding: 14px 0;
  border-bottom: 2px dotted var(--mp-ink);
}
.mp-faq details:last-of-type { border-bottom: 0; }
.mp-faq summary {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 18px;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.mp-faq summary::-webkit-details-marker { display: none; }
.mp-faq summary::after {
  content: "▼";
  color: var(--mp-red);
  font-size: 14px;
  transition: transform .2s;
  flex-shrink: 0;
}
.mp-faq details[open] summary::after { transform: rotate(180deg); }
.mp-faq details > div,
.mp-faq details > p {
  margin-top: 12px;
  line-height: 1.6;
  font-size: 15px;
  font-family: Georgia, "Times New Roman", serif;
}

/* -- 10. Single article restylé ------------------------------ */

.single .entry-title,
.single .entry-header h1 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(26px, 3.4vw, 44px) !important;
  line-height: 1.05 !important;
  text-transform: uppercase;
  letter-spacing: -.01em;
  margin: 16px 0 20px !important;
  color: var(--mp-ink) !important;
}
.single .entry-content > h2,
.single .entry-content > h3 {
  position: relative;
  padding-left: 18px;
  border-left: 6px solid var(--mp-red);
  text-transform: uppercase;
  margin-top: 1.6em;
}
.single .entry-content blockquote {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
  padding: 20px 24px;
  margin: 1.6em 0;
  font-family: "Bangers", "Bangers-fallback", "Comic Sans MS", sans-serif;
  font-size: 20px;
  color: var(--mp-ink);
  position: relative;
  border-radius: 8px;
}
.single .entry-content blockquote::before {
  content: "";
  position: absolute;
  bottom: -16px;
  left: 32px;
  width: 0; height: 0;
  border: 14px solid transparent;
  border-top-color: var(--mp-ink);
  border-bottom: 0;
}
.single .entry-content blockquote::after {
  content: "";
  position: absolute;
  bottom: -12px;
  left: 35px;
  width: 0; height: 0;
  border: 11px solid transparent;
  border-top-color: var(--mp-paper);
  border-bottom: 0;
}

/* Featured image — bordure ink, sans ombre dure */
.single .featured-image img,
.single .post-image img {
  border: 3px solid var(--mp-ink);
  box-shadow: none;
}
.single .featured-image figcaption::before {
  border-bottom-color: var(--mp-paper-2);
}

/* Author box restylé (réutilise le markup existant /css/authors.css) */
.author-box {
  background: var(--mp-paper-2);
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
}

/* Categories pills (badges-pills.css existant) — fond rouge ou contour rouge selon le contexte */
.entry-header .cat-links a,
.post-categories a,
.badges-pills a,
.entry-header .badges-pills a,
.entry-meta .post-categories a,
.entry-header a[rel="category tag"],
.entry-header a[rel="tag"] {
  background: var(--mp-red) !important;
  color: var(--mp-paper) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  font-size: 12px !important;
  padding: 4px 10px !important;
  text-decoration: none !important;
  border: 2px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  margin: 0 4px 4px 0 !important;
  display: inline-block;
  line-height: 1.4 !important;
}
.entry-header .cat-links a:hover,
.post-categories a:hover,
.badges-pills a:hover {
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
}

/* === Bouton "Partager cet article" === */
.partager-cet-article,
.share-buttons-toggler button,
.share-buttons-toggler .button-native,
button.button-native[data-share-url],
.entry-content .partager,
a.partager-article {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: .15em !important;
  padding: 12px 20px !important;
  border: 3px solid var(--mp-ink) !important;
  box-shadow: 4px 4px 0 var(--mp-red) !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: transform .15s, box-shadow .15s !important;
  border-radius: 0 !important;
}
.partager-cet-article:hover,
.share-buttons-toggler button:hover,
button.button-native[data-share-url]:hover {
  transform: translate(-2px,-2px) !important;
  box-shadow: 6px 6px 0 var(--mp-red) !important;
  background: var(--mp-red) !important;
  border-color: var(--mp-red) !important;
}
.partager-cet-article svg,
.share-buttons-toggler svg,
.button-native svg {
  width: 18px !important;
  height: 18px !important;
  fill: currentColor !important;
}

/* === "Voir le résumé" — version subtile ===
   Cible le markup réel : <details><summary><span class="show">...</span>
   <span class="hide">...</span></summary><contenu...></details>
   Plus aérée, plus discrète, sans box-shadow agressive. */
.entry-content details,
.entry-content > details {
  background: transparent !important;
  border: 1.5px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  margin: 1.5em 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  overflow: hidden;
}
.entry-content details > summary,
.entry-content summary {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  background: var(--mp-paper-2) !important;
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  padding: 14px 18px !important;
  border: 0 !important;
  border-bottom: 1.5px solid var(--mp-ink) !important;
  box-shadow: none !important;
  cursor: pointer !important;
  margin: 0 !important;
  list-style: none !important;
  transition: background .15s, color .15s !important;
}
.entry-content summary::-webkit-details-marker { display: none !important; }
.entry-content summary::marker { display: none !important; content: "" !important; }
.entry-content summary::before {
  content: "" !important;
  width: 14px;
  height: 14px;
  background: var(--mp-red);
  display: inline-block;
  flex-shrink: 0;
  transform: rotate(0deg);
  transition: transform .2s ease-out;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.entry-content details[open] > summary::before {
  transform: rotate(90deg);
}
.entry-content details:not([open]) > summary:hover {
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
  border-bottom-color: var(--mp-red) !important;
}
.entry-content details:not([open]) > summary:hover::before {
  background: var(--mp-paper);
}
/* Spans .show / .hide alternés */
.entry-content summary .show,
.entry-content summary .hide { display: none; }
.entry-content details:not([open]) > summary .show { display: inline; }
.entry-content details[open] > summary .hide { display: inline; }

/* Contenu déplié : fond papier subtil, padding aéré */
.entry-content details > *:not(summary) {
  padding: 16px 18px !important;
  margin: 0 !important;
  background: var(--mp-paper) !important;
}
.entry-content details > p {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 15px;
  line-height: 1.65;
}
.entry-content details > ul,
.entry-content details > ol {
  padding: 16px 18px 16px 40px !important;
  background: var(--mp-paper) !important;
}
.entry-content details > ul li,
.entry-content details > ol li {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 14.5px;
  line-height: 1.6;
  margin: 6px 0;
}

/* Surcharge éventuelle des classes bouton legacy "voir le résumé" */
.voir-le-resume,
a.voir-le-resume,
.gisme-summary-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: var(--mp-paper-2) !important;
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  padding: 10px 16px !important;
  border: 1.5px solid var(--mp-ink) !important;
  box-shadow: none !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border-radius: 0 !important;
  margin: 12px 0 !important;
}
.voir-le-resume:hover,
.gisme-summary-toggle:hover {
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
}

/* Author box : on laisse le CSS d'origine du thème (authors.css) gérer.
   Aucun override Manga Print pour ne pas casser la structure native. */

/* === Bouton Google News === */
.google-news-button-container {
  margin: 32px 0 !important;
  text-align: center;
}
.google-news-card a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  background: var(--mp-paper) !important;
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 14px !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  padding: 14px 24px !important;
  border: 3px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  box-shadow: 5px 5px 0 var(--mp-red) !important;
  transition: transform .15s, box-shadow .15s !important;
  text-decoration: none !important;
  font-weight: 400 !important;
}
.google-news-card a::before {
  content: "★";
  color: var(--mp-red);
  font-size: 16px;
}
.google-news-card a:hover {
  transform: translate(-2px,-2px) !important;
  box-shadow: 7px 7px 0 var(--mp-red) !important;
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
  border-color: var(--mp-ink) !important;
}
.google-news-card a:hover::before { color: var(--mp-paper); }
.google-news-card svg {
  margin-left: 0 !important;
  width: 20px;
  height: 20px;
  vertical-align: middle !important;
}

/* === "À ne pas manquer" (nav.related-articles) ===
   Restyle léger : on garde la grille native (.wp-block-latest-posts__list)
   et les proportions d'images intactes, on accentue juste le titre
   et les hover dans la DA Manga Print. */

nav.related-articles {
  margin: 40px 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
nav.related-articles > h2,
nav.related-articles > h2.simple {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(22px, 2.4vw, 30px) !important;
  text-transform: uppercase;
  letter-spacing: -.01em;
  color: var(--mp-ink) !important;
  margin: 0 0 20px !important;
  padding: 0 0 8px !important;
  position: relative;
  border-bottom: 3px solid var(--mp-ink) !important;
}
nav.related-articles > h2::before {
  content: "★ ";
  color: var(--mp-red);
}
nav.related-articles > h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 80px;
  height: 3px;
  background: var(--mp-red);
}

/* Items de la grille — accents subtils, pas de bordure cassée */
nav.related-articles ul.wp-block-latest-posts__list > li,
nav.related-articles .wp-block-latest-posts > li {
  transition: transform .15s !important;
}
nav.related-articles ul.wp-block-latest-posts__list > li:hover {
  transform: translateY(-3px);
}
/* Image : juste un fin liseré encre au hover */
nav.related-articles .wp-block-latest-posts__featured-image {
  position: relative;
  overflow: hidden;
}
nav.related-articles .wp-block-latest-posts__featured-image img {
  transition: transform .35s ease-out, filter .25s !important;
}
nav.related-articles ul.wp-block-latest-posts__list > li:hover .wp-block-latest-posts__featured-image img {
  transform: scale(1.04);
}
/* Titre item : Anton uppercase, accent rouge au hover */
nav.related-articles ul.wp-block-latest-posts__list > li > a,
nav.related-articles .wp-block-latest-posts__post-title {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: -.005em;
  font-size: 16px !important;
  line-height: 1.15 !important;
  color: var(--mp-ink) !important;
  text-decoration: none !important;
  display: block;
  margin-top: 10px;
  transition: color .15s !important;
}
nav.related-articles ul.wp-block-latest-posts__list > li:hover > a {
  color: var(--mp-red) !important;
}
/* Date : italique discret */
nav.related-articles .wp-block-latest-posts__post-date {
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  font-size: 12px !important;
  color: var(--contrast-2) !important;
  margin-top: 4px;
  display: block;
}

/* === oEmbed interne : remplacement de l'iframe WP par carte custom === */

.mp-internal-embed {
  display: flex !important;
  gap: 0 !important;
  background: var(--mp-paper) !important;
  border: 3px solid var(--mp-ink) !important;
  box-shadow: 5px 5px 0 var(--mp-red) !important;
  padding: 0 !important;
  margin: 1.6em 0 !important;
  color: var(--mp-ink) !important;
  transition: transform .15s, box-shadow .15s !important;
  overflow: hidden;
  border-radius: 0 !important;
  align-items: stretch !important;
  position: relative;
}
.mp-internal-embed:hover {
  transform: translate(-2px, -2px) !important;
  box-shadow: 7px 7px 0 var(--mp-red) !important;
}
/* Overlay <a> qui couvre tout le bloc → clic n'importe où mène à l'article. */
.mp-internal-embed__overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1;
  text-indent: -9999px;
  background: transparent;
}
.mp-internal-embed__overlay:focus-visible {
  outline: 3px solid var(--mp-red);
  outline-offset: -3px;
}
/* Les liens visibles passent au-dessus de l'overlay */
.mp-internal-embed h3 a,
.mp-internal-embed .mp-link {
  position: relative;
  z-index: 2;
  text-decoration: none !important;
  color: inherit !important;
}
.mp-internal-embed h3 a:hover { color: var(--mp-red) !important; }
.mp-internal-embed .mp-img {
  flex: 0 0 240px;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-right: 3px solid var(--mp-ink);
}
.mp-internal-embed .mp-img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  margin: 0 !important;
}
.mp-internal-embed .mp-body {
  flex: 1;
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: center;
}
.mp-internal-embed .mp-kicker {
  display: inline-block;
  background: var(--mp-red) !important;
  color: var(--mp-paper) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase;
  letter-spacing: .15em;
  font-size: 11px;
  padding: 4px 10px;
  border: 2px solid var(--mp-ink);
  width: fit-content;
  margin-bottom: 6px;
}
.mp-internal-embed h3 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 22px !important;
  text-transform: uppercase;
  line-height: 1.05 !important;
  letter-spacing: -.005em;
  margin: 0 !important;
  color: var(--mp-ink) !important;
}
.mp-internal-embed p {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 14px !important;
  line-height: 1.5 !important;
  margin: 4px 0 0 !important;
  color: var(--contrast-2);
}
.mp-internal-embed .mp-link {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  color: var(--mp-red) !important;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 13px;
  margin-top: 8px;
  display: inline-block;
}
@media (max-width: 600px) {
  .mp-internal-embed { flex-direction: column !important; }
  .mp-internal-embed .mp-img {
    flex-basis: auto;
    width: 100%;
    aspect-ratio: 16/10;
    border-right: 0;
    border-bottom: 3px solid var(--mp-ink);
  }
  .mp-internal-embed h3 { font-size: 18px !important; }
}

/* === Embeds Gutenberg (oEmbed Twitter, YouTube, etc.) === */
.entry-content .wp-block-embed,
.entry-content figure.wp-block-embed {
  margin: 1.6em 0 !important;
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
  padding: 0;
  background: var(--mp-paper);
}
.entry-content .wp-block-embed figcaption {
  background: var(--mp-paper-2);
  padding: 8px 14px;
  font-family: Georgia, serif;
  font-style: italic;
  font-size: 13px;
  border-top: 2px dotted var(--mp-ink);
}

/* === Sous-catégorie : header simple sans hero noir === */
.mp-subcat-head {
  margin: 24px 0 28px;
  padding: 0 0 16px;
  border-bottom: 4px solid var(--mp-ink);
  position: relative;
}
.mp-subcat-head::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 80px;
  height: 4px;
  background: var(--mp-red);
}
.mp-subcat-head .mp-eyebrow {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 13px;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin: 0 0 8px;
  color: var(--contrast-2);
}
.mp-subcat-head .mp-eyebrow a {
  color: var(--mp-red) !important;
  text-decoration: none;
  border-bottom: 2px solid var(--mp-red);
}
.mp-subcat-head .mp-eyebrow a:hover { color: var(--mp-ink) !important; border-color: var(--mp-ink); }
.mp-subcat-head h1 {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(36px, 5vw, 64px) !important;
  line-height: .95 !important;
  text-transform: uppercase;
  letter-spacing: -.02em;
  margin: 0 0 12px !important;
  color: var(--mp-ink) !important;
}
.mp-subcat-head .mp-intro {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 16px;
  line-height: 1.65;
  max-width: 760px;
  color: var(--mp-ink);
}
.mp-subcat-head .mp-intro p:last-child { margin-bottom: 0; }

/* === Menu MOBILE — clean & propre ===
   Architecture GP mobile :
   - #mobile-menu-control-wrapper = barre top avec [search][hamburger]
   - #site-navigation = la vraie nav (cachée fermée, déployée si .toggled)
   - Le toggle dans #site-navigation est en doublon → on le cache
*/
@media (max-width: 768px) {
  /* Toutes les règles d'override sur le menu mobile / hamburger / search ont été
     RETIRÉES pour ne plus interférer avec ton fix Customizer.
     Seuls les ajustements de taille texte mobile sont conservés. */
  .mp-panel.mp-1 h2,
  .mp-panel.mp-1 h3 { font-size: 26px !important; }
  .single .entry-title { font-size: clamp(22px, 6vw, 32px) !important; }
  .mp-cat-cover-compact { padding: 20px 16px !important; }
  .mp-cat-cover-compact h1 { font-size: clamp(28px, 8vw, 44px) !important; }
}

/* -- 11. Archives WP par défaut (fallback / liste) ----------- */
/* Restyle des cards d'articles d'archive sans dépendre d'articles-reset-cards.css */

.archive .site-main article,
.blog .site-main article {
  background: var(--mp-paper);
  border: 3px solid var(--mp-ink);
  box-shadow: 5px 5px 0 var(--mp-ink);
  padding: 0;
  margin-bottom: 32px;
  overflow: hidden;
}
.archive .site-main article .post-image img,
.blog .site-main article .post-image img,
.archive .site-main article .featured-image img {
  width: 100%;
  display: block;
  border: 0;
  box-shadow: none;
}
.archive .site-main article .inside-article {
  padding: 20px;
}
.archive .site-main article .entry-title,
.blog .site-main article .entry-title {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 24px;
  text-transform: uppercase;
  margin: 0 0 12px;
  line-height: 1;
}
.archive .site-main article .entry-meta,
.blog .site-main article .entry-meta {
  font-style: italic;
  font-size: 12px;
  border-top: 1px dotted var(--mp-ink);
  padding-top: 8px;
  margin-top: 12px;
}

/* -- 12. Pagination ------------------------------------------ */

.paging-navigation,
.nav-links {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 40px 0;
  flex-wrap: wrap;
}
.paging-navigation .page-numbers,
.nav-links .page-numbers {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: .1em;
  padding: 8px 14px;
  border: 2px solid var(--mp-ink);
  background: var(--mp-paper);
  color: var(--mp-ink);
  text-decoration: none;
}
.paging-navigation .page-numbers.current,
.nav-links .page-numbers.current {
  background: var(--mp-red);
  border-color: var(--mp-red);
  color: var(--mp-paper);
}
.paging-navigation .page-numbers:hover,
.nav-links .page-numbers:hover {
  background: var(--mp-ink);
  color: var(--mp-paper);
}

/* -- 13. Breadcrumb (Yoast / WP) ----------------------------- */

#breadcrumbs,
.breadcrumb,
.mp-breadcrumb {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 13px;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin: 24px 0 16px;
  color: var(--mp-ink);
}
#breadcrumbs a,
.breadcrumb a,
.mp-breadcrumb a { color: var(--mp-ink); text-decoration: none; }
#breadcrumbs a:hover,
.breadcrumb a:hover,
.mp-breadcrumb a:hover { color: var(--mp-red); }
#breadcrumbs .separator,
.mp-breadcrumb .sep { color: var(--mp-red); margin: 0 8px; }

/* === Commentaires + formulaire (DA Manga Print) === */

.comments-area {
  margin: 48px 0 32px !important;
  background: var(--mp-paper-2) !important;
  border: 3px solid var(--mp-ink) !important;
  box-shadow: 6px 6px 0 var(--mp-ink) !important;
  padding: 32px 28px !important;
}

/* Titre "Publiez un commentaire" / "X commentaires" */
.comments-title,
.comment-reply-title,
#reply-title {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: clamp(22px, 2.4vw, 30px) !important;
  text-transform: uppercase !important;
  letter-spacing: -.01em !important;
  color: var(--mp-ink) !important;
  margin: 0 0 24px !important;
  padding-bottom: 10px !important;
  position: relative;
  border-bottom: 3px solid var(--mp-ink) !important;
}
.comments-title::before,
.comment-reply-title::before,
#reply-title::before {
  content: "★ ";
  color: var(--mp-red);
}
.comments-title::after,
.comment-reply-title::after,
#reply-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 80px;
  height: 3px;
  background: var(--mp-red);
}
/* Lien "Annuler la réponse" à côté du titre */
.comment-reply-title small,
#reply-title small {
  display: inline-block;
  margin-left: 12px;
  font-family: Georgia, serif;
  font-size: 13px;
  font-style: italic;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}
.comment-reply-title small a,
#reply-title small a {
  color: var(--mp-red) !important;
  text-decoration: underline;
  text-decoration-color: var(--mp-red);
}

/* Texte "Connexion en tant que…" */
.logged-in-as {
  font-family: Georgia, "Times New Roman", serif !important;
  font-style: italic !important;
  font-size: 14px !important;
  color: var(--contrast-2) !important;
  margin: 0 0 16px !important;
  padding: 10px 14px !important;
  background: var(--mp-paper) !important;
  border-left: 3px solid var(--mp-red) !important;
}
.logged-in-as a {
  color: var(--mp-red) !important;
  text-decoration: underline;
}

/* Champs : textarea + inputs (author, email, url) */
.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
#comment {
  background: var(--mp-paper) !important;
  border: 2px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  padding: 12px 14px !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  color: var(--mp-ink) !important;
  width: 100% !important;
  box-shadow: none !important;
  transition: border-color .15s, box-shadow .15s !important;
}
.comment-form textarea:focus,
.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form input[type="url"]:focus,
#comment:focus {
  outline: 0 !important;
  border-color: var(--mp-red) !important;
  box-shadow: 4px 4px 0 var(--mp-red) !important;
}

.comment-form label {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  font-size: 12px !important;
  color: var(--mp-ink) !important;
  margin-bottom: 4px !important;
  display: inline-block;
}

/* Notes "Vous pouvez gérer les abonnements…" */
.comments-area p,
.comment-form p {
  margin-bottom: 14px !important;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--contrast-2);
}
.comments-area p a,
.comment-form p a {
  color: var(--mp-red);
  text-decoration: underline;
  text-decoration-color: var(--mp-red);
}

/* Bouton "Publier mon commentaire" */
.comment-form .form-submit input[type="submit"],
.comment-form #submit,
input#submit.submit,
.form-submit .submit,
button.submit {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--mp-ink) !important;
  color: var(--mp-paper) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-size: 15px !important;
  text-transform: uppercase !important;
  letter-spacing: .15em !important;
  padding: 14px 26px !important;
  border: 3px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  box-shadow: 5px 5px 0 var(--mp-red) !important;
  cursor: pointer !important;
  transition: transform .15s, box-shadow .15s, background .15s !important;
  text-decoration: none !important;
  margin-top: 8px !important;
}
.comment-form .form-submit input[type="submit"]:hover,
.comment-form #submit:hover,
input#submit.submit:hover,
.form-submit .submit:hover {
  transform: translate(-2px, -2px) !important;
  box-shadow: 7px 7px 0 var(--mp-red) !important;
  background: var(--mp-red) !important;
  border-color: var(--mp-red) !important;
}

/* Liste des commentaires */
.comment-list,
.commentlist,
ol.comment-list {
  list-style: none !important;
  margin: 0 0 32px !important;
  padding: 0 !important;
}
.comment-list .comment,
.comment-list li.comment {
  background: var(--mp-paper) !important;
  border: 2px solid var(--mp-ink) !important;
  box-shadow: 4px 4px 0 var(--mp-ink) !important;
  padding: 20px 22px !important;
  margin: 0 0 24px !important;
  list-style: none !important;
  position: relative;
}
.comment-list .comment .comment-author {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 10px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px dotted var(--mp-ink) !important;
}
.comment-list .comment .comment-author img,
.comment-list .comment .avatar {
  width: 40px !important;
  height: 40px !important;
  border-radius: 0 !important;
  border: 2px solid var(--mp-ink) !important;
}
.comment-list .comment .fn,
.comment-list .comment .comment-author cite {
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  font-style: normal !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--mp-ink) !important;
  font-size: 16px !important;
}
.comment-list .comment .says { display: none !important; }
.comment-list .comment .comment-metadata,
.comment-list .comment .comment-meta {
  font-family: Georgia, serif !important;
  font-style: italic !important;
  font-size: 12px !important;
  color: var(--contrast-2) !important;
  margin-left: auto;
}
.comment-list .comment .comment-content,
.comment-list .comment .comment-body {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: var(--mp-ink) !important;
}
.comment-list .comment .comment-content p,
.comment-list .comment .comment-body p {
  margin: 0 0 10px !important;
  color: var(--mp-ink) !important;
}
/* Bouton "Répondre" */
.comment-list .reply a,
.comment-reply-link {
  display: inline-block !important;
  background: var(--mp-paper-2) !important;
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .1em !important;
  font-size: 11px !important;
  padding: 6px 12px !important;
  border: 2px solid var(--mp-ink) !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  margin-top: 8px !important;
  transition: background .15s, color .15s !important;
}
.comment-list .reply a:hover,
.comment-reply-link:hover {
  background: var(--mp-red) !important;
  color: var(--mp-paper) !important;
  border-color: var(--mp-red) !important;
}
/* Réponses imbriquées */
.comment-list .children {
  list-style: none !important;
  margin: 16px 0 0 24px !important;
  padding: 0 !important;
  border-left: 3px solid var(--mp-red) !important;
  padding-left: 16px !important;
}
.comment-list .children .comment {
  box-shadow: 3px 3px 0 var(--mp-ink) !important;
}

/* "Pas de commentaires" / pagination commentaires */
.no-comments,
.comments-area .nav-previous a,
.comments-area .nav-next a {
  font-family: Georgia, serif;
  font-style: italic;
  color: var(--contrast-2);
}

/* Mobile : commentaires plus tassés */
@media (max-width: 768px) {
  .comments-area { padding: 20px 18px !important; }
  .comment-list .comment { padding: 16px 14px !important; }
  .comment-list .children { margin-left: 12px !important; padding-left: 12px !important; }
  .comment-form .form-submit input[type="submit"] { padding: 12px 20px !important; font-size: 14px !important; }
}

/* -- 14. Footer ----------------------------------------------
   Le footer est rendu via un .gb-container GenerateBlocks (custom user).
   On force le wrapper .site-footer du parent GP à 0 padding / 0 bordure /
   transparent pour qu'il ne crée pas un espace vide noir/rouge entre
   le contenu et le footer custom. */
.site-footer {
  background: transparent !important;
  padding: 0 !important;
  border: 0 !important;
  margin: 0 !important;
}

/* -- 15. Responsive ------------------------------------------ */

@media (max-width: 900px) {
  .mp-hero-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  .mp-panel.mp-1, .mp-panel.mp-2, .mp-panel.mp-3, .mp-panel.mp-4 {
    grid-column: 1; grid-row: auto;
  }
  .mp-panel.mp-4 { flex-direction: column; }
  .mp-panel.mp-4 .mp-img { width: 100%; aspect-ratio: 16/9; border-right: 0; border-bottom: 3px solid var(--mp-ink); }
  .mp-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .mp-duo-grid, .mp-feat-row { grid-template-columns: 1fr; }
  .mp-toc-list { grid-template-columns: 1fr; }
  .mp-cat-cover { padding: 32px 24px; margin: 16px 0 32px; }
  .mp-cat-cover .mp-jp { display: none; }
  .mp-faq { padding: 24px; }
}

@media (max-width: 540px) {
  .mp-grid-4 { grid-template-columns: 1fr; }
  .mp-wrap { padding: 0 16px; }
  .mp-bubble { font-size: 22px; padding: 10px 16px; top: -10px; right: 6px; }
  .mp-carousel-item { flex-basis: 240px; }
}

/* Carousel : indicateur visuel "scroller" sur desktop */
@media (min-width: 901px) {
  .mp-carousel { padding: 16px 8px 28px; }
}

/* -- 14. Single — meta compact (publié + auteur + lecture) sous le titre */

.single .entry-header > .entry-meta,
.single .inside-article > header.entry-header + .entry-meta,
.single article > .entry-meta:first-of-type {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 10px;
  row-gap: 4px;
  margin: 0 0 18px !important;
  padding: 8px 0 10px;
  border-top: 1px dotted var(--mp-ink);
  border-bottom: 1px dotted var(--mp-ink);
  font-family: Georgia, "Times New Roman", serif;
  font-style: italic;
  font-size: 13px;
  line-height: 1.4;
  color: var(--contrast-2);
}
.single .entry-header > .entry-meta > span,
.single .inside-article > header.entry-header + .entry-meta > span,
.single article > .entry-meta:first-of-type > span {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  margin: 0 !important;
  white-space: nowrap;
}
.single .entry-meta .meta-item { white-space: nowrap; }
.single .entry-meta time,
.single .entry-meta .author-name,
.single .entry-meta .byline a {
  font-style: normal;
  font-weight: 700;
  color: var(--mp-ink) !important;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  letter-spacing: .02em;
  text-transform: none;
}
.single .entry-meta .byline a:hover { color: var(--mp-red) !important; }
.single .entry-meta .updated:not(.updated-visible) { display: none; }
.single .entry-meta .o50 { color: var(--mp-red); opacity: 1; padding: 0 2px; }
.single .entry-meta .gp-icon { display: none !important; }

@media (max-width: 540px) {
  .single .entry-header > .entry-meta,
  .single .inside-article > header.entry-header + .entry-meta,
  .single article > .entry-meta:first-of-type {
    font-size: 12px;
    column-gap: 8px;
  }
}

/* -- 15. Single — Related-article "simple" inline ------------- */

.entry-content a.related-article.simple,
.entry-content p > a.related-article.simple {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
  margin: 1.6em 0;
  padding: 12px 16px;
  background: var(--mp-paper-2);
  border: 3px solid var(--mp-ink);
  border-radius: 6px;
  box-shadow: 5px 5px 0 var(--mp-red);
  color: var(--mp-ink) !important;
  text-decoration: none !important;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.entry-content a.related-article.simple:hover,
.entry-content p > a.related-article.simple:hover {
  background: var(--mp-paper);
  transform: translate(-2px, -2px);
  box-shadow: 7px 7px 0 var(--mp-red);
}
.entry-content a.related-article.simple .label {
  flex-shrink: 0;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .12em;
  background: var(--mp-red);
  color: var(--mp-paper);
  padding: 4px 10px;
  border-radius: 4px;
  white-space: nowrap;
  line-height: 1.2;
}
.entry-content a.related-article.simple .title {
  flex: 1;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 600;
  font-size: 15px;
  line-height: 1.3;
  color: var(--mp-ink);
}
.entry-content a.related-article.simple svg {
  flex-shrink: 0;
  color: var(--mp-red);
  transition: transform .2s ease;
}
.entry-content a.related-article.simple:hover svg {
  transform: translateX(4px);
}

@media (max-width: 540px) {
  .entry-content a.related-article.simple,
  .entry-content p > a.related-article.simple {
    flex-wrap: wrap;
    gap: 8px;
  }
  .entry-content a.related-article.simple .title { font-size: 14px; }
}

/* -- 16. Single — Tags en pied d'article --------------------- */

.single footer.entry-meta .tags-links,
.single .entry-meta .tags-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
  padding-top: 16px;
  border-top: 2px solid var(--mp-ink);
  font-size: 0;
  line-height: 1;
}
.single footer.entry-meta .tags-links::before,
.single .entry-meta .tags-links::before {
  content: "Tags";
  display: inline-block;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mp-ink);
  margin-right: 4px;
}
.single footer.entry-meta .tags-links a,
.single .entry-meta .tags-links a {
  display: inline-block;
  font-family: "Anton", "Anton-fallback", Impact, sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 10px;
  background: var(--mp-paper-2);
  border: 2px solid var(--mp-ink);
  border-radius: 4px;
  color: var(--mp-ink) !important;
  text-decoration: none !important;
  transition: transform .15s, box-shadow .15s, background .15s, color .15s, border-color .15s;
}
.single footer.entry-meta .tags-links a:hover,
.single .entry-meta .tags-links a:hover {
  background: var(--mp-red);
  border-color: var(--mp-red);
  color: var(--mp-paper) !important;
  transform: translate(-2px, -2px);
  box-shadow: 3px 3px 0 var(--mp-ink);
}
.single footer.entry-meta .tags-links .gp-icon,
.single .entry-meta .tags-links .gp-icon { display: none; }
.single footer.entry-meta .tags-links .screen-reader-text,
.single .entry-meta .tags-links .screen-reader-text { display: none; }
