:root {
  --adg-ivoire: #F4EBDC; --adg-ivoire-soft: #FBF6EC;
  --adg-sable: #D9C8A8; --adg-sable-soft: #E8DCC2;
  --adg-espresso: #2A1A12; --adg-espresso-soft: #3D2A1F;
  --adg-cafe-au-lait: #7A4A2E;
  --adg-cuivre: #A65A2A; --adg-cuivre-soft: #C77B47;
  --adg-success: #5A7A3E; --adg-warning: #B8841C; --adg-error: #A33027;
  --adg-font-serif: 'Cormorant Garamond', Georgia, serif;
  --adg-font-sans: 'Inter', system-ui, sans-serif;
  --adg-radius-sm: 2px; --adg-radius-md: 6px; --adg-radius-lg: 12px;
}
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; font-family: var(--adg-font-sans); color: var(--adg-espresso); background: var(--adg-ivoire-soft); line-height: 1.65; font-size: 17px; }
h1, h2, h3, h4 { font-family: var(--adg-font-serif); font-weight: 600; color: var(--adg-espresso); letter-spacing: -0.01em; }
a { color: var(--adg-cuivre); text-decoration: none; border-bottom: 1px solid rgba(166, 90, 42, 0.25); transition: border-color .2s, color .2s; }
a:hover { color: var(--adg-espresso); border-bottom-color: var(--adg-espresso); }

.adg-progress { position: fixed; top: 0; left: 0; width: 100%; height: 3px; background: transparent; z-index: 9999; }
.adg-progress__bar { height: 100%; width: 0%; background: var(--adg-cuivre); transition: width .15s ease-out; }

.adg-fake-header { background: var(--adg-ivoire); border-bottom: 1px solid var(--adg-sable-soft); padding: 16px 32px; display: flex; justify-content: space-between; align-items: center; }
.adg-fake-header .logo { font-family: var(--adg-font-serif); font-size: 24px; color: var(--adg-espresso); }
.adg-fake-header .logo em { color: var(--adg-cuivre); font-style: normal; }
.adg-fake-header nav { display: flex; gap: 28px; font-size: 14px; color: var(--adg-cafe-au-lait); }
.adg-fake-header nav a { color: var(--adg-cafe-au-lait); border: none; }

.adg-hero { background: var(--adg-ivoire); padding: 48px 36px; border-radius: 12px; margin: 0 0 8px; }
.adg-hero__inner { max-width: 100%; margin: 0; }
.adg-breadcrumb { font-size: 13px; color: var(--adg-cafe-au-lait); margin-bottom: 24px; letter-spacing: 0.02em; }
.adg-breadcrumb a { color: var(--adg-cafe-au-lait); border: none; }
.adg-breadcrumb a:hover { color: var(--adg-cuivre); }
.adg-breadcrumb span.sep { margin: 0 8px; opacity: .5; }
.adg-eyebrow { display: inline-block; font-size: 12px; font-weight: 500; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); background: rgba(166, 90, 42, 0.08); padding: 6px 14px; border-radius: 2px; margin-bottom: 20px; }
.adg-hero h1 { font-size: clamp(34px, 5vw, 56px) !important; line-height: 1.1 !important; margin: 0 0 20px !important; font-weight: 500 !important; color: var(--adg-espresso) !important; font-family: var(--adg-font-serif) !important; }
.adg-hero h1 em { color: var(--adg-cuivre); font-style: italic; }
.adg-hero .deck { font-family: var(--adg-font-serif); font-style: italic; font-size: 22px; color: var(--adg-cafe-au-lait); margin: 0 0 32px; line-height: 1.4; max-width: 720px; }
.adg-meta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; padding-top: 24px; border-top: 1px solid var(--adg-sable-soft); }
.adg-meta__author { display: flex; align-items: center; gap: 12px; }
.adg-meta__avatar { width: 44px !important; height: 44px !important; min-width: 44px; min-height: 44px; max-width: 44px; max-height: 44px; border-radius: 50%; background: var(--adg-sable-soft); display: flex; align-items: center; justify-content: center; font-family: var(--adg-font-serif); font-size: 18px; color: var(--adg-espresso); font-weight: 600; border: 2px solid var(--adg-ivoire); box-shadow: 0 0 0 1px var(--adg-sable); overflow: hidden; flex-shrink: 0; }
.adg-meta__author-name { font-size: 14px; font-weight: 600; color: var(--adg-espresso); }
.adg-meta__author-role { font-size: 12px; color: var(--adg-cafe-au-lait); }
.adg-meta__sep { width: 1px; height: 32px; background: var(--adg-sable); }
.adg-meta__item { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--adg-cafe-au-lait); }
.adg-meta__item svg { width: 14px; height: 14px; stroke: var(--adg-cafe-au-lait); }

