/*
Theme Name: Holiterie
Theme URI: https://holiterie.fr
Description: Thème Holiterie - literie d'hôtel pour particuliers
Version: 2.0.0
Text Domain: holiterie
*/

/* ─── VARIABLES ──────────────────────────────────────────────────────────── */
:root {
  /* Palette "Maison Holiterie" : lin, champagne, encre */
  --ink:          #1A1510;
  --ink-soft:     #3A342E;
  --taupe:        #6E6258;
  --sand:         #EFE8DC;
  --sand-light:   #F7F3EE;
  --linen:        #FAF8F4;
  --border:       #DDD3C4;
  --border-light: #EAE2D8;
  --champagne:    #B8935A;
  --champagne-l:  #D4B990;
  --champagne-bg: rgba(184,147,90,.08);
  --sage:         #586B5D;
  --blue-grey:    #465460;
  --white:        #FFFFFF;
  --star:         #C8A84B;

  /* Spacing / layout */
  --max-w:     940px;
  --max-w-xl:  1080px;
  --container-w: var(--max-w-xl);
  --container-px: 1.5rem;
  --radius-xs: 3px;
  --radius:    6px;
  --radius-lg: 12px;

  /* Shadows */
  --shadow:    0 1px 4px rgba(24,19,15,.05), 0 4px 16px rgba(24,19,15,.04);
  --shadow-lg: 0 2px 8px rgba(24,19,15,.06), 0 8px 32px rgba(24,19,15,.08);
  --shadow-xl: 0 4px 12px rgba(24,19,15,.08), 0 16px 48px rgba(24,19,15,.1);

  /* Typography */
  --font-serif: 'Marcellus', Georgia, 'Times New Roman', serif;
  --font-sans:  'Mulish', system-ui, -apple-system, sans-serif;
}

/* ─── RESET ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.72;
  color: var(--ink);
  background-color: var(--linen);
  /* Marcellus n'existe qu'en 400 : on interdit le faux-gras synthetise,
     les titres retombent sur la graisse reelle au lieu d'etre deformes */
  font-synthesis-weight: none;
}
img { max-width: 100%; height: auto; display: block; }
svg { display: block; }
a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; transition: color .15s; }
a:hover { color: var(--champagne); }
ul, ol { padding-left: 1.5em; }
p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }
figure { margin: 0; }
button { font-family: var(--font-sans); }

/* ─── TYPOGRAPHIE ────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: .6em;
  letter-spacing: .01em;
}
h1 { font-size: clamp(2rem, 5vw, 3rem); font-weight: 400; letter-spacing: .02em; }
h2 { font-size: clamp(1.5rem, 3.5vw, 2.125rem); margin-top: 2.25em; }
h3 { font-size: clamp(1.125rem, 2.5vw, 1.5rem); margin-top: 1.75em; }
h4 { font-size: 1.125rem; margin-top: 1.5em; }

/* ─── LAYOUT ─────────────────────────────────────────────────────────────── */
.site-container { display: flex; flex-direction: column; min-height: 100vh; }
/* Garde-fou anti-overflow : un enfant flex (min-width:auto par défaut) ne doit jamais
   être élargi par un contenu intrinsèquement large (table min-width). On autorise le rétrécissement. */
.site-container > * { min-width: 0; }
main, .entry-content { min-width: 0; }
.wrap          { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; width: 100%; }
.wrap--xl      { max-width: var(--max-w-xl); margin: 0 auto; padding: 0 1.5rem; width: 100%; }
.container     { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; width: 100%; }
.container--wide { max-width: var(--max-w-xl); margin: 0 auto; padding: 0 1.5rem; width: 100%; }
main { flex: 1; }

/* ─── HEADER ─────────────────────────────────────────────────────────────── */
.site-header {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 200;
}
.site-header .container {
  display: flex;
  align-items: center;
  height: 68px;
  gap: .5rem;
}

/* Logo */
.site-logo {
  display: inline-flex;
  align-items: center;
  width: 176px;
  max-width: 58vw;
  font-family: var(--font-serif);
  font-size: 1.6875rem;
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: .04em;
  flex-shrink: 0;
  line-height: 1;
}
.site-logo img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 44px;
  object-fit: contain;
}
.site-logo span { color: var(--champagne); }
.site-logo:hover { color: var(--ink); opacity: .9; }

/* Nav */
.site-nav { margin-left: auto; }
.site-nav ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  align-items: center;
  gap: .0625rem;
}
.site-nav a {
  font-family: var(--font-sans);
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--taupe);
  text-decoration: none;
  padding: .4375rem .875rem;
  border-radius: var(--radius);
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.site-nav a:hover,
.site-nav .current-menu-item > a,
.site-nav .current_page_item > a {
  color: var(--ink);
  background: var(--sand);
}
.site-nav .nav-cta { margin-left: .375rem; }
.site-nav .nav-cta > a {
  background: var(--ink);
  color: var(--white);
  font-weight: 500;
  border-radius: var(--radius);
}
.site-nav .nav-cta > a:hover {
  background: var(--ink-soft);
  color: var(--white);
}

/* Hamburger */
.nav-toggle {
  display: none;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  padding: .4375rem .5rem;
  color: var(--ink);
  margin-left: auto;
  align-items: center;
  justify-content: center;
  line-height: 0;
}
.nav-toggle:hover { background: var(--sand); }

@media (max-width: 720px) {
  .nav-toggle { display: flex; }
  .site-nav {
    display: none;
    position: fixed;
    top: 68px; left: 0; right: 0; bottom: 0;
    z-index: 190;
    background: var(--white);
    overflow-y: auto;
    padding: 1.25rem 1.5rem 2rem;
    border-top: 1px solid var(--border);
  }
  .site-nav.is-open { display: block; }
  .site-nav ul { flex-direction: column; gap: 0; }
  .site-nav a { display: block; padding: .875rem .25rem; font-size: .875rem; border-radius: 0; border-bottom: 1px solid var(--border-light); }
  .site-nav .nav-cta { margin-left: 0; }
  .site-nav .nav-cta > a { display: block; border-radius: var(--radius); border-bottom: none; text-align: center; margin-top: 1rem; padding: .875rem; }
}

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
.site-footer {
  background-color: var(--ink);
  color: rgba(255,255,255,.55);
  padding: 3.5rem 0 1.75rem;
  margin-top: 5rem;
  font-size: .875rem;
  line-height: 1.65;
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1.75fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 2.75rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
  margin-bottom: 1.75rem;
}
.site-footer__brand .site-logo { color: rgba(255,255,255,.9); font-size: 1.5rem; width: 188px; }
.site-footer__brand .site-logo span { color: var(--champagne-l); }
.site-footer__brand .site-logo:hover { color: var(--white); }
.site-footer__brand p { margin-top: 1rem; color: rgba(255,255,255,.4); font-size: .8125rem; line-height: 1.7; max-width: 220px; }
.site-footer h4 {
  font-family: var(--font-sans);
  font-size: .625rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--champagne-l);
  margin: 0 0 1rem;
}
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer ul li + li { margin-top: .5rem; }
.site-footer a { color: rgba(255,255,255,.5); text-decoration: none; font-size: .8125rem; }
.site-footer a:hover { color: var(--champagne-l); }
.site-footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: .75rem;
  color: rgba(255,255,255,.25);
}
.site-footer__bottom a { color: rgba(255,255,255,.25); }
.site-footer__bottom a:hover { color: rgba(255,255,255,.5); }
@media (max-width: 768px) {
  .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .site-footer__brand { grid-column: 1 / -1; }
  .site-footer__brand p { max-width: 100%; }
}
@media (max-width: 480px) { .site-footer__grid { grid-template-columns: 1fr; } }

/* ─── PAGE TEMPLATES ─────────────────────────────────────────────────────── */
.entry-header {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 3rem 0 2.5rem;
  margin-bottom: 3rem;
}
.entry-label {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--champagne);
  text-decoration: none;
  margin-bottom: .875rem;
}
.entry-label::before {
  content: '';
  display: block;
  width: 20px;
  height: 1px;
  background: var(--champagne);
  flex-shrink: 0;
}
.entry-title {
  font-family: var(--font-serif);
  font-size: clamp(1.875rem, 4vw, 2.875rem);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.18;
  margin: 0 0 .5rem;
  letter-spacing: .015em;
}
.entry-desc {
  font-size: 1.0625rem;
  color: var(--taupe);
  max-width: 620px;
  margin: .625rem 0 0;
  line-height: 1.65;
}
.entry-content {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 1.5rem 4rem;
}
/* Pages comparateur/configurateur : grille plus large */
.entry-content:has(.hol-comparateur),
.entry-content:has(.hol-configurateur) {
  max-width: var(--max-w-xl);
}
.entry-content > * + * { margin-top: 1em; }
.entry-content h2 {
  margin-top: 2.75em;
  padding-top: 2em;
  border-top: 1px solid var(--border-light);
}
.entry-content h3 { margin-top: 2em; }
.entry-content ul, .entry-content ol { margin-bottom: 1em; }
.entry-content li + li { margin-top: .375em; }
.entry-content strong { color: var(--ink); font-weight: 600; }
.entry-content a { color: var(--ink); font-weight: 500; border-bottom: 1px solid var(--border); text-decoration: none; }
.entry-content a:hover { border-color: var(--champagne); color: var(--champagne); }
.entry-content table { width: 100%; border-collapse: collapse; font-size: .9375rem; margin: 1.5em 0; }
.entry-content th { background: var(--ink); color: var(--white); padding: .625rem .875rem; font-family: var(--font-sans); font-size: .75rem; font-weight: 500; letter-spacing: .05em; text-align: left; }
.entry-content td { padding: .625rem .875rem; border-bottom: 1px solid var(--border-light); }
.entry-content tr:last-child td { border-bottom: none; }
.entry-content tr:nth-child(odd) td { background: var(--white); }
.entry-content tr:nth-child(even) td { background: var(--sand-light); }

