/* ═══════════════════════════════════════════════════════════════
   ASSORTIS MOI — Blog Articles CSS (Child Theme)
   Design System v2.0 · Rose + Cream + Dark
   
   Ce fichier va dans le child theme et s'applique automatiquement
   à TOUS les articles existants et futurs.
   Cible : .single-post .entry-content
   ═══════════════════════════════════════════════════════════════ */

/* ── Variables (si pas déjà définies dans le theme) ── */
:root {
  --am-rose: #E8466A;
  --am-rose-hover: #F06B87;
  --am-rose-pale: #FDF0F3;
  --am-rose-mid: #FAD7DF;
  --am-dark: #1C1018;
  --am-text: #2A1520;
  --am-muted: #8C6070;
  --am-cream: #FEFBF9;
  --am-white: #FFFFFF;
  --am-border: #F0E4E8;
  --am-green: #2E9E6B;
  --am-green-bg: #EDF9F3;
  --am-amber: #D07A10;
  --am-amber-bg: #FFF8EC;
  --am-font-display: "Fraunces", Georgia, serif;
  --am-font-body: "DM Sans", -apple-system, sans-serif;
  --am-max-w: 1020px;
  --am-radius: 12px;
  --am-radius-lg: 16px;
  --am-radius-pill: 50px;
}

/* ═══════════════════════════════════════════════════
   GLOBAL — SINGLE POST
   ═══════════════════════════════════════════════════ */

.single-post .entry-content {
  font-family: var(--am-font-body);
  font-size: 16px;
  line-height: 1.8;
  color: var(--am-text);
  -webkit-font-smoothing: antialiased;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
}