.adg-article-wrap { max-width: 100%; margin: 0; padding: 32px 0 48px; display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 48px; }
.adg-article { font-size: 17px; line-height: 1.75; color: var(--adg-espresso-soft); max-width: 720px; }
.adg-article p { margin: 0 0 24px; }
.adg-article h2 { font-size: 34px; margin: 56px 0 24px; line-height: 1.2; scroll-margin-top: 80px; }
.adg-article h2 .num { display: inline-block; font-family: var(--adg-font-sans); font-size: 14px; font-weight: 600; color: var(--adg-cuivre); letter-spacing: 0.15em; margin-bottom: 8px; text-transform: uppercase; }
.adg-article h2 .num::before { content: ""; display: inline-block; width: 28px; height: 1px; background: var(--adg-cuivre); margin-right: 12px; vertical-align: middle; }
.adg-article h3 { font-size: 26px; margin: 48px 0 12px; line-height: 1.2; scroll-margin-top: 80px; }
.adg-article ul, .adg-article ol { margin: 0 0 24px; padding-left: 22px; }
.adg-article li { margin-bottom: 8px; }
.adg-article strong { color: var(--adg-espresso); }
.adg-article blockquote { border-left: 3px solid var(--adg-cuivre); padding: 8px 0 8px 24px; margin: 32px 0; font-family: var(--adg-font-serif); font-style: italic; font-size: 22px; color: var(--adg-espresso); line-height: 1.5; }

.adg-toc { position: relative; }
.adg-toc__inner { position: sticky; top: 32px; background: var(--adg-ivoire); border: 1px solid var(--adg-sable-soft); border-radius: var(--adg-radius-lg); padding: 28px 24px; }
.adg-toc__label { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 4px; }
.adg-toc__title { font-family: var(--adg-font-serif); font-size: 22px; font-weight: 600; color: var(--adg-espresso); margin-bottom: 4px; }
.adg-toc__progress { font-size: 12px; color: var(--adg-cafe-au-lait); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; }
.adg-toc__progress-bar { flex: 1; height: 3px; background: var(--adg-sable-soft); border-radius: 2px; overflow: hidden; }
.adg-toc__progress-bar > span { display: block; height: 100%; width: 0%; background: var(--adg-cuivre); transition: width .3s ease-out; }
.adg-toc__list { list-style: none; padding: 0; margin: 0; }
.adg-toc__item { display: flex; align-items: flex-start; gap: 10px; padding: 9px 0; font-size: 14px; line-height: 1.4; border-bottom: 1px solid rgba(217, 200, 168, 0.4); transition: color .2s; }
.adg-toc__item:last-child { border-bottom: none; }
.adg-toc__item a { color: var(--adg-cafe-au-lait); border: none; flex: 1; transition: color .2s, transform .2s; }
.adg-toc__check { flex-shrink: 0; width: 18px; height: 18px; border: 1.5px solid var(--adg-sable); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-top: 2px; transition: all .35s cubic-bezier(.5, 0, .25, 1.5); background: transparent; }
.adg-toc__check svg { width: 11px; height: 11px; stroke: var(--adg-ivoire); stroke-width: 3; opacity: 0; transition: opacity .2s; }
.adg-toc__item.is-active a { color: var(--adg-espresso); font-weight: 600; transform: translateX(2px); }
.adg-toc__item.is-active .adg-toc__check { border-color: var(--adg-cuivre); background: var(--adg-ivoire); }
.adg-toc__item.is-done a { color: var(--adg-cafe-au-lait); }
.adg-toc__item.is-done .adg-toc__check { border-color: var(--adg-cuivre); background: var(--adg-cuivre); transform: scale(1.05); }
.adg-toc__item.is-done .adg-toc__check svg { opacity: 1; }
.adg-toc-mobile { display: none; }

/* TL;DR */
.adg-tldr { background: var(--adg-espresso); color: var(--adg-ivoire); border-radius: var(--adg-radius-lg); padding: 32px 36px; margin: 40px 0; position: relative; }
.adg-tldr__label { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre-soft); margin-bottom: 8px; }
.adg-tldr__title { font-family: var(--adg-font-serif) !important; font-size: 26px !important; margin: 0 0 20px !important; color: var(--adg-ivoire) !important; font-weight: 500 !important; }
.adg-tldr__rank { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid rgba(244, 235, 220, 0.12); align-items: flex-start; }
.adg-tldr__rank:last-child { border-bottom: none; }
.adg-tldr__rank-num { flex-shrink: 0; width: 38px; height: 38px; border-radius: 50%; background: var(--adg-cuivre); color: var(--adg-ivoire); display: flex; align-items: center; justify-content: center; font-family: var(--adg-font-serif); font-weight: 700; font-size: 18px; }
.adg-tldr__rank-num.gold { background: var(--adg-cuivre-soft); color: var(--adg-espresso); }
.adg-tldr__rank-content { flex: 1; padding-top: 4px; }
.adg-tldr__rank-name { font-family: var(--adg-font-serif) !important; font-size: 20px !important; color: var(--adg-ivoire) !important; margin: 0 0 4px !important; font-weight: 600 !important; }
.adg-tldr__rank-why { font-size: 14px; line-height: 1.5; color: rgba(244, 235, 220, 0.85); margin: 0; }