/* ─── ARTICLE-INTRO ──────────────────────────────────────────────────────── */
.article-intro {
  border-left: 2px solid var(--champagne);
  padding: 1.125rem 1.5rem;
  background: var(--white);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--ink-soft);
  margin-bottom: 2em;
  box-shadow: var(--shadow);
}

/* ─── SOMMAIRE ───────────────────────────────────────────────────────────── */
.sommaire {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.375rem 1.625rem;
  margin-bottom: 2em;
  display: block;
  width: 100%;
  max-width: 100%;
  box-shadow: var(--shadow);
}
.sommaire__title {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--taupe);
  margin-bottom: .875rem;
}
.sommaire ol { margin: 0; padding-left: 1.25em; }
.sommaire li { font-size: .9375rem; margin-bottom: .4em; }
.sommaire a { text-decoration: none; color: var(--ink-soft); border-bottom: none; }
.sommaire a:hover { color: var(--champagne); }

/* ─── INFO-BOX ───────────────────────────────────────────────────────────── */
.info-box {
  background: var(--champagne-bg);
  border: 1px solid var(--champagne-l);
  border-radius: var(--radius);
  padding: 1.125rem 1.375rem;
  margin: 1.75em 0;
  font-size: .9375rem;
  line-height: 1.7;
}
.info-box strong:first-child {
  display: block;
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--champagne);
  margin-bottom: .5em;
}

/* ─── TABLES ─────────────────────────────────────────────────────────────── */
.tarifs-table-wrap,
.hol-table {
  overflow-x: auto;
  margin: 1.75em 0;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.tarifs-table,
.hol-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9375rem;
}
.tarifs-table th,
.hol-table th {
  background: var(--ink);
  color: var(--white);
  padding: .625rem 1rem;
  text-align: left;
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.tarifs-table td,
.hol-table td {
  padding: .625rem 1rem;
  border-bottom: 1px solid var(--border-light);
}
.tarifs-table tr:last-child td,
.hol-table tr:last-child td { border-bottom: none; }
.tarifs-table tr:nth-child(even) td,
.hol-table tr:nth-child(even) td { background: var(--sand-light); }
.tarifs-table .prix { font-weight: 600; color: var(--ink); }

/* ─── CTA-BOX ────────────────────────────────────────────────────────────── */
.cta-box {
  border-radius: var(--radius-lg);
  padding: 2rem 2.25rem;
  margin: 2.5em 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.cta-box--primary {
  background: var(--ink);
  background-image: linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
}
.cta-box--primary .cta-box__text h3 { color: var(--white); margin: 0 0 .375em; font-size: 1.375rem; font-weight: 400; }
.cta-box--primary .cta-box__text p { color: rgba(255,255,255,.6); margin: 0; font-size: .9375rem; }
.cta-box--secondary { background: var(--white); border: 1px solid var(--border); }
.cta-box--secondary .cta-box__text h3 { color: var(--ink); margin: 0 0 .375em; font-size: 1.375rem; font-weight: 400; font-family: var(--font-serif); }
.cta-box--secondary .cta-box__text p { color: var(--taupe); margin: 0; font-size: .9375rem; }
.cta-box__text { flex: 1; min-width: 200px; }
.cta-btn { flex-shrink: 0; }
.cta-btn--primary {
  display: inline-block;
  background: var(--champagne);
  color: var(--ink);
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: .875rem;
  letter-spacing: .04em;
  padding: .6875rem 1.5rem;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background .15s, transform .1s;
  white-space: nowrap;
  border: none;
}
.cta-btn--primary:hover { background: var(--champagne-l); color: var(--ink); transform: translateY(-1px); }
.cta-btn--ghost {
  display: inline-block; background: transparent; color: var(--ink);
  font-family: var(--font-sans); font-weight: 500; font-size: .875rem; letter-spacing: .04em;
  padding: .6875rem 1.5rem; border-radius: var(--radius); text-decoration: none;
  border: 1px solid var(--border); white-space: nowrap; transition: border-color .15s, color .15s;
}
.cta-btn--ghost:hover { border-color: var(--champagne); color: var(--champagne); }
.cta-box__actions { display: flex; gap: .6rem; flex-wrap: wrap; flex-shrink: 0; }

/* ─── MODULE CONVERSION (pages carrefours) ───────────────────────────────── */
.hol-conv-wrap { margin-top: 2.5em; }
.hol-conv-wrap .hol-inline-cta {
  font-family: var(--font-sans); font-size: .78rem; font-weight: 600; letter-spacing: .03em;
  color: var(--champagne); text-decoration: none; white-space: nowrap;
}
.hol-conv-wrap .hol-inline-cta:hover { color: var(--ink); }
.hol-budget-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem;
  margin: 1.5em 0 2em; max-width: 100%;
}
.hol-budget-card {
  display: flex; flex-direction: column; gap: .45rem;
  padding: 1.3rem 1.4rem; background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow);
}
.hol-budget-tier {
  font-family: var(--font-sans); font-size: .66rem; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; color: var(--champagne);
}
.hol-budget-name { font-family: var(--font-serif); font-size: 1.12rem; color: var(--ink); text-decoration: none; line-height: 1.25; border: none; }
.hol-budget-name:hover { color: var(--champagne); }
.hol-budget-price { font-family: var(--font-sans); font-size: .9rem; color: var(--taupe); }
.hol-budget-link {
  margin-top: .4rem; align-self: flex-start;
  font-family: var(--font-sans); font-size: .8rem; font-weight: 600;
  color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--champagne); padding-bottom: 1px;
}
.hol-budget-link:hover { color: var(--champagne); }
@media (max-width: 680px) {
  .hol-budget-grid { grid-template-columns: 1fr; }
  .cta-box__actions { width: 100%; }
  .cta-box__actions .cta-btn { flex: 1; text-align: center; }
}

/* ─── PRODUCT-BOX ────────────────────────────────────────────────────────── */
.product-box {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--white);
  box-shadow: var(--shadow);
  overflow: hidden;
  margin: 1.75em 0;
  position: relative;
  transition: box-shadow .2s, border-color .2s;
}
.product-box:hover { box-shadow: var(--shadow-lg); border-color: var(--champagne-l); }
.product-box__badge {
  position: absolute;
  top: 1rem; left: 1rem;
  background: var(--ink);
  color: var(--white);
  font-family: var(--font-sans);
  font-size: .625rem;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .3rem .625rem;
  border-radius: var(--radius-xs);
  z-index: 1;
}
.product-box__inner {
  display: grid;
  grid-template-columns: 220px 1fr;
}
.product-box__img {
  background: var(--sand);
  min-height: 200px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-box__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.product-box:hover .product-box__img img { transform: scale(1.03); }
.product-box__content { padding: 1.625rem 1.75rem; display: flex; flex-direction: column; }
.product-box__name {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 .25em;
  line-height: 1.25;
}
.product-box__stars { color: var(--star); font-size: .9375rem; letter-spacing: .075em; margin: .375em 0; }
.product-box__price { font-family: var(--font-serif); font-size: 1.375rem; font-weight: 600; color: var(--ink); margin: .375em 0 .625em; }
.product-box__price small { font-family: var(--font-sans); font-size: .8125rem; font-weight: 400; color: var(--taupe); }
.product-box__pros { list-style: none; padding: 0; margin: 0 0 1em; flex: 1; }
.product-box__pros li {
  font-size: .875rem;
  line-height: 1.5;
  padding: .2em 0 .2em 1.375em;
  position: relative;
  color: var(--ink-soft);
}
.product-box__pros li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .55em;
  width: 14px;
  height: 1px;
  background: var(--champagne);
}
.product-box__cta {
  display: inline-block;
  align-self: flex-start;
  background: var(--ink);
  color: var(--white);
  font-family: var(--font-sans);
  font-size: .8125rem;
  font-weight: 500;
  letter-spacing: .04em;
  padding: .5625rem 1.25rem;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background .15s;
  margin-top: auto;
}
.product-box__cta:hover { background: var(--ink-soft); color: var(--white); }
@media (max-width: 600px) {
  .product-box__inner { grid-template-columns: 1fr; }
  .product-box__img { height: 200px; min-height: unset; }
}