/* Max-width sur le texte — enfants directs */
.single-post .entry-content > p,
.single-post .entry-content > h2,
.single-post .entry-content > h3,
.single-post .entry-content > h4,
.single-post .entry-content > ul,
.single-post .entry-content > ol,
.single-post .entry-content > blockquote,
.single-post .entry-content > table,
.single-post .entry-content > .am-toc,
.single-post .entry-content > .am-infobox,
.single-post .entry-content > .am-warnbox,
.single-post .entry-content > .am-cta-block,
.single-post .entry-content > .am-tool,
.single-post .entry-content > .am-checklist,
.single-post .entry-content > .am-article-footer {
  max-width: var(--am-max-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

/* Max-width sur le texte dans les blocs Flatsome UX text (pas les layouts) */
.single-post .entry-content .ux-text p,
.single-post .entry-content .text-inner p {
  max-width: var(--am-max-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

/* ═══ HERO ARTICLE ═══ */
.am-hero {
  position: relative !important;
  width: 100% !important;
  max-width: 1100px !important;
  margin: 0 auto 40px !important;
  border-radius: 0 0 24px 24px !important;
  overflow: hidden !important;
  min-height: 420px !important;
  display: block !important;
  background-color: #1C1018 !important;
}

/* Image réelle en <img> — impossible à supprimer par WP Rocket */
.am-hero > img.am-hero-img {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  filter: brightness(0.55) !important;
  z-index: 0 !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  max-width: none !important;
}

/* Fallback sans image → gradient */
.am-hero-fallback {
  background: linear-gradient(135deg, #1C1018 0%, #3d1f2e 50%, #2a1018 100%) !important;
}

.am-hero-overlay {
  position: relative !important;
  z-index: 1 !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 140px 40px 60px !important;
  color: #fff !important;
  text-align: center !important;
}
.am-hero-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  font-size: 13px;
  color: rgba(255,255,255,.7);
  flex-wrap: wrap;
  justify-content: center;
}
.am-hero-meta .cat {
  background: var(--am-rose);
  color: white;
  padding: 4px 12px;
  border-radius: var(--am-radius-pill);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.am-hero h1 {
  font-family: var(--am-font-display);
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 1.2;
  margin-bottom: 14px;
  color: white;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.am-hero-excerpt {
  font-size: 16px;
  line-height: 1.7;
  color: rgba(255,255,255,.8);
  max-width: 620px;
  margin: 0 auto;
}


/* ═══════════════════════════════════════════════════
   TYPOGRAPHIE — TITRES
   ═══════════════════════════════════════════════════ */

.single-post .entry-content h2 {
  font-family: var(--am-font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--am-dark);
  margin: 48px 0 16px;
  padding-top: 24px;
  border-top: 1px solid var(--am-border);
  line-height: 1.3;
  text-align: center;
}
.single-post .entry-content h2:first-of-type {
  border-top: none;
  padding-top: 0;
}

.single-post .entry-content h3 {
  font-family: var(--am-font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--am-dark);
  margin: 32px 0 10px;
  line-height: 1.3;
  text-align: center;
}

.single-post .entry-content h4 {
  font-family: var(--am-font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--am-dark);
  margin: 24px 0 8px;
  line-height: 1.3;
}


/* ═══════════════════════════════════════════════════
   TYPOGRAPHIE — CORPS DE TEXTE
   ═══════════════════════════════════════════════════ */

.single-post .entry-content p {
  margin: 0 0 18px;
  color: var(--am-text);
}

.single-post .entry-content a {
  color: var(--am-rose);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: var(--am-rose-mid);
  transition: all .2s;
}
.single-post .entry-content a:hover {
  color: var(--am-rose-hover);
  text-decoration-color: var(--am-rose-hover);
}

.single-post .entry-content strong {
  font-weight: 600;
  color: var(--am-dark);
}

.single-post .entry-content em {
  font-style: italic;
}


/* ═══════════════════════════════════════════════════
   LISTES
   ═══════════════════════════════════════════════════ */

.single-post .entry-content ul,
.single-post .entry-content ol {
  margin: 0 0 20px;
  padding-left: 24px;
}

.single-post .entry-content li {
  margin-bottom: 8px;
  line-height: 1.7;
}

.single-post .entry-content ul li::marker {
  color: var(--am-rose);
}

.single-post .entry-content ol li::marker {
  color: var(--am-rose);
  font-weight: 700;
}


/* ═══════════════════════════════════════════════════
   BLOCKQUOTE
   ═══════════════════════════════════════════════════ */

.single-post .entry-content blockquote {
  margin: 28px 0;
  padding: 20px 24px;
  background: var(--am-rose-pale);
  border-left: 4px solid var(--am-rose);
  border-radius: 0 var(--am-radius) var(--am-radius) 0;
  font-family: var(--am-font-display);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--am-dark);
  line-height: 1.6;
}
.single-post .entry-content blockquote p {
  margin: 0;
}


/* ═══════════════════════════════════════════════════
   IMAGES & FIGURES
   — Scoped pour ne PAS toucher les images Flatsome UX builder
   ═══════════════════════════════════════════════════ */

.single-post .entry-content > img,
.single-post .entry-content > p img,
.single-post .entry-content > a > img {
  max-width: 100%;
  height: auto;
  border-radius: var(--am-radius-lg);
  display: block;
  margin: 24px auto;
}

.single-post .entry-content > figure,
.single-post .entry-content > .am-figure {
  margin: 32px -20px;
  padding: 0;
}
.single-post .entry-content > figure img,
.single-post .entry-content > .am-figure img {
  width: 100%;
  border-radius: var(--am-radius-lg);
}

.single-post .entry-content figcaption {
  font-size: 13px;
  color: var(--am-muted);
  text-align: center;
  margin-top: 10px;
  font-style: italic;
}


/* ═══════════════════════════════════════════════════
   TABLE DES MATIÈRES (am-toc)
   ═══════════════════════════════════════════════════ */

.am-toc {
  background: var(--am-white);
  border: 1.5px solid var(--am-border);
  border-radius: var(--am-radius-lg);
  padding: 20px 24px;
  margin: 28px 0;
}
.am-toc > strong {
  display: block;
  font-family: var(--am-font-display);
  font-size: .95rem;
  font-weight: 700;
  color: var(--am-dark);
  margin-bottom: 10px;
}
.am-toc ol {
  padding-left: 20px;
  margin: 0;
}
.am-toc li {
  margin-bottom: 6px;
  font-size: 14px;
}
.am-toc a {
  text-decoration: none;
  font-weight: 500;
}


/* ═══════════════════════════════════════════════════
   TABLEAUX
   ═══════════════════════════════════════════════════ */

.single-post .entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
  border-radius: var(--am-radius);
  overflow: hidden;
  border: 1px solid var(--am-border);
}

.single-post .entry-content thead th {
  background: var(--am-dark);
  color: white;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 12px 16px;
  text-align: left;
}

.single-post .entry-content tbody td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--am-border);
}

.single-post .entry-content tbody tr:nth-child(even) {
  background: rgba(254,251,249,.5);
}

.single-post .entry-content tbody tr:hover {
  background: var(--am-rose-pale);
}


/* ═══════════════════════════════════════════════════
   ENCADRÉS — INFO (vert) & WARN (jaune)
   ═══════════════════════════════════════════════════ */

.am-infobox {
  background: var(--am-green-bg);
  border: 1px solid rgba(46,158,107,.15);
  border-radius: var(--am-radius);
  padding: 16px 20px;
  margin: 24px 0;
  font-size: 14px;
  line-height: 1.7;
  color: #1a5c3a;
}
.am-infobox strong {
  display: block;
  color: #1a5c3a;
  margin-bottom: 4px;
  font-size: 14px;
}
.am-infobox p { margin: 0; color: inherit; }

.am-warnbox {
  background: var(--am-amber-bg);
  border: 1px solid #F5E0A0;
  border-radius: var(--am-radius);
  padding: 16px 20px;
  margin: 24px 0;
  font-size: 14px;
  line-height: 1.7;
  color: #7a5900;
}
.am-warnbox strong {
  display: block;
  color: #7a5900;
  margin-bottom: 4px;
  font-size: 14px;
}
.am-warnbox p { margin: 0; color: inherit; }


/* ═══════════════════════════════════════════════════
   BLOC CTA
   ═══════════════════════════════════════════════════ */

.am-cta-block {
  background: linear-gradient(135deg, var(--am-rose-pale) 0%, #FFE8EE 50%, #FFF5F7 100%);
  border: 1.5px solid var(--am-rose-mid);
  border-radius: var(--am-radius-lg);
  padding: 32px;
  margin: 36px 0;
  text-align: center;
}
.am-cta-block h3,
.single-post .entry-content .am-cta-block h3 {
  font-family: var(--am-font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--am-dark);
  margin: 0 0 8px;
  border: none;
  padding: 0;
  text-align: center;
}
.am-cta-block p {
  font-size: 14px;
  color: var(--am-muted);
  margin: 0 0 18px;
}
.am-cta-buttons {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

.am-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  border-radius: var(--am-radius-pill);
  background: var(--am-rose);
  color: white !important;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none !important;
  transition: all .25s;
}
.am-btn-primary:hover {
  background: var(--am-rose-hover);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(232,70,106,.3);
}

.am-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  border-radius: var(--am-radius-pill);
  background: var(--am-white);
  color: var(--am-dark) !important;
  font-weight: 600;
  font-size: 14px;
  border: 1.5px solid var(--am-border);
  text-decoration: none !important;
  transition: all .2s;
}
.am-btn-secondary:hover {
  border-color: var(--am-rose-mid);
  color: var(--am-rose) !important;
}


/* ═══════════════════════════════════════════════════
   AUTEUR (bas d'article)
   ═══════════════════════════════════════════════════ */

.am-article-footer {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--am-border);
}
.am-author {
  display: flex;
  align-items: center;
  gap: 14px;
}
.am-author-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--am-rose);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--am-font-display);
  font-weight: 700;
  font-size: 16px;
  flex-shrink: 0;
}
.am-author strong {
  display: block;
  font-size: 14px;
  color: var(--am-dark);
}
.am-author span {
  font-size: 13px;
  color: var(--am-muted);
}