/* Bloc Conseil de barista */
.adg-callout { display: flex; gap: 20px; align-items: flex-start; background: var(--adg-ivoire); border-left: 4px solid var(--adg-cuivre); border-radius: var(--adg-radius-md); padding: 24px 28px; margin: 36px 0; }
.adg-callout__icon img { width: 100%; height: 100%; object-fit: cover; object-position: center 20%; border-radius: 50%; display: block; }
.adg-callout__icon { flex-shrink: 0; width: 44px; height: 44px; min-width: 44px; min-height: 44px; overflow: hidden; padding: 0; border-radius: 50%; background: var(--adg-cuivre); color: var(--adg-ivoire); display: flex; align-items: center; justify-content: center; font-family: var(--adg-font-serif); font-size: 20px; font-weight: 600; font-style: italic; }
.adg-callout__body { flex: 1; font-size: 15.5px; line-height: 1.6; color: var(--adg-espresso-soft); }
.adg-callout__label { font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 6px; }
.adg-callout__body p:last-child { margin-bottom: 0; }
.adg-callout__body strong { color: var(--adg-espresso); }

/* Bloc "Le saviez-vous" */
.adg-knowit { background: var(--adg-sable-soft); border-radius: var(--adg-radius-md); padding: 24px 28px; margin: 36px 0; display: flex; gap: 18px; align-items: flex-start; }
.adg-knowit__emoji { font-size: 30px; line-height: 1; flex-shrink: 0; }
.adg-knowit__content { flex: 1; }
.adg-knowit__label { font-family: var(--adg-font-serif); font-style: italic; font-size: 18px; color: var(--adg-cafe-au-lait); margin-bottom: 4px; }
.adg-knowit p { margin: 0; font-size: 15.5px; line-height: 1.6; color: var(--adg-espresso-soft); }

/* Citation pull-quote */
.adg-pullquote { margin: 48px 0; padding: 28px 32px; background: var(--adg-ivoire); border-radius: 12px; position: relative; }
.adg-pullquote::before { content: "\201C"; position: absolute; top: 0; left: 24px; transform: translateY(-40%); font-family: var(--adg-font-serif); font-size: 100px; line-height: 1; color: var(--adg-cuivre); font-weight: 600; }
.adg-pullquote__text { font-family: var(--adg-font-serif); font-style: italic; font-size: 26px; line-height: 1.4; color: var(--adg-espresso); margin: 0 0 16px; }
.adg-pullquote__cite { font-family: var(--adg-font-sans); font-size: 13px; color: var(--adg-cafe-au-lait); display: flex; align-items: center; gap: 10px; }
.adg-pullquote__cite::before { content: ""; display: inline-block; width: 24px; height: 1px; background: var(--adg-cuivre); }

/* CTA catégorie */
.adg-catcta { display: flex; align-items: center; gap: 24px; padding: 24px 28px; margin: 36px 0; background: var(--adg-espresso); color: var(--adg-ivoire); border-radius: var(--adg-radius-md); text-decoration: none; transition: transform .2s; border: none; }
a.adg-catcta { border: none; }
.adg-catcta:hover { transform: translateX(4px); color: var(--adg-ivoire); border: none; }
.adg-catcta__icon { font-size: 36px; line-height: 1; flex-shrink: 0; }
.adg-catcta__body { flex: 1; }
.adg-catcta__label { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre-soft); margin-bottom: 4px; }
.adg-catcta__title { font-family: var(--adg-font-serif); font-size: 22px; margin: 0; font-weight: 500; }
.adg-catcta__sub { font-size: 13px; color: rgba(244, 235, 220, 0.7); margin-top: 4px; }
.adg-catcta__arrow { font-size: 24px; color: var(--adg-cuivre-soft); flex-shrink: 0; }