/* ─── FAQ-BLOCK ──────────────────────────────────────────────────────────── */
.faq-block { margin: 2.5em 0; }
.faq-block details {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: .375rem;
  overflow: hidden;
  transition: border-color .15s, box-shadow .15s;
}
.faq-block details:hover { border-color: var(--champagne-l); }
.faq-block details[open] { border-color: var(--champagne-l); box-shadow: var(--shadow); }
.faq-block summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  font-family: var(--font-sans);
  font-size: .9375rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  list-style: none;
  gap: 1rem;
  user-select: none;
}
.faq-block summary::-webkit-details-marker { display: none; }
.faq-block summary::after {
  content: '';
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: center/10px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10' fill='none' stroke='%236E6258' stroke-width='1.5'%3E%3Cline x1='5' y1='2' x2='5' y2='8'/%3E%3Cline x1='2' y1='5' x2='8' y2='5'/%3E%3C/svg%3E");
  transition: background-color .15s, border-color .15s;
}
.faq-block details[open] summary::after {
  background: var(--ink) center/10px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10' fill='none' stroke='%23ffffff' stroke-width='1.5'%3E%3Cline x1='2' y1='5' x2='8' y2='5'/%3E%3C/svg%3E");
  border-color: var(--ink);
}
.faq-block details > div,
.faq-block details > p {
  padding: 0 1.25rem 1.125rem;
  font-size: .9375rem;
  line-height: 1.7;
  color: var(--ink-soft);
  border-top: 1px solid var(--border-light);
  padding-top: 1rem;
}

/* ─── HOMEPAGE LAYOUT ────────────────────────────────────────────────────── */
/* Les sections .hol-section / .hol-section--ink gèrent elles-mêmes leur largeur.
   On ne contraint que les blocs Gutenberg bruts éventuels. */
.home-content > .wp-block-heading,
.home-content > .wp-block-list,
.home-content > .wp-block-paragraph {
  max-width: var(--max-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
.home-content > .wp-block-heading { padding-top: 3rem; }
.home-content > .wp-block-heading:first-of-type { padding-top: 3.5rem; }
.home-content > .wp-block-list,
.home-content > .wp-block-paragraph { padding-bottom: .5rem; }

/* ─── HOL-HERO ───────────────────────────────────────────────────────────── */
.hol-hero {
  padding: 5.5rem max(1.5rem, calc((100vw - var(--max-w)) / 2)) 5rem;
  background-color: var(--white);
  background-image:
    radial-gradient(ellipse 80% 100% at -5% 50%, rgba(239,232,220,.65) 0%, transparent 65%),
    radial-gradient(ellipse 50% 60% at 100% 0%, rgba(184,147,90,.06) 0%, transparent 60%);
  position: relative;
  overflow: hidden;
  text-align: left;
}
.hol-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--champagne);
  margin-bottom: 1.25rem;
}
.hol-hero__eyebrow::before {
  content: '';
  display: block;
  width: 24px;
  height: 1px;
  background: var(--champagne);
}
.hol-hero__title {
  font-family: var(--font-serif);
  font-size: clamp(2.375rem, 5.5vw, 4rem);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.1;
  letter-spacing: .015em;
  margin: 0 0 1.25rem;
  max-width: 600px;
}
.hol-hero__title em { font-style: italic; color: var(--champagne); }
.hol-hero__sub {
  font-family: var(--font-sans);
  font-size: clamp(.9375rem, 1.75vw, 1.0625rem);
  color: var(--taupe);
  max-width: 440px;
  line-height: 1.72;
  margin: 0 0 2.5rem;
}
.hol-hero__ctas { display: flex; gap: .75rem; flex-wrap: wrap; align-items: center; }

/* ─── HOL-BTN ────────────────────────────────────────────────────────────── */
.hol-btn {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .875rem;
  font-weight: 500;
  letter-spacing: .03em;
  padding: .75rem 1.625rem;
  border-radius: var(--radius);
  text-decoration: none;
  transition: all .18s;
  cursor: pointer;
  border: 1px solid transparent;
  line-height: 1.2;
}
.hol-btn--primary {
  background: var(--ink);
  color: var(--white);
  border-color: var(--ink);
}
.hol-btn--primary:hover {
  background: var(--ink-soft);
  border-color: var(--ink-soft);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(24,19,15,.14);
}
.hol-btn--secondary {
  background: transparent;
  color: var(--ink);
  border-color: var(--border);
}
.hol-btn--secondary:hover {
  border-color: var(--ink);
  background: var(--sand-light);
  color: var(--ink);
}
.hol-btn--champagne {
  background: var(--champagne);
  color: var(--ink);
  border-color: var(--champagne);
}
.hol-btn--champagne:hover { background: var(--champagne-l); border-color: var(--champagne-l); color: var(--ink); transform: translateY(-1px); }

/* ─── HOL-ENSEIGNE-CARDS ─────────────────────────────────────────────────── */
.hol-enseigne-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .875rem;
  margin: 2em 0;
}
.hol-enseigne-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.25rem 1.25rem;
  text-align: center;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .25rem;
  transition: box-shadow .2s, border-color .2s, transform .2s;
  box-shadow: var(--shadow);
}
.hol-enseigne-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--champagne-l);
  transform: translateY(-3px);
  color: var(--ink);
}
/* Nom de l'enseigne (.hol-enseigne-card__name ou <strong>) */
.hol-enseigne-card__name,
.hol-enseigne-card > strong {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
  display: block;
  margin-bottom: .25rem;
}
/* Sous-titre (.hol-enseigne-card__group ou <span>) */
.hol-enseigne-card__group,
.hol-enseigne-card > span {
  font-size: .75rem;
  color: var(--taupe);
  display: block;
  line-height: 1.4;
  margin-bottom: .375rem;
}
.hol-enseigne-card__cta {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--champagne);
  margin-top: auto;
}

/* ─── HOL-BADGE ──────────────────────────────────────────────────────────── */
.hol-badge {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .625rem;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: .25rem .5rem;
  border-radius: var(--radius-xs);
  vertical-align: middle;
}
.hol-badge--ok {
  background: rgba(90,140,90,.08);
  color: #3A7A3A;
  border: 1px solid rgba(90,140,90,.2);
}
.hol-badge--na {
  background: rgba(100,90,80,.07);
  color: var(--taupe);
  border: 1px solid rgba(100,90,80,.15);
}

/* ─── HOL-CONFIGURATEUR ──────────────────────────────────────────────────── */
.hol-configurateur {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2.25rem;
  box-shadow: var(--shadow);
  margin: 2em 0;
}
.hol-config-step { margin-bottom: 2.25rem; }
.hol-config-step:last-child { margin-bottom: 0; }
.hol-config-step > h3 {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--taupe);
  margin: 0 0 1rem;
}
.hol-enseigne-grid { display: flex; flex-wrap: wrap; gap: .5rem; }
.hol-enseigne-btn {
  padding: .5625rem 1.125rem;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: var(--white);
  color: var(--ink-soft);
  font-family: var(--font-sans);
  font-size: .875rem;
  font-weight: 400;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s, box-shadow .15s;
  line-height: 1;
}
.hol-enseigne-btn:hover {
  border-color: var(--champagne-l);
  background: var(--champagne-bg);
  color: var(--ink);
  box-shadow: 0 1px 6px rgba(184,147,90,.12);
}
.hol-enseigne-btn--active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--white);
  box-shadow: 0 2px 8px rgba(24,19,15,.15);
}
.hol-config-result {
  background: var(--sand-light);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.625rem 1.75rem;
  margin-top: 1.5rem;
}
.hol-config-result h3 { margin-top: 0; font-size: 1.375rem; font-weight: 400; }
.hol-composants-list { list-style: none; padding: 0; margin: 1.25rem 0 0; }
.hol-composant-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 1.25rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--border-light);
  align-items: start;
}
.hol-composant-item:last-child { border-bottom: none; }
.hol-composant-item__label {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  color: var(--taupe);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding-top: .125rem;
}
.hol-composant-item__name { font-size: .9375rem; font-weight: 500; color: var(--ink); margin-bottom: .25rem; }
.hol-composant-tech {
  display: inline-block;
  font-size: .6875rem;
  background: var(--sand);
  color: var(--taupe);
  padding: .2rem .5rem;
  border-radius: 100px;
  margin-right: .25rem;
  margin-bottom: .25rem;
  border: 1px solid var(--border);
}
.hol-composant-item__link {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  margin-top: .625rem;
  font-family: var(--font-sans);
  font-size: .8125rem;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  padding-bottom: 1px;
  transition: border-color .15s, color .15s;
}
.hol-composant-item__link:hover { border-color: var(--champagne); color: var(--champagne); }

/* Classes utilisées dans le HTML du configurateur (batch5) */
.hol-config-label {
  font-size: .9375rem;
  font-weight: 500;
  color: var(--ink-soft);
  margin-bottom: .875rem;
}
.hol-composant-type {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  color: var(--taupe);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding-top: .125rem;
}
.hol-config-cta {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border-light);
}