/* ═══════════════════════════════════════════════════
   OUTILS INTERACTIFS
   ═══════════════════════════════════════════════════ */

.am-tool {
  background: var(--am-white);
  border: 1.5px solid var(--am-border);
  border-radius: var(--am-radius-lg);
  overflow: hidden;
  margin: 28px 0;
  box-shadow: 0 4px 20px rgba(28,16,24,.06);
}
.am-tool-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 20px;
  background: var(--am-dark);
  color: white;
}
.am-tool-icon { font-size: 20px; }

.am-tool-header h3,
.single-post .entry-content .am-tool-header h3 {
  font-family: var(--am-font-display);
  font-size: 1rem;
  font-weight: 700;
  color: white;
  margin: 0;
  border: none;
  padding: 0;
  text-align: left;
}
.am-tool-body { padding: 24px 20px; }

.am-tool-q {
  font-family: var(--am-font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--am-dark);
  margin-bottom: 14px !important;
}

.am-tool-step,
.quiz-q { display: none; }

.am-tool-step.active,
.quiz-q.active {
  display: block;
  animation: amFadeInUp .3s ease;
}

@keyframes amFadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.am-tool-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.am-tool-options button {
  padding: 10px 16px;
  border-radius: var(--am-radius);
  border: 1.5px solid var(--am-border);
  background: var(--am-cream);
  color: var(--am-text);
  font-family: var(--am-font-body);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .2s;
}
.am-tool-options button:hover {
  border-color: var(--am-rose-mid);
  background: var(--am-rose-pale);
  color: var(--am-rose);
}
.am-tool-options button.selected {
  border-color: var(--am-rose);
  background: var(--am-rose);
  color: white;
}