/* Bloc produit inline */
.adg-product-inline { display: grid; grid-template-columns: 140px 1fr auto; align-items: center; gap: 24px; background: var(--adg-ivoire); border: 1px solid var(--adg-sable-soft); border-left: 4px solid var(--adg-cuivre); border-radius: var(--adg-radius-md); padding: 18px 24px 18px 20px; margin: 24px 0 32px; text-decoration: none; color: inherit; transition: transform .2s, box-shadow .2s; }
a.adg-product-inline { border: 1px solid var(--adg-sable-soft); border-left: 4px solid var(--adg-cuivre); }
.adg-product-inline:hover { transform: translateX(2px); box-shadow: 0 8px 20px rgba(42, 26, 18, 0.08); }
.adg-product-inline__img { width: 140px; height: 110px; background-color: var(--adg-sable-soft); background-size: cover; background-position: center; background-repeat: no-repeat; border-radius: var(--adg-radius-sm); flex-shrink: 0; }
.adg-product-inline__body { min-width: 0; }
.adg-product-inline__label { font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 4px; }
.adg-product-inline__brand { font-size: 11px; color: var(--adg-cafe-au-lait); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; }
.adg-product-inline__name { font-family: var(--adg-font-serif); font-size: 22px; line-height: 1.2; margin: 4px 0 6px; color: var(--adg-espresso); font-weight: 500; }
.adg-product-inline__why { font-size: 14px; color: var(--adg-cafe-au-lait); line-height: 1.5; margin: 0; }
.adg-product-inline__cta { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.adg-product-inline__price { font-family: var(--adg-font-serif); font-size: 22px; font-weight: 600; color: var(--adg-espresso); }
.adg-product-inline__btn { font-size: 12px; font-weight: 600; color: var(--adg-cuivre); text-transform: uppercase; letter-spacing: 0.1em; }
.adg-product-inline:hover .adg-product-inline__btn { color: var(--adg-espresso); }

/* === FICHE MARQUE (specifique a cet article) === */
.adg-brand-card { background: var(--adg-ivoire); border-radius: var(--adg-radius-lg); padding: 28px 32px; margin: 24px 0 16px; border: 1px solid var(--adg-sable-soft); }
.adg-brand-card__head { display: flex !important; flex-wrap: wrap !important; gap: 16px; align-items: flex-start; padding-bottom: 16px; border-bottom: 1px solid var(--adg-sable-soft); margin-bottom: 16px; }
.adg-brand-card__rank { flex-shrink: 0; width: 60px; text-align: center; }
.adg-brand-card__rank-label { font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--adg-cafe-au-lait); }
.adg-brand-card__rank-num { font-family: var(--adg-font-serif); font-size: 48px; font-weight: 700; color: var(--adg-cuivre); line-height: 1; margin-top: 4px; }
.adg-brand-card__title { flex: 1 1 200px !important; min-width: 0 !important; }
.adg-brand-card__name { font-family: var(--adg-font-serif) !important; font-size: 32px !important; font-weight: 600 !important; color: var(--adg-espresso) !important; margin: 0 0 4px !important; line-height: 1.1 !important; }
.adg-brand-card__tagline { font-family: var(--adg-font-serif); font-style: italic; font-size: 17px; color: var(--adg-cafe-au-lait); }
.adg-brand-card__score { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
.adg-brand-card__score-num { font-family: var(--adg-font-serif); font-weight: 700; color: var(--adg-espresso); font-size: 28px; line-height: 1; }
.adg-brand-card__score-num span { font-size: 16px; color: var(--adg-cafe-au-lait); font-weight: 400; }
.adg-brand-card__score-stars { display: flex; gap: 2px; }
.adg-brand-card__score-stars span { color: var(--adg-cuivre); font-size: 14px; }
.adg-brand-card__score-stars span.empty { color: var(--adg-sable); }

.adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
.adg-fact { background: var(--adg-ivoire-soft); padding: 10px 12px; border-radius: var(--adg-radius-sm); min-width: 0 !important; overflow: hidden; }
.adg-fact__label { font-size: 10px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--adg-cafe-au-lait); margin-bottom: 4px; display: block; }
.adg-fact__value { font-size: 13px; color: var(--adg-espresso); font-weight: 500; line-height: 1.3; overflow-wrap: anywhere !important; word-break: break-word !important; min-width: 0; }
.adg-fact__value .icon { font-size: 14px; margin-right: 4px; }

/* Bloc verdict pour chaque marque (mini résumé) */
.adg-verdict { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0 8px; }
.adg-verdict__col { padding: 14px 16px; border-radius: var(--adg-radius-sm); background: var(--adg-ivoire-soft); border-top: 3px solid var(--adg-success); }
.adg-verdict__col.no { border-top-color: var(--adg-error); }
.adg-verdict__title { font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }
.adg-verdict__col.yes .adg-verdict__title { color: var(--adg-success); }
.adg-verdict__col.no .adg-verdict__title { color: var(--adg-error); }
.adg-verdict ul { margin: 0; padding-left: 16px; font-size: 13px; line-height: 1.5; }
.adg-verdict li { margin-bottom: 2px; color: var(--adg-espresso-soft); }

/* FAQ accordeon */
.adg-faq { margin: 32px 0; }
.adg-faq__item { background: var(--adg-ivoire); border: 1px solid var(--adg-sable-soft); border-radius: var(--adg-radius-md); margin-bottom: 10px; overflow: hidden; }
.adg-faq__item summary { padding: 18px 24px; font-family: var(--adg-font-serif); font-size: 19px; font-weight: 600; color: var(--adg-espresso); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; list-style: none; }
.adg-faq__item summary::-webkit-details-marker { display: none; }
.adg-faq__item summary::after { content: "+"; font-family: var(--adg-font-sans); font-size: 24px; font-weight: 300; color: var(--adg-cuivre); transition: transform .2s; flex-shrink: 0; }
.adg-faq__item[open] summary::after { transform: rotate(45deg); }
.adg-faq__item summary:hover { background: var(--adg-ivoire-soft); }
.adg-faq__body { padding: 0 24px 22px; font-size: 15.5px; line-height: 1.65; color: var(--adg-espresso-soft); }
.adg-faq__body p { margin: 0 0 12px; }
.adg-faq__body p:last-child { margin-bottom: 0; }