/* ─── HOL-COMPARATEUR ────────────────────────────────────────────────────── */
.hol-comparateur { margin: 2em 0; }
.hol-filtres {
  display: flex;
  flex-wrap: wrap;
  gap: .625rem;
  margin-bottom: 1.75rem;
  padding: 1.125rem 1.375rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  align-items: center;
  box-shadow: var(--shadow);
}
.hol-select {
  padding: .5rem 2.25rem .5rem .875rem;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: var(--sand-light) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6' fill='none' stroke='%236E6258' stroke-width='1.5'%3E%3Cpath d='M1 1l4 4 4-4'/%3E%3C/svg%3E") right 12px center / 10px no-repeat;
  font-family: var(--font-sans);
  font-size: .8125rem;
  color: var(--ink);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color .15s;
}
.hol-select:focus { outline: none; border-color: var(--champagne-l); background-color: var(--white); }
.hol-btn-reset {
  padding: .5rem .875rem;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: transparent;
  font-family: var(--font-sans);
  font-size: .75rem;
  color: var(--taupe);
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
.hol-btn-reset:hover { border-color: var(--ink); color: var(--ink); }
.hol-produits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.125rem;
}
.hol-produit-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.375rem;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  gap: .375rem;
  transition: box-shadow .2s, border-color .2s, transform .2s;
}
.hol-produit-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--champagne-l);
  transform: translateY(-2px);
}
.hol-produit-card__enseigne {
  font-family: var(--font-sans);
  font-size: .625rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--champagne);
}
.hol-produit-card__name {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.25;
}
.hol-produit-card__type { font-size: .8125rem; color: var(--taupe); }
.hol-produit-card__tech { display: flex; flex-wrap: wrap; gap: .25rem; margin: .25rem 0; }
.hol-produit-card__price {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ink);
  margin-top: auto;
  padding-top: .75rem;
}
.hol-produit-card__price small { font-family: var(--font-sans); font-size: .8125rem; font-weight: 400; color: var(--taupe); }
.hol-produit-card__cta {
  display: block;
  text-align: center;
  background: var(--ink);
  color: var(--white);
  text-decoration: none;
  font-family: var(--font-sans);
  font-size: .8125rem;
  font-weight: 500;
  letter-spacing: .03em;
  padding: .5625rem 1rem;
  border-radius: var(--radius);
  margin-top: .75rem;
  transition: background .15s;
}
.hol-produit-card__cta:hover { background: var(--ink-soft); color: var(--white); }

/* Classes utilisées dans le HTML du comparateur (batch5) */
.hol-result-count {
  font-size: .8125rem;
  color: var(--taupe);
  margin-bottom: .875rem;
}
.hol-produit-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  margin-bottom: .125rem;
}
.hol-produit-enseigne {
  font-family: var(--font-sans);
  font-size: .625rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--champagne);
}
.hol-produit-type { font-size: .75rem; color: var(--taupe); }
.hol-produit-nom {
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  text-decoration: none;
  display: block;
}
.hol-produit-nom:hover { color: var(--champagne); }
.hol-produit-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .375rem;
  font-size: .8125rem;
  color: var(--taupe);
  margin-top: auto;
  padding-top: .375rem;
}
.hol-btn--small {
  font-size: .75rem;
  font-weight: 500;
  padding: .4375rem .875rem;
  margin-top: .75rem;
  background: var(--ink);
  color: var(--white) !important;
  border-color: var(--ink);
  text-align: center;
  display: block;
  border-radius: var(--radius);
}
.hol-btn--small:hover { background: var(--ink-soft); border-color: var(--ink-soft); }

/* ─── UTILS ──────────────────────────────────────────────────────────────── */
.text-muted { color: var(--taupe); }
.text-small { font-size: .875rem; }
.text-center { text-align: center; }
.text-label {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--taupe);
}
.divider {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: 2.5em 0;
}

/* ─── CONTENU GUTENBERG ──────────────────────────────────────────────────── */

/* Premier paragraphe → article-intro automatique */
.entry-content > .wp-block-paragraph:first-child,
.entry-content > p.wp-block-paragraph:first-of-type {
  font-size: 1.0625rem;
  color: var(--ink-soft);
  border-left: 2px solid var(--champagne);
  padding: 1rem 1.375rem;
  background: var(--white);
  border-radius: 0 var(--radius) var(--radius) 0;
  line-height: 1.75;
  margin-bottom: 2.25em;
  box-shadow: var(--shadow);
}

/* H2 avec trait champagne */
.entry-content .wp-block-heading[data-level="2"],
.entry-content h2.wp-block-heading {
  margin-top: 3em;
  padding-top: 0;
  border-top: none;
}
.entry-content h2.wp-block-heading::before {
  content: '';
  display: block;
  width: 28px;
  height: 2px;
  background: var(--champagne);
  margin-bottom: .75rem;
}

/* H3 */
.entry-content h3.wp-block-heading { color: var(--ink-soft); }

/* Listes Gutenberg */
.entry-content .wp-block-list {
  list-style: none;
  padding: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 1.5em 0;
}
.entry-content .wp-block-list li {
  padding: .75rem 1rem .75rem 2.5rem;
  border-bottom: 1px solid var(--border-light);
  position: relative;
  font-size: .9375rem;
  margin: 0;
}
.entry-content .wp-block-list li:last-child { border-bottom: none; }
.entry-content .wp-block-list li::before {
  content: '';
  position: absolute;
  left: 1rem;
  top: 1.1em;
  width: 16px;
  height: 1px;
  background: var(--champagne);
}
.entry-content .wp-block-list li a { border-bottom: none; font-weight: 500; }
.entry-content .wp-block-list li a:hover { color: var(--champagne); }

/* Paragraphe de lien interne isolé (ex: "Détail du matelas Novotel…") */
.entry-content .wp-block-paragraph:has(> a:only-child) {
  margin: -.5em 0 1.5em;
  font-size: .875rem;
}
.entry-content .wp-block-paragraph:has(> a:only-child) a {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  color: var(--taupe);
  border-bottom: none;
  font-weight: 400;
  font-size: .875rem;
}
.entry-content .wp-block-paragraph:has(> a:only-child) a::after {
  content: '→';
  font-size: .875em;
  color: var(--champagne);
}
.entry-content .wp-block-paragraph:has(> a:only-child) a:hover { color: var(--champagne); }

/* ─── NAV SOUS-PAGES ─────────────────────────────────────────────────────── */
.entry-subnav {
  margin-top: 3rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--border-light);
}
.entry-subnav__label {
  font-family: var(--font-sans);
  font-size: .6875rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--taupe);
  margin-bottom: 1rem;
}
.entry-subnav ul {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .625rem;
}
.entry-subnav ul li { margin: 0; }
.entry-subnav ul a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .875rem 1.125rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .9375rem;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  border-bottom: none;
  transition: border-color .15s, box-shadow .15s;
}
.entry-subnav ul a::after {
  content: '→';
  color: var(--champagne);
  font-size: .875em;
  flex-shrink: 0;
}
.entry-subnav ul a:hover {
  border-color: var(--champagne-l);
  box-shadow: var(--shadow);
  color: var(--ink);
}

/* ─── GUTENBERG RESET ────────────────────────────────────────────────────── */
.wp-block-group { max-width: 100%; }
.entry-content .wp-block-separator {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: 2.5em 0;
}
.entry-content .wp-block-quote {
  border-left: 2px solid var(--champagne);
  margin: 2em 0;
  padding: 1rem 1.5rem;
  background: var(--white);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.entry-content .wp-block-quote p { font-style: italic; color: var(--ink-soft); margin: 0; }

/* ─── COMPARATEUR v3 ────────────────────────────────────────────────────────── */
.hol-cmp-page { max-width: var(--container-w); margin: 0 auto; padding: 2rem var(--container-px) 4rem; }

.hol-cmp-header { margin-bottom: 2rem; }
.hol-cmp-header h1 { font-family: var(--font-serif); font-size: clamp(1.5rem,3vw,2rem); margin-bottom: .375rem; }
.hol-cmp-header p  { color: var(--ink-soft); max-width: 60ch; margin: 0; }

/* Filtres */
.hol-cmp-filtres {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .75rem 1.5rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--border);
}
.hol-cmp-enseignes { display: flex; flex-wrap: wrap; gap: .375rem; }
.hol-cmp-e {
  padding: .4rem 1rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--white);
  font-family: var(--font-sans);
  font-size: .875rem;
  color: var(--ink);
  cursor: pointer;
  transition: border-color .12s, background .12s;
}
.hol-cmp-e:hover { border-color: var(--champagne); }
.hol-cmp-e--active { background: var(--ink); color: var(--white); border-color: var(--ink); }

.hol-cmp-type-wrap { display: flex; align-items: center; gap: .5rem; }
.hol-cmp-reset {
  background: none;
  border: none;
  color: var(--ink-soft);
  font-size: .875rem;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
}
.hol-cmp-reset:hover { color: var(--ink); }

.hol-cmp-count { font-size: .875rem; color: var(--ink-soft); margin-bottom: 1.25rem; }

/* Grille */
.hol-cmp-grille {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
}

/* Carte */
.hol-cmp-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .625rem;
  transition: box-shadow .15s, border-color .15s;
}
.hol-cmp-card:hover { border-color: var(--champagne-l); box-shadow: var(--shadow); }

/* Média : visuel produit en tête de carte, pleine largeur */
.hol-cmp-card__media {
  display: block;
  margin: -1.25rem -1.25rem .25rem;
  border-radius: var(--radius) var(--radius) 0 0;
  overflow: hidden;
  background: var(--sand);
  aspect-ratio: 4 / 3;
}
.hol-cmp-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.hol-cmp-card:hover .hol-cmp-card__media img { transform: scale(1.03); }