.am-tool-result,
.quiz-result {
  text-align: center;
  animation: amFadeInUp .4s ease;
}
.am-tool-result-icon { font-size: 2.5rem; margin-bottom: 8px; }

.am-tool-result h4,
.quiz-result h4 {
  font-family: var(--am-font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--am-dark);
  margin-bottom: 8px;
}
.am-tool-result p,
.quiz-result p {
  font-size: 14px;
  color: var(--am-muted);
  max-width: 480px;
  margin: 0 auto 12px;
  line-height: 1.7;
}
.am-tool-result-price {
  font-family: var(--am-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--am-rose);
  margin-bottom: 16px;
}

.am-tool-cta {
  display: inline-flex;
  align-items: center;
  padding: 12px 24px;
  border-radius: var(--am-radius-pill);
  background: var(--am-rose);
  color: white !important;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none !important;
  transition: all .25s;
}
.am-tool-cta:hover {
  background: var(--am-rose-hover);
  transform: translateY(-1px);
}

.am-tool-reset {
  display: block;
  margin: 12px auto 0;
  background: none;
  border: none;
  color: var(--am-muted);
  font-family: var(--am-font-body);
  font-size: 12px;
  cursor: pointer;
  text-decoration: underline;
  transition: color .2s;
}
.am-tool-reset:hover { color: var(--am-rose); }


/* ═══════════════════════════════════════════════════
   CHECKLIST INTERACTIVE
   ═══════════════════════════════════════════════════ */

.am-checklist {
  background: var(--am-white);
  border: 1.5px solid var(--am-border);
  border-radius: var(--am-radius-lg);
  padding: 24px;
  margin: 28px 0;
}
.am-checklist h3,
.single-post .entry-content .am-checklist h3 {
  font-family: var(--am-font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--am-dark);
  margin: 0 0 16px;
  border: none;
  padding: 0;
  text-align: left;
}
.am-checklist-progress {
  background: var(--am-border);
  border-radius: var(--am-radius-pill);
  height: 6px;
  margin-bottom: 16px;
  overflow: hidden;
}
.am-checklist-progress-bar {
  background: var(--am-green);
  height: 100%;
  border-radius: var(--am-radius-pill);
  transition: width .3s ease;
  width: 0;
}
.am-checklist label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--am-border);
  font-size: 14px;
  color: var(--am-text);
  cursor: pointer;
  transition: opacity .2s;
}
.am-checklist label:last-child { border-bottom: none; }
.am-checklist label.checked { opacity: .5; text-decoration: line-through; }
.am-checklist input[type="checkbox"] {
  accent-color: var(--am-rose);
  margin-top: 3px;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════
   ARTICLES LIÉS
   ═══════════════════════════════════════════════════ */

.am-related {
  max-width: 1100px;
  margin: 48px auto 60px;
  padding: 0 40px;
}
.am-related h3 {
  font-family: var(--am-font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--am-dark);
  margin-bottom: 16px;
  text-align: left;
}
.am-related-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}
.am-related-card {
  background: var(--am-white);
  border: 1px solid var(--am-border);
  border-radius: var(--am-radius-lg);
  overflow: hidden;
  text-decoration: none;
  transition: all .2s;
}
.am-related-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(28,16,24,.08);
  border-color: var(--am-rose-mid);
}
.am-related-thumb {
  height: 140px;
  background-size: cover;
  background-position: center;
}
.am-related-info { padding: 14px; }
.am-related-info .cat {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--am-rose);
  margin-bottom: 4px;
}
.am-related-info h4 {
  font-family: var(--am-font-display);
  font-size: .85rem;
  font-weight: 700;
  color: var(--am-dark);
  line-height: 1.3;
  margin: 0;
}


/* ═══════════════════════════════════════════════════
   BREADCRUMB (article)
   ═══════════════════════════════════════════════════ */

.am-breadcrumb {
  font-size: 12px;
  color: var(--am-muted);
  padding: 14px 20px;
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.am-breadcrumb a { color: var(--am-muted); text-decoration: none; }
.am-breadcrumb a:hover { color: var(--am-rose); }
.am-breadcrumb .sep { opacity: .4; }


/* ═══════════════════════════════════════════════════
   RÉASSURANCE STRIP (bas d'article)
   ═══════════════════════════════════════════════════ */

.am-reassurance-strip {
  background: var(--am-white);
  border-top: 1px solid var(--am-border);
  border-bottom: 1px solid var(--am-border);
  padding: 16px 20px;
  margin-top: 32px;
}
.am-reassurance-strip .inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--am-text);
}
.am-reassurance-strip .sep { opacity: .2; }