/* Vidéo YouTube */
.adg-video { margin: 40px 0; background: var(--adg-espresso); border-radius: var(--adg-radius-lg); overflow: hidden; }
.adg-video__head { padding: 16px 24px; display: flex; align-items: center; gap: 12px; color: var(--adg-ivoire); }
.adg-video__head svg { width: 18px; height: 18px; fill: var(--adg-cuivre-soft); }
.adg-video__head span { font-size: 12px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--adg-cuivre-soft); }
.adg-video__head .label { color: var(--adg-ivoire); font-family: var(--adg-font-serif); font-style: italic; font-size: 16px; letter-spacing: 0; text-transform: none; margin-left: auto; opacity: .8; }
/* Video play card 16:9 cliquable avec thumbnail YouTube */
.adg-video__play { position: relative; display: block; width: 100%; padding-bottom: 56.25%; background-size: cover; background-position: center; background-color: #000; text-decoration: none; border: none !important; transition: opacity .25s; }
.adg-video__play::before { content: ""; position: absolute; inset: 0; background: rgba(42,26,18,0.25); }
.adg-video__play:hover { opacity: .94; }
.adg-video__playbtn { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 72px; height: 72px; border-radius: 50%; background: var(--adg-cuivre); color: var(--adg-ivoire); display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 24px rgba(0,0,0,0.35); font-size: 28px; line-height: 1; padding-left: 4px; }
.adg-video__play:hover .adg-video__playbtn { transform: translate(-50%, -50%) scale(1.06); }
.adg-video__playlabel { position: absolute; bottom: 14px; right: 16px; background: rgba(42,26,18,0.7); color: var(--adg-ivoire); font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; padding: 6px 12px; border-radius: 2px; }

.adg-video__embed { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }
.adg-video__embed iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* Bloc auteur */
.adg-author-block { margin: 64px 0 0; padding: 36px; background: var(--adg-ivoire); border-radius: var(--adg-radius-lg); display: grid; grid-template-columns: 110px 1fr; gap: 28px; border: 1px solid var(--adg-sable-soft); }
.adg-author-block__img { width: 110px !important; height: 110px !important; min-width: 110px; min-height: 110px; max-width: 110px; max-height: 110px; border-radius: 50%; background: var(--adg-sable-soft); display: flex; align-items: center; justify-content: center; font-family: var(--adg-font-serif); font-size: 38px; color: var(--adg-espresso); font-weight: 600; border: 2px solid var(--adg-ivoire); box-shadow: 0 0 0 1px var(--adg-sable); overflow: hidden; flex-shrink: 0; }
.adg-author-block__label { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 6px; }
.adg-author-block__name { font-family: var(--adg-font-serif); font-size: 28px; margin: 0 0 4px; font-weight: 500; }
.adg-author-block__role { font-size: 13px; color: var(--adg-cafe-au-lait); margin-bottom: 14px; }
.adg-author-block__bio { font-size: 15px; line-height: 1.6; color: var(--adg-espresso-soft); margin: 0 0 16px; }
.adg-author-block__more { font-size: 13px; color: var(--adg-cuivre); font-weight: 600; border: none; display: inline-flex; align-items: center; gap: 6px; }
.adg-author-block__more:hover { color: var(--adg-espresso); border: none; }

.adg-related { background: var(--adg-ivoire); padding: 48px 36px; border-radius: 12px; margin: 32px 0 0; border: 1px solid var(--adg-sable-soft); }
.adg-related__inner { max-width: 100%; margin: 0; }
.adg-related__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; }
.adg-related__title { font-family: var(--adg-font-serif); font-size: 32px; margin: 0; font-weight: 500; }
.adg-related__title em { color: var(--adg-cuivre); font-style: italic; }
.adg-related__more { font-size: 13px; color: var(--adg-cuivre); font-weight: 600; border: none; }
.adg-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.adg-related__card { background: var(--adg-ivoire-soft); border-radius: var(--adg-radius-md); overflow: hidden; text-decoration: none; color: inherit; border: 1px solid var(--adg-sable-soft); display: flex; flex-direction: column; transition: transform .2s; }
a.adg-related__card { border: 1px solid var(--adg-sable-soft); }
.adg-related__card:hover { transform: translateY(-3px); }
.adg-related__card-img { height: 160px; background: var(--adg-sable-soft); background-image: repeating-linear-gradient(45deg, transparent 0 14px, rgba(122, 74, 46, 0.08) 14px 15px); }
.adg-related__card-body { padding: 18px 22px; }
.adg-related__card-cat { font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 8px; }
.adg-related__card-title { font-family: var(--adg-font-serif); font-size: 19px; line-height: 1.3; margin: 0 0 8px; color: var(--adg-espresso); font-weight: 500; }
.adg-related__card-meta { font-size: 12px; color: var(--adg-cafe-au-lait); }

/* === OVERLAY LINKS (PS strippe les <a> autour des <div>, on utilise overlay absolute) === */
.adg-product-inline,
.adg-product,
.adg-related__card,
.adg-gazette-hub__featured-card { position: relative; }
.adg-product-inline__overlay,
.adg-product__overlay,
.adg-related__card-overlay,
.adg-gazette-hub__featured-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  border: none !important;
  text-decoration: none;
  background: transparent;
}
.adg-product-inline__overlay:focus,
.adg-product__overlay:focus,
.adg-related__card-overlay:focus,
.adg-gazette-hub__featured-overlay:focus {
  outline: 2px solid var(--adg-cuivre);
  outline-offset: 2px;
}