.hol-cmp-card__top {
  display: flex;
  align-items: center;
  gap: .5rem;
}
.hol-cmp-card__enseigne {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--champagne);
}
.hol-cmp-card__type {
  font-size: .7rem;
  color: var(--ink-soft);
  background: var(--sand);
  padding: .1em .45em;
  border-radius: 3px;
}

.hol-cmp-card__nom {
  font-family: var(--font-serif);
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}

.hol-cmp-card__fab { font-size: .8125rem; }

/* Badges */
.cmp-badge {
  display: inline-block;
  padding: .15em .55em;
  border-radius: 3px;
  font-size: .72rem;
  font-weight: 600;
}
.cmp-badge--ok   { background: #D4EDDA; color: #155724; }
.cmp-badge--warn { background: #FFF3CD; color: #7A5A00; }

.hol-cmp-card__prix {
  display: flex;
  align-items: baseline;
  gap: .5rem;
  flex-wrap: wrap;
  font-weight: 600;
  font-size: 1.0625rem;
  color: var(--ink);
}
.hol-cmp-card__date { font-size: .7rem; font-weight: 400; color: var(--ink-soft); }

/* Specs */
.hol-cmp-card__specs {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .25rem;
  font-size: .8125rem;
  color: var(--ink-soft);
}
.hol-cmp-card__specs li { display: flex; gap: .375rem; }
.hol-cmp-spec-lbl { color: var(--ink); font-weight: 500; min-width: 5.5rem; flex-shrink: 0; }

/* Actions */
.hol-cmp-card__actions {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid var(--border-light, #eee);
}
.hol-cmp-btn {
  display: inline-block;
  padding: .4rem .875rem;
  border-radius: var(--radius);
  font-size: .8125rem;
  font-weight: 500;
  text-decoration: none;
  transition: opacity .12s;
}
.hol-cmp-btn:hover { opacity: .82; }
.hol-cmp-btn--pri { background: var(--champagne); color: var(--white); }
.hol-cmp-btn--sec { background: var(--sand); color: var(--ink); border: 1px solid var(--border); }

/* Footer liens */
.hol-cmp-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  font-size: .875rem;
}
.hol-cmp-footer-links a { color: var(--ink-soft); }
.hol-cmp-footer-links a:hover { color: var(--ink); }

.hol-cmp-empty { grid-column: 1 / -1; color: var(--ink-soft); font-style: italic; padding: 2rem 0; }

/* COMPARATEUR - EXTENSIONS v2 (legacy) */
.hol-page-comparateur { padding: 2rem var(--container-px); max-width: var(--container-w); margin: 0 auto; }
.hol-page-header { margin-bottom: 2rem; }
.hol-page-title { font-family: var(--font-serif); font-size: clamp(1.5rem,3vw,2rem); margin-bottom: .5rem; }
.hol-page-intro { color: var(--ink-soft); max-width: 60ch; }

/* Badge warn (très probable) */
.hol-badge--warn {
  display: inline-block;
  padding: .15em .55em;
  border-radius: 3px;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .03em;
  background: #FFF3CD;
  color: #856404;
  border: 1px solid #FFEEBA;
}

/* Tags dimensions */
.hol-produit-dims { margin: .375rem 0; display: flex; flex-wrap: wrap; gap: .25rem; align-items: center; }
.hol-dim-tag {
  display: inline-block;
  padding: .1em .45em;
  background: var(--sand);
  border: 1px solid var(--border);
  border-radius: 3px;
  font-size: .7rem;
  font-family: var(--font-sans);
  color: var(--ink-soft);
}

/* Prix et vérification */
.hol-produit-prix {
  margin: .5rem 0;
  font-weight: 600;
  color: var(--champagne-d, var(--champagne));
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .4rem;
}
.hol-produit-prix small { font-size: .72rem; font-weight: 400; color: var(--ink-soft); }
.hol-produit-verif { display: block; font-size: .7rem; color: var(--ink-soft); margin-top: .5rem; }

/* Actions */
.hol-produit-actions { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .75rem; }

/* Comparateur - page container */
.hol-compare-links { font-size: .9rem; color: var(--ink-soft); }
.hol-compare-links p { margin: .4rem 0; }

/* Configurateur - extensions Phase 5 */
.hol-config-step-group { margin-bottom: 1.5rem; }
.hol-config-step-label { font-weight: 600; margin-bottom: .5rem; font-size: .9375rem; }
.hol-config-select { width: 100%; max-width: 360px; padding: .6rem .875rem; border: 1px solid var(--border); border-radius: var(--radius); font-family: var(--font-sans); font-size: .9375rem; background: var(--white); color: var(--ink); }
.hol-config-preuve-badge { font-size: .75rem; font-weight: 600; padding: .2em .5em; border-radius: 3px; }
.hol-config-preuve--ok  { background: #D4EDDA; color: #155724; }
.hol-config-preuve--warn { background: #FFF3CD; color: #856404; }
.hol-config-preuve--na  { background: #F8D7DA; color: #721C24; }
.hol-config-composant-result { border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1rem; background: var(--white); }
.hol-config-composant-result h4 { font-size: 1rem; margin: 0 0 .5rem; font-family: var(--font-serif); }
.hol-config-no-result { color: var(--ink-soft); font-style: italic; padding: .75rem 0; }

/* Reprise UX 2026-06-18 */
[x-cloak] { display: none !important; }

.hol-hero {
  min-height: min(680px, calc(100vh - 68px));
  display: flex;
  align-items: center;
  isolation: isolate;
  background:
    linear-gradient(90deg, rgba(26,21,16,.86) 0%, rgba(26,21,16,.64) 42%, rgba(26,21,16,.12) 72%),
    url("assets/images/hero-literie-hotel.jpg") right center / cover no-repeat;
  color: var(--white);
}
.hol-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 7rem;
  background: linear-gradient(180deg, rgba(250,248,244,0), var(--linen));
  z-index: -1;
}
.hol-hero__inner,
.hol-hero > div {
  width: min(var(--max-w-xl), calc(100vw - 3rem));
  margin: 0 auto;
}
.hol-hero__title,
.hol-hero__title em,
.hol-hero .hol-hero__sub,
.hol-hero__eyebrow { color: var(--white); }
.hol-hero__title { max-width: 680px; text-wrap: balance; }
.hol-hero__sub { max-width: 610px; color: rgba(255,255,255,.86); }
.hol-hero__proofs {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.5rem;
}
.hol-hero__proofs span,
.hol-mini-tag {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: .35rem .65rem;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--radius);
  background: rgba(255,255,255,.09);
  color: inherit;
  font-size: .8125rem;
  line-height: 1.25;
}

.hol-section {
  max-width: var(--max-w-xl);
  margin: 0 auto;
  padding: 3rem 1.5rem 0;
}
.hol-section > h2 { margin-top: 0; }
.hol-section--ink {
  max-width: none;
  margin-top: 3rem;
  padding: 3.25rem max(1.5rem, calc((100vw - var(--max-w-xl)) / 2));
  background: var(--ink);
  color: rgba(255,255,255,.82);
}
.hol-section--ink h2,
.hol-section--ink h3,
.hol-section--ink strong { color: var(--white); }
.hol-section--ink a { color: var(--champagne-l); }

.hol-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1rem;
  margin: 1.5rem 0;
}
.hol-card-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.hol-card {
  min-height: 11rem;
  padding: 1.25rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: var(--shadow);
}
.hol-card h3 { margin-top: 0; font-size: 1.25rem; }
.hol-card p { color: var(--ink-soft); }
.hol-card--feature {
  background: var(--blue-grey);
  border-color: rgba(255,255,255,.08);
  color: rgba(255,255,255,.86);
}
.hol-card--feature h3,
.hol-card--feature p { color: inherit; }

.hol-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  margin: 1.5rem 0;
}
.hol-kpi {
  min-height: 6.5rem;
  padding: 1rem;
  border-radius: var(--radius);
  background: var(--sand-light);
  border: 1px solid var(--border);
}
.hol-kpi strong {
  display: block;
  font-family: var(--font-serif);
  font-size: 1.7rem;
  line-height: 1;
}
.hol-kpi span {
  display: block;
  margin-top: .45rem;
  color: var(--ink-soft);
  font-size: .875rem;
  line-height: 1.35;
}

.hol-table-wrap {
  overflow-x: auto;
  margin: 1.5rem 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
}
.hol-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  font-size: .9375rem;
}
.hol-table th,
.hol-table td {
  padding: .8rem .9rem;
  border-bottom: 1px solid var(--border-light);
  vertical-align: top;
}
.hol-table th {
  background: var(--ink);
  color: var(--white);
  text-align: left;
  font-weight: 600;
}
.hol-table tr:last-child td { border-bottom: 0; }
/* Table clé/valeur (2 colonnes) : tient dans le viewport, pas de scroll horizontal forcé */
.hol-table-wrap--kv { overflow-x: visible; }
.hol-table--kv { min-width: 0; }
.hol-table--kv td:first-child { width: 40%; white-space: normal; }
.hol-table--kv td { white-space: normal; overflow-wrap: anywhere; }