/* ═══════════════════════════════════════════════════
   OVERRIDE FLATSOME (écraser l'ancien style)
   ═══════════════════════════════════════════════════ */

/* Flatsome met des styles inline et des classes sur les titres */
.single-post .entry-content .ux-text h2,
.single-post .entry-content .row h2,
.single-post .entry-content .col h2 {
  font-family: var(--am-font-display) !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  color: var(--am-dark) !important;
}

/* Flatsome images — laissées à Flatsome (pas de border-radius forcé) */

/* Flatsome buttons → transformer en am style */
.single-post .entry-content .button,
.single-post .entry-content .ux-button {
  background: var(--am-rose) !important;
  border-radius: var(--am-radius-pill) !important;
  font-family: var(--am-font-body) !important;
  color: white !important;
  border: none !important;
}

/* ⚠️ NE PAS toucher aux .row et .col de Flatsome — 
   ça casse le système de grille et empile les colonnes.
   Les marges/paddings Flatsome sont nécessaires pour le layout. */

/* ═══ PROTECTION LAYOUT FLATSOME UX BUILDER ═══ */
/* Annuler nos styles img/figure quand ils sont dans des blocs Flatsome */
.single-post .entry-content .row img,
.single-post .entry-content .col img,
.single-post .entry-content .ux_banner img,
.single-post .entry-content .img-inner img,
.single-post .entry-content .ux_image img,
.single-post .entry-content .banner-image img {
  margin: 0 !important;
  border-radius: 0 !important;
}

.single-post .entry-content .row figure,
.single-post .entry-content .col figure {
  margin: 0 !important;
  padding: 0 !important;
}

/* Ne pas limiter la largeur des blocs Flatsome */
.single-post .entry-content .row,
.single-post .entry-content .ux_banner,
.single-post .entry-content .section {
  max-width: none !important;
}


/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */

@media (max-width: 768px) {
  .am-hero h1 { font-size: 1.7rem; }
  .am-hero { min-height: 340px !important; }
  .am-hero-overlay { padding: 100px 20px 40px; }
  
  .single-post .entry-content {
    font-size: 15px;
    padding: 0 16px;
  }
  .single-post .entry-content > p,
  .single-post .entry-content > h2,
  .single-post .entry-content > h3,
  .single-post .entry-content > ul,
  .single-post .entry-content > ol,
  .single-post .entry-content > blockquote,
  .single-post .entry-content > .am-toc,
  .single-post .entry-content > .am-infobox,
  .single-post .entry-content > .am-warnbox,
  .single-post .entry-content > .am-cta-block,
  .single-post .entry-content > .am-tool,
  .single-post .entry-content > .am-checklist {
    padding-left: 0;
    padding-right: 0;
  }
  .single-post .entry-content h2 {
    font-size: 1.35rem;
    margin: 36px 0 14px;
  }
  .single-post .entry-content h3 {
    font-size: 1.05rem;
  }
  .single-post .entry-content > figure,
  .single-post .entry-content > .am-figure {
    margin: 24px -16px;
  }
  
  .am-tool-options { flex-direction: column; }
  .am-cta-buttons { flex-direction: column; align-items: center; }
  
  .single-post .entry-content table { font-size: 12px; }
  .single-post .entry-content thead th,
  .single-post .entry-content tbody td { padding: 10px 12px; }
  
  .am-related { padding: 0 20px; margin: 36px auto 40px; }
  .am-related-grid { grid-template-columns: 1fr; }
  .am-related-thumb { height: 120px; }
  
  .am-reassurance-strip .inner {
    flex-direction: column;
    gap: 8px;
  }

  /* TOC compact */
  .am-toc { padding: 16px; }
  .am-toc-list a { font-size: 13px; padding: 6px 0; }

  /* Blocs info/warning */
  .am-infobox, .am-warnbox { padding: 14px 16px; }

  /* CTA block */
  .am-cta-block { padding: 20px 16px; }

  /* Blockquote */
  .single-post .entry-content blockquote { padding: 16px 18px; font-size: 1rem; }

  /* Article footer */
  .am-article-footer { padding: 16px; }
}

@media (max-width: 480px) {
  .am-hero h1 { font-size: 1.4rem; }
  .am-hero { min-height: 280px !important; }
  .am-hero-overlay { padding: 80px 16px 32px; }
  .am-hero-excerpt { font-size: 14px; }
  .single-post .entry-content { font-size: 14px; }
}