.adg-catcta { position: relative; }
.adg-catcta__overlay { position: absolute; inset: 0; z-index: 2; border: none !important; text-decoration: none; }

/* === ANTI-DEBORDEMENT (responsive safety nets) === */
.adg-article-wrap, .adg-article-wrap * { min-width: 0; max-width: 100%; }
.adg-article img, .adg-gazette-hub img { max-width: 100%; height: auto; }
.adg-article h1, .adg-article h2, .adg-article h3, .adg-article h4,
.adg-brand-card__name, .adg-tldr__rank-name, .adg-tldr__title,
.adg-product-inline__name, .adg-faq__item summary,
.adg-gazette-hub__title, .adg-gazette-hub__featured-title { overflow-wrap: anywhere; word-break: break-word; }
.adg-product-inline__body { min-width: 0; overflow: hidden; }
.adg-brand-card__head { flex-wrap: wrap; }
.adg-brand-card__title { min-width: 0; flex: 1 1 200px; }
.adg-fact { min-width: 0; }
.adg-fact__value { overflow-wrap: anywhere; }


/* Placeholder propre quand image produit pas dispo (en attendant fix covers BDD PS) */
.adg-product-inline__img {
  background-color: var(--adg-ivoire-soft);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 12px;
  border: 1px solid var(--adg-sable-soft);
  border-radius: 4px;
}
.adg-product-inline__placeholder {
  font-family: var(--adg-font-serif);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--adg-cuivre);
  text-align: center;
  line-height: 1.2;
}