.hol-path {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  counter-reset: path;
  margin: 1.5rem 0;
}
.hol-path__step {
  counter-increment: path;
  position: relative;
  min-height: 10rem;
  padding: 1.2rem;
  border-radius: var(--radius);
  background: var(--white);
  border: 1px solid var(--border);
}
.hol-path__step::before {
  content: counter(path);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin-bottom: .9rem;
  border-radius: 50%;
  background: var(--sage);
  color: var(--white);
  font-weight: 700;
}

.hol-note,
.hol-proof-strip {
  padding: 1rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--sand-light);
  color: var(--ink-soft);
}
.hol-proof-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  background: var(--ink);
  color: rgba(255,255,255,.8);
  border-color: var(--ink);
}
.hol-proof-strip strong { color: var(--white); display: block; }

.hol-tool-hero {
  position: relative;
  min-height: 420px;
  display: flex;
  align-items: center;
  margin: 0 0 1.5rem;
  padding: 3.5rem max(1.5rem, calc((100vw - var(--max-w-xl)) / 2));
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(26,21,16,.9), rgba(26,21,16,.64) 48%, rgba(26,21,16,.14)),
    url("assets/images/hero-literie-hotel.jpg") right center / cover no-repeat;
  color: var(--white);
}
.hol-tool-hero__content {
  width: min(650px, 100%);
  position: relative;
  z-index: 1;
}
.hol-tool-hero h1 {
  color: var(--white);
  margin: .25rem 0 .75rem;
  text-wrap: balance;
}
.hol-tool-hero p { color: rgba(255,255,255,.86); }
.hol-tool-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.5rem;
}
.hol-hero .hol-btn--secondary,
.hol-tool-hero .hol-btn--secondary {
  color: var(--white);
  border-color: rgba(255,255,255,.72);
  background: rgba(255,255,255,.08);
}
.hol-hero .hol-btn--secondary:hover,
.hol-tool-hero .hol-btn--secondary:hover {
  color: var(--white);
  border-color: var(--white);
  background: rgba(255,255,255,.16);
}
.hol-eyebrow {
  display: inline-block;
  margin: 0 0 .45rem;
  color: var(--champagne-l);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
}

.hol-tool-stats {
  max-width: var(--max-w-xl);
  margin: -2.8rem auto 2rem;
  padding: 0 1.5rem;
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.hol-tool-stats div {
  min-height: 5.5rem;
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow-lg);
}
.hol-tool-stats strong {
  display: block;
  font-family: var(--font-serif);
  font-size: 1.8rem;
  line-height: 1;
}
.hol-tool-stats span {
  display: block;
  margin-top: .35rem;
  color: var(--ink-soft);
  font-size: .875rem;
}

.hol-cmp-page,
.hol-page-configurateur {
  max-width: none;
  padding: 0 0 4rem;
}
.hol-cmp-wrap,
.hol-tool-help,
.hol-page-configurateur > .hol-configurateur {
  max-width: var(--max-w-xl);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
.hol-cmp-panel {
  margin: 1.5rem 0;
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow);
}
.hol-cmp-filtres {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr)) auto;
  align-items: end;
  gap: .75rem;
  margin: 1rem 0 0;
  padding: 0;
  border: 0;
}
.hol-cmp-filtres label {
  display: grid;
  gap: .3rem;
  min-width: 0;
}
.hol-cmp-filtres label > span {
  color: var(--ink-soft);
  font-size: .75rem;
  font-weight: 700;
}
.hol-cmp-panel .hol-select,
.hol-config-select,
.hol-config-input {
  width: 100%;
  min-height: 2.7rem;
  border-radius: var(--radius);
}
.hol-cmp-card {
  min-height: 24rem;
}
.hol-cmp-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  min-height: 1.6rem;
}
.cmp-badge--neutral { background: #E6EAED; color: var(--blue-grey); }
.cmp-badge--ink { background: var(--ink); color: var(--white); }
.hol-cmp-note {
  min-height: 3rem;
  padding: .7rem;
  border-radius: var(--radius);
  background: var(--sand-light);
  color: var(--ink-soft);
  font-size: .8125rem;
  line-height: 1.45;
}
.hol-cmp-btn,
.hol-btn--small {
  min-height: 2.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.hol-configurateur {
  margin-top: 2rem;
  padding: 0 1.5rem;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.hol-config-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 1.25rem;
  align-items: start;
}
.hol-config-sidebar {
  position: sticky;
  top: 88px;
  display: grid;
  gap: .7rem;
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--white);
}
.hol-step-dot {
  display: grid;
  grid-template-columns: 2rem 1fr;
  align-items: center;
  gap: .65rem;
  min-height: 2.6rem;
  color: var(--taupe);
}
.hol-step-dot span {
  display: inline-flex;
  width: 2rem;
  height: 2rem;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--sand-light);
  font-weight: 700;
}
.hol-step-dot--active span { background: var(--ink); color: var(--white); border-color: var(--ink); }
.hol-step-dot--done span { background: var(--sage); color: var(--white); border-color: var(--sage); }
.hol-config-main {
  min-width: 0;
  display: grid;
  gap: 1rem;
}
.hol-config-main .hol-config-step,
.hol-config-result {
  margin: 0;
  padding: 1.25rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  box-shadow: var(--shadow);
}
.hol-enseigne-btn {
  min-height: 4.1rem;
  border-radius: var(--radius);
  display: grid;
  align-content: center;
  gap: .2rem;
  line-height: 1.25;
}
.hol-enseigne-btn small { color: currentColor; opacity: .72; }
.hol-config-selected {
  display: grid;
  gap: .25rem;
  margin-bottom: 1rem;
  padding: .9rem 1rem;
  border-radius: var(--radius);
  background: var(--sand-light);
  border: 1px solid var(--border);
}
.hol-config-selected span { color: var(--ink-soft); }
.hol-config-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
}
.hol-config-form-grid label {
  display: grid;
  gap: .35rem;
}
.hol-config-form-grid label > span {
  color: var(--ink-soft);
  font-size: .8125rem;
  font-weight: 700;
}
.hol-config-check {
  grid-column: span 3;
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: row;
  align-items: center;
  min-height: 2.8rem;
  padding: .6rem .8rem;
  border-radius: var(--radius);
  background: var(--sand-light);
}
.hol-config-check input { margin-right: .55rem; }
.hol-config-result__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.hol-config-result__head h2 { margin: 0; font-size: clamp(1.45rem, 3vw, 2rem); }
.hol-config-product-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
}
.hol-config-product-top h3 { margin: 0; }
.hol-config-product-type {
  margin: 0 0 .25rem;
  color: var(--champagne);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
}
.hol-config-proof {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 1rem;
  margin: .8rem 0;
  color: var(--ink-soft);
  font-size: .8125rem;
}
.hol-config-specs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .6rem;
  margin: .8rem 0;
}
.hol-config-specs div {
  padding: .65rem;
  border-radius: var(--radius);
  background: var(--sand-light);
  min-height: 4rem;
}
.hol-config-specs dt {
  color: var(--taupe);
  font-size: .72rem;
  font-weight: 700;
}
.hol-config-specs dd {
  margin: .2rem 0 0;
  color: var(--ink);
  font-weight: 600;
}
.hol-config-note {
  padding: .75rem;
  border-radius: var(--radius);
  background: var(--sand-light);
  color: var(--ink-soft);
  font-size: .85rem;
}
.hol-tool-help {
  padding-top: 2rem;
}
.hol-tool-help__inner {
  max-width: 760px;
  margin: 0 auto;
}
.hol-tool-help__inner h2 {
  margin-top: 2.4rem;
}
.hol-tool-help__inner h2:first-child { margin-top: 0; }
.hol-tool-help__inner p { margin: 0 0 1.1rem; }
.hol-config-count { color: var(--ink-soft, #6b6257); font-weight: 400; }
.hol-config-product-id { display: flex; gap: .9rem; align-items: center; }
.hol-config-thumb { width: 64px; height: 64px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }

@media (max-width: 900px) {
  .hol-card-grid--3,
  .hol-kpi-row,
  .hol-path,
  .hol-proof-strip,
  .hol-cmp-filtres,
  .hol-config-layout,
  .hol-config-form-grid,
  .hol-config-specs {
    grid-template-columns: 1fr;
  }
  .hol-config-sidebar { position: static; grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .hol-step-dot { grid-template-columns: 1fr; justify-items: center; text-align: center; }
}

@media (max-width: 640px) {
  :root { --container-px: 1rem; }
  .hol-hero,
  .hol-tool-hero {
    min-height: auto;
    padding-top: 2.1rem;
    padding-bottom: 2.1rem;
    background-position: 62% center;
  }
  .hol-hero__title,
  .hol-tool-hero h1 { font-size: 1.95rem; margin-bottom: .5rem; }
  .hol-tool-hero p { font-size: .95rem; }
  .hol-hero__ctas,
  .hol-tool-hero__actions,
  .hol-produit-actions,
  .hol-cmp-card__actions { flex-direction: column; align-items: stretch; }
  .hol-btn,
  .hol-cmp-btn { width: 100%; text-align: center; }
  .hol-tool-hero__actions { margin-top: 1rem; }
  /* Stats : bande compacte 3 colonnes, ne repousse pas les filtres */
  .hol-tool-stats { margin-top: -1.6rem; margin-bottom: 1.25rem; gap: .4rem; }
  .hol-tool-stats div { min-height: 0; padding: .6rem .4rem; text-align: center; }
  .hol-tool-stats strong { font-size: 1.3rem; }
  .hol-tool-stats span { font-size: .68rem; margin-top: .15rem; line-height: 1.2; }
  /* Raccourcis enseignes plus visibles, accès rapide aux filtres */
  .hol-cmp-enseignes { gap: .4rem; margin-bottom: .25rem; }
  .hol-cmp-e { padding: .5rem 1rem; font-size: .92rem; font-weight: 500; box-shadow: var(--shadow); }
  .hol-config-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .35rem;
    padding: .65rem;
  }
  .hol-step-dot { min-height: 2.2rem; font-size: .75rem; }
  .hol-step-dot span { width: 1.7rem; height: 1.7rem; }
  .hol-config-product-top,
  .hol-config-result__head { flex-direction: column; }
}

/* ═══ HOMEPAGE v3 (best-of) ═══════════════════════════════════════════════ */

/* En-tête de section : eyebrow + titre + intro */
.hol-section__head { max-width: 660px; margin: 0 auto 2.25rem; text-align: center; }
.hol-section__head--left { margin-left: 0; margin-right: 0; text-align: left; max-width: 720px; }
.hol-section__eyebrow {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-sans); font-size: .6875rem; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--champagne);
  margin-bottom: .9rem;
}
.hol-section__eyebrow::before {
  content: ''; display: block; width: 22px; height: 1px; background: var(--champagne);
}
.hol-section__head h2 { margin: 0; }
.hol-section__intro { margin: .9rem auto 0; color: var(--taupe); font-size: 1.0625rem; line-height: 1.7; }
.hol-section__head--left .hol-section__intro { margin-left: 0; }

