/* ═══════════════════════════════════════════════════════
   ARTICLE MOBILE — overrides responsives pour les pages blog/*.html
   - Force min-width:0 sur les grid items pour éviter overflow
   - Stack le layout 2 col en 1 col propre
   - Réduit typo/padding pour mobile
   Inclus via <link rel="stylesheet" href="/assets/article-mobile.css">
   ═══════════════════════════════════════════════════════ */

/* Fix grid overflow : les enfants doivent pouvoir rétrécir */
.ar-layout > .ar-toc,
.ar-layout > .ar-body {
  min-width: 0;
}
.ar-body img,
.ar-body iframe,
.ar-body video,
.ar-body table {
  max-width: 100%;
}
.ar-body {
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* Tablette / petit desktop — déjà géré par @media 1100 inline */

@media (max-width: 768px) {
  .ar-header { padding-left: 22px !important; padding-right: 22px !important; }
  .ar-hero { padding-left: 22px !important; padding-right: 22px !important; }
  .ar-layout { padding-left: 22px !important; padding-right: 22px !important; gap: 24px !important; }
  .ar-breadcrumb { padding-left: 22px !important; padding-right: 22px !important; }
  .ar-h1 { font-size: 32px !important; line-height: 1.12 !important; }
  .ar-lead { font-size: 17.5px !important; line-height: 1.5 !important; }
  .ar-author-row { flex-wrap: wrap; gap: 12px; }
  .ar-read-time { margin-left: 0; font-size: 12.5px; }
  .ar-hero-glyph { font-size: 110px !important; }
}

@media (max-width: 600px) {
  /* Layout + typo */
  .ar-header { padding-left: 18px !important; padding-right: 18px !important; padding-top: 16px !important; }
  .ar-hero { padding-left: 18px !important; padding-right: 18px !important; margin-top: 20px !important; }
  .ar-layout { padding-left: 18px !important; padding-right: 18px !important; margin-top: 28px !important; }
  .ar-breadcrumb { padding-left: 18px !important; padding-right: 18px !important; font-size: 11px !important; margin-top: 20px !important; }
  .ar-h1 { font-size: 28px !important; line-height: 1.14 !important; margin-bottom: 14px !important; }
  .ar-h1 .underline-hand::after { height: 10px !important; bottom: 6% !important; }
  .ar-lead { font-size: 16.5px !important; margin-bottom: 22px !important; }

  /* Body typo */
  .ar-body p { font-size: 16px !important; line-height: 1.68 !important; margin-bottom: 18px !important; }
  .ar-body ul, .ar-body ol { font-size: 16px !important; padding-left: 22px !important; margin-bottom: 22px !important; }
  .ar-body h2 { font-size: 23px !important; line-height: 1.22 !important; margin-top: 40px !important; margin-bottom: 14px !important; }
  .ar-body h2 .ar-h2-num { font-size: 13px !important; margin-right: 8px !important; }
  .ar-body h3 { font-size: 18.5px !important; margin-top: 28px !important; margin-bottom: 10px !important; }

  /* Hero compact */
  .ar-hero-frame { border-radius: 14px !important; }
  .ar-hero-glyph { font-size: 84px !important; }
  .ar-hero-label { bottom: 14px !important; left: 16px !important; font-size: 10.5px !important; }
  .ar-hero-caption { bottom: 14px !important; right: 16px !important; font-size: 10.5px !important; }

  /* Auteur row */
  .ar-author-row { padding: 14px 0 !important; }
  .ar-avatar { width: 36px !important; height: 36px !important; font-size: 14px !important; }
  .ar-author-name { font-size: 13.5px !important; }
  .ar-author-meta { font-size: 11.5px !important; }
  .ar-share a, .ar-share button { width: 30px !important; height: 30px !important; }

  /* Cat line */
  .ar-cat-line { gap: 8px !important; font-size: 11.5px !important; margin-bottom: 16px !important; }
  .ar-cat-chip { padding: 4px 10px !important; font-size: 11px !important; }

  /* Disclosure post-it */
  .ar-disclosure { font-size: 14px !important; padding: 12px 18px !important; margin: 20px auto 14px !important; }
  .ar-disclosure strong, .ar-disclosure a { font-size: 15px !important; }

  /* Screenshot fake */
  .ar-screenshot { margin: 26px 0 24px !important; transform: rotate(-0.3deg) !important; }
  .ar-screenshot-bar { height: 28px !important; padding: 0 10px !important; }
  .ar-screenshot-dots span { width: 9px !important; height: 9px !important; }
  .ar-screenshot-url { font-size: 10.5px !important; margin-right: 30px !important; }
  .ar-screenshot-body { padding: 18px 18px 22px !important; min-height: 180px !important; }
  .ar-shot-title { font-size: 14.5px !important; }
  .ar-shot-row { gap: 10px !important; }

  /* Pull quote */
  .ar-pullquote { font-size: 18px !important; padding: 24px 24px 20px !important; margin: 32px auto !important; }
  .ar-pullquote-cite { font-size: 15px !important; }
  .ar-pullquote::before { font-size: 60px !important; top: -4px !important; left: 14px !important; }

  /* Tableau */
  .ar-table-wrap { margin: 28px 0 24px !important; }
  .ar-table-bar { height: 28px !important; }
  .ar-table-bar .ar-table-title { font-size: 10.5px !important; }
  .ar-table { font-size: 13px !important; }
  .ar-table th { padding: 10px 12px !important; font-size: 11.5px !important; }
  .ar-table td { padding: 10px 12px !important; }

  /* Takeaway */
  .ar-takeaway { padding: 18px 22px !important; margin: 32px 0 28px !important; }
  .ar-takeaway-title { font-size: 22px !important; }

  /* Video frame */
  .ar-video { margin: 26px 0 24px !important; }
  .ar-video-bar { padding: 0 10px !important; height: 28px !important; }
  .ar-video-title { font-size: 11px !important; }
  .ar-video-body iframe { aspect-ratio: 16/9 !important; height: auto !important; }

  /* Fig inline */
  .ar-fig { margin: 28px 0 24px !important; }

  /* CTAs mid */
  .ar-cta-mid { padding: 22px 22px !important; }
  .ar-cta-mid h3 { font-size: 18px !important; }

  /* Related */
  .ar-related-grid { gap: 16px !important; }
}