/* === RESPONSIVE === */
/* Tablet and below */
@media (max-width: 1100px) {
  .adg-article-wrap { grid-template-columns: 1fr; gap: 32px; padding-top: 24px; }
  .adg-article { max-width: 100%; }
  .adg-toc { display: none; }
  .adg-toc-mobile { display: block; position: sticky; top: 0; z-index: 200; background: var(--adg-ivoire); border-bottom: 1px solid var(--adg-sable-soft); margin: 0 -24px 16px; }
  .adg-toc-mobile__bar { padding: 14px 24px; display: flex; align-items: center; justify-content: space-between; cursor: pointer; }
  .adg-toc-mobile__current { font-size: 14px; font-weight: 600; color: var(--adg-espresso); display: flex; align-items: center; gap: 8px; min-width: 0; flex: 1; }
  .adg-toc-mobile__current span:first-child { color: var(--adg-cuivre); font-family: var(--adg-font-sans); flex-shrink: 0; }
  .adg-toc-mobile__current span:last-child { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .adg-toc-mobile__toggle { font-size: 14px; color: var(--adg-cuivre); flex-shrink: 0; margin-left: 12px; }
  .adg-toc-mobile__list { display: none; padding: 8px 24px 16px; max-height: 60vh; overflow-y: auto; }
  .adg-toc-mobile.is-open .adg-toc-mobile__list { display: block; }
  .adg-toc-mobile__list ol { list-style: none; padding: 0; margin: 0; counter-reset: tocm; }
  .adg-toc-mobile__list li { counter-increment: tocm; padding: 10px 0; border-bottom: 1px solid var(--adg-sable-soft); font-size: 14px; }
  .adg-toc-mobile__list li::before { content: counter(tocm, decimal-leading-zero); font-family: var(--adg-font-serif); color: var(--adg-cuivre); margin-right: 12px; font-weight: 600; }
  .adg-toc-mobile__list a { color: var(--adg-espresso-soft); border: none; }
  .adg-toc-mobile__list li.is-active a { color: var(--adg-cuivre); font-weight: 600; }
  .adg-toc-mobile__list li.is-done a { color: var(--adg-cafe-au-lait); text-decoration: line-through; text-decoration-color: rgba(166, 90, 42, 0.3); }
  .adg-pullquote { margin: 40px 0; padding: 24px 28px; }
  .adg-pullquote__text { font-size: 22px; }
  .adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
}

/* Tablet portrait */
@media (max-width: 900px) {
  .adg-hero h1 { font-size: clamp(28px, 6vw, 42px); }
  .adg-hero .deck { font-size: 18px; }
  .adg-product-inline { grid-template-columns: 110px 1fr auto; gap: 16px; }
  .adg-product-inline__img { width: 110px; height: 90px; }
  .adg-product-inline__name { font-size: 19px; }
  .adg-related__grid { grid-template-columns: repeat(2, 1fr); }
}

/* Mobile */
@media (max-width: 720px) {
  .adg-hero { padding: 32px 18px 24px; }
  .adg-hero__inner { max-width: 100%; }
  .adg-hero h1 { font-size: clamp(26px, 7vw, 34px); line-height: 1.15; }
  .adg-hero .deck { font-size: 16px; margin-bottom: 22px; }
  .adg-breadcrumb { font-size: 12px; margin-bottom: 16px; word-break: break-word; }
  .adg-eyebrow { font-size: 11px; padding: 5px 10px; margin-bottom: 14px; }
  .adg-meta { gap: 12px; padding-top: 18px; }
  .adg-meta__sep { display: none; }
  .adg-meta__author { gap: 10px; }
  .adg-meta__avatar { width: 38px; height: 38px; font-size: 16px; }
  .adg-meta__item { font-size: 12px; }
  .adg-article-wrap { padding: 24px 18px 32px; gap: 20px; }
  .adg-toc-mobile { margin: 0 -18px 16px; }
  .adg-article { font-size: 16px; line-height: 1.7; }
  .adg-article p { margin: 0 0 18px; }
  .adg-article h2 { font-size: 26px; margin: 36px 0 16px; line-height: 1.2; }
  .adg-article h2 .num { font-size: 12px; margin-bottom: 4px; }
  .adg-article h2 .num::before { width: 20px; margin-right: 8px; }
  .adg-article h3 { font-size: 21px; margin: 28px 0 10px; }
  .adg-article ul, .adg-article ol { padding-left: 20px; }
  .adg-article blockquote { font-size: 19px; padding: 6px 0 6px 16px; margin: 24px 0; }
  .adg-tldr { padding: 24px 20px; margin: 28px 0; border-radius: 8px; }
  .adg-tldr__title { font-size: 20px; }
  .adg-tldr__rank { gap: 12px; padding: 12px 0; }
  .adg-tldr__rank-num { width: 32px; height: 32px; font-size: 16px; }
  .adg-tldr__rank-name { font-size: 17px; }
  .adg-tldr__rank-why { font-size: 13.5px; }
  .adg-callout { flex-direction: column; gap: 14px; padding: 20px; margin: 24px 0; }
  .adg-callout__icon { width: 36px; height: 36px; font-size: 18px; }
  .adg-knowit { gap: 14px; padding: 18px 20px; margin: 24px 0; flex-direction: column; }
  .adg-knowit__emoji { font-size: 26px; }
  .adg-pullquote { margin: 32px 0; padding: 22px 22px 22px 26px; }
  .adg-pullquote::before { font-size: 70px; left: 14px; }
  .adg-pullquote__text { font-size: 19px; }
  .adg-catcta { flex-direction: column; align-items: flex-start; gap: 14px; padding: 22px; margin: 28px 0; }
  .adg-catcta__icon { font-size: 28px; }
  .adg-catcta__title { font-size: 19px; }
  .adg-catcta__sub { font-size: 12px; }
  .adg-catcta__arrow { display: none; }
  .adg-product-inline { grid-template-columns: 1fr; gap: 14px; padding: 16px; margin: 18px 0 24px; }
  .adg-product-inline__img { width: 100%; height: 160px; }
  .adg-product-inline__name { font-size: 19px; }
  .adg-product-inline__cta { flex-direction: row; justify-content: space-between; align-items: center; width: 100%; padding-top: 6px; border-top: 1px solid var(--adg-sable-soft); }
  .adg-brand-card { padding: 20px 18px; margin: 22px 0 14px; border-radius: 8px; }
  .adg-brand-card__head { flex-wrap: wrap; gap: 12px; padding-bottom: 14px; margin-bottom: 14px; }
  .adg-brand-card__rank { width: auto; flex: 0 0 auto; text-align: left; display: flex; align-items: center; gap: 10px; }
  .adg-brand-card__rank-label { font-size: 9px; }
  .adg-brand-card__rank-num { font-size: 32px; }
  .adg-brand-card__title { flex: 1 1 60%; min-width: 0; }
  .adg-brand-card__name { font-size: 22px; }
  .adg-brand-card__tagline { font-size: 14px; }
  .adg-brand-card__score { width: 100%; flex-direction: row; align-items: center; justify-content: space-between; gap: 8px; padding-top: 10px; border-top: 1px solid var(--adg-sable-soft); }
  .adg-brand-card__score-num { font-size: 22px; }
  .adg-brand-card__score-num span { font-size: 13px; }
  .adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
  .adg-fact { padding: 8px 10px; }
  .adg-fact__value { font-size: 12.5px; }
  .adg-verdict { grid-template-columns: 1fr; gap: 10px; }
  .adg-faq__item summary { padding: 16px 18px; font-size: 17px; gap: 12px; }
  .adg-faq__item summary::after { font-size: 22px; }
  .adg-faq__body { padding: 0 18px 18px; font-size: 14.5px; }
  .adg-video__playbtn { width: 56px; height: 56px; }
  .adg-video__playbtn svg { width: 22px; height: 22px; }
  .adg-video__playlabel { font-size: 10px; padding: 5px 10px; bottom: 10px; right: 10px; }
  .adg-author-block { grid-template-columns: 1fr; gap: 16px; padding: 24px; margin-top: 40px; text-align: center; border-radius: 8px; }
  .adg-author-block__img { margin: 0 auto; width: 90px; height: 90px; font-size: 32px; }
  .adg-author-block__name { font-size: 24px; }
  .adg-author-block__bio { font-size: 14px; }
  .adg-related { padding: 40px 18px; margin-top: 40px; }
  .adg-related__head { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 22px; }
  .adg-related__title { font-size: 26px; }
  .adg-related__grid { grid-template-columns: 1fr; gap: 18px; }
  .adg-related__card-img { height: 140px; }
  .adg-related__card-title { font-size: 18px; }
}

/* Very small phones */
@media (max-width: 380px) {
  .adg-hero { padding: 24px 14px 20px; }
  .adg-article-wrap { padding: 20px 14px 24px; }
  .adg-toc-mobile { margin: 0 -14px 14px; }
  .adg-tldr { padding: 20px 16px; }
  .adg-brand-card { padding: 16px 14px; }
  .adg-callout, .adg-knowit { padding: 16px 14px; }
}


/* === LA GAZETTE DU CAFÉ - PAGE HUB === */
.adg-gazette-hub { max-width: 1100px; margin: 0 auto; padding: 64px 24px; font-family: var(--adg-font-sans); color: var(--adg-espresso); }
.adg-gazette-hub__header { text-align: center; max-width: 720px; margin: 0 auto 64px; }
.adg-gazette-hub__eyebrow { display: inline-block; font-size: 12px; font-weight: 500; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); background: rgba(166, 90, 42, 0.08); padding: 6px 14px; border-radius: 2px; margin-bottom: 20px; }
.adg-gazette-hub__title { font-family: var(--adg-font-serif); font-size: clamp(40px, 6vw, 64px); line-height: 1.1; margin: 0 0 18px; font-weight: 500; color: var(--adg-espresso); letter-spacing: -0.01em; }
.adg-gazette-hub__title em { color: var(--adg-cuivre); font-style: italic; }
.adg-gazette-hub__deck { font-family: var(--adg-font-serif); font-style: italic; font-size: 22px; color: var(--adg-cafe-au-lait); line-height: 1.5; margin: 0; }
.adg-gazette-hub__featured-label { font-size: 12px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--adg-sable-soft); }
.adg-gazette-hub__featured-card { display: grid; grid-template-columns: 1.2fr 1fr; gap: 0; background: var(--adg-ivoire); border-radius: var(--adg-radius-lg); overflow: hidden; text-decoration: none; color: inherit; border: 1px solid var(--adg-sable-soft); transition: transform .25s, box-shadow .25s; margin-bottom: 48px; }
a.adg-gazette-hub__featured-card { border: 1px solid var(--adg-sable-soft); }
.adg-gazette-hub__featured-card:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(42, 26, 18, 0.12); color: inherit; border-color: var(--adg-cuivre); }
.adg-gazette-hub__featured-img { min-height: 360px; background-size: cover; background-position: center; background-color: var(--adg-sable-soft); }
.adg-gazette-hub__featured-body { padding: 40px 36px; display: flex; flex-direction: column; justify-content: center; }
.adg-gazette-hub__featured-cat { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--adg-cuivre); margin-bottom: 14px; }
.adg-gazette-hub__featured-title { font-family: var(--adg-font-serif); font-size: 32px; line-height: 1.15; margin: 0 0 14px; color: var(--adg-espresso); font-weight: 600; }
.adg-gazette-hub__featured-excerpt { font-size: 16px; line-height: 1.6; color: var(--adg-espresso-soft); margin: 0 0 18px; }
.adg-gazette-hub__featured-meta { font-size: 13px; color: var(--adg-cafe-au-lait); }
.adg-gazette-hub__more { text-align: center; padding: 32px 0; }
.adg-gazette-hub__placeholder { font-family: var(--adg-font-serif); font-style: italic; font-size: 18px; color: var(--adg-cafe-au-lait); margin: 0; }
@media (max-width: 720px) { .adg-gazette-hub { padding: 40px 20px; } .adg-gazette-hub__featured-card { grid-template-columns: 1fr; } .adg-gazette-hub__featured-img { min-height: 220px; } .adg-gazette-hub__featured-body { padding: 28px; } .adg-gazette-hub__featured-title { font-size: 26px; } }