/* Pastille d'icône */
.hol-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.75rem; height: 2.75rem; border-radius: 50%;
  background: var(--champagne-bg); color: var(--champagne);
  border: 1px solid var(--champagne-l); flex-shrink: 0;
}
.hol-ico svg { width: 1.3rem; height: 1.3rem; }

/* Cartes "feature" (parcours + composants) */
.hol-feature-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin: 0;
}
.hol-feature-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.hol-feature {
  display: flex; flex-direction: column; gap: .65rem;
  padding: 1.6rem; background: var(--white);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); text-decoration: none; color: var(--ink);
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.hol-feature:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--champagne-l); color: var(--ink); }
.hol-feature h3 { margin: .35rem 0 0; font-size: 1.25rem; }
.hol-feature p { margin: 0; color: var(--ink-soft); font-size: .9375rem; }
.hol-feature__more {
  margin-top: auto; padding-top: .4rem;
  font-family: var(--font-sans); font-size: .7rem; font-weight: 500;
  letter-spacing: .08em; text-transform: uppercase; color: var(--champagne);
  display: inline-flex; align-items: center; gap: .4rem;
}
.hol-feature__more svg { width: 1rem; height: 1rem; transition: transform .2s; }
.hol-feature:hover .hol-feature__more svg { transform: translateX(4px); }

/* Vitrine des outils (2 colonnes) */
.hol-tools-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 0; }
.hol-tool-promo {
  display: flex; flex-direction: column; gap: .85rem;
  padding: 2.1rem; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--border);
}
.hol-tool-promo--ink {
  background-image: linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
  color: rgba(255,255,255,.78); border-color: var(--ink);
}
.hol-tool-promo--ink h3 { color: var(--white); }
.hol-tool-promo--ink .hol-ico { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.18); color: var(--champagne-l); }
.hol-tool-promo--light { background: var(--white); box-shadow: var(--shadow); }
.hol-tool-promo h3 { margin: .3rem 0 0; font-size: 1.5rem; }
.hol-tool-promo > p { margin: 0; font-size: .9375rem; }
.hol-tool-promo ul { list-style: none; padding: 0; margin: .15rem 0; display: grid; gap: .45rem; }
.hol-tool-promo li { display: flex; align-items: flex-start; gap: .6rem; font-size: .875rem; line-height: 1.45; }
.hol-tool-promo li svg { width: 1rem; height: 1rem; color: var(--champagne); flex-shrink: 0; margin-top: .15rem; }
.hol-tool-promo--ink li svg { color: var(--champagne-l); }
.hol-tool-promo .hol-btn { margin-top: auto; align-self: flex-start; }

/* Section confiance (fond encre) */
.hol-trust-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; margin: 1.9rem 0 0; }
.hol-trust {
  padding: 1.6rem; border-radius: var(--radius-lg);
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
}
.hol-trust .hol-ico { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.18); color: var(--champagne-l); margin-bottom: .9rem; }
.hol-trust h3 { font-size: 1.125rem; margin: 0 0 .45rem; }
.hol-trust p { margin: 0; font-size: .9rem; line-height: 1.6; }

/* Ligne prix dans les cartes enseigne */
.hol-enseigne-card__price { font-family: var(--font-sans); font-size: .8125rem; color: var(--ink-soft); font-weight: 500; }

/* CTA final */
.hol-cta-final { max-width: var(--max-w-xl); margin: 3.25rem auto 0; padding: 0 1.5rem; }

/* Badge fabricant inline dans tableau */
.hol-fab-line { display: inline-flex; align-items: center; gap: .45rem; flex-wrap: wrap; }

@media (max-width: 900px) {
  .hol-feature-grid--3,
  .hol-tools-grid,
  .hol-trust-grid { grid-template-columns: 1fr; }
  .hol-section__head { margin-bottom: 1.75rem; }
}

/* Surcharges contraste fond sombre */
.hol-section--ink .hol-section__eyebrow { color: var(--champagne-l); }
.hol-section--ink .hol-section__eyebrow::before { background: var(--champagne-l); }
.hol-section--ink .hol-section__intro { color: rgba(255,255,255,.72); }
.hol-hero .hol-hero__title em { color: var(--champagne-l); font-style: italic; }

/* ═══ COMPOSANTS PAGES ÉDITORIALES (silos, produits, guides) ══════════════ */

/* Image bandeau en tête de contenu */
.hol-wide-image { margin: 0 0 2em; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); }
.hol-wide-image img { width: 100%; height: clamp(200px, 32vw, 320px); object-fit: cover; }

/* Fiche d'identité (key facts) */
.hol-keyfacts {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .75rem; margin: 0 0 2em; padding: 0; list-style: none;
}
.hol-keyfact {
  padding: 1rem 1.1rem; border: 1px solid var(--border);
  border-radius: var(--radius); background: var(--white); box-shadow: var(--shadow);
}
.hol-keyfact dt {
  font-family: var(--font-sans); font-size: .625rem; text-transform: uppercase;
  letter-spacing: .1em; color: var(--taupe); font-weight: 600; margin-bottom: .35rem;
}
.hol-keyfact dd {
  margin: 0; font-family: var(--font-serif); font-size: 1.15rem;
  color: var(--ink); font-weight: 600; line-height: 1.2;
}
.hol-keyfact dd small { font-family: var(--font-sans); font-size: .75rem; font-weight: 400; color: var(--taupe); display: block; margin-top: .15rem; }
.hol-keyfact dd a { border-bottom: 1px solid var(--border) !important; }

/* Barre d'achat fiche produit (prix + CTA, juste après les keyfacts) */
.hol-buybar {
  display: flex; align-items: center; justify-content: space-between; gap: 1.25rem;
  flex-wrap: wrap; max-width: 100%;
  padding: 1.15rem 1.4rem; margin: 0 0 2.25em;
  background: var(--white); border: 1px solid var(--border);
  border-left: 3px solid var(--champagne);
  border-radius: var(--radius); box-shadow: var(--shadow);
}
.hol-buybar__info { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.hol-buybar__price { font-family: var(--font-serif); font-size: 1.6rem; color: var(--ink); line-height: 1.1; }
.hol-buybar__meta { font-family: var(--font-sans); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--taupe); }
@media (max-width: 480px) {
  .hol-buybar { gap: .85rem; }
  .hol-buybar .cta-btn { width: 100%; text-align: center; }
}

/* Verdict d'achat (à choisir si / à éviter si / meilleur usage) */
.hol-verdict {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1px;
  margin: 2em 0; max-width: 100%;
  background: var(--border); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow);
}
.hol-verdict__col { background: var(--white); padding: 1.3rem 1.4rem; }
.hol-verdict__col--good { background: linear-gradient(180deg, rgba(88,107,93,.06), var(--white) 60%); }
.hol-verdict__col--avoid { background: linear-gradient(180deg, rgba(184,147,90,.07), var(--white) 60%); }
.hol-verdict__lbl {
  font-family: var(--font-sans); font-size: .68rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase; color: var(--champagne);
  margin-bottom: .7rem; display: flex; align-items: center; gap: .4rem;
}
.hol-verdict__col--good .hol-verdict__lbl { color: var(--sage); }
.hol-verdict__lbl i { width: 15px; height: 15px; }
.hol-verdict__col p { font-size: .9rem; line-height: 1.6; color: var(--ink-soft); margin: 0; }
.hol-verdict__col ul { margin: 0; padding-left: 1.05em; }
.hol-verdict__col li { font-size: .9rem; line-height: 1.5; margin-bottom: .35em; color: var(--ink-soft); }
@media (max-width: 680px) {
  .hol-verdict { grid-template-columns: 1fr; }
}

/* Étapes numérotées (how-to) */
.hol-steps { list-style: none; padding: 0; margin: 1.75em 0; display: grid; gap: .75rem; counter-reset: holstep; }
.hol-steps li {
  counter-increment: holstep; position: relative;
  padding: 1.1rem 1.2rem 1.1rem 3.6rem;
  background: var(--white); border: 1px solid var(--border); border-radius: var(--radius);
  font-size: .9375rem; line-height: 1.6;
}
.hol-steps li::before {
  content: counter(holstep); position: absolute; left: 1rem; top: 1.05rem;
  width: 1.85rem; height: 1.85rem; border-radius: 50%;
  background: var(--ink); color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-serif); font-weight: 600; font-size: 1rem;
}
.hol-steps li strong { display: block; margin-bottom: .15rem; color: var(--ink); }

/* Lien interne « en savoir plus » avec flèche */
.entry-content .hol-inline-link { margin: -.25em 0 1.5em; }
.entry-content .hol-inline-link a {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: var(--font-sans); font-size: .875rem; font-weight: 500;
  color: var(--champagne); border-bottom: none !important;
}
.entry-content .hol-inline-link a::after { content: '→'; }
.entry-content .hol-inline-link a:hover { color: var(--ink); }

/* Les liens-composants dans le contenu éditorial ne doivent pas hériter du soulignement */
.entry-content a.hol-feature,
.entry-content a.hol-enseigne-card,
.entry-content .cta-btn,
.entry-content .hol-btn,
.entry-content .hol-feature__more { border-bottom: none; }

/* ═══ HOMEPAGE — cartes photos & bande photo (Session images) ═════════════ */
.hol-photo-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin: 0; }
.hol-photo-card { display: flex; flex-direction: column; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); text-decoration: none; color: var(--ink); transition: transform .2s, box-shadow .2s, border-color .2s; }
.hol-photo-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--champagne-l); color: var(--ink); }
.hol-photo-card__img { aspect-ratio: 4 / 3; overflow: hidden; background: var(--sand); }
.hol-photo-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.hol-photo-card:hover .hol-photo-card__img img { transform: scale(1.05); }
.hol-photo-card__body { padding: 1.05rem 1.2rem 1.2rem; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.hol-photo-card__body h3 { margin: 0; font-size: 1.2rem; }
.hol-photo-card__body p { margin: 0; color: var(--ink-soft); font-size: .9rem; line-height: 1.5; }
.hol-photo-card__more { margin-top: auto; padding-top: .35rem; font-family: var(--font-sans); font-size: .7rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--champagne); display: inline-flex; align-items: center; gap: .4rem; }
.hol-photo-card__more svg { width: 1rem; height: 1rem; transition: transform .2s; }
.hol-photo-card:hover .hol-photo-card__more svg { transform: translateX(4px); }

/* Références les plus recherchées + budget rapide (home) */
.hol-section--soft {
  max-width: none;
  margin: 3rem 0 0;
  padding: 3.5rem max(1.5rem, calc((100vw - var(--max-w-xl)) / 2));
  background: var(--sand);
}
.hol-section--soft .hol-section__head { margin-bottom: 2rem; }
.hol-pop-grid { display: grid; gap: .8rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin: 0 0 2rem; }
.hol-pop-card { display: flex; align-items: center; gap: .25rem; flex-wrap: wrap; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: .85rem 1.05rem; text-decoration: none; color: var(--ink); box-shadow: var(--shadow); transition: transform .2s, border-color .2s; }
.hol-pop-card:hover { transform: translateY(-2px); border-color: var(--champagne-l); color: var(--ink); }
.hol-pop-card__ens { width: 100%; font-family: var(--font-sans); font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--champagne); }
.hol-pop-card strong { font-family: var(--font-serif, serif); font-size: 1.1rem; font-weight: 400; }
.hol-pop-card svg { width: 1rem; height: 1rem; margin-left: auto; color: var(--champagne); transition: transform .2s; }
.hol-pop-card:hover svg { transform: translateX(4px); }
.hol-budget-quick { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg, 10px); padding: 1.4rem 1.6rem; box-shadow: var(--shadow); }
.hol-budget-quick h3 { margin: 0 0 .9rem; font-size: 1.2rem; }
.hol-budget-quick ul { list-style: none; margin: 0 0 1rem; padding: 0; display: flex; flex-direction: column; gap: .6rem; }
.hol-budget-quick li { font-size: .94rem; color: var(--ink-soft); line-height: 1.5; }
.hol-budget-quick__tag { display: inline-block; min-width: 130px; margin-right: .5rem; font-family: var(--font-sans); font-size: .66rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--champagne); }

.hol-photo-band { position: relative; margin: 3.5rem 0 0; min-height: 360px; display: flex; align-items: center; padding: 3.5rem max(1.5rem, calc((100vw - var(--max-w-xl)) / 2)); background-size: cover; background-position: center; color: var(--white); isolation: isolate; overflow: hidden; }
.hol-photo-band::before { content: ""; position: absolute; inset: 0; background: linear-gradient(95deg, rgba(26,21,16,.84), rgba(26,21,16,.5) 55%, rgba(26,21,16,.18)); z-index: -1; }
.hol-photo-band__inner { max-width: 540px; }
.hol-photo-band__eyebrow { display: inline-flex; align-items: center; gap: .55rem; font-family: var(--font-sans); font-size: .6875rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--champagne-l); margin-bottom: .9rem; }
.hol-photo-band h2 { color: var(--white); margin: 0 0 .8rem; }
.hol-photo-band p { color: rgba(255,255,255,.86); margin: 0 0 1.6rem; font-size: 1.0625rem; line-height: 1.7; }
@media (max-width: 900px) { .hol-photo-band { min-height: auto; padding-top: 2.5rem; padding-bottom: 2.5rem; } }

/* ─── Bloc réponse home : photo + tableau enseignes (Session 15) ──────────── */
.hol-answer {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.18fr);
  gap: clamp(1.5rem, 3vw, 2.75rem);
  align-items: stretch;
  margin-top: 2.25rem;
}
.hol-answer__media {
  display: flex;
  flex-direction: column;
  margin: 0;
  border-radius: 18px;
  overflow: hidden;
  background: var(--sand-light);
  border: 1px solid var(--border-light);
  box-shadow: 0 22px 45px -30px rgba(26,21,16,.5);
}
.hol-answer__media img {
  width: 100%;
  flex: 1 1 auto;
  min-height: 230px;
  object-fit: cover;
  display: block;
}
.hol-answer__caption {
  padding: 1.1rem 1.35rem 1.25rem;
  font-family: var(--font-sans);
  font-size: .9rem;
  line-height: 1.62;
  color: var(--ink-soft);
}
.hol-answer__caption strong { color: var(--ink); }
.hol-answer__table {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hol-answer .hol-table-wrap { margin: 0 0 .85rem; overflow-x: auto; }
.hol-table--brands { min-width: 0; }
.hol-table--brands th,
.hol-table--brands td { white-space: normal; vertical-align: middle; }
.hol-table--brands th:first-child { width: 40%; }
.hol-brand-cell {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  text-decoration: none;
  color: var(--ink);
  font-weight: 600;
  font-family: var(--font-sans);
}
.hol-brand-cell:hover { color: var(--champagne); }
.hol-brand-cell__logo {
  height: 24px;
  width: auto;
  max-width: 72px;
  object-fit: contain;
  flex: 0 0 auto;
}
.hol-brand-fab {
  display: block;
  margin-top: .28rem;
  font-family: var(--font-sans);
  font-size: .76rem;
  line-height: 1.3;
  color: var(--ink-soft);
}
.hol-table--brands th:last-child,
.hol-brand-price { text-align: right; }
.hol-brand-price {
  white-space: nowrap;
  font-weight: 600;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.hol-np { white-space: nowrap; }
.hol-answer__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 1.25rem;
  flex-wrap: wrap;
}
.hol-answer__foot p { margin: 0; flex: 1 1 14rem; }
.hol-answer__foot .hol-btn { flex: 0 0 auto; }
@media (max-width: 820px) {
  .hol-answer { grid-template-columns: 1fr; }
  .hol-answer__media img { min-height: 200px; max-height: 300px; }
  .hol-brand-price { white-space: normal; }
  .hol-table--brands th,
  .hol-table--brands td { padding: .6rem .55rem; }
  .hol-brand-cell { gap: .5rem; }
  .hol-brand-cell__logo { height: 20px; max-width: 54px; }
  .hol-answer__foot { flex-direction: column; align-items: stretch; }
  .hol-answer__foot p { flex: 0 0 auto; }
  .hol-answer__foot .hol-btn { width: 100%; text-align: center; }
}