@media (max-width: 480px) {
  .adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
  .adg-brand-card__head { flex-direction: column; align-items: flex-start; }
  .adg-brand-card__score { width: 100%; }
}


/* === FIX MOBILE BRAND CARD FACTS (sans debordement) === */
@media (max-width: 900px) {
  .adg-brand-card { padding: 18px 16px !important; }
  .adg-brand-card__head { flex-wrap: wrap; gap: 10px !important; }
  .adg-brand-card__rank { width: auto !important; flex: 0 0 auto !important; }
  .adg-brand-card__title { flex: 1 1 60% !important; min-width: 0; }
  .adg-brand-card__score { flex: 0 0 100% !important; width: 100% !important; flex-direction: row !important; justify-content: space-between; padding-top: 8px; border-top: 1px solid var(--adg-sable-soft); }
  .adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
  .adg-fact { padding: 8px 10px !important; min-width: 0 !important; }
  .adg-fact__label { font-size: 9px !important; }
  .adg-fact__value { font-size: 12px !important; line-height: 1.3 !important; overflow-wrap: anywhere !important; word-break: break-word !important; }
}
@media (max-width: 420px) {
  .adg-brand-card__facts { display: grid !important; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important; gap: 10px !important; margin-bottom: 8px !important; }
  .adg-brand-card__name { font-size: 22px !important; }
}
