/* ═══════════════════════════════════════════════════════════
   LES OBSERVATEURS — Design System
   Table des matières :
   1.  RESET & BASE
   2.  DESIGN TOKENS (CSS Variables)
   3.  TOPBAR
   4.  HEADER
   5.  HEADER SEARCH (inline)
   6.  SEARCH OVERLAY
   7.  NAV
   8.  HAMBURGER & MOBILE MENU
   9.  TICKER
   10. MAIN LAYOUT
   11. HERO GRID (accueil)
   12. SECTION HEADERS
   13. ARTICLE CARDS
   14. BREVES
   15. ECLAIRAGE (full-width)
   16. LIST SECTION
   17. NEWSLETTER
   18. BOUTIQUE / SHOP
   19. BREADCRUMB
   20. CATEGORY PAGE
   21. PAGINATION
   22. SEARCH RESULTS
   23. ARTICLE PAGE (single)
   24. AUTHOR PAGE
   25. PRODUCT PAGE
   26. LIGHTBOX
   27. LOGIN PAGE
   28. ACCOUNT PAGE (logged-in)
   29. DONATION PAGE
   30. SUPPORT BAND
   31. FOOTER
   32. COOKIE BANNER
   33. BACK TO TOP
   34. 404 PAGE
   35. TRANSITIONS
   36. RESPONSIVE — 1069px (hamburger + search reflow)
   37. RESPONSIVE — 999px (mobile/tablet)
   38. RESPONSIVE — 600px (mobile)
   39. RESPONSIVE — 500px (cookie banner)
   ═══════════════════════════════════════════════════════════ */


/* ═══════════════════════════════════════════════════════════
   1. RESET & BASE
   ═══════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  background: var(--white);
  color: var(--gray-900);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; color: inherit; transition: color 0.25s ease; }


/* ═══════════════════════════════════════════════════════════
   2. DESIGN TOKENS
   ═══════════════════════════════════════════════════════════ */

:root {
  /* Couleurs */
  --red: #C41E1E;
  --red-dark: #9B1515;
  --red-light: #F8ECEC;
  --black: #0E0E0E;
  --gray-900: #1A1A1A;
  --gray-700: #3A3A3A;
  --gray-500: #6B6B6B;
  --gray-300: #CACACA;
  --gray-100: #F2F0ED;
  --white: #FFFFFF;
  --gray-hover: #EBE8E4;

  /* Overlays */
  --overlay-dark-40: rgba(0,0,0,0.4);
  --overlay-dark-60: rgba(14,14,14,0.6);
  --overlay-dark-85: rgba(0,0,0,0.85);

  /* Succès */
  --success: #2d7d3a;
  --success-bg: #e8f5e9;
  --success-border: #a5d6a7;

  /* Layout */
  --container-max: 1260px;
  --gutter-desktop: 40px;
  --gutter-tablet: 20px;
  --gutter-mobile: 16px;

  /* Rayons */
  --radius-sm: 6px;
  --radius-full: 999px;

  /* Z-index */
  --z-sharebar: 10;
  --z-header: 100;
  --z-mobile-overlay: 199;
  --z-mobile-menu: 200;
  --z-search-overlay: 999;
  --z-backtotop: 998;
  --z-cookie: 9999;
  --z-lightbox: 10000;
  --z-lightbox-ui: 10001;

  /* Bordures */
  --border: 1px solid #E2DDD8;

  /* Typographie */
  --serif: 'Playfair Display', Georgia, serif;
  --body-serif: 'Source Serif 4', Georgia, serif;
  --sans: 'DM Sans', sans-serif;
}

/* ═══════════════════════════════════════════════════════════
   2B. SHARED PATTERNS (non destructif)
   Factorisations purement techniques, sans incidence visuelle
   ═══════════════════════════════════════════════════════════ */

.hero-cat,
.article-cat,
.breve-cat,
.list-cat,
.related-card-cat,
.category-card-cat,
.author-article-cat {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.hero-cat span,
.single-cat span,
.product-cat span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--red);
}

.article-img a,
.hero-main-img a,
.eclairage-img a,
.list-img a {
  display: block;
  width: 100%;
  height: 100%;
}

.article-img img,
.hero-main-img img,
.category-card-img img,
.related-card-img img,
.author-article-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-link,
.search-btn,
.hamburger-btn,
.mobile-menu-close,
.cookie-close,
.back-to-top,
.lightbox-close,
.lightbox-nav,
.qty-btn,
.product-meta-link,
.account-nav-item,
.order-view-btn {
  -webkit-tap-highlight-color: transparent;
}

/* ═══════════════════════════════════════════════════════════
   3. TOPBAR
   ═══════════════════════════════════════════════════════════ */

.topbar { background: var(--gray-900); height: 36px; }

.topbar-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter-desktop);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.topbar-left {
  font-size: 12px;
  color: rgba(255,255,255,0.7);
  font-weight: 500;
  letter-spacing: 0.03em;
}

.topbar-right { display: flex; align-items: center; gap: 20px; }

.btn-support-top {
  background: var(--red);
  color: white;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border: none;
  cursor: pointer;
  transition: background 0.3s ease;
  white-space: nowrap;
}

.btn-support-top:hover { background: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   4. HEADER
   ═══════════════════════════════════════════════════════════ */

header {
  position: sticky;
  top: 0;
  background: var(--white);
  z-index: var(--z-header);
  border-bottom: var(--border);
}

.header-top { height: 80px; border-bottom: var(--border); }

.header-top-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter-desktop);
  height: 100%;
  display: flex;
  align-items: center;
  gap: 40px;
}

.logo-area { display: flex; align-items: center; flex: 0 0 50%; min-width: 0; }
.logo-area img { display: block; width: 100%; height: auto; }

.btn-support {
  background: var(--red);
  color: white;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 8px 18px;
  border: none;
  cursor: pointer;
  transition: background 0.3s ease;
}

.btn-support:hover { background: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   5. HEADER SEARCH (inline)
   ═══════════════════════════════════════════════════════════ */

.header-search-wrap { flex: 1 1 0; min-width: 0; }

.header-search-inner {
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  border: none;
  border-bottom: 1px solid var(--gray-300);
  background: #FFFDE7;
  padding: 0 6px 0 4px;
  gap: 8px;
  transition: border-color 0.3s ease, background 0.3s ease;
}

.header-search-inner:focus-within { border-color: var(--black); }

.header-search-inner svg { width: 16px; height: 16px; color: var(--gray-500); flex-shrink: 0; }

.header-search-input {
  flex: 1;
  border: none;
  background: transparent;
  outline: none;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--gray-900);
  caret-color: var(--red);
}

.header-search-input::placeholder { color: var(--gray-300); }

.header-search-btn {
  background: var(--red);
  border: none;
  color: white;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 5px 12px;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.35s ease;
  height: 28px;
}

.header-search-btn:hover { background: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   6. SEARCH OVERLAY
   ═══════════════════════════════════════════════════════════ */

.search-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  background: none;
  border: 1px solid var(--gray-300);
  padding: 7px 14px;
  cursor: pointer;
  color: var(--gray-500);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 500;
  transition: border-color 0.3s ease, color 0.3s ease;
  white-space: nowrap;
}

.search-btn:hover { border-color: var(--gray-700); color: var(--gray-700); }
.search-btn svg { width: 14px; height: 14px; flex-shrink: 0; }

.search-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-dark-60);
  backdrop-filter: blur(4px);
  z-index: var(--z-search-overlay);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 120px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.search-overlay.open { opacity: 1; pointer-events: all; }

.search-box {
  background: var(--white);
  width: 100%;
  max-width: 680px;
  margin: 0 20px;
  padding: 28px 28px 24px;
  transform: translateY(-12px);
  transition: transform 0.35s ease;
}

.search-overlay.open .search-box { transform: translateY(0); }

.search-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.search-label::before { content: ''; display: block; width: 20px; height: 2px; background: var(--red); }

.search-input-wrap {
  display: flex;
  align-items: center;
  border-bottom: 2px solid var(--black);
  gap: 12px;
  padding-bottom: 10px;
}

.search-input-wrap svg { width: 20px; height: 20px; color: var(--gray-500); flex-shrink: 0; }

.search-input {
  flex: 1;
  border: none;
  outline: none;
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  color: var(--black);
  background: transparent;
  caret-color: var(--red);
}

.search-input::placeholder { color: var(--gray-300); }

.search-input-wrap button {
  background: var(--red);
  border: none;
  color: white;
  padding: 8px 16px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.35s ease;
}

.search-input-wrap button:hover { background: var(--red-dark); }

.search-hints { margin-top: 16px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.search-hints span { font-size: 12px; color: var(--gray-500); }

.search-hint-tag {
  font-size: 12px;
  color: var(--gray-700);
  background: var(--gray-100);
  padding: 4px 10px;
  cursor: pointer;
  transition: background 0.35s ease;
}

.search-hint-tag:hover { background: var(--gray-300); }

.search-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  font-size: 24px;
  line-height: 1;
  transition: color 0.35s ease;
}

.search-close:hover { color: white; }


/* ═══════════════════════════════════════════════════════════
   7. NAV
   ═══════════════════════════════════════════════════════════ */

nav { border-top: var(--border); overflow-x: auto; scrollbar-width: none; }
nav::-webkit-scrollbar { display: none; }

.nav-inner-wrap { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--gutter-desktop); }

.nav-inner { display: flex; gap: 0; min-width: max-content; }

.nav-link {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--gray-700);
  padding: 12px 18px;
  position: relative;
  transition: color 0.35s ease;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 18px; right: 18px;
  height: 2px;
  background: var(--red);
  transform: scaleX(0);
  transition: transform 0.3s ease;
}

.nav-link:hover { color: var(--red); }
.nav-link:hover::after { transform: scaleX(1); }
.nav-link.active { color: var(--red); }
.nav-link.active::after { transform: scaleX(1); }


/* ═══════════════════════════════════════════════════════════
   8. HAMBURGER & MOBILE MENU
   ═══════════════════════════════════════════════════════════ */

.hamburger-btn {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  flex-shrink: 0;
  z-index: var(--z-sharebar);
}

.hamburger-line {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--gray-900);
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.hamburger-btn.active .hamburger-line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger-btn.active .hamburger-line:nth-child(2) { opacity: 0; }
.hamburger-btn.active .hamburger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-dark-40);
  z-index: var(--z-mobile-overlay);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.mobile-menu-overlay.open { opacity: 1; pointer-events: all; }

.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 280px;
  max-width: 85vw;
  height: 100vh; height: 100dvh;
  background: var(--white);
  z-index: var(--z-mobile-menu);
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -4px 0 24px rgba(0,0,0,0.12);
}

.mobile-menu.open { transform: translateX(0); }

.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: var(--border);
}

.mobile-menu-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gray-500);
}

.mobile-menu-close {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--gray-500);
  cursor: pointer;
  padding: 4px;
  line-height: 1;
  transition: color 0.35s ease;
}

.mobile-menu-close:hover { color: var(--black); }

.mobile-menu-links { flex: 1; overflow-y: auto; padding: 8px 0; }

.mobile-menu-link {
  display: block;
  padding: 14px 24px;
  font-size: 15px;
  font-weight: 600;
  color: var(--gray-700);
  border-left: 3px solid transparent;
  transition: background 0.35s ease, color 0.35s ease, border-color 0.35s ease;
}

.mobile-menu-link:hover,
.mobile-menu-link.active {
  background: var(--gray-100);
  color: var(--red);
  border-left-color: var(--red);
}

.mobile-menu-footer { padding: 20px 24px; border-top: var(--border); }

.mobile-menu-support {
  display: block;
  text-align: center;
  background: var(--red);
  color: white;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 20px;
  transition: background 0.3s ease;
}

.mobile-menu-support:hover { background: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   9. TICKER
   ═══════════════════════════════════════════════════════════ */

.ticker-bar { background: var(--red); color: white; overflow: hidden; margin-bottom: 56px; }

.ticker-inner { max-width: var(--container-max); margin: 0 auto; display: flex; align-items: center; padding: 0 var(--gutter-desktop); }

.ticker-label {
  background: var(--red-dark);
  padding: 10px 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}

.ticker-track { flex: 1; overflow: hidden; position: relative; height: 38px; }

.ticker-content {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 40px;
  animation: ticker 35s linear infinite;
  white-space: nowrap;
  padding: 0 20px;
}

.ticker-content:hover { animation-play-state: paused; }

@keyframes ticker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.ticker-item {
  font-size: 13px;
  font-weight: 400;
  color: rgba(255,255,255,0.92);
  white-space: nowrap;
  cursor: pointer;
  flex-shrink: 0;
}

.ticker-item:hover { color: white; text-decoration: underline; }

.ticker-sep { color: rgba(255,255,255,0.7); font-size: 18px; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════════
   10. MAIN LAYOUT
   ═══════════════════════════════════════════════════════════ */

main { max-width: var(--container-max); margin: 0 auto; padding: 8px 40px 80px; }

.full-bleed-wrapper { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--gutter-desktop); }

.section-divider { border: none; border-top: var(--border); margin: 0 0 56px; }


/* ═══════════════════════════════════════════════════════════
   11. HERO GRID (accueil)
   ═══════════════════════════════════════════════════════════ */

.hero-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  grid-template-rows: auto;
  gap: 0;
  border: var(--border);
  margin-bottom: 56px;
}

.hero-main {
  border-right: var(--border);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  overflow: hidden;
}

.hero-main::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--red);
}

.hero-main-img {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--gray-100);
  overflow: hidden;
  position: relative;
}

.hero-main-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.hero-main-img:hover img { transform: scale(1.02); }

.hero-cat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.hero-cat span { display: block; width: 18px; height: 2px; background: var(--red); }

.hero-title {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--black);
  letter-spacing: -0.4px;
}

.hero-title a:hover { color: var(--red); }

.hero-excerpt {
  font-family: var(--body-serif);
  font-size: 16px;
  line-height: 1.65;
  color: var(--gray-700);
  font-weight: 300;
}

.hero-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--gray-500);
  margin-top: auto;
  padding-top: 16px;
  border-top: var(--border);
}

.hero-author { font-weight: 600; color: var(--gray-700); }

.hero-sidebar { display: flex; flex-direction: column; }

.sidebar-article {
  padding: 22px;
  border-bottom: var(--border);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: background 0.2s ease;
}

.sidebar-article:hover { background: var(--gray-hover); }
.sidebar-article:last-child { border-bottom: none; }
.sidebar-article .hero-cat { font-size: 12px; }

.sidebar-title {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
}

.sidebar-title a:hover { color: var(--red); }
.sidebar-meta { font-size: 12px; color: var(--gray-500); }


/* ═══════════════════════════════════════════════════════════
   12. SECTION HEADERS
   ═══════════════════════════════════════════════════════════ */

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--black);
}

.section-title {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: -0.3px;
}

.section-more {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--red);
  display: flex;
  align-items: center;
  gap: 4px;
}

.section-more:hover { text-decoration: underline; }


/* ═══════════════════════════════════════════════════════════
   13. ARTICLE CARDS
   ═══════════════════════════════════════════════════════════ */

.content-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 32px;
  margin-bottom: 56px;
}

.article-card { display: flex; flex-direction: column; gap: 12px; }

.article-img { aspect-ratio: 16/9; background: var(--gray-100); overflow: hidden; }

.article-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.article-card:hover .article-img img { transform: scale(1.03); }

.article-img a, .hero-main-img a, .eclairage-img a, .list-img a { display: block; width: 100%; height: 100%; }

/* À la une : forcer le 16:9 sur tous les conteneurs/wrappers d’image,
   y compris avec lazy-load, liens et picture intermédiaires. */
.content-row .article-img,
.content-row .article-img > a,
.content-row .article-img .lo-lazy-media,
.content-row .article-img picture {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden;
}

.content-row .article-img > a,
.content-row .article-img .lo-lazy-media,
.content-row .article-img picture {
  height: 100% !important;
}

.content-row .article-img img,
.content-row .article-img .lo-lazy-media img,
.content-row .article-img picture img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
}
.eclairage-img a img { width: 100%; height: 100%; object-fit: cover; display: block; }

.article-cat {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.article-title {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
}

.article-title a:hover { color: var(--red); }
.article-title.large { font-size: 22px; }

.article-excerpt {
  font-family: var(--body-serif);
  font-size: 14px;
  line-height: 1.6;
  color: var(--gray-500);
  font-weight: 300;
}

.article-meta {
  font-size: 12px;
  color: var(--gray-500);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
}

.article-meta .author { font-weight: 600; color: var(--gray-700); }


/* ═══════════════════════════════════════════════════════════
   14. BREVES
   ═══════════════════════════════════════════════════════════ */

.breves-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: var(--border);
  margin-bottom: 56px;
}

.breve-item {
  padding: 22px 24px;
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: background 0.2s ease;
}

.breve-item:last-child { border-right: none; }
.breve-item:hover { background: var(--gray-hover); }

.breve-cat {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.breve-title {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--black);
}

.breve-title a:hover { color: var(--red); }

.breve-excerpt { font-size: 13px; line-height: 1.55; color: var(--gray-500); }


/* ═══════════════════════════════════════════════════════════
   15. ECLAIRAGE (full-width)
   ═══════════════════════════════════════════════════════════ */

.eclairage-section { margin-bottom: 56px; }

.eclairage-inner { border: var(--border); display: grid; grid-template-columns: 1fr 1fr; }

.eclairage-content {
  padding: 36px 40px;
  border-right: var(--border);
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
}

.eclairage-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.eclairage-label::before { content: ''; display: block; width: 24px; height: 2px; background: var(--red); }

.eclairage-title {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--black);
  letter-spacing: -0.4px;
}

.eclairage-title a:hover { color: var(--red); }

.eclairage-author { font-size: 13px; font-weight: 600; color: var(--gray-700); }

.eclairage-excerpt {
  font-family: var(--body-serif);
  font-size: 15px;
  line-height: 1.65;
  color: var(--gray-500);
  font-weight: 300;
}

.eclairage-img { background: var(--gray-100); overflow: hidden; min-height: 280px; }
.eclairage-img img { width: 100%; height: 100%; object-fit: cover; }


/* ═══════════════════════════════════════════════════════════
   16. LIST SECTION
   ═══════════════════════════════════════════════════════════ */

.list-section { margin-bottom: 56px; }

.article-list { display: flex; flex-direction: column; gap: 0; border: var(--border); }

.list-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 0;
  border-bottom: var(--border);
  transition: background 0.2s ease;
}

.list-item:last-child { border-bottom: none; }
.list-item:hover { background: var(--gray-hover); }

.list-img {
  height: 80px;
  background: var(--gray-100);
  overflow: hidden;
  border-right: var(--border);
  flex-shrink: 0;
}

.list-img img { width: 100%; height: 100%; object-fit: cover; }

.list-content {
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: center;
}

.list-cat { font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); }

.list-title {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
}

.list-title a:hover { color: var(--red); }
.list-meta { font-size: 12px; color: var(--gray-500); }


/* ═══════════════════════════════════════════════════════════
   17. NEWSLETTER
   ═══════════════════════════════════════════════════════════ */

.newsletter-band {
  margin-top: 56px;
  margin-bottom: 56px;
  background: var(--black);
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
}

.newsletter-deco {
  background: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 40px;
  position: relative;
  overflow: hidden;
}

.newsletter-deco::before {
  content: '✉';
  position: absolute;
  font-size: 180px;
  opacity: 0.07;
  right: -20px;
  bottom: -20px;
  line-height: 1;
}

.newsletter-deco-inner { position: relative; z-index: 1; }

.newsletter-deco-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  margin-bottom: 12px;
}

.newsletter-deco-title {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 700;
  color: white;
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 12px;
}

.newsletter-deco-sub { font-size: 13px; color: rgba(255,255,255,0.8); line-height: 1.6; }

.newsletter-form-side {
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
}

.newsletter-field-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-bottom: 6px;
  display: block;
}

.newsletter-input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: #414141;
  font-family: var(--sans);
  font-size: 14px;
  padding: 12px 16px;
  outline: none;
  transition: border-color 0.3s ease, background 0.3s ease;
}

.newsletter-input::placeholder { color: rgba(255,255,255,0.25); }
.newsletter-input:focus { border-color: var(--red); background: rgba(255,255,255,0.09); }

.newsletter-input:-webkit-autofill,
.newsletter-input:-webkit-autofill:hover,
.newsletter-input:-webkit-autofill:focus {
  -webkit-text-fill-color: #ffffff !important;
  -webkit-box-shadow: 1px 1px 1px 1000px #2a2a2a inset !important;
  box-shadow: 1px 1px 1px 1000px #2a2a2a inset !important;
  caret-color: #ffffff;
}

.newsletter-optin { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; }

.newsletter-optin input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 1px solid rgba(255,255,255,0.25);
  background: transparent;
  cursor: pointer;
  margin-top: 1px;
  position: relative;
  transition: border-color 0.3s ease, background 0.3s ease;
}

.newsletter-optin input[type="checkbox"]:checked { background: var(--red); border-color: var(--red); }

.newsletter-optin input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: 2px solid white;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

.newsletter-optin-text { font-size: 12px; line-height: 1.6; color: rgba(255,255,255,0.7); }
.newsletter-optin-text a { color: rgba(255,255,255,0.75); text-decoration: underline; }

.newsletter-submit {
  background: var(--red);
  border: none;
  color: white;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  padding: 14px 28px;
  cursor: pointer;
  transition: background 0.3s ease, transform 0.35s ease;
  align-self: flex-start;
  width: 100%;
}

.newsletter-submit:hover { background: var(--red-dark); }
.newsletter-submit:disabled { opacity: 0.5; cursor: not-allowed; }

.newsletter-success { display: none; text-align: center; padding: 16px 0; }
.newsletter-success-icon { font-size: 32px; margin-bottom: 10px; }
.newsletter-success p { font-size: 14px; color: rgba(255,255,255,0.7); line-height: 1.6; }
.newsletter-success strong { color: white; }


/* ═══════════════════════════════════════════════════════════
   18. BOUTIQUE / SHOP
   ═══════════════════════════════════════════════════════════ */

.boutique-section { margin-bottom: 56px; }

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

.book-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.book-cover {
  aspect-ratio: 2/3;
  background: var(--gray-100);
  position: relative;
  overflow: hidden;
  border: var(--border);
}

.book-cover-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
}

.book-cover-spine { position: absolute; left: 0; top: 0; bottom: 0; width: 6px; background: var(--red); }
.book-cover-icon { font-size: 36px; opacity: 0.15; }

.book-cover-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gray-300);
  text-align: center;
}

.book-card:hover .book-cover { border-color: var(--gray-700); }

.book-card:hover .book-cover::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.04);
}

.book-badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
  background: var(--red-light);
  padding: 3px 8px;
  align-self: flex-start;
}

.book-title {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
}

.book-title a { transition: color 0.2s ease; }
.book-title a:hover { color: var(--red); }

.book-subtitle {
  font-family: var(--body-serif);
  font-size: 14px;
  font-style: italic;
  line-height: 1.45;
  color: var(--gray-700);
  margin: -4px 0 0;
}

.book-author { font-size: 12px; color: var(--gray-500); font-weight: 500; }
.book-price { font-size: 15px; font-weight: 700; color: var(--black); margin-top: auto; }

.book-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--black);
  color: white;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 10px 16px;
  border: none;
  cursor: pointer;
  transition: background 0.3s ease;
  width: 100%;
}

.book-btn:hover { background: var(--red); }

.boutique-cta { text-align: center; margin-top: 32px; }

.boutique-cta a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
  border-bottom: 2px solid var(--gray-300);
  padding-bottom: 2px;
  transition: color 0.35s ease, border-color 0.35s ease;
}

.boutique-cta a:hover { color: var(--red); border-color: var(--red); }

/* Shop page specific */
.shop-page { max-width: var(--container-max); margin: 0 auto; padding: 32px 40px 80px; }
.shop-header { margin-bottom: 32px; }
.shop-title { font-family: var(--serif); font-size: 36px; font-weight: 700; color: var(--black); letter-spacing: -0.5px; margin-bottom: 8px; }
.shop-desc { font-family: var(--body-serif); font-size: 16px; line-height: 1.7; color: var(--gray-500); font-weight: 300; }
.shop-separator { width: 48px; height: 3px; background: var(--red); margin-top: 16px; }

.shop-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: var(--border);
  flex-wrap: wrap;
}

.shop-result-count { font-size: 13px; color: var(--gray-500); white-space: nowrap; }
.shop-filter-group { display: flex; align-items: center; gap: 8px; }

.shop-pagination { display: flex; align-items: center; justify-content: center; gap: 4px; margin-top: 56px; }


/* ═══════════════════════════════════════════════════════════
   19. BREADCRUMB
   ═══════════════════════════════════════════════════════════ */

.breadcrumb-bar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }

.breadcrumb {
  font-size: 12px;
  color: var(--gray-500);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.breadcrumb a { color: var(--gray-500); transition: color 0.25s ease; }
.breadcrumb a:hover { color: var(--red); }
.breadcrumb .sep { color: var(--gray-300); }

.cart-icon-link { position: relative; color: var(--gray-500); transition: color 0.25s ease; }
.cart-icon-link:hover { color: var(--red); }
.cart-icon-link svg { width: 22px; height: 22px; }

.cart-badge {
  position: absolute;
  top: -6px;
  right: -8px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}


/* ═══════════════════════════════════════════════════════════
   20. CATEGORY PAGE
   ═══════════════════════════════════════════════════════════ */

.category-header { max-width: var(--container-max); margin: 0 auto; padding: 48px 40px 0; }

.category-title {
  font-family: var(--serif);
  font-size: 42px;
  font-weight: 900;
  color: var(--black);
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 12px;
}

.category-desc {
  font-family: var(--body-serif);
  font-size: 17px;
  line-height: 1.65;
  color: var(--gray-500);
  font-weight: 300;
  max-width: 720px;
  margin-bottom: 28px;
}

.category-separator { width: 48px; height: 3px; background: var(--red); margin-bottom: 40px; }

.category-content { max-width: var(--container-max); margin: 0 auto; padding: 0 40px 80px; }

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

.category-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: var(--border);
  transition: box-shadow 0.35s ease;
}

.category-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.08); }

.category-card-img { aspect-ratio: 16/9; background: var(--gray-100); overflow: hidden; }
.category-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.category-card:hover .category-card-img img { transform: scale(1.04); }

.category-card-body { padding: 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }

.category-card-cat {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.category-card-title {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--black);
  letter-spacing: -0.2px;
}

.category-card-title a:hover { color: var(--red); }

.category-card-excerpt {
  font-family: var(--body-serif);
  font-size: 14px;
  line-height: 1.6;
  color: var(--gray-500);
  font-weight: 300;
  flex: 1;
}

.category-card-excerpt mark {
  background: var(--red-light);
  color: var(--red-dark);
  padding: 0 2px;
  font-style: normal;
}

.category-card-meta {
  font-size: 12px;
  color: var(--gray-500);
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.category-card-meta .author { font-weight: 600; color: var(--gray-700); }


/* ═══════════════════════════════════════════════════════════
   21. PAGINATION
   ═══════════════════════════════════════════════════════════ */

.category-pagination,
.author-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 56px;
}

.author-pagination { margin-top: 40px; }

.page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-700);
  border: var(--border);
  background: var(--white);
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.page-link:hover { background: var(--gray-100); border-color: var(--gray-700); }
.page-link.active { background: var(--red); color: white; border-color: var(--red); }
.page-link.disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }
.page-link svg { width: 16px; height: 16px; }


/* ═══════════════════════════════════════════════════════════
   22. SEARCH RESULTS
   ═══════════════════════════════════════════════════════════ */

.search-header { max-width: var(--container-max); margin: 0 auto; padding: 48px 40px 0; }

.search-query-title {
  font-family: var(--serif);
  font-size: 42px;
  font-weight: 900;
  color: var(--black);
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 12px;
}

.search-query-title em { font-style: normal; color: var(--red); }

.search-result-count {
  font-family: var(--body-serif);
  font-size: 17px;
  line-height: 1.65;
  color: var(--gray-500);
  font-weight: 300;
  margin-bottom: 28px;
}

.search-separator { width: 48px; height: 3px; background: var(--red); margin-bottom: 40px; }


/* ═══════════════════════════════════════════════════════════
   23. ARTICLE PAGE (single)
   ═══════════════════════════════════════════════════════════ */

.article-page {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 32px 40px 80px;
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
}

/* Article header */
.single-cat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 12px;
}

.single-cat span { display: block; width: 18px; height: 2px; background: var(--red); }

.single-title {
  font-family: var(--serif);
  font-size: 34px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--black);
  letter-spacing: -0.5px;
  margin-bottom: 16px;
}

.single-chapo {
  font-family: var(--body-serif);
  font-size: 18px;
  font-style: italic;
  line-height: 1.65;
  color: var(--gray-700);
  font-weight: 400;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: var(--border);
}

.single-meta { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; flex-wrap: wrap; }

.single-author-avatar {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  background: var(--gray-100);
  overflow: hidden;
  flex-shrink: 0;
}

.single-author-avatar img { width: 100%; height: 100%; object-fit: cover; }
.single-meta-text { display: flex; flex-direction: column; gap: 2px; }
.single-author-name { font-weight: 600; font-size: 14px; color: var(--gray-900); }
.single-author-name a:hover { color: var(--red); }
.single-date { font-size: 12px; color: var(--gray-500); }
.single-reading-time { font-size: 12px; color: var(--gray-500); margin-left: auto; display: flex; align-items: center; gap: 4px; }

/* Share bar */
.share-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  padding: 14px 0;
  border-bottom: var(--border);
  position: sticky;
  background: var(--white);
  z-index: var(--z-sharebar);
}

.share-bar-label { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-500); margin-right: 4px; }

.share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid #E2DDD8;
  background: transparent;
  cursor: pointer;
  transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease;
  color: var(--gray-500);
}

.share-btn:hover { background: var(--gray-100); border-color: var(--gray-700); color: var(--gray-900); }
.share-btn svg { width: 16px; height: 16px; }

/* Featured image */
.single-featured { margin-bottom: 28px; }
.single-featured-img { width: 100%; aspect-ratio: 16/9; background: var(--gray-100); overflow: hidden; }
.single-featured-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.single-featured-img:hover img { transform: scale(1.02); }
.single-caption { font-size: 12px; color: var(--gray-500); margin-top: 8px; line-height: 1.5; }
.single-caption .credit { font-style: italic; }

/* Article body */
.single-body { font-family: var(--body-serif); font-size: 18px; line-height: 1.8; color: var(--gray-900); font-weight: 450; margin-bottom: 40px; -webkit-font-smoothing: auto; -moz-osx-font-smoothing: auto; }
.single-body p { margin-bottom: 1.4em; letter-spacing: 0.005em; }
.single-body h2 { font-family: var(--serif); font-size: 24px; font-weight: 700; color: var(--black); margin: 2em 0 0.8em; line-height: 1.3; }
.single-body h3 { font-family: var(--serif); font-size: 20px; font-weight: 700; color: var(--black); margin: 1.6em 0 0.6em; line-height: 1.35; }
.single-body blockquote { border-left: 3px solid var(--red); padding: 16px 24px; margin: 1.6em 0; background: var(--gray-100); font-style: italic; color: var(--gray-700); }
.single-body ul, .single-body ol { margin: 1em 0 1.4em 1.4em; }
.single-body li { margin-bottom: 0.5em; }
.single-body a { color: var(--red); border-bottom: 1px solid transparent; transition: border-color 0.25s ease, color 0.25s ease; }
.single-body a:hover { border-bottom-color: var(--red); }
.single-body figure { margin: 1.4em 0; line-height: 0; }
.single-body figure img { display: block; width: 100%; height: auto; }
.single-body figure > a, .single-body figure > a img { display: block; }
.single-body img { display: block; vertical-align: bottom; }
.single-body .lo-lazy-media { line-height: 0; font-size: 0; display: block; }
.single-body p > .lo-lazy-media, .single-body p > img { margin-bottom: 0; }
.single-body figcaption { font-family: var(--sans); font-size: 12px; line-height: 1.5; color: var(--gray-500); margin-top: 6px; }
.single-body strong { font-weight: 600; color: var(--black); }

/* Tags */
.single-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; padding-bottom: 32px; border-bottom: var(--border); }

.single-tag {
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-700);
  background: var(--gray-100);
  padding: 5px 12px;
  transition: background 0.25s ease, color 0.25s ease;
}

.single-tag:hover { background: var(--red-light); color: var(--red); }

/* Author box */
.author-box { display: flex; gap: 20px; padding: 28px; border: var(--border); margin-bottom: 40px; }
.author-box-avatar { width: 72px; height: 72px; border-radius: var(--radius-full); background: var(--gray-100); overflow: hidden; flex-shrink: 0; }
.author-box-avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-box-info { display: flex; flex-direction: column; gap: 6px; }
.author-box-name { font-family: var(--serif); font-size: 18px; font-weight: 700; color: var(--black); }
.author-box-bio { font-size: 14px; line-height: 1.6; color: var(--gray-500); }
.author-box-link { font-size: 12px; font-weight: 600; color: var(--red); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 4px; transition: color 0.25s ease; }
.author-box-link:hover { color: var(--red-dark); }

/* CTA Newsletter (inline) */
.single-newsletter { background: var(--black); padding: 36px; margin-bottom: 48px; }
.single-newsletter-title { font-family: var(--serif); font-size: 22px; font-weight: 700; color: white; margin-bottom: 8px; }
.single-newsletter-desc { font-size: 14px; color: rgba(255,255,255,0.7); margin-bottom: 20px; line-height: 1.6; }
.single-newsletter-form { display: flex; gap: 10px; }
.single-newsletter-input { flex: 1; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); color: #414141; font-family: var(--sans); font-size: 14px; padding: 12px 16px; outline: none; transition: border-color 0.3s ease; }
.single-newsletter-input::placeholder { color: rgba(255,255,255,0.25); }
.single-newsletter-input:focus { border-color: var(--red); }
.single-newsletter-input:-webkit-autofill,
.single-newsletter-input:-webkit-autofill:hover,
.single-newsletter-input:-webkit-autofill:focus {
  -webkit-text-fill-color: #ffffff !important;
  -webkit-box-shadow: 1px 1px 1px 1000px #2a2a2a inset !important;
  box-shadow: 1px 1px 1px 1000px #2a2a2a inset !important;
  caret-color: #ffffff;
}
.single-newsletter-btn { background: var(--red); border: none; color: white; font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 12px 24px; cursor: pointer; transition: background 0.3s ease; white-space: nowrap; }
.single-newsletter-btn:hover { background: var(--red-dark); }
.single-newsletter-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.single-newsletter-btn:disabled:hover { background: var(--red); }

#single-nl-optin:checked { background: var(--red); border-color: var(--red); }
#single-nl-optin:checked::after { content: ''; position: absolute; left: 4px; top: 1px; width: 5px; height: 9px; border: 2px solid white; border-top: none; border-left: none; transform: rotate(45deg); }

/* Related articles */
.related-section { margin-bottom: 48px; }
.related-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--black); }
.related-title { font-family: var(--serif); font-size: 20px; font-weight: 700; color: var(--black); }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.related-card { display: flex; flex-direction: column; gap: 10px; }
.related-card-img { aspect-ratio: 16/9; background: var(--gray-100); overflow: hidden; }
.related-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.35s ease, opacity 0.28s ease; }
.related-card:hover .related-card-img img { transform: scale(1.03); }
.related-card-cat { font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); }
.related-card-title { font-family: var(--serif); font-size: 15px; font-weight: 700; line-height: 1.35; color: var(--black); }
.related-card-title a:hover { color: var(--red); }
.related-card-meta { font-size: 12px; color: var(--gray-500); margin-top: auto; }

/* Comments */
.comments-section { margin-bottom: 48px; }
.comments-header { font-family: var(--serif); font-size: 20px; font-weight: 700; color: var(--black); margin-bottom: 24px; padding-bottom: 10px; border-bottom: 2px solid var(--black); }
.comment-form { margin-bottom: 32px; }
.comment-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.comment-input { width: 100%; border: var(--border); background: var(--white); font-family: var(--sans); font-size: 14px; padding: 12px 16px; outline: none; transition: border-color 0.25s ease; color: var(--gray-900); }
.comment-input:focus { border-color: var(--gray-700); }
.comment-input::placeholder { color: var(--gray-300); }
.comment-textarea { width: 100%; border: var(--border); background: var(--white); font-family: var(--sans); font-size: 14px; padding: 12px 16px; outline: none; resize: vertical; min-height: 120px; margin-bottom: 12px; transition: border-color 0.25s ease; color: var(--gray-900); }
.comment-textarea:focus { border-color: var(--gray-700); }
.comment-textarea::placeholder { color: var(--gray-300); }
.comment-submit { background: var(--black); color: white; border: none; font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 12px 28px; cursor: pointer; transition: background 0.3s ease; }
.comment-submit:hover { background: var(--red); }
.comment-list { display: flex; flex-direction: column; gap: 0; }
.comment-item { padding: 20px 0; border-bottom: var(--border); }
.comment-item:first-child { border-top: var(--border); }
.comment-author-row { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.comment-avatar { width: 36px; height: 36px; border-radius: var(--radius-full); background: var(--gray-100); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: var(--gray-500); }
.comment-author-name { font-size: 14px; font-weight: 600; color: var(--gray-900); }
.comment-date { font-size: 12px; color: var(--gray-500); margin-left: auto; }
.comment-text { font-size: 14px; line-height: 1.65; color: var(--gray-700); }

/* Sidebar */
.article-sidebar { display: flex; flex-direction: column; gap: 32px; }
.sidebar-widget { border: var(--border); }
.sidebar-widget-title { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-900); padding: 16px 20px; border-bottom: var(--border); background: var(--gray-100); }

/* Sidebar — boutique widget */
.sidebar-shop-item { padding: 16px 20px; border-bottom: var(--border); display: flex; gap: 14px; transition: background 0.25s ease; }
.sidebar-shop-item:last-child { border-bottom: none; }
.sidebar-shop-item:hover { background: var(--gray-100); }
.sidebar-shop-cover { width: 56px; height: 80px; background: var(--gray-100); border: var(--border); flex-shrink: 0; position: relative; overflow: hidden; }
.sidebar-shop-cover .spine { position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--red); }
.sidebar-shop-info { display: flex; flex-direction: column; gap: 4px; }
.sidebar-shop-title { font-family: var(--serif); font-size: 14px; font-weight: 700; color: var(--black); line-height: 1.3; }
.sidebar-shop-subtitle { font-size: 12px; line-height: 1.35; color: var(--gray-500); }
.sidebar-shop-author { font-size: 12px; color: var(--gray-500); }
.sidebar-shop-price { font-size: 14px; font-weight: 700; color: var(--black); margin-top: auto; }
.sidebar-shop-cta { display: block; text-align: center; padding: 12px 20px; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--red); border-top: var(--border); transition: background 0.25s ease, color 0.25s ease; }
.sidebar-shop-cta:hover { background: var(--red); color: white; }

/* Sidebar — recent articles */
.sidebar-recent-item { padding: 14px 20px; border-bottom: var(--border); transition: background 0.25s ease; }
.sidebar-recent-item:last-child { border-bottom: none; }
.sidebar-recent-item:hover { background: var(--gray-100); }
.sidebar-recent-title { font-family: var(--serif); font-size: 14px; font-weight: 700; line-height: 1.35; color: var(--black); margin-bottom: 4px; }
.sidebar-recent-title a:hover { color: var(--red); }
.sidebar-recent-date { font-size: 12px; color: var(--gray-500); }

/* Sidebar — categories */
.sidebar-cat-item { display: flex; align-items: center; justify-content: space-between; padding: 12px 20px; border-bottom: var(--border); transition: background 0.25s ease, color 0.25s ease; }
.sidebar-cat-item:last-child { border-bottom: none; }
.sidebar-cat-item:hover { background: var(--gray-100); color: var(--red); }
.sidebar-cat-name { font-size: 14px; font-weight: 500; }
.sidebar-cat-count { font-size: 12px; color: var(--gray-300); }

/* Sidebar — support widget */
.sidebar-support { padding: 24px 20px; text-align: center; background: var(--gray-900); color: white; }
.sidebar-support-title { font-family: var(--serif); font-size: 18px; font-weight: 700; margin-bottom: 8px; }
.sidebar-support-desc { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.6; margin-bottom: 16px; }
.sidebar-support-btn { display: inline-flex; align-items: center; background: var(--red); color: white; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 12px 24px; transition: background 0.3s ease; }
.sidebar-support-btn:hover { background: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   24. AUTHOR PAGE
   ═══════════════════════════════════════════════════════════ */

.author-layout {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 48px 40px 80px;
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 48px;
  align-items: start;
}

.author-sidebar { position: sticky; top: 140px; }

.author-avatar-circle {
  width: 120px;
  height: 120px;
  border-radius: var(--radius-full);
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 42px;
  font-weight: 700;
  color: var(--gray-500);
  margin-bottom: 24px;
  flex-shrink: 0;
}

.author-name {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 900;
  color: var(--black);
  line-height: 1.2;
  letter-spacing: -0.3px;
  margin-bottom: 4px;
}

.author-role {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
}

.author-separator { width: 36px; height: 3px; background: var(--red); margin-bottom: 16px; }

.author-bio {
  font-family: var(--body-serif);
  font-size: 15px;
  line-height: 1.7;
  color: var(--gray-500);
  font-weight: 300;
  margin-bottom: 1.5rem;
}

.author-bio p {
  margin: 0;
}

.author-meta-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.author-meta-item { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--gray-500); }
.author-meta-item svg { width: 16px; height: 16px; color: var(--gray-500); flex-shrink: 0; }
.author-meta-item a { color: var(--red); font-weight: 600; }
.author-meta-item a:hover { color: var(--red-dark); }

.author-social { display: flex; gap: 8px; }
.author-social a { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: var(--border); color: var(--gray-500); transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease; }
.author-social a:hover { background: var(--red); color: white; border-color: var(--red); }
.author-social a svg { width: 16px; height: 16px; }

.author-articles-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; padding-bottom: 16px; border-bottom: var(--border); }
.author-articles-title { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--black); }
.author-articles-count { font-size: 13px; color: var(--gray-500); font-weight: 500; }

.author-article-list { display: flex; flex-direction: column; gap: 0; }

.author-article {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  padding: 24px 0;
  border-bottom: var(--border);
  align-items: start;
  transition: background 0.3s ease;
}

.author-article:first-child { padding-top: 0; }
.author-article:hover { background: rgba(242,240,237,0.4); }

.author-article-img { display: block; aspect-ratio: 16/9; background: var(--gray-100); overflow: hidden; }
.author-article-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.author-article:hover .author-article-img img { transform: scale(1.04); }

.author-article-body { display: flex; flex-direction: column; gap: 6px; }
.author-article-cat { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); }

.author-article-title {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--black);
  letter-spacing: -0.2px;
}

.author-article-title a:hover { color: var(--red); }

.author-article-excerpt {
  font-family: var(--body-serif);
  font-size: 14px;
  line-height: 1.6;
  color: var(--gray-500);
  font-weight: 300;
}

.author-article-date { font-size: 12px; color: var(--gray-500); margin-top: 2px; }


/* ═══════════════════════════════════════════════════════════
   25. PRODUCT PAGE
   ═══════════════════════════════════════════════════════════ */

.product-page { max-width: var(--container-max); margin: 0 auto; padding: 32px 40px 80px; }
.product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }

/* Gallery */
.product-gallery { display: flex; flex-direction: column; gap: 12px; }
.product-main-img { width: 100%; background: var(--white); border: var(--border); overflow: hidden; cursor: zoom-in; position: relative; }
.product-main-img img { width: 100%; height: auto; display: block; transition: transform 0.4s ease; }
.product-main-img:hover img { transform: scale(1.05); }

.product-thumbnails { display: flex; gap: 10px; }
.product-thumb { width: 80px; height: 106px; background: var(--gray-100); border: 2px solid transparent; overflow: hidden; cursor: pointer; transition: border-color 0.25s ease; flex-shrink: 0; }
.product-thumb.active { border-color: var(--red); }
.product-thumb:hover { border-color: var(--gray-500); }
.product-thumb.active:hover { border-color: var(--red); }
.product-thumb img { width: 100%; height: 100%; object-fit: contain; }

/* Product info */
.product-info { display: flex; flex-direction: column; gap: 0; }
.product-cat { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--red); margin-bottom: 12px; }
.product-cat span { display: block; width: 18px; height: 2px; background: var(--red); }
.product-title { font-family: var(--serif); font-size: 32px; font-weight: 700; line-height: 1.2; color: var(--black); letter-spacing: -0.5px; margin-bottom: 8px; }
.product-subtitle { font-family: var(--body-serif); font-size: 17px; font-style: italic; line-height: 1.5; color: var(--gray-700); font-weight: 300; margin-bottom: 12px; }
.product-author { font-family: var(--body-serif); font-size: 16px; color: var(--gray-500); margin-bottom: 20px; }
.product-author a { color: var(--gray-700); font-weight: 600; }
.product-author a:hover { color: var(--red); }

.product-price { font-family: var(--serif); font-size: 28px; font-weight: 700; color: var(--black); margin-bottom: 20px; display: flex; align-items: baseline; gap: 8px; }
.product-price .currency { font-size: 16px; font-weight: 600; color: var(--gray-500); }

.product-stock { font-size: 13px; color: var(--success); font-weight: 600; margin-bottom: 20px; display: flex; align-items: center; gap: 6px; }
.product-stock::before { content: ''; width: 8px; height: 8px; border-radius: var(--radius-full); background: var(--success); flex-shrink: 0; }

.product-short-desc { font-family: var(--body-serif); font-size: 16px; line-height: 1.7; color: var(--gray-700); font-weight: 300; margin-bottom: 24px; padding-bottom: 24px; border-bottom: var(--border); }

/* Add to cart */
.product-cart-row { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.qty-wrap { display: flex; align-items: center; border: var(--border); height: 48px; }
.qty-btn { width: 44px; height: 100%; background: var(--gray-100); border: none; font-size: 18px; font-weight: 600; color: var(--gray-700); cursor: pointer; transition: background 0.25s ease, color 0.25s ease; display: flex; align-items: center; justify-content: center; }
.qty-btn:hover { background: var(--gray-300); color: var(--black); }
.qty-input { width: 52px; height: 100%; border: none; border-left: var(--border); border-right: var(--border); text-align: center; font-family: var(--sans); font-size: 15px; font-weight: 600; color: var(--gray-900); outline: none; background: var(--white); -moz-appearance: textfield; }
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.btn-add-cart { flex: 1; height: 48px; background: var(--red); border: none; color: white; font-family: var(--sans); font-size: 13px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; transition: background 0.3s ease; display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-add-cart:hover { background: var(--red-dark); }
.btn-add-cart svg { width: 18px; height: 18px; }

.product-meta-links { display: flex; gap: 20px; margin-bottom: 28px; padding-bottom: 28px; border-bottom: var(--border); }
.product-meta-link { font-size: 12px; color: var(--gray-500); display: flex; align-items: center; gap: 5px; transition: color 0.25s ease; cursor: pointer; }
.product-meta-link:hover { color: var(--red); }
.product-meta-link svg { width: 14px; height: 14px; }

/* Technical details */
.product-details { margin-bottom: 0; }
.product-details-title { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-900); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.product-details-title::before { content: ''; width: 18px; height: 2px; background: var(--red); }
.product-details-table { width: 100%; }
.product-details-table tr { border-bottom: var(--border); }
.product-details-table tr:last-child { border-bottom: none; }
.product-details-table td { padding: 10px 0; font-size: 14px; vertical-align: top; }
.product-details-table td:first-child { color: var(--gray-500); width: 140px; font-weight: 500; }
.product-details-table td:last-child { color: var(--gray-900); font-weight: 400; }

/* Full description tabs */
.product-full-desc { max-width: var(--container-max); margin: 0 auto; padding: 0 40px 60px; }
.product-desc-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--black); margin-bottom: 28px; }
.product-desc-tab { padding: 12px 24px; font-size: 13px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gray-500); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color 0.25s ease, border-color 0.25s ease; background: none; border-top: none; border-left: none; border-right: none; font-family: var(--sans); }
.product-desc-tab.active { color: var(--black); border-bottom-color: var(--red); }
.product-desc-tab:hover { color: var(--black); }
.product-tab-content { display: none; }
.product-tab-content.active { display: block; }
.product-tab-content .desc-body { font-family: var(--body-serif); font-size: 17px; line-height: 1.8; color: var(--gray-700); font-weight: 300; max-width: 760px; }
.product-tab-content .desc-body p { margin-bottom: 1.2em; }
.product-tab-content .desc-body strong { font-weight: 600; color: var(--black); }

/* Related products */
.related-products { max-width: var(--container-max); margin: 0 auto; padding: 0 40px 60px; }
.related-products-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; padding-bottom: 10px; border-bottom: 2px solid var(--black); }
.related-products-title { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--black); }

/* Cart feedback */
.cart-feedback { display: none; align-items: center; gap: 8px; padding: 12px 16px; background: var(--success-bg); border: 1px solid var(--success-border); margin-bottom: 20px; font-size: 14px; color: var(--success); font-weight: 500; }
.cart-feedback.show { display: flex; }
.cart-feedback svg { width: 18px; height: 18px; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════════════
   26. LIGHTBOX
   ═══════════════════════════════════════════════════════════ */

.lightbox-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-dark-85);
  z-index: var(--z-lightbox);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(4px);
}

.lightbox-overlay.open { opacity: 1; pointer-events: all; }

.lightbox-img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  transform: scale(0.92);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.lightbox-overlay.open .lightbox-img { transform: scale(1); }

.lightbox-close {
  position: absolute;
  top: 24px;
  right: 28px;
  background: none;
  border: none;
  color: rgba(255,255,255,0.7);
  font-size: 28px;
  cursor: pointer;
  transition: color 0.25s ease;
  z-index: var(--z-lightbox-ui);
  line-height: 1;
}

.lightbox-close:hover { color: white; }

.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.1);
  border: none;
  color: rgba(255,255,255,0.8);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease;
  border-radius: var(--radius-full);
}

.lightbox-nav:hover { background: rgba(255,255,255,0.2); color: white; }
.lightbox-nav svg { width: 22px; height: 22px; stroke: currentColor; stroke-width: 2.5; fill: none; }
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }

.lightbox-counter {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  font-family: var(--sans);
  letter-spacing: 0.06em;
}


/* ═══════════════════════════════════════════════════════════
   27. LOGIN PAGE
   ═══════════════════════════════════════════════════════════ */

.login-page { max-width: var(--container-max); margin: 0 auto; padding: 32px 40px 80px; }

.login-card { max-width: 420px; margin: 40px auto 0; background: var(--white); border: var(--border); padding: 40px; }

.login-card-title { font-family: var(--serif); font-size: 26px; font-weight: 700; color: var(--black); text-align: center; margin-bottom: 8px; }

.login-card-subtitle { font-family: var(--body-serif); font-size: 14px; color: var(--gray-500); text-align: center; margin-bottom: 32px; font-weight: 300; }

.login-form { display: flex; flex-direction: column; gap: 20px; }

.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-700); }

.form-input {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--gray-900);
  background: var(--white);
  border: var(--border);
  outline: none;
  transition: border-color 0.3s ease;
}

.form-input:focus { border-color: var(--black); }
.form-input::placeholder { color: var(--gray-300); }

.form-checkbox-row { display: flex; align-items: center; gap: 8px; }
.form-checkbox-row input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--red); cursor: pointer; }
.form-checkbox-row label { font-size: 13px; color: var(--gray-700); cursor: pointer; }

.btn-login {
  width: 100%;
  height: 48px;
  background: var(--red);
  color: white;
  border: none;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.3s ease;
}

.btn-login:hover { background: var(--red-dark); }

.login-forgot { text-align: center; margin-top: 4px; }
.login-forgot a { font-size: 13px; color: var(--gray-500); transition: color 0.25s ease; }
.login-forgot a:hover { color: var(--red); }

.login-note {
  text-align: center;
  margin-top: 32px;
  padding-top: 24px;
  border-top: var(--border);
  font-size: 13px;
  color: var(--gray-500);
  line-height: 1.6;
  font-family: var(--body-serif);
  font-style: italic;
}


/* ═══════════════════════════════════════════════════════════
   28. ACCOUNT PAGE (logged-in)
   ═══════════════════════════════════════════════════════════ */

.account-page { max-width: var(--container-max); margin: 0 auto; padding: 32px 40px 80px; }
.account-layout { display: grid; grid-template-columns: 220px 1fr; gap: 48px; margin-top: 32px; }

.account-sidebar { display: flex; flex-direction: column; gap: 2px; }

.account-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 500;
  color: var(--gray-700);
  border-left: 3px solid transparent;
  transition: all 0.25s ease;
  cursor: pointer;
}

.account-nav-item:hover { background: var(--gray-100); color: var(--red); border-left-color: var(--red); }
.account-nav-item.active { background: var(--red-light); color: var(--red); border-left-color: var(--red); font-weight: 600; }
.account-nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }
.account-nav-item.logout { color: var(--gray-500); margin-top: 12px; border-top: var(--border); padding-top: 16px; }
.account-nav-item.logout:hover { color: var(--red); }

.account-content { min-width: 0; }
.account-welcome { font-family: var(--serif); font-size: 28px; font-weight: 700; color: var(--black); margin-bottom: 8px; }
.account-welcome-sub { font-family: var(--body-serif); font-size: 15px; color: var(--gray-500); font-weight: 300; margin-bottom: 32px; line-height: 1.6; }

.account-section-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.account-section-title::before { content: ''; display: block; width: 20px; height: 2px; background: var(--red); }

/* Orders table */
.orders-table { width: 100%; border-collapse: collapse; }
.orders-table th { text-align: left; font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-500); padding: 10px 12px; border-bottom: 2px solid var(--gray-100); }
.orders-table td { font-size: 14px; color: var(--gray-700); padding: 14px 12px; border-bottom: var(--border); vertical-align: middle; }
.orders-table tr:last-child td { border-bottom: none; }
.order-number { font-weight: 600; color: var(--black); }
.order-status { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 600; letter-spacing: 0.04em; padding: 4px 10px; }
.order-status.completed { background: #E8F5E9; color: #2E7D32; }
.order-status.processing { background: #FFF3E0; color: #E65100; }
.order-status.pending { background: var(--gray-100); color: var(--gray-500); }
.order-view-btn { font-size: 12px; font-weight: 600; color: var(--red); background: none; border: none; cursor: pointer; text-transform: uppercase; letter-spacing: 0.06em; transition: color 0.25s ease; }
.order-view-btn:hover { color: var(--red-dark); }

/* Info cards */
.info-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 32px; }
.info-card { border: var(--border); padding: 20px; }
.info-card-title { font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-500); margin-bottom: 12px; }
.info-card p { font-size: 14px; color: var(--gray-700); line-height: 1.6; }
.info-card a { font-size: 12px; font-weight: 600; color: var(--red); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 12px; display: inline-block; transition: color 0.25s ease; }
.info-card a:hover { color: var(--red-dark); }


/* ═══════════════════════════════════════════════════════════
   29. DONATION PAGE
   ═══════════════════════════════════════════════════════════ */

.donation-page { max-width: var(--container-max); margin: 0 auto; padding: 32px 40px 80px; }
.donation-layout { display: grid; grid-template-columns: 1fr 420px; gap: 64px; margin-top: 32px; align-items: start; }

/* Hero */
.donation-hero h1 { font-family: var(--serif); font-size: 40px; font-weight: 900; color: var(--black); line-height: 1.15; letter-spacing: -0.5px; margin-bottom: 16px; }
.donation-hero-subtitle { font-family: var(--body-serif); font-size: 18px; font-style: italic; color: var(--gray-500); line-height: 1.7; font-weight: 300; margin-bottom: 32px; }
.donation-separator { width: 48px; height: 3px; background: var(--red); margin-bottom: 32px; }
.donation-text { font-family: var(--body-serif); font-size: 16px; line-height: 1.8; color: var(--gray-700); font-weight: 300; margin-bottom: 24px; }
.donation-text strong { font-weight: 600; color: var(--black); }

/* Progress */
.donation-progress { margin-top: 40px; padding: 24px; background: var(--gray-100); }
.donation-progress-amounts { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.donation-progress-raised { display: flex; align-items: baseline; gap: 6px; }
.donation-progress-number { font-family: var(--serif); font-size: 36px; font-weight: 700; color: var(--red); line-height: 1; font-variant-numeric: tabular-nums; }
.donation-progress-currency { font-size: 16px; font-weight: 600; color: var(--gray-700); }
.donation-progress-label { font-size: 14px; color: var(--gray-500); }
.donation-progress-goal { font-size: 14px; color: var(--gray-500); padding-left: 8px; border-left: 1px solid var(--gray-300); }
.donation-progress-goal strong { font-weight: 600; color: var(--gray-700); }
.donation-track { width: 100%; height: 8px; background: var(--gray-300); position: relative; overflow: visible; margin-bottom: 8px; }
.donation-fill { position: absolute; top: 0; left: 0; bottom: 0; width: 63%; background: var(--red); transition: width 1.8s cubic-bezier(0.16, 1, 0.3, 1); }
.donation-glow { position: absolute; top: 50%; transform: translateY(-50%); width: 14px; height: 14px; border-radius: var(--radius-full); background: white; border: 3px solid var(--red); box-shadow: 0 0 0 4px rgba(196,30,30,0.2); left: 63%; transition: left 1.8s cubic-bezier(0.16, 1, 0.3, 1); pointer-events: none; }
.donation-progress-meta { display: flex; justify-content: space-between; font-size: 12px; }
.donation-progress-pct { font-weight: 700; color: var(--red); }
.donation-progress-donors { color: var(--gray-500); }

/* Form card */
.donation-form-card { border: var(--border); padding: 32px; background: var(--white); position: sticky; top: 140px; }
.donation-form-title { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--black); margin-bottom: 8px; text-align: center; }
.donation-form-sub { font-size: 13px; color: var(--gray-500); text-align: center; margin-bottom: 24px; }

/* Frequency toggle */
.frequency-toggle { display: flex; border: var(--border); margin-bottom: 24px; }
.frequency-btn { flex: 1; padding: 10px 16px; font-family: var(--sans); font-size: 13px; font-weight: 600; text-align: center; background: var(--white); border: none; cursor: pointer; color: var(--gray-500); transition: all 0.25s ease; }
.frequency-btn.active { background: var(--red); color: white; }
.frequency-btn:not(.active):hover { background: var(--gray-100); color: var(--gray-700); }

/* Amount buttons */
.amount-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 16px; }
.amount-btn { padding: 14px; font-family: var(--sans); font-size: 16px; font-weight: 700; text-align: center; border: var(--border); background: var(--white); cursor: pointer; color: var(--gray-700); transition: all 0.25s ease; }
.amount-btn:hover { border-color: var(--gray-700); }
.amount-btn.active { background: var(--red); color: white; border-color: var(--red); }

/* Custom amount */
.custom-amount-wrap { display: flex; align-items: center; border: var(--border); margin-bottom: 24px; overflow: hidden; }
.custom-amount-label { padding: 0 14px; font-size: 13px; font-weight: 600; color: var(--gray-500); background: var(--gray-100); height: 44px; display: flex; align-items: center; flex-shrink: 0; }
.custom-amount-input { flex: 1; height: 44px; border: none; outline: none; padding: 0 14px; font-family: var(--sans); font-size: 16px; font-weight: 600; color: var(--gray-900); background: var(--white); }
.custom-amount-input::placeholder { color: var(--gray-300); font-weight: 400; }
.custom-amount-currency { padding: 0 14px; font-size: 14px; font-weight: 600; color: var(--gray-500); flex-shrink: 0; }

/* Email */
.donation-email-group { margin-bottom: 24px; }
.donation-email-label { font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-700); margin-bottom: 6px; display: block; }
.donation-email-input { width: 100%; height: 44px; padding: 0 14px; font-family: var(--sans); font-size: 14px; color: var(--gray-900); background: var(--white); border: var(--border); outline: none; transition: border-color 0.3s ease; }
.donation-email-input:focus { border-color: var(--black); }
.donation-email-input::placeholder { color: var(--gray-300); }

/* Submit */
.btn-donate { width: 100%; height: 52px; background: var(--red); color: white; border: none; font-family: var(--sans); font-size: 14px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; transition: background 0.3s ease; margin-bottom: 20px; }
.btn-donate:hover { background: var(--red-dark); }

/* Payment icons */
.payment-icons { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 16px; padding-top: 16px; border-top: var(--border); }
.payment-icon { font-size: 11px; font-weight: 600; color: var(--gray-500); background: var(--gray-100); padding: 6px 12px; letter-spacing: 0.04em; }
.donation-note { font-size: 12px; color: var(--gray-500); text-align: center; line-height: 1.6; font-family: var(--body-serif); font-style: italic; }


/* ═══════════════════════════════════════════════════════════
   30. SUPPORT BAND
   ═══════════════════════════════════════════════════════════ */

.support-band-outer {}

.support-band {
  background: #242424;
  padding: 64px 40px;
  margin-bottom: 0;
  border-top: 3px solid var(--red);
}

.support-inner {
  max-width: var(--container-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

/* Le widget de don tiers (colonne droite) embarque souvent un wrapper avec
   une marge/hauteur supérieure à son contenu visible : on aligne donc le
   contenu visible des deux colonnes en haut, et on compense la colonne
   texte pour qu'elle s'aligne visuellement avec le titre "OBJECTIF DE
   COLLECTE" du widget. */
.footer-support-inner .footer-support-text {
  padding-top: 0;
}
.footer-support-inner .footer-support-slot {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.support-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.support-eyebrow::before { content: ''; display: block; width: 24px; height: 2px; background: var(--red); }

.support-text h2 { font-family: var(--serif); font-size: 28px; font-weight: 900; color: white; line-height: 1.25; margin-bottom: 14px; letter-spacing: -0.3px; }
.support-text p { font-family: var(--body-serif); font-size: 15px; line-height: 1.65; color: rgba(255,255,255,0.7); font-weight: 300; }
.support-text em { color: var(--red); font-style: normal; font-weight: 600; }

.support-band h2 { font-family: var(--serif); font-size: 28px; font-weight: 700; color: white; line-height: 1.25; letter-spacing: -0.4px; margin-bottom: 14px; }
.support-band p { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,0.7); margin: 0; }

.support-fundraiser { display: flex; flex-direction: column; gap: 20px; }
.support-amounts { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.support-raised { display: flex; align-items: baseline; gap: 6px; }
.amount-number { font-family: var(--serif); font-size: 48px; font-weight: 700; color: white; line-height: 1; letter-spacing: -1px; font-variant-numeric: tabular-nums; }
.amount-currency { font-size: 20px; font-weight: 600; color: rgba(255,255,255,0.75); }
.amount-label { font-size: 14px; color: rgba(255,255,255,0.7); }

.support-goal { font-size: 14px; color: rgba(255,255,255,0.7); padding-left: 8px; border-left: 1px solid rgba(255,255,255,0.15); }
.support-goal strong { color: rgba(255,255,255,0.7); font-weight: 600; }

.progress-track { width: 100%; height: 6px; background: rgba(255,255,255,0.08); position: relative; overflow: visible; }
.progress-fill { position: absolute; top: 0; left: 0; bottom: 0; width: 0%; background: var(--red); transition: width 1.8s cubic-bezier(0.16, 1, 0.3, 1); }

.progress-glow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  border-radius: var(--radius-full);
  background: white;
  border: 3px solid var(--red);
  box-shadow: 0 0 0 4px rgba(196,30,30,0.25);
  left: 0%;
  transition: left 1.8s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.progress-meta { display: flex; align-items: center; justify-content: space-between; }
.progress-pct { font-size: 12px; font-weight: 700; color: var(--red); letter-spacing: 0.05em; }
.progress-donors { font-size: 12px; color: rgba(255,255,255,0.7); letter-spacing: 0.04em; }

.support-btn {
  display: inline-flex;
  align-items: center;
  background: var(--red);
  color: white;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 14px 28px;
  transition: background 0.3s ease, transform 0.35s ease;
  align-self: flex-start;
}

.support-btn:hover { background: var(--red-dark); transform: translateX(2px); }


/* ═══════════════════════════════════════════════════════════
   31. FOOTER
   ═══════════════════════════════════════════════════════════ */

.site-footer {
  border-top: 1px solid rgba(255,255,255,0.08);
  background: var(--gray-900);
  color: var(--white);
  padding: 48px 40px 32px;
}

.footer-inner { max-width: var(--container-max); margin: 0 auto; }

.footer-top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }

.footer-brand {}

.footer-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.footer-logo img { height: 28px; width: auto; filter: brightness(0) invert(1); }

.footer-name { font-family: var(--serif); font-size: 18px; font-weight: 700; color: white; }

.footer-desc { font-size: 13px; line-height: 1.65; color: rgba(255,255,255,0.75); margin-bottom: 20px; }

.footer-brand-slot { margin-top: 18px; }
.footer-brand-widget { font-size: 13px; line-height: 1.65; color: rgba(255,255,255,0.75); max-width: 360px; }
.footer-brand-widget p { margin: 0 0 12px; }
.footer-brand-widget p:last-child { margin-bottom: 0; }
.footer-brand-widget a { color: rgba(255,255,255,0.9); text-decoration: underline; text-underline-offset: 3px; }
.footer-brand-widget-title { margin-bottom: 10px; font-family: var(--sans); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.18em; color: rgba(255,255,255,0.45); }

.footer-col-title { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.7); margin-bottom: 16px; }

.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: 14px; color: rgba(255,255,255,0.7); transition: color 0.2s ease; }
.footer-links a:hover { color: white; }

.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: rgba(255,255,255,0.7);
}

.footer-bottom a { transition: color 0.2s ease; }


/* ═══════════════════════════════════════════════════════════
   32. COOKIE BANNER
   ═══════════════════════════════════════════════════════════ */

.cookie-banner {
  position: fixed;
  bottom: 32px;
  left: 32px;
  width: 380px;
  background: var(--gray-900);
  color: white;
  z-index: var(--z-cookie);
  transform: translateY(calc(100% + 40px));
  opacity: 0;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
  box-shadow: 0 8px 40px rgba(0,0,0,0.35);
}

.cookie-banner.visible { transform: translateY(0); opacity: 1; }
.cookie-banner.hiding { transform: translateY(calc(100% + 40px)); opacity: 0; }

.cookie-top { padding: 24px 24px 0; display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.cookie-icon { font-size: 22px; line-height: 1; flex-shrink: 0; margin-top: 1px; }

.cookie-close {
  background: none;
  border: none;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0;
  flex-shrink: 0;
  transition: color 0.35s ease;
  margin-top: 1px;
}

.cookie-close:hover { color: white; }

.cookie-body { padding: 14px 24px 20px; }
.cookie-title { font-family: var(--serif); font-size: 16px; font-weight: 700; color: white; margin-bottom: 8px; line-height: 1.3; }
.cookie-text { font-size: 12px; line-height: 1.65; color: rgba(255,255,255,0.7); }
.cookie-text a { color: rgba(255,255,255,0.7); text-decoration: underline; transition: color 0.35s ease; }
.cookie-text a:hover { color: white; }

.cookie-toggles { padding: 0 24px 20px; display: flex; flex-direction: column; gap: 12px; border-top: 1px solid rgba(255,255,255,0.08); padding-top: 16px; }
.cookie-toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cookie-toggle-label { display: flex; flex-direction: column; gap: 2px; }
.cookie-toggle-name { font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.85); }
.cookie-toggle-desc { font-size: 12px; color: rgba(255,255,255,0.7); }

.cookie-switch { position: relative; width: 36px; height: 20px; flex-shrink: 0; }
.cookie-switch input { opacity: 0; width: 0; height: 0; position: absolute; }

.cookie-switch-track {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.12);
  cursor: pointer;
  transition: background 0.3s ease;
  border-radius: 20px;
}

.cookie-switch input:checked + .cookie-switch-track { background: var(--red); }
.cookie-switch input:disabled + .cookie-switch-track { opacity: 0.5; cursor: not-allowed; }

.cookie-switch-track::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  background: white;
  border-radius: var(--radius-full);
  top: 3px;
  left: 3px;
  transition: transform 0.3s ease;
}

.cookie-switch input:checked + .cookie-switch-track::after { transform: translateX(16px); }

.cookie-actions { padding: 0 24px 24px; display: flex; gap: 10px; }

.cookie-btn-accept {
  flex: 1;
  background: var(--red);
  color: white;
  border: none;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 11px 16px;
  cursor: pointer;
  transition: background 0.35s ease;
}

.cookie-btn-accept:hover { background: var(--red-dark); }

.cookie-btn-refuse {
  flex: 1;
  background: transparent;
  color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.12);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 11px 16px;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease;
}

.cookie-btn-refuse:hover { border-color: rgba(255,255,255,0.7); color: rgba(255,255,255,0.7); }


/* ═══════════════════════════════════════════════════════════
   33. BACK TO TOP
   ═══════════════════════════════════════════════════════════ */

.back-to-top {
  position: fixed;
  bottom: 36px;
  right: 36px;
  width: 44px;
  height: 44px;
  background: var(--red);
  color: white;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-backtotop);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.2s ease;
  pointer-events: none;
}

.back-to-top.visible { opacity: 1; transform: translateY(0); pointer-events: all; }
.back-to-top:hover { background: var(--red-dark); }
.back-to-top svg { width: 18px; height: 18px; stroke: white; stroke-width: 2.5; fill: none; }


/* ═══════════════════════════════════════════════════════════
   34. 404 PAGE
   ═══════════════════════════════════════════════════════════ */

.error-header { padding: 24px 0; text-align: center; border-bottom: var(--border); background: var(--white); }
.error-header a { display: inline-block; }
.error-header img { height: 32px; width: auto; }

.error-container {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 24px;
}

.error-code {
  font-family: var(--serif);
  font-size: clamp(120px, 20vw, 220px);
  font-weight: 700;
  line-height: 1;
  color: var(--red);
  opacity: 0.85;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}

.error-title {
  font-family: var(--serif);
  font-size: clamp(24px, 4vw, 36px);
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--black);
}

.error-message {
  font-family: var(--body-serif);
  font-style: italic;
  font-size: clamp(16px, 2.5vw, 20px);
  color: var(--gray-500);
  line-height: 1.6;
  max-width: 440px;
  margin-bottom: 40px;
}

.error-actions { display: flex; gap: 16px; flex-wrap: wrap; justify-content: center; }

.btn-primary,
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: all 0.2s ease;
  cursor: pointer;
}

.btn-primary { background: var(--red); color: #fff; border: 2px solid var(--red); }
.btn-primary:hover { background: var(--red-dark); border-color: var(--red-dark); }
.btn-outline { background: transparent; color: var(--black); border: 2px solid var(--black); }
.btn-outline:hover { background: var(--black); color: #fff; }

.error-footer { text-align: center; padding: 24px; font-size: 13px; color: var(--gray-500); font-family: var(--sans); }


/* ═══════════════════════════════════════════════════════════
   35. TRANSITIONS
   ═══════════════════════════════════════════════════════════ */

.nav-link { transition: color 0.15s ease; }

.hero-title a,
.sidebar-title a,
.article-title a,
.breve-title a,
.eclairage-title a,
.list-title a,
.book-title a { transition: color 0.2s ease; }

.book-card .book-cover { transition: border-color 0.2s ease; }

.hero-main-img img,
.article-img img { transition: transform 0.35s ease; }

.btn-support-top,
.header-search-btn,
.newsletter-submit,
.book-btn,
.support-btn,
.cookie-btn-accept { transition: background 0.2s ease; }

.section-more,
.boutique-cta a { transition: color 0.2s ease, border-color 0.2s ease; }


/* ═══════════════════════════════════════════════════════════
   36. RESPONSIVE — 1069px (hamburger + search reflow)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 1069px) {
  .hamburger-btn { display: flex; }
  nav { display: none; }
  .header-search-wrap { flex-basis: 100%; order: 3; margin-top: 2px; }
  .header-search-inner { height: 36px; }
  .header-search-btn { font-size: 12px; padding: 4px 10px; height: 26px; }
}


/* ═══════════════════════════════════════════════════════════
   37. RESPONSIVE — 999px (mobile/tablet)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 999px) {
  /* Topbar & Header */
  .topbar-inner { padding: 0 var(--gutter-tablet); }
  .header-top { height: auto; }
  .header-top-inner { padding: 12px 20px; flex-wrap: wrap; gap: 12px; height: auto; justify-content: space-between; }
  .logo-area { flex: 0 0 100%; min-width: 0; order: 1; justify-content: flex-start; }
  .logo-area img { display: block; width: 100%; max-width: none; height: auto; }
  .header-search-wrap { order: 2; flex: 1 1 0; flex-basis: auto; margin-top: 0; min-width: 0; }
  .hamburger-btn { flex-shrink: 0; order: 3; margin-left: 10px; }
  .header-search-inner { max-width: none; }
  .nav-inner-wrap { padding: 0 var(--gutter-tablet); }
  .nav-link { padding: 10px 14px; font-size: 12px; }

  /* Main & Hero */
  main { padding: 24px 20px 60px; }
  .full-bleed-wrapper { padding: 0 20px; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-main { border-right: none; border-bottom: var(--border); }
  .hero-title { font-size: 24px; }
  .content-row { grid-template-columns: 1fr 1fr; gap: 24px; }
  .content-row .article-card:first-child { grid-column: 1 / -1; }
  .breves-grid { grid-template-columns: 1fr; }
  .breve-item { border-right: none; border-bottom: var(--border); }
  .eclairage-inner { grid-template-columns: 1fr; }
  .eclairage-content { border-right: none; border-bottom: var(--border); padding: 28px 24px; }
  .eclairage-title { font-size: 22px; }

  /* Newsletter */
  .newsletter-band { grid-template-columns: 1fr; }
  .newsletter-band, .support-band { margin-left: 0; margin-right: 0; }
  .newsletter-deco { padding: 36px 24px; }
  .newsletter-deco-title { font-size: 26px; }
  .newsletter-form-side { padding: 32px 24px; }

  /* Boutique / Shop */
  .books-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .shop-page { padding: 24px 20px 60px; }

  /* Category */
  .category-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .category-header { padding: 36px 20px 0; }
  .category-content { padding: 0 20px 60px; }
  .category-title { font-size: 34px; }

  /* Search results */
  .search-header { padding: 36px 20px 0; }
  .search-query-title { font-size: 34px; }

  /* Article page */
  .article-page { grid-template-columns: 1fr; gap: 40px; padding: 24px 20px 60px; }
  .related-grid { grid-template-columns: 1fr 1fr; }
  .single-title { font-size: 28px; }

  /* Author page */
  .author-layout { grid-template-columns: 1fr; gap: 32px; padding: 32px 20px 60px; }
  .author-sidebar { position: static; display: grid; grid-template-columns: 200px 1fr; gap: 24px; align-items: start; }
  .author-avatar-circle { margin-bottom: 0; }
  .author-article { grid-template-columns: 160px 1fr; gap: 20px; }

  /* Product page */
  .product-page { padding: 24px 20px 60px; }
  .product-layout { grid-template-columns: 1fr 1fr; gap: 40px; }
  .product-full-desc { padding: 0 20px 40px; }
  .related-products { padding: 0 20px 40px; }

  /* Login page */
  .login-page { padding: 24px 20px 60px; }
  .login-card { padding: 32px 24px; margin-top: 24px; }

  /* Account page */
  .account-page { padding: 24px 20px 60px; }
  .account-layout { grid-template-columns: 1fr; gap: 24px; margin-top: 20px; }
  .account-sidebar { flex-direction: row; overflow-x: auto; gap: 0; border-bottom: var(--border); padding-bottom: 8px; }
  .account-nav-item { border-left: none; border-bottom: 3px solid transparent; padding: 10px 14px; white-space: nowrap; font-size: 13px; }
  .account-nav-item:hover, .account-nav-item.active { border-left: none; border-bottom-color: var(--red); }
  .account-nav-item.logout { border-top: none; margin-top: 0; padding-top: 10px; }
  .info-cards { grid-template-columns: 1fr; }

  /* Donation page */
  .donation-page { padding: 24px 20px 60px; }
  .donation-layout { grid-template-columns: 1fr; gap: 32px; }
  .donation-form-card { position: static; }
  .donation-hero h1 { font-size: 32px; }

  /* Support band */
  .support-inner { grid-template-columns: 1fr; gap: 40px; }
  .amount-number { font-size: 36px; }
  .support-band { padding: 48px 20px; }
  .support-band-outer { padding: 0 20px !important; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr 1fr; gap: 36px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
  .site-footer { padding: 40px 24px 28px; }
}


/* ═══════════════════════════════════════════════════════════
   38. RESPONSIVE — 799px (logo intermediate scale)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 799px) {
  .logo-area img {
    width: 100%;
    max-width: none;
  }
}


/* ═══════════════════════════════════════════════════════════
   39. RESPONSIVE — 600px (mobile)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 600px) {
  /* Topbar & Header */
  .topbar-inner { padding: 0 var(--gutter-mobile); }
  .topbar-left { font-size: 12px; }
  .btn-support-top { font-size: 12px; padding: 4px 10px; }
  .header-top { height: auto; }
  .header-top-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    gap: 12px;
    height: auto;
  }
  .logo-area { flex: 0 0 100%; min-width: 0; order: 1; justify-content: flex-start; }
  .logo-area img { display: block; width: 100%; height: auto; max-width: none; }
  .header-search-wrap { order: 2; flex: 1 1 0; flex-basis: auto; margin-top: 0; min-width: 0; }
  .hamburger-btn { position: static; flex-shrink: 0; order: 3; margin-left: 8px; }
  .nav-inner-wrap { padding: 0 12px; }
  .nav-link { padding: 10px 10px; font-size: 12px; letter-spacing: 0.05em; }

  /* Main & Hero */
  main { padding: 16px 16px 48px; }
  .full-bleed-wrapper { padding: 0 16px; }
  .hero-grid { margin-bottom: 40px; }
  .hero-main { padding: 20px; }
  .hero-title { font-size: 20px; }
  .hero-excerpt { font-size: 14px; }
  .sidebar-article { padding: 16px; }
  .content-row { grid-template-columns: 1fr; gap: 20px; margin-bottom: 40px; }
  .article-title.large { font-size: 18px; }
  .section-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .eclairage-content { padding: 20px; }
  .eclairage-title { font-size: 20px; }
  .eclairage-excerpt { font-size: 14px; }
  .list-item { grid-template-columns: 80px 1fr; }
  .list-img { height: 70px; }
  .list-content { padding: 10px 14px; }

  /* Ticker */
  .ticker-inner { padding: 0 var(--gutter-mobile); }
  .ticker-label { padding: 8px 14px; font-size: 12px; }
  .ticker-item { font-size: 12px; }

  /* Boutique / Shop */
  .books-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
  .shop-page { padding: 16px 16px 48px; }
  .shop-title { font-size: 28px; }

  /* Category */
  .category-grid { grid-template-columns: 1fr; gap: 16px; }
  .category-header { padding: 28px 16px 0; }
  .category-content { padding: 0 16px 48px; }
  .category-title { font-size: 28px; }
  .category-desc { font-size: 15px; }

  /* Search results */
  .search-header { padding: 28px 16px 0; }
  .search-query-title { font-size: 28px; }
  .search-result-count { font-size: 15px; }

  /* Article page */
  .article-page { padding: 16px 16px 48px; }
  .single-title { font-size: 22px; }
  .single-chapo { font-size: 16px; }
  .single-body { font-size: 16px; }
  .share-bar { position: static; flex-wrap: wrap; }
  .comment-form-row { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
  .author-box { flex-direction: column; align-items: center; text-align: center; }
  .single-newsletter-form { flex-direction: column; }

  /* Author page */
  .author-layout { padding: 24px 16px 48px; gap: 24px; }
  .author-sidebar { grid-template-columns: 1fr; text-align: center; }
  .author-avatar-circle { max-width: 140px; font-size: 48px; margin: 0 auto 16px; }
  .author-separator { margin: 0 auto 16px; }
  .author-meta-list { align-items: center; }
  .author-social { justify-content: center; }
  .author-article { grid-template-columns: 1fr; gap: 12px; }
  .author-article-img { max-height: 200px; }

  /* Product page */
  .product-page { padding: 16px 16px 48px; }
  .product-layout { gap: 24px; }
  .product-title { font-size: 24px; }
  .product-price { font-size: 24px; }
  .product-cart-row { flex-direction: column; align-items: stretch; }
  .qty-wrap { align-self: flex-start; }
  .product-thumb { width: 64px; height: 85px; }
  .product-full-desc { padding: 0 16px 32px; }
  .product-desc-tab { padding: 10px 16px; font-size: 12px; }
  .related-products { padding: 0 16px 32px; }

  /* Login page */
  .login-page { padding: 16px 16px 48px; }
  .login-card { padding: 28px 20px; max-width: 100%; }
  .login-card-title { font-size: 22px; }

  /* Account page */
  .account-page { padding: 16px 16px 48px; }
  .account-welcome { font-size: 22px; }
  .orders-table { font-size: 13px; }
  .orders-table th, .orders-table td { padding: 10px 8px; }

  /* Donation page */
  .donation-page { padding: 16px 16px 48px; }
  .donation-hero h1 { font-size: 26px; }
  .donation-form-card { padding: 24px 20px; }

  /* Support band */
  .support-band { padding: 32px 16px; }
  .support-inner { gap: 28px; }
  .support-band h2 { font-size: 22px; }
  .support-band p { font-size: 13px; }
  .amount-number { font-size: 28px; }
  .amount-currency { font-size: 16px; }
  .support-btn { width: 100%; justify-content: center; padding: 12px 20px; }
  .support-band-outer { padding: 0 16px !important; }

  /* Search overlay */
  .search-overlay { padding-top: 60px; }
  .search-box { padding: 20px; margin: 0 12px; }
  .search-input { font-size: 18px; }

  /* Back to top */
  .back-to-top { bottom: 20px; right: 20px; width: 38px; height: 38px; }

  /* Footer */
  .site-footer { padding: 32px 16px 24px; }
  .footer-top { grid-template-columns: 1fr; gap: 28px; margin-bottom: 32px; }
  .footer-brand { text-align: left; }
  .footer-col-title { margin-bottom: 10px; }
  .footer-links { gap: 8px; }
  .footer-links a { font-size: 13px; }
  .footer-bottom { flex-direction: column; gap: 10px; text-align: center; font-size: 12px; }
}


/* ═══════════════════════════════════════════════════════════
   39. RESPONSIVE — 500px (cookie banner)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 500px) {
  .cookie-banner { left: 16px; right: 16px; bottom: 16px; width: auto; }
}
/* ═══════════════════════════════════════════════════════════
   40. LEGAL PAGE
   ═══════════════════════════════════════════════════════════ */

.legal-page {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 48px 40px 80px;
}

.legal-inner {
  max-width: 860px;
}

.legal-title {
  font-family: var(--serif);
  font-size: 42px;
  font-weight: 900;
  color: var(--black);
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 10px;
}

.legal-updated {
  font-size: 13px;
  color: var(--gray-500);
  margin-bottom: 36px;
}

.legal-body {
  font-family: var(--body-serif);
  font-size: 17px;
  line-height: 1.8;
  color: var(--gray-700);
  font-weight: 300;
}

.legal-body h2 {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--black);
  margin: 2.2em 0 0.8em;
}

.legal-body p,
.legal-body ul,
.legal-body ol,
.legal-body table,
.legal-body address {
  margin-bottom: 1.4em;
}

.legal-body ul,
.legal-body ol {
  padding-left: 1.4em;
}

.legal-body li {
  margin-bottom: 0.5em;
}

.legal-body strong {
  font-weight: 600;
  color: var(--black);
}

.legal-body a {
  color: var(--red);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.25s ease, color 0.25s ease;
}

.legal-body a:hover {
  border-bottom-color: var(--red);
}

.legal-body address {
  font-style: normal;
  line-height: 1.8;
  color: var(--gray-700);
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--sans);
  font-size: 14px;
  background: var(--white);
  border: var(--border);
}

.legal-table th,
.legal-table td {
  padding: 14px 16px;
  text-align: left;
  vertical-align: top;
  border-bottom: var(--border);
}

.legal-table th {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
  background: var(--gray-100);
}

.legal-table tr:last-child td {
  border-bottom: none;
}

@media (max-width: 999px) {
  .legal-page {
    padding: 36px 20px 60px;
  }

  .legal-title {
    font-size: 34px;
  }

  .legal-body {
    font-size: 16px;
  }

  .legal-body h2 {
    font-size: 22px;
  }
}

@media (max-width: 600px) {
  .legal-page {
    padding: 28px 16px 48px;
  }

  .legal-title {
    font-size: 28px;
  }

  .legal-updated {
    font-size: 12px;
    margin-bottom: 28px;
  }

  .legal-body {
    font-size: 15px;
    line-height: 1.75;
  }

  .legal-body h2 {
    font-size: 20px;
  }

  .legal-table {
    font-size: 13px;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .legal-table th,
  .legal-table td {
    padding: 12px 14px;
  }
}
/* ═══════════════════════════════════════════════════════════
   41. UTILITAIRES (EXTRACTION INLINE)
   Compléments nécessaires après nettoyage HTML
   ═══════════════════════════════════════════════════════════ */

/* Logo header */
.logo-img {
  width: min(100%, 475px);
  height: auto;
  display: block;
}

/* Support band (remplacement inline) */
.support-band-outer--padded {
  padding: 0 40px;
  background: #242424;
}

.support-band--no-padding {
  padding-left: 0;
  padding-right: 0;
}

/* Logo footer (sécurisation si hors .footer-logo) */
.footer-logo-img {
  filter: brightness(0) invert(1);
}

/* Bouton inline footer (cookies) */
.footer-inline-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  font-size: 12px;
  font-family: inherit;
  padding: 0;
  transition: color 0.35s ease;
}

.footer-inline-btn:hover {
  color: rgba(255,255,255,0.9);
}

/* Lien développeur footer */
.footer-dev-link {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color 0.35s ease;
}

.footer-dev-link:hover {
  color: rgba(255,255,255,0.9);
}
/* oEmbed propre et responsive */
.single-body .lo-embed,
.entry-content .lo-embed {
  width: 100%;
  max-width: 100%;
  margin: 2.2rem 0;
  overflow: hidden;
}

.single-body .lo-embed iframe,
.entry-content .lo-embed iframe {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  border: 0;
}

.single-body .lo-embed--video,
.entry-content .lo-embed--video {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #0f1115;
}

.single-body .lo-embed--video iframe,
.entry-content .lo-embed--video iframe {
  position: absolute;
  inset: 0;
  height: 100% !important;
}

.single-body .lo-embed--iframe iframe,
.entry-content .lo-embed--iframe iframe,
.single-body .lo-embed--wordpress iframe,
.entry-content .lo-embed--wordpress iframe {
  min-height: 320px;
}

.single-body .lo-embed--social,
.entry-content .lo-embed--social {
  display: flex;
  justify-content: center;
}

.single-body .lo-embed--social > *,
.entry-content .lo-embed--social > * {
  max-width: 100% !important;
}

/* Tweets (Twitter / X) — force responsive width.
   widgets.js applique des largeurs inline (min-width:220px, max-width:550px,
   parfois une width fixe en px sur <twitter-widget>) qui débordent sur mobile. */
.single-body .lo-embed--social .twitter-tweet,
.entry-content .lo-embed--social .twitter-tweet,
.single-body .lo-embed--social twitter-widget,
.entry-content .lo-embed--social twitter-widget,
.single-body .lo-embed--social iframe,
.entry-content .lo-embed--social iframe {
  width: 100% !important;
  max-width: 550px !important;
  min-width: 0 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.single-body .wp-block-embed,
.entry-content .wp-block-embed {
  width: 100%;
  max-width: 100%;
  margin: 2.2rem 0;
}

.single-body .wp-block-embed__wrapper,
.entry-content .wp-block-embed__wrapper {
  width: 100%;
  max-width: 100%;
}

.single-body .wp-block-embed.is-type-video .wp-block-embed__wrapper,
.entry-content .wp-block-embed.is-type-video .wp-block-embed__wrapper {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #0f1115;
}

.single-body .wp-block-embed.is-type-video iframe,
.entry-content .wp-block-embed.is-type-video iframe {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  border: 0;
}

.single-body .lo-internal-embed,
.entry-content .lo-internal-embed {
  display: grid;
  grid-template-columns: minmax(300px, 38%) minmax(0, 1fr);
  align-items: stretch;
  gap: 0;
  width: 100%;
  margin: 1.7rem 0;
  border: 1px solid rgba(0, 0, 0, 0.13);
  background: #fbfaf8;
  box-shadow: none;
  overflow: hidden;
  transition: border-color 0.25s ease, background-color 0.25s ease;
}

.single-body .lo-internal-embed:hover,
.entry-content .lo-internal-embed:hover,
.single-body .lo-internal-embed:focus-within,
.entry-content .lo-internal-embed:focus-within {
  border-color: rgba(178, 31, 36, 0.38);
  background: #fff;
}

.single-body .lo-internal-embed--noimage,
.entry-content .lo-internal-embed--noimage {
  display: block;
}

.single-body .lo-internal-embed__image,
.entry-content .lo-internal-embed__image {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
  background: #efede9;
}

.single-body .lo-internal-embed__thumb,
.entry-content .lo-internal-embed__thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}

.single-body .lo-internal-embed:hover .lo-internal-embed__thumb,
.entry-content .lo-internal-embed:hover .lo-internal-embed__thumb,
.single-body .lo-internal-embed:focus-within .lo-internal-embed__thumb,
.entry-content .lo-internal-embed:focus-within .lo-internal-embed__thumb {
  transform: scale(1.025);
}

.single-body .lo-internal-embed__body,
.entry-content .lo-internal-embed__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  padding: 18px 22px;
}

.single-body .lo-internal-embed__label,
.entry-content .lo-internal-embed__label {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 7px;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #b21f24;
}

.single-body .lo-internal-embed__label::after,
.entry-content .lo-internal-embed__label::after {
  content: '';
  width: 22px;
  height: 2px;
  background: currentColor;
}

.single-body .lo-internal-embed__title,
.entry-content .lo-internal-embed__title {
  margin: 0;
  font-size: clamp(1.05rem, 1.35vw, 1.28rem);
  line-height: 1.22;
  font-weight: 600;
}

.single-body .lo-internal-embed__title a,
.entry-content .lo-internal-embed__title a {
  color: #151515;
  text-decoration: none;
  transition: color 0.25s ease;
}

.single-body .lo-internal-embed:hover .lo-internal-embed__title a,
.entry-content .lo-internal-embed:hover .lo-internal-embed__title a,
.single-body .lo-internal-embed:focus-within .lo-internal-embed__title a,
.entry-content .lo-internal-embed:focus-within .lo-internal-embed__title a {
  color: #b21f24;
}

.single-body .lo-internal-embed__excerpt,
.entry-content .lo-internal-embed__excerpt {
  margin: 7px 0 0;
  font-family: var(--sans);
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--gray-600);
}

.single-body .lo-internal-embed__meta,
.entry-content .lo-internal-embed__meta,
.single-body .lo-internal-embed__kicker,
.entry-content .lo-internal-embed__kicker {
  display: none;
}

@media (max-width: 720px) {
  .single-body .lo-internal-embed,
  .entry-content .lo-internal-embed {
    grid-template-columns: 1fr;
  }

  .single-body .lo-internal-embed__image,
  .entry-content .lo-internal-embed__image {
    display: none;
  }

  .single-body .lo-internal-embed__body,
  .entry-content .lo-internal-embed__body {
    padding: 16px 18px 18px;
  }
}
}


/* Correctif oEmbed interne : neutralise les <br>/<p> ajoutés par wpautop et force l’image à remplir sa colonne */
.single-body .lo-internal-embed > p,
.entry-content .lo-internal-embed > p,
.single-body .lo-internal-embed__image > br,
.entry-content .lo-internal-embed__image > br {
  display: none !important;
}

.single-body .lo-internal-embed__image .lo-lazy-media,
.entry-content .lo-internal-embed__image .lo-lazy-media,
.single-body .lo-internal-embed__image picture,
.entry-content .lo-internal-embed__image picture,
.single-body .lo-internal-embed__image img,
.entry-content .lo-internal-embed__image img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
}

.single-body .lo-internal-embed__image img,
.entry-content .lo-internal-embed__image img,
.single-body .lo-internal-embed__thumb,
.entry-content .lo-internal-embed__thumb {
  object-fit: cover;
  object-position: center center;
}

@media (max-width: 720px) {
  .single-body .lo-internal-embed__image,
  .entry-content .lo-internal-embed__image {
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   41. TYPOGRAPHIE ÉDITORIALE + PAGES + COMMENTAIRES — v0.7
   ═══════════════════════════════════════════════════════════ */

:root {
  --serif: Georgia, "Times New Roman", Times, serif;
  --body-serif: Georgia, "Times New Roman", Times, serif;
}

body {
  -webkit-font-smoothing: auto;
  -moz-osx-font-smoothing: auto;
}

.single-title,
.category-title,
.archive-title,
.author-title,
.page-title,
.related-title,
.sidebar-widget-title,
.comments-title,
.comment-reply-title {
  font-family: var(--serif);
}

.single-body,
.page-body {
  font-family: var(--body-serif);
  font-weight: 400;
  letter-spacing: 0;
  color: #202020;
}

.single-body p,
.page-body p {
  letter-spacing: 0;
}

.single-body strong,
.page-body strong {
  font-weight: 600;
}

/* Pages WordPress génériques */
.page-layout {
  max-width: 860px;
  margin: 0 auto;
  padding: 36px var(--gutter-desktop) 80px;
}

.page-article {
  width: 100%;
}

.page-breadcrumb {
  margin-bottom: 28px;
}

.page-hero {
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: var(--border);
}

.page-title {
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.08;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--black);
  margin: 0;
}

.page-chapo {
  max-width: 760px;
  margin-top: 16px;
  font-family: var(--body-serif);
  font-size: 20px;
  line-height: 1.65;
  color: var(--gray-700);
}

.page-featured {
  margin: 0 0 34px;
}

.page-featured img {
  display: block;
  width: 100%;
  height: auto;
}

.page-featured figcaption {
  margin-top: 8px;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--gray-500);
}

.page-body {
  font-size: 19px;
  line-height: 1.82;
}

.page-body p,
.page-body ul,
.page-body ol,
.page-body blockquote,
.page-body figure,
.page-body table {
  margin-bottom: 1.35em;
}

.page-body h2 {
  margin: 2em 0 0.75em;
  font-family: var(--serif);
  font-size: 28px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--black);
}

.page-body h3 {
  margin: 1.7em 0 0.65em;
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.3;
  font-weight: 700;
  color: var(--black);
}

.page-body ul,
.page-body ol {
  padding-left: 1.25em;
}

.page-body li {
  margin-bottom: 0.45em;
}

.page-body a {
  color: var(--red);
  border-bottom: 1px solid rgba(196, 30, 30, 0.25);
}

.page-body a:hover {
  border-bottom-color: var(--red);
}

.page-body img {
  max-width: 100%;
  height: auto;
}

.page-body blockquote {
  padding: 18px 24px;
  border-left: 3px solid var(--red);
  background: var(--gray-100);
  color: var(--gray-700);
  font-style: italic;
}

/* Commentaires WordPress */
.comments-section {
  margin-top: 56px;
  padding-top: 36px;
  border-top: 2px solid var(--black);
}

.comments-area {
  font-family: var(--sans);
}

.comments-area-header {
  margin-bottom: 24px;
}

.comments-title,
.comment-reply-title {
  font-size: 24px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--black);
  margin: 0 0 14px;
}

.comment-reply-title small {
  margin-left: 16px;
  font-size: 14px;
  font-weight: 600;
}

.comment-reply-title small #cancel-comment-reply-link {
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.editorial-comment-list,
.comment-list {
  list-style: none;
  margin: 0 0 36px;
  padding: 0;
}

.editorial-comment {
  margin: 0;
  padding: 0;
}

.editorial-comment-body {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 16px;
  padding: 22px 0;
  border-bottom: var(--border);
}

.editorial-comment:first-child > .editorial-comment-body {
  border-top: var(--border);
}

.editorial-comment-avatar img {
  display: block;
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
}

.editorial-comment-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
}

.editorial-comment-author {
  font-size: 14px;
  font-weight: 700;
  color: var(--black);
}

.editorial-comment-date {
  font-size: 12px;
  color: var(--gray-500);
}

.editorial-comment-text {
  font-family: var(--body-serif);
  font-size: 17px;
  line-height: 1.7;
  color: var(--gray-700);
}

.editorial-comment-text p {
  margin: 0 0 0.9em;
}

.editorial-comment-text p:last-child {
  margin-bottom: 0;
}

.editorial-comment-awaiting {
  display: inline-block;
  margin: 0 0 10px;
  padding: 6px 10px;
  background: var(--red-light);
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 600;
}

.editorial-comment-footer {
  display: flex;
  gap: 14px;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.editorial-comment-footer a {
  color: var(--gray-500);
}

.editorial-comment-footer a:hover {
  color: var(--red);
}

/* Réponses imbriquées (1 niveau autorisé) */
.editorial-comment-list .children {
  list-style: none;
  margin: 0;
  padding: 0 0 0 64px;
  border-left: 2px solid var(--gray-100);
  margin-left: 26px;
}
.editorial-comment-list .children .editorial-comment-body {
  padding-top: 20px;
  padding-bottom: 20px;
}
.editorial-comment-list .children .editorial-comment > .editorial-comment-body {
  border-top: 1px solid var(--gray-100);
}
@media (max-width: 640px) {
  .editorial-comment-list .children {
    padding-left: 24px;
    margin-left: 12px;
  }
}

.comment-navigation {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 36px;
  font-size: 13px;
  font-weight: 700;
}

.comments-closed {
  margin-bottom: 28px;
  font-size: 14px;
  color: var(--gray-500);
}

.editorial-comment-respond {
  margin-top: 34px;
  padding: 28px;
  border: var(--border);
  background: #FAF9F7;
}

.editorial-comment-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.editorial-comment-form p {
  margin: 0;
}

.comment-notes,
.logged-in-as {
  grid-column: 1 / -1;
  font-size: 14px;
  line-height: 1.6;
  color: var(--gray-500);
  margin-bottom: 2px !important;
}

.logged-in-as a,
.comment-notes a {
  color: var(--red);
}

.comment-form-comment,
.comment-form-url,
.comment-form-cookies-consent,
.form-submit {
  grid-column: 1 / -1;
}

.editorial-comment-form label {
  display: block;
  margin-bottom: 7px;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
}

.editorial-comment-form .required {
  color: var(--red);
}

.editorial-comment-form input[type="text"],
.editorial-comment-form input[type="email"],
.editorial-comment-form input[type="url"],
.editorial-comment-form textarea {
  width: 100%;
  border: 1px solid #D7D0C8;
  background: var(--white);
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.5;
  padding: 12px 14px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.editorial-comment-form textarea {
  min-height: 170px;
  resize: vertical;
}

.editorial-comment-form input:focus,
.editorial-comment-form textarea:focus {
  border-color: var(--black);
  box-shadow: 0 0 0 3px rgba(14, 14, 14, 0.06);
}

.editorial-comment-form .form-submit {
  margin-top: 4px;
}

.editorial-comment-form .submit {
  appearance: none;
  border: none;
  background: var(--black);
  color: var(--white);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 13px 24px;
  cursor: pointer;
  transition: background 0.25s ease;
}

.editorial-comment-form .submit:hover {
  background: var(--red);
}

.comment-form-cookies-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--gray-500);
}

.comment-form-cookies-consent input {
  margin-top: 3px;
}

.comment-form-cookies-consent label {
  margin: 0;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--gray-500);
}

@media (max-width: 999px) {
  .page-layout {
    padding: 28px var(--gutter-tablet) 64px;
  }

  .page-body {
    font-size: 18px;
  }
}

@media (max-width: 600px) {
  .page-layout {
    padding: 24px var(--gutter-mobile) 56px;
  }

  .page-title {
    font-size: 34px;
  }

  .page-chapo,
  .page-body {
    font-size: 17px;
  }

  .editorial-comment-respond {
    padding: 22px 18px;
  }

  .editorial-comment-form {
    grid-template-columns: 1fr;
  }

  .editorial-comment-body {
    grid-template-columns: 40px 1fr;
    gap: 12px;
  }

  .editorial-comment-avatar img {
    width: 40px;
    height: 40px;
  }

  .editorial-comment-header {
    display: block;
  }

  .editorial-comment-date {
    display: block;
    margin-top: 2px;
  }
}


/* v0.8 — durcissement WordPress : recherche, navigation, accessibilité */
.screen-reader-text {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.screen-reader-text:focus {
  position: fixed !important;
  top: 12px;
  left: 12px;
  z-index: 9999;
  width: auto;
  height: auto;
  padding: 10px 14px;
  clip: auto;
  background: #fff;
  color: var(--gray-900);
  border: 1px solid var(--gray-300);
}
.lo-search-form {
  display: flex;
  gap: 10px;
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
}
.lo-search-field {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--gray-300);
  padding: 13px 14px;
  font: inherit;
  background: #fff;
  color: var(--gray-900);
}
.lo-search-submit {
  border: 1px solid var(--gray-900);
  background: var(--gray-900);
  color: #fff;
  padding: 0 18px;
  font-weight: 700;
  cursor: pointer;
}
.error-search {
  margin: 28px auto 18px;
  max-width: 680px;
}
.error-categories {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}
.error-categories a {
  border: 1px solid var(--gray-300);
  padding: 8px 12px;
  color: var(--gray-700);
  text-decoration: none;
}
.error-categories a:hover {
  border-color: var(--red);
  color: var(--red);
}
.single-post-nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin: 48px 0;
  padding-top: 28px;
  border-top: 1px solid var(--gray-200);
}
.single-post-nav a {
  display: block;
  min-height: 100%;
  padding: 18px;
  border: 1px solid var(--gray-200);
  text-decoration: none;
  color: var(--gray-900);
  background: #fff;
}
.single-post-nav span {
  display: block;
  margin-bottom: 8px;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-500);
  font-family: var(--sans);
}
.single-post-nav strong {
  display: block;
  font-size: 17px;
  line-height: 1.35;
}
.single-post-nav__next {
  text-align: right;
}
.widget ul {
  list-style: none;
  margin: 0;
  padding: 16px 20px;
}
.widget li + li {
  margin-top: 10px;
}
.widget a {
  color: var(--gray-800);
  text-decoration: none;
}
.widget a:hover { color: var(--red); }
@media (max-width: 700px) {
  .lo-search-form,
  .single-post-nav {
    grid-template-columns: 1fr;
  }
  .lo-search-form {
    flex-direction: column;
  }
  .lo-search-submit {
    padding: 13px 18px;
  }
  .single-post-nav__next { text-align: left; }
}


/* Lazy loading éditorial : fond gris + spinner sobre */
.lo-lazy-media {
  position: relative;
  display: block;
  overflow: hidden;
  background: #f1f1f1;
}
.lo-lazy-media img {
  display: block;
  width: 100%;
  height: auto;
  opacity: 1;
  color: transparent;
  font-size: 0;
  text-indent: -9999px;
  transition: opacity 0.28s ease, transform 0.4s ease;
}
.lo-js .lo-lazy-media:not(.is-loaded) img {
  opacity: 0;
}
.lo-lazy-media.is-loaded img {
  opacity: 1;
}
.lo-lazy-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  width: 28px;
  height: 28px;
  margin: -14px 0 0 -14px;
  border: 2px solid rgba(0, 0, 0, 0.12);
  border-top-color: rgba(0, 0, 0, 0.42);
  border-radius: 999px;
  animation: loLazySpin 0.75s linear infinite;
  pointer-events: none;
}
.lo-lazy-media.is-loaded .lo-lazy-spinner {
  opacity: 0;
  visibility: hidden;
}

.lo-lazy-media--related {
  display: block;
  background: var(--gray-100);
}
.lo-lazy-media--related a {
  display: block;
  width: 100%;
  height: 100%;
}
.lo-lazy-media--related img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lo-lazy-media--content {
  margin: 2rem 0;
}
.single-body .lo-lazy-media--content img {
  margin: 0;
}
.single-featured-img.lo-lazy-media {
  background: #eeeeee;
}
@keyframes loLazySpin {
  to {
    transform: rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .lo-lazy-media img {
    transition: none;
  }
  .lo-lazy-spinner {
    animation: none;
  }
}

/* Auteur : photo de profil locale WordPress */
.author-avatar-circle img,
.author-avatar-img,
.lo-local-avatar {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

/* Lazy loading sur toutes les cartes éditoriales */
.lo-lazy-media--card {
  display: block;
  aspect-ratio: 16 / 9;
  background: var(--gray-100, #f1f1f1);
}
.lo-lazy-media--card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.category-card-img.lo-lazy-media,
.author-article-img.lo-lazy-media,
.article-card-image.lo-lazy-media {
  background: var(--gray-100, #f1f1f1);
}

/* v1.4.2 - Micro-espacements éditoriaux */
.article-page .breadcrumb {
  margin-bottom: 1.5rem;
}

.category-pagination,
.author-pagination {
  padding-top: 1.5rem;
}


/* Footer refinement — support slot ready for future widget */
.footer-support-outer {
  background: #242424;
  padding: 0 40px;
}

.footer-support-band {
  max-width: var(--container-max);
  margin: 0 auto;
  border-top: 3px solid var(--red);
  padding: 64px 0;
}

.footer-support-inner {
  max-width: none;
}

.footer-support-slot {
  min-width: 0;
}

.footer-support-widget {
  color: rgba(255,255,255,0.85);
}

.footer-support-widget-title {
  font-family: var(--serif);
  color: white;
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 12px;
}

.site-footer {
  border-top: 1px solid rgba(255,255,255,0.08);
}

.site-footer .footer-logo img {
  height: 34px;
  max-width: 300px;
}

.footer-cookie-button {
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  font-size: 12px;
  font-family: inherit;
  padding: 0;
  transition: color 0.35s ease;
}

.footer-cookie-button:hover,
.footer-cookie-button:focus-visible,
.footer-credit-link:hover,
.footer-credit-link:focus-visible {
  color: rgba(255,255,255,0.95);
}

.footer-credit-link {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color 0.35s ease;
}

@media (max-width: 999px) {
  .footer-support-outer { padding: 0 24px; }
  .footer-support-band { padding: 52px 0; }
  .footer-support-inner { grid-template-columns: 1fr; gap: 36px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px 32px; }
}

@media (max-width: 700px) {
  .footer-support-outer { padding: 0 16px; }
  .footer-support-band { padding: 40px 0; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { align-items: flex-start; flex-direction: column; gap: 10px; }
  .site-footer .footer-logo img { height: 30px; max-width: min(100%, 280px); }
}


/* Widgets texte du bandeau de soutien footer */
.footer-support-copy .widget,
.footer-support-text-widget {
  margin: 0;
}

.footer-support-copy p,
.footer-support-text-widget p {
  margin: 0;
}

/* Footer : colonnes widgetisées */
.footer-widget-col .widget {
  margin: 0;
}

.footer-column-widget .footer-col-title,
.footer-widget-col .widget-title,
.footer-widget-col .wp-block-heading {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin: 0 0 16px;
}

.footer-widget-col ul,
.footer-widget-col .menu {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-widget-col li {
  margin: 0;
  padding: 0;
}

.footer-widget-col a {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  transition: color 0.2s ease;
}

.footer-widget-col a:hover,
.footer-widget-col a:focus-visible {
  color: #fff;
}

.footer-widget-col p {
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.7);
  margin: 0 0 12px;
}

.footer-widget-col p:last-child {
  margin-bottom: 0;
}

@media (max-width: 600px) {
  .footer-widget-col .widget-title,
  .footer-widget-col .wp-block-heading,
  .footer-column-widget .footer-col-title {
    margin-bottom: 10px;
  }

  .footer-widget-col ul,
  .footer-widget-col .menu {
    gap: 8px;
  }

  .footer-widget-col a {
    font-size: 13px;
  }
}

/* Footer widgets: normalise paragraph/list spacing so dynamic widgets match hardcoded columns */
.footer-widget-col :where(p, .wp-block-paragraph) {
  margin: 0;
  padding: 0;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(255,255,255,0.7);
}

.footer-widget-col :where(p, .wp-block-paragraph) + :where(p, .wp-block-paragraph),
.footer-widget-col :where(p, .wp-block-paragraph) + :where(ul, .menu, .wp-block-list),
.footer-widget-col :where(ul, .menu, .wp-block-list) + :where(p, .wp-block-paragraph) {
  margin-top: 10px;
}

.footer-widget-col :where(p, .wp-block-paragraph):empty {
  display: none;
}

.footer-widget-col :where(p, .wp-block-paragraph) a {
  display: inline-block;
  font-size: inherit;
  line-height: inherit;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
}

.footer-widget-col :where(p, .wp-block-paragraph) a:hover,
.footer-widget-col :where(p, .wp-block-paragraph) a:focus-visible {
  color: #fff;
}

.footer-widget-col :where(ul, .menu, .wp-block-list) {
  gap: 10px;
}

/* Footer widget columns: exact alignment with hardcoded footer-links columns */
.site-footer .footer-widget-col .footer-column-widget {
  margin: 0;
  padding: 0;
}

.site-footer .footer-widget-col .footer-column-widget .wp-block-heading,
.site-footer .footer-widget-col .footer-column-widget .widget-title {
  display: block;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin: 0;
  padding: 0;
}

.site-footer .footer-widget-col .footer-column-widget:has(.wp-block-heading),
.site-footer .footer-widget-col .footer-column-widget:has(.widget-title) {
  margin-bottom: 16px;
}

.site-footer .footer-widget-col .footer-column-widget.widget_text p,
.site-footer .footer-widget-col .footer-column-widget.widget_block p,
.site-footer .footer-widget-col .wp-block-paragraph {
  margin: 0 !important;
  padding: 0;
  font-size: 14px;
  line-height: 1.4;
  color: rgba(255,255,255,0.7);
}

.site-footer .footer-widget-col .footer-column-widget.widget_text + .footer-column-widget.widget_text,
.site-footer .footer-widget-col .footer-column-widget.widget_text + .footer-column-widget.widget_block,
.site-footer .footer-widget-col .footer-column-widget.widget_block + .footer-column-widget.widget_text {
  margin-top: 10px;
}

.site-footer .footer-widget-col .footer-column-widget:has(.wp-block-heading) + .footer-column-widget.widget_text,
.site-footer .footer-widget-col .footer-column-widget:has(.widget-title) + .footer-column-widget.widget_text {
  margin-top: 0;
}

.site-footer .footer-widget-col .footer-column-widget.widget_text a,
.site-footer .footer-widget-col .footer-column-widget.widget_block p a,
.site-footer .footer-widget-col .footer-column-widget .menu a {
  display: block;
  margin: 0;
  padding: 0;
  font-size: 14px;
  line-height: 1.4;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color 0.2s ease;
}

.site-footer .footer-widget-col .footer-column-widget.widget_text a:hover,
.site-footer .footer-widget-col .footer-column-widget.widget_text a:focus-visible,
.site-footer .footer-widget-col .footer-column-widget .menu a:hover,
.site-footer .footer-widget-col .footer-column-widget .menu a:focus-visible {
  color: #fff;
}

.site-footer .footer-widget-col .footer-column-widget ul,
.site-footer .footer-widget-col .footer-column-widget .menu,
.site-footer .footer-widget-col .footer-column-widget .wp-block-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-footer .footer-widget-col .footer-column-widget li {
  margin: 0;
  padding: 0;
}

@media (max-width: 600px) {
  .site-footer .footer-widget-col .footer-column-widget:has(.wp-block-heading),
  .site-footer .footer-widget-col .footer-column-widget:has(.widget-title) {
    margin-bottom: 10px;
  }

  .site-footer .footer-widget-col .footer-column-widget.widget_text + .footer-column-widget.widget_text,
  .site-footer .footer-widget-col .footer-column-widget.widget_text + .footer-column-widget.widget_block,
  .site-footer .footer-widget-col .footer-column-widget.widget_block + .footer-column-widget.widget_text,
  .site-footer .footer-widget-col .footer-column-widget ul,
  .site-footer .footer-widget-col .footer-column-widget .menu,
  .site-footer .footer-widget-col .footer-column-widget .wp-block-list {
    gap: 8px;
    margin-top: 8px;
  }

  .site-footer .footer-widget-col .footer-column-widget.widget_text a,
  .site-footer .footer-widget-col .footer-column-widget.widget_block p a,
  .site-footer .footer-widget-col .footer-column-widget .menu a {
    font-size: 13px;
  }
}

/* Homepage category sections */
.breves-grid--with-images .breve-item {
  padding: 22px 24px;
  gap: 10px;
}

.breves-grid--with-images .breve-img {
  display: block;
  width: 100%;
  aspect-ratio: 300 / 169;
  background: var(--gray-100);
  overflow: hidden;
  margin: 0 0 4px;
}

.breves-grid--with-images .breve-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.breves-grid--with-images .breve-meta {
  font-size: 11px;
  color: var(--gray-500);
}

.breves-grid--with-images .breve-excerpt {
  margin-bottom: 0;
}

/* v1.5.8 / v1.8.0 - Sections Politique et Médias : présentation en cartes */
.politique-grid .breve-img,
.medias-grid .breve-img {
  position: relative;
  overflow: hidden;
}

.politique-grid .breve-img img,
.medias-grid .breve-img img {
  transition: transform 0.35s ease, opacity 0.28s ease;
  will-change: transform;
}

.politique-grid .breve-item:hover .breve-img img,
.politique-grid .breve-item:focus-within .breve-img img,
.politique-grid .breve-img:focus-visible img,
.medias-grid .breve-item:hover .breve-img img,
.medias-grid .breve-item:focus-within .breve-img img,
.medias-grid .breve-img:focus-visible img {
  transform: scale(1.035);
}

.politique-grid .breve-item:hover .breve-title a,
.politique-grid .breve-item:focus-within .breve-title a,
.medias-grid .breve-item:hover .breve-title a,
.medias-grid .breve-item:focus-within .breve-title a {
  color: var(--red);
}

@media (prefers-reduced-motion: reduce) {
  .politique-grid .breve-img img,
  .medias-grid .breve-img img {
    transition: none;
    will-change: auto;
  }

  .politique-grid .breve-item:hover .breve-img img,
  .politique-grid .breve-item:focus-within .breve-img img,
  .politique-grid .breve-img:focus-visible img,
  .medias-grid .breve-item:hover .breve-img img,
  .medias-grid .breve-item:focus-within .breve-img img,
  .medias-grid .breve-img:focus-visible img {
    transform: none;
  }
}

.politique-grid .breve-item,
.medias-grid .breve-item {
  cursor: pointer;
}

@media (max-width: 999px) {
  .breves-grid.politique-grid,
  .breves-grid.medias-grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    border: none;
  }

  .breves-grid.politique-grid .breve-item,
  .breves-grid.medias-grid .breve-item {
    border: var(--border);
  }

  .breves-grid.politique-grid .breve-item:first-child,
  .breves-grid.medias-grid .breve-item:first-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  .breves-grid.politique-grid,
  .breves-grid.medias-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .breves-grid.politique-grid .breve-item:first-child,
  .breves-grid.medias-grid .breve-item:first-child {
    grid-column: auto;
  }
}

/* v1.6.2 - Sections thématiques homepage : structure identique au bloc Suisse & Europe de la maquette */
.home-category-section .article-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: none;
}

.home-category-section .list-item {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 0;
  border: none;
  border-top: var(--border);
  transition: background 0.2s ease;
}

.home-category-section .list-item:last-child {
  border-bottom: none;
}

.home-category-section .list-item:hover,
.home-category-section .list-item:focus-within {
  background: var(--gray-hover);
}

.home-category-section .list-img {
  height: 80px;
  background: var(--gray-100);
  overflow: hidden;
  border-right: var(--border);
  flex-shrink: 0;
}

.home-category-section .list-img .lo-lazy-media,
.home-category-section .list-img a {
  display: block;
  width: 100%;
  height: 100%;
}

.home-category-section .lo-lazy-media--list {
  aspect-ratio: auto;
  background: var(--gray-100);
}

.home-category-section .list-img img,
.home-category-section .lo-lazy-media--list img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-category-section .list-content {
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: center;
  min-width: 0;
}

.home-category-section .list-cat {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.home-category-section .list-title {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
}

.home-category-section .list-title a:hover,
.home-category-section .list-item:hover .list-title a,
.home-category-section .list-item:focus-within .list-title a {
  color: var(--red);
}

.home-category-section .list-meta {
  font-size: 12px;
  color: var(--gray-500);
}

@media (max-width: 600px) {
  .home-category-section .list-item {
    grid-template-columns: 80px 1fr;
  }

  .home-category-section .list-img {
    height: 70px;
  }

  .home-category-section .list-content {
    padding: 10px 14px;
  }
}

/* v1.7.2 — oEmbed interne : bandeau compact image + texte */
.single-body .lo-internal-embed,
.entry-content .lo-internal-embed {
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: 100% !important;
  min-height: 169px;
  margin: 1.65rem 0 !important;
  padding: 0 !important;
  border: 1px solid rgba(0, 0, 0, 0.13) !important;
  background: #fbfaf8 !important;
  overflow: hidden !important;
  box-shadow: none !important;
}

.single-body .lo-internal-embed__image,
.entry-content .lo-internal-embed__image {
  display: block !important;
  flex: 0 0 300px !important;
  width: 300px !important;
  height: 169px !important;
  max-width: 300px !important;
  min-height: 169px !important;
  margin: 0 !important;
  overflow: hidden !important;
  background: #efede9 !important;
}

.single-body .lo-internal-embed__thumb,
.entry-content .lo-internal-embed__thumb {
  display: block !important;
  width: 300px !important;
  height: 169px !important;
  max-width: none !important;
  object-fit: cover !important;
}

.single-body .lo-internal-embed__body,
.entry-content .lo-internal-embed__body {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  padding: 18px 22px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.single-body .lo-internal-embed__label,
.entry-content .lo-internal-embed__label {
  margin: 0 0 7px !important;
}

.single-body .lo-internal-embed__title,
.entry-content .lo-internal-embed__title {
  margin: 0 !important;
  font-size: clamp(1.05rem, 1.35vw, 1.28rem) !important;
  line-height: 1.22 !important;
}

.single-body .lo-internal-embed__title br,
.entry-content .lo-internal-embed__title br {
  display: none !important;
}

.single-body .lo-internal-embed__excerpt,
.entry-content .lo-internal-embed__excerpt {
  margin: 8px 0 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.9rem !important;
  line-height: 1.45 !important;
  color: var(--gray-600) !important;
}

.single-body .lo-internal-embed__source,
.entry-content .lo-internal-embed__source {
  margin-top: 8px;
  font-family: var(--sans);
  font-size: 0.75rem;
  line-height: 1.2;
  color: var(--gray-500);
}

.single-body .lo-internal-embed--noimage,
.entry-content .lo-internal-embed--noimage {
  display: block !important;
  min-height: 0 !important;
}

.single-body .lo-internal-embed--noimage .lo-internal-embed__body,
.entry-content .lo-internal-embed--noimage .lo-internal-embed__body {
  padding: 18px 22px !important;
}

@media (max-width: 720px) {
  .single-body .lo-internal-embed,
  .entry-content .lo-internal-embed {
    display: block !important;
  }

  .single-body .lo-internal-embed__image,
  .entry-content .lo-internal-embed__image,
  .single-body .lo-internal-embed__thumb,
  .entry-content .lo-internal-embed__thumb {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
  }
}

/* v1.7.5 — oEmbed interne : image simple contrôlée, sans wrapper picture/WebP */
.single-body .lo-internal-embed,
.entry-content .lo-internal-embed {
  align-items: stretch !important;
}

.single-body .lo-internal-embed__image,
.entry-content .lo-internal-embed__image {
  display: block !important;
  flex: 0 0 300px !important;
  width: 300px !important;
  min-width: 300px !important;
  max-width: 300px !important;
  height: auto !important;
  min-height: 169px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #efede9 !important;
}

.single-body .lo-internal-embed__image .lo-internal-embed__thumb,
.entry-content .lo-internal-embed__image .lo-internal-embed__thumb {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 169px !important;
  max-width: none !important;
  margin: 0 !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.single-body .lo-internal-embed__image .lo-lazy-media,
.entry-content .lo-internal-embed__image .lo-lazy-media,
.single-body .lo-internal-embed__image picture,
.entry-content .lo-internal-embed__image picture {
  display: contents !important;
}

.single-body .lo-internal-embed > p,
.entry-content .lo-internal-embed > p,
.single-body .lo-internal-embed__image > br,
.entry-content .lo-internal-embed__image > br,
.single-body .lo-internal-embed__body > p:empty,
.entry-content .lo-internal-embed__body > p:empty {
  display: none !important;
}

@media (max-width: 720px) {
  .single-body .lo-internal-embed__image,
  .entry-content .lo-internal-embed__image {
    display: none !important;
  }
}

/* Unified card hover states: image hover also highlights title */
.hero-main:hover .hero-title a,
.hero-main:focus-within .hero-title a,
.sidebar-article:hover .sidebar-title a,
.sidebar-article:focus-within .sidebar-title a,
.article-card:hover .article-title a,
.article-card:focus-within .article-title a,
.category-card:hover .category-card-title a,
.category-card:focus-within .category-card-title a,
.author-article:hover .author-article-title a,
.author-article:focus-within .author-article-title a,
.list-item:hover .list-title a,
.list-item:focus-within .list-title a {
  color: var(--red);
}

.sidebar-title a,
.article-title a,
.category-card-title a,
.author-article-title a,
.list-title a,
.hero-title a {
  transition: color 0.2s ease;
}

.category-card:hover .category-card-img img,
.category-card:focus-within .category-card-img img,
.author-article:hover .author-article-img img,
.author-article:focus-within .author-article-img img,
.list-item:hover .list-img img,
.list-item:focus-within .list-img img {
  transform: scale(1.04);
}

.list-img img {
  transition: transform 0.35s ease;
}

/* WooCommerce product page - intégration thème Les Observateurs */
.product-main .woocommerce-notices-wrapper { max-width: var(--container-max); margin: 0 auto 18px; padding: 0 40px; }
.product-main-cover { width: 100%; height: auto; display: block; }
.product-cover-placeholder { min-height: 480px; display: grid; place-items: center; }
.product-cart-row form.cart { display: flex; align-items: center; gap: 14px; width: 100%; margin: 0; }
.product-cart-row .quantity { display: flex; align-items: center; }
.product-cart-row .qty { width: 76px; min-height: 44px; border: var(--border); text-align: center; font-family: var(--sans); font-size: 15px; }
.product-cart-row .single_add_to_cart_button { min-height: 44px; padding: 0 22px; border: 0; background: var(--red); color: var(--white); font-family: var(--sans); font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; transition: background .25s ease, transform .25s ease; }
.product-cart-row .single_add_to_cart_button:hover,
.product-cart-row .single_add_to_cart_button:focus-visible { background: var(--black); transform: translateY(-1px); }
.product-cart-row .single_add_to_cart_button.disabled,
.product-cart-row .single_add_to_cart_button:disabled { cursor: not-allowed; opacity: .55; transform: none; }
.product-stock--out { color: #9b1c1c; }
.product-stock--out::before { background: #9b1c1c; }
.product-meta-link { border: 0; background: transparent; padding: 0; font-family: var(--sans); }
.woocommerce div.product form.cart .variations { margin-bottom: 18px; }
.woocommerce div.product form.cart .variations select { min-height: 42px; border: var(--border); padding: 0 12px; background: var(--white); }
.product-full-desc .woocommerce-tabs { display: none; }
.product-main .related.products { max-width: var(--container-max); margin: 0 auto; padding: 0 40px 60px; }
.product-main .related.products > h2 { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--black); margin: 0 0 24px; padding-bottom: 10px; border-bottom: 2px solid var(--black); }

@media (max-width: 900px) {
  .product-main .woocommerce-notices-wrapper { padding: 0 20px; }
  .product-cart-row form.cart { align-items: stretch; }
}

@media (max-width: 600px) {
  .product-cart-row form.cart { flex-direction: column; }
  .product-cart-row .quantity,
  .product-cart-row .qty,
  .product-cart-row .single_add_to_cart_button { width: 100%; }
  .product-main .woocommerce-notices-wrapper { padding: 0 16px; }
}

/* WooCommerce produit - nettoyage bloc achat / miniature simple */
.product-cart-row .stock,
.product-cart-row p.stock,
.product-cart-row .woocommerce-variation-availability {
  display: none !important;
}

.product-cart-row form.cart {
  display: grid;
  grid-template-columns: 84px 96px 84px minmax(220px, 1fr);
  align-items: stretch;
  gap: 0;
  width: 100%;
  margin: 0;
}

.product-cart-row .lo-qty-btn,
.product-cart-row .quantity .qty {
  min-height: 64px;
  border: 1px solid var(--gray-200);
  background: var(--white);
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 700;
  text-align: center;
  border-radius: 0;
  box-shadow: none;
}

.product-cart-row .lo-qty-btn {
  cursor: pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.product-cart-row .lo-qty-btn:hover,
.product-cart-row .lo-qty-btn:focus-visible {
  background: var(--gray-100);
  color: var(--red);
  border-color: var(--gray-300);
}

.product-cart-row .quantity {
  display: block;
  margin: 0;
}

.product-cart-row .quantity .qty,
.woocommerce .product-cart-row .quantity .qty {
  width: 100%;
  height: 64px;
  min-height: 64px;
  padding: 0;
  appearance: textfield;
  -moz-appearance: textfield;
}

.product-cart-row .quantity .qty::-webkit-outer-spin-button,
.product-cart-row .quantity .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.product-cart-row .single_add_to_cart_button,
.woocommerce .product-cart-row .single_add_to_cart_button.button,
.woocommerce .product-cart-row .single_add_to_cart_button.button.alt {
  min-height: 64px;
  width: 100%;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--red) !important;
  color: var(--white) !important;
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 28px;
  box-shadow: none !important;
  transition: background .25s ease, transform .25s ease;
}

.product-cart-row .single_add_to_cart_button::before,
.woocommerce .product-cart-row .single_add_to_cart_button.button::before {
  content: '';
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'%2F%3E%3Ccircle cx='20' cy='21' r='1'%2F%3E%3Cpath d='M1 1h4l2.7 13.4a2 2 0 0 0 2 1.6h9.7a2 2 0 0 0 2-1.6L23 6H6'%2F%3E%3C%2Fsvg%3E");
}

.product-cart-row .single_add_to_cart_button:hover,
.product-cart-row .single_add_to_cart_button:focus-visible,
.woocommerce .product-cart-row .single_add_to_cart_button.button:hover,
.woocommerce .product-cart-row .single_add_to_cart_button.button:focus-visible {
  background: var(--black) !important;
  transform: translateY(-1px);
}

.product-cart-row .single_add_to_cart_button.disabled,
.product-cart-row .single_add_to_cart_button:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
}

.product-short-desc {
  border-bottom: 1px solid var(--gray-200);
}

.product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.product-thumb picture,
.product-thumb source {
  display: contents;
}

@media (max-width: 900px) {
  .product-cart-row form.cart {
    grid-template-columns: 64px 80px 64px minmax(180px, 1fr);
  }
}

@media (max-width: 600px) {
  .product-cart-row form.cart {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0;
  }

  .product-cart-row .single_add_to_cart_button,
  .woocommerce .product-cart-row .single_add_to_cart_button.button,
  .woocommerce .product-cart-row .single_add_to_cart_button.button.alt {
    grid-column: 1 / -1;
    margin-top: 12px;
  }
}

/* Résultats de recherche séparés : articles / produits */
.search-split-content {
  display: flex;
  flex-direction: column;
  gap: 56px;
}

.search-results-section + .search-results-section {
  border-top: var(--border);
  padding-top: 48px;
}

.search-section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 28px;
  padding-bottom: 18px;
  border-bottom: 3px solid var(--black);
}

.search-section-heading h2 {
  font-family: var(--serif);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  line-height: 1;
  color: var(--black);
  letter-spacing: -0.03em;
}

.search-section-heading span {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gray-500);
  white-space: nowrap;
}

.search-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.search-product-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: var(--border);
  transition: box-shadow 0.35s ease;
}

.search-product-card:hover,
.search-product-card:focus-within {
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
}

.search-product-card__image {
  display: block;
  background: var(--gray-100);
  overflow: hidden;
  padding: 24px;
}

.search-product-card__image img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 360px;
  object-fit: contain;
  margin: 0 auto;
  transition: transform 0.35s ease;
}

.search-product-card:hover .search-product-card__image img,
.search-product-card:focus-within .search-product-card__image img {
  transform: scale(1.03);
}

.search-product-card__body {
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.search-product-card__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
}

.search-product-card__title {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--black);
  letter-spacing: -0.02em;
}

.search-product-card__title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.25s ease;
}

.search-product-card:hover .search-product-card__title a,
.search-product-card:focus-within .search-product-card__title a {
  color: var(--red);
}

.search-product-card__subtitle {
  font-family: var(--body-serif);
  font-size: 15px;
  line-height: 1.45;
  color: var(--gray-600);
  font-style: italic;
}

.search-product-card__price {
  margin-top: auto;
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--black);
}

.search-product-card__cta {
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--red);
  text-decoration: none;
}

.search-product-card__cta:hover,
.search-product-card__cta:focus-visible {
  color: var(--red-dark);
}

@media (max-width: 999px) {
  .search-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
  }
}

@media (max-width: 640px) {
  .search-split-content {
    gap: 40px;
  }

  .search-results-section + .search-results-section {
    padding-top: 36px;
  }

  .search-section-heading {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }

  .search-product-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* Prix WooCommerce unifiés */
.lo-price,
.product-price .lo-price,
.search-product-card__price .lo-price,
.woocommerce .price .lo-price {
  display: inline-flex;
  align-items: baseline;
  gap: 0.35em;
  font-family: "Playfair Display", var(--serif);
  line-height: 1;
  white-space: nowrap;
}

.lo-price__amount {
  color: var(--black);
  font-size: 1em;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.lo-price__currency {
  color: var(--gray-500);
  font-size: 0.5em;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.product-price {
  font-family: "Playfair Display", var(--serif);
  font-size: 34px;
  margin-bottom: 24px;
}

.search-product-card__price {
  font-family: "Playfair Display", var(--serif);
  font-size: 28px;
}

.book-price,
.sidebar-shop-price {
  font-family: "Playfair Display", var(--serif);
}

.lo-price-sale {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
}

.lo-price-sale del {
  color: var(--gray-500);
  text-decoration-thickness: 1px;
  opacity: 0.75;
}

.lo-price-sale ins {
  text-decoration: none;
}

.lo-price-range {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
}

.lo-price-range__prefix {
  font-family: var(--sans);
  font-size: 0.35em;
  font-weight: 700;
  color: var(--gray-500);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 720px) {
  .product-price {
    font-size: 30px;
  }

  .search-product-card__price {
    font-size: 24px;
  }
}


/* v1.8.6 - Prix produit plus sobre + icône panier SVG contrôlée */
.woocommerce div.product .product-price {
  font-size: 34px;
}

.woocommerce div.product .product-price .lo-price__currency {
  color: var(--gray-500);
  font-size: 0.52em;
}

@media (max-width: 720px) {
  .woocommerce div.product .product-price {
    font-size: 30px;
  }
}

/* v1.8.7 - Alignement strict page produit sur la maquette HTML */
.woocommerce div.product .product-price,
.product-price {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 20px;
  display: flex;
  align-items: baseline;
  gap: 8px;
  line-height: 1;
}

.woocommerce div.product .product-price .lo-price,
.product-price .lo-price {
  gap: 8px;
}

.woocommerce div.product .product-price .lo-price__amount,
.product-price .lo-price__amount {
  font-size: 1em;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.woocommerce div.product .product-price .lo-price__currency,
.product-price .lo-price__currency,
.product-price .currency {
  font-size: 16px;
  font-weight: 600;
  color: var(--gray-500);
  letter-spacing: 0.02em;
}

.product-cart-row form.cart,
.woocommerce div.product .product-cart-row form.cart {
  display: grid;
  grid-template-columns: 44px 52px 44px minmax(220px, 1fr);
  align-items: stretch;
  column-gap: 0;
  width: 100%;
  margin: 0;
}

.product-cart-row .lo-qty-btn,
.product-cart-row .quantity .qty,
.woocommerce .product-cart-row .quantity .qty {
  width: 100%;
  height: 48px;
  min-height: 48px;
  border: var(--border);
  background: var(--white);
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  border-radius: 0;
  box-shadow: none;
}

.product-cart-row .lo-qty-btn {
  background: var(--gray-100);
  font-size: 18px;
  cursor: pointer;
}

.product-cart-row .lo-qty-btn:hover,
.product-cart-row .lo-qty-btn:focus-visible {
  background: var(--gray-300);
  color: var(--black);
  border-color: #E2DDD8;
}

.product-cart-row .quantity {
  display: block;
  margin: 0;
}

.product-cart-row .quantity .qty {
  border-left: 0;
  border-right: 0;
  appearance: textfield;
  -moz-appearance: textfield;
}

.product-cart-row .single_add_to_cart_button,
.woocommerce .product-cart-row .single_add_to_cart_button.button,
.woocommerce .product-cart-row .single_add_to_cart_button.button.alt {
  min-height: 48px;
  height: 48px;
  width: 100%;
  margin-left: 28px;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--red) !important;
  color: var(--white) !important;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 28px;
  box-shadow: none !important;
  transition: background 0.3s ease;
}

.product-cart-row .single_add_to_cart_button::before,
.woocommerce .product-cart-row .single_add_to_cart_button.button::before {
  content: '';
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E");
}

.product-cart-row .single_add_to_cart_button:hover,
.product-cart-row .single_add_to_cart_button:focus-visible,
.woocommerce .product-cart-row .single_add_to_cart_button.button:hover,
.woocommerce .product-cart-row .single_add_to_cart_button.button:focus-visible {
  background: var(--red-dark) !important;
  transform: none;
}

@media (max-width: 600px) {
  .woocommerce div.product .product-price,
  .product-price {
    font-size: 24px;
  }

  .woocommerce div.product .product-price .lo-price__currency,
  .product-price .lo-price__currency,
  .product-price .currency {
    font-size: 14px;
  }

  .product-cart-row form.cart,
  .woocommerce div.product .product-cart-row form.cart {
    grid-template-columns: 44px 52px 44px;
    width: max-content;
    max-width: 100%;
  }

  .product-cart-row .single_add_to_cart_button,
  .woocommerce .product-cart-row .single_add_to_cart_button.button,
  .woocommerce .product-cart-row .single_add_to_cart_button.button.alt {
    grid-column: 1 / -1;
    width: calc(100vw - 32px);
    max-width: 100%;
    margin-left: 0;
    margin-top: 14px;
  }
}

/* Product page breakpoint hardening — keep two columns until real mobile */
@media (min-width: 769px) and (max-width: 999px) {
  .single-product .product-layout,
  .woocommerce.single-product .product-layout,
  body.single-product .product-layout {
    display: grid !important;
    grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr) !important;
    gap: 36px !important;
    align-items: start !important;
  }

  .single-product .product-gallery,
  .woocommerce.single-product .product-gallery,
  body.single-product .product-gallery,
  .single-product .product-info,
  .woocommerce.single-product .product-info,
  body.single-product .product-info {
    min-width: 0;
  }

  .single-product .product-main-img img,
  .woocommerce.single-product .product-main-img img,
  body.single-product .product-main-img img {
    width: 100%;
    height: auto;
  }
}

@media (max-width: 768px) {
  .single-product .product-layout,
  .woocommerce.single-product .product-layout,
  body.single-product .product-layout {
    grid-template-columns: 1fr !important;
  }
}

/* v1.9.1 - Recherche produits : sélecteurs renforcés */
.search-results-section--products #search-products-title,
.search-results-section--products .search-section-heading h2 {
  font-family: var(--serif);
  font-size: 36px !important;
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.search-results-section--products .search-product-card__image {
  display: block;
  padding: 0 !important;
  background: transparent !important;
  overflow: hidden;
}

.search-results-section--products .search-product-card__image img {
  display: block;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain;
  margin: 0 !important;
}

@media (max-width: 720px) {
  .search-results-section--products #search-products-title,
  .search-results-section--products .search-section-heading h2 {
    font-size: 30px !important;
  }
}


/* v1.9.2 - Recherche : titres sections + image produit nette */
.search-results-section--articles #search-articles-title,
.search-results-section--articles .search-section-heading h2,
.search-results-section--products #search-products-title,
.search-results-section--products .search-section-heading h2 {
  font-family: var(--serif);
  font-size: 36px !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}

.search-product-card__image,
.search-results-section--products .search-product-card__image {
  display: block !important;
  padding: 0 !important;
  background: transparent !important;
  overflow: hidden !important;
}

.search-product-card__image img,
.search-results-section--products .search-product-card__image img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  margin: 0 !important;
  image-rendering: auto;
}

@media (max-width: 720px) {
  .search-results-section--articles #search-articles-title,
  .search-results-section--articles .search-section-heading h2,
  .search-results-section--products #search-products-title,
  .search-results-section--products .search-section-heading h2 {
    font-size: 30px !important;
  }
}


/* WooCommerce notices — native styling */
.woocommerce-notices-wrapper {
  margin: 0 0 32px;
}

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error,
.woocommerce-page .woocommerce-message,
.woocommerce-page .woocommerce-info,
.woocommerce-page .woocommerce-error,
.single-product .woocommerce-message,
.single-product .woocommerce-info,
.single-product .woocommerce-error {
  position: relative;
  background: #F5F4F1 !important;
  border: 1px solid #E2DDD8 !important;
  border-left: 4px solid #2d7d3a !important;
  border-top: 1px solid #E2DDD8 !important;
  color: var(--gray-700) !important;
  padding: 18px 22px 18px 54px !important;
  margin: 0 0 32px !important;
  font-family: var(--sans) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
  box-shadow: none !important;
  outline: none !important;
}

.woocommerce .woocommerce-info,
.woocommerce-page .woocommerce-info,
.single-product .woocommerce-info {
  border-left-color: var(--gray-500) !important;
}

.woocommerce .woocommerce-error,
.woocommerce-page .woocommerce-error,
.single-product .woocommerce-error {
  border-left-color: var(--red) !important;
}

.woocommerce .woocommerce-message::before,
.woocommerce-page .woocommerce-message::before,
.single-product .woocommerce-message::before {
  top: 18px !important;
  left: 22px !important;
  color: #2d7d3a !important;
}

.woocommerce .woocommerce-info::before,
.woocommerce-page .woocommerce-info::before,
.single-product .woocommerce-info::before {
  top: 18px !important;
  left: 22px !important;
  color: var(--gray-500) !important;
}

.woocommerce .woocommerce-error::before,
.woocommerce-page .woocommerce-error::before,
.single-product .woocommerce-error::before {
  top: 18px !important;
  left: 22px !important;
  color: var(--red) !important;
}

.woocommerce .woocommerce-message .button,
.woocommerce .woocommerce-info .button,
.woocommerce .woocommerce-error .button,
.woocommerce-page .woocommerce-message .button,
.woocommerce-page .woocommerce-info .button,
.woocommerce-page .woocommerce-error .button,
.single-product .woocommerce-message .button,
.single-product .woocommerce-info .button,
.single-product .woocommerce-error .button {
  float: right;
  background: rgba(0,0,0,0.06) !important;
  color: var(--gray-700) !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  padding: 10px 18px !important;
  line-height: 1.2 !important;
  box-shadow: none !important;
}

.woocommerce .woocommerce-message .button:hover,
.woocommerce .woocommerce-info .button:hover,
.woocommerce .woocommerce-error .button:hover,
.woocommerce-page .woocommerce-message .button:hover,
.woocommerce-page .woocommerce-info .button:hover,
.woocommerce-page .woocommerce-error .button:hover,
.single-product .woocommerce-message .button:hover,
.single-product .woocommerce-info .button:hover,
.single-product .woocommerce-error .button:hover {
  background: var(--red) !important;
  color: #fff !important;
}

@media (max-width: 600px) {
  .woocommerce .woocommerce-message,
  .woocommerce .woocommerce-info,
  .woocommerce .woocommerce-error,
  .woocommerce-page .woocommerce-message,
  .woocommerce-page .woocommerce-info,
  .woocommerce-page .woocommerce-error,
  .single-product .woocommerce-message,
  .single-product .woocommerce-info,
  .single-product .woocommerce-error {
    padding: 16px 18px 16px 48px !important;
    font-size: 14px !important;
  }

  .woocommerce .woocommerce-message .button,
  .woocommerce .woocommerce-info .button,
  .woocommerce .woocommerce-error .button,
  .woocommerce-page .woocommerce-message .button,
  .woocommerce-page .woocommerce-info .button,
  .woocommerce-page .woocommerce-error .button,
  .single-product .woocommerce-message .button,
  .single-product .woocommerce-info .button,
  .single-product .woocommerce-error .button {
    float: none;
    display: block;
    width: 100%;
    margin: 12px 0 0;
    text-align: center;
  }
}

/* Boutique home — book cover image fix */
.book-cover {
  display: block;
}

.book-cover > img,
.book-cover .book-cover-img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
}

.book-cover picture,
.book-cover picture img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
}

.book-cover picture img {
  object-fit: cover;
}


/* WooCommerce shop archive — centre de page calé sur boutique.html */
.woocommerce-shop-page {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 32px 40px 80px;
}

.woocommerce-shop-page .shop-header {
  margin-bottom: 32px;
}

.woocommerce-shop-page .shop-title {
  font-family: var(--serif);
  font-size: 36px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: -0.5px;
  line-height: 1.15;
  margin-bottom: 8px;
}

.woocommerce-shop-page .shop-desc {
  font-family: var(--body-serif);
  font-size: 16px;
  line-height: 1.7;
  color: var(--gray-500);
  font-weight: 300;
}

.woocommerce-shop-page .shop-desc p {
  margin: 0;
}

.woocommerce-shop-page .shop-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: var(--border);
  flex-wrap: wrap;
}

.woocommerce-shop-page .shop-result-count,
.woocommerce-shop-page .woocommerce-result-count {
  float: none !important;
  margin: 0 !important;
  font-size: 13px;
  color: var(--gray-500);
  white-space: nowrap;
}

.woocommerce-shop-page .shop-filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
}

.woocommerce-shop-page .shop-filter-label {
  font-size: 13px;
  color: var(--gray-500);
}

.woocommerce-shop-page .woocommerce-ordering {
  float: none !important;
  margin: 0 !important;
}

.woocommerce-shop-page .woocommerce-ordering select,
.woocommerce-shop-page .orderby {
  min-width: 180px;
  height: 38px;
  border: var(--border);
  background: var(--white);
  color: var(--gray-700);
  font-family: var(--sans);
  font-size: 13px;
  padding: 0 34px 0 12px;
  outline: none;
  border-radius: 0;
}

.woocommerce-shop-page .books-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.woocommerce-shop-page .lo-shop-product-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  color: inherit;
  min-width: 0;
}

.woocommerce-shop-page .lo-shop-product-card__cover {
  aspect-ratio: 2 / 3;
  background: var(--white);
  border: var(--border);
  position: relative;
  overflow: hidden;
  display: block;
  width: 100%;
}

.woocommerce-shop-page .lo-shop-product-card__cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.woocommerce-shop-page .lo-shop-product-card__cover .book-cover-placeholder {
  background: var(--gray-100);
}

.woocommerce-shop-page .lo-shop-product-card:hover .lo-shop-product-card__cover {
  border-color: var(--gray-700);
}

.woocommerce-shop-page .lo-shop-product-card:hover .lo-shop-product-card__cover::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.04);
  pointer-events: none;
}

.woocommerce-shop-page .lo-shop-product-card__title {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black);
  margin: 0;
}

.woocommerce-shop-page .lo-shop-product-card__title a:hover,
.woocommerce-shop-page .lo-shop-product-card:hover .lo-shop-product-card__title a {
  color: var(--red);
}

.woocommerce-shop-page .lo-shop-product-card__subtitle {
  font-family: var(--body-serif);
  font-size: 14px;
  font-style: italic;
  line-height: 1.45;
  color: var(--gray-700);
  margin: -4px 0 0;
}

.woocommerce-shop-page .book-author {
  font-size: 12px;
  color: var(--gray-500);
  font-weight: 500;
}

.woocommerce-shop-page .book-price {
  margin-top: auto;
}

.woocommerce-shop-page .book-price .lo-price,
.woocommerce-shop-page .book-price .lo-price-amount {
  font-family: var(--serif);
}

.woocommerce-shop-page .book-price .lo-price__amount,
.woocommerce-shop-page .book-price .lo-price-amount {
  font-size: 20px;
  font-weight: 700;
  color: var(--black);
  line-height: 1;
}

.woocommerce-shop-page .book-price .lo-price__currency,
.woocommerce-shop-page .book-price .lo-price-currency {
  font-size: 11px;
  font-weight: 700;
  color: var(--gray-500);
  margin-left: 4px;
  text-transform: uppercase;
}

.woocommerce-shop-page .lo-shop-product-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  background: var(--black);
  color: #fff;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 11px 16px;
  border: none;
  transition: background 0.25s ease;
}

.woocommerce-shop-page .lo-shop-product-card__btn:hover {
  background: var(--red);
  color: #fff;
}

.woocommerce-shop-page .shop-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 56px;
}

.woocommerce-shop-page .woocommerce-pagination ul,
.woocommerce-shop-page .woocommerce-pagination ul.page-numbers {
  border: none !important;
  display: flex;
  gap: 4px;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-shop-page .woocommerce-pagination ul li {
  border: none !important;
  list-style: none;
}

.woocommerce-shop-page .woocommerce-pagination .page-numbers {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px !important;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-700);
  border: var(--border) !important;
  background: var(--white) !important;
  line-height: 1 !important;
}

.woocommerce-shop-page .woocommerce-pagination .page-numbers.current {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #fff !important;
}

.woocommerce-shop-page .woocommerce-pagination .page-numbers:hover {
  background: var(--gray-100) !important;
  border-color: var(--gray-700) !important;
}

@media (max-width: 999px) {
  .woocommerce-shop-page {
    padding: 24px 20px 60px;
  }

  .woocommerce-shop-page .books-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
}

@media (max-width: 600px) {
  .woocommerce-shop-page {
    padding: 16px 16px 48px;
  }

  .woocommerce-shop-page .shop-title {
    font-size: 28px;
  }

  .woocommerce-shop-page .shop-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .woocommerce-shop-page .shop-filter-group,
  .woocommerce-shop-page .woocommerce-ordering,
  .woocommerce-shop-page .woocommerce-ordering select,
  .woocommerce-shop-page .orderby {
    width: 100%;
  }

  .woocommerce-shop-page .books-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .woocommerce-shop-page .lo-shop-product-card__title {
    font-size: 15px;
  }

  .woocommerce-shop-page .lo-shop-product-card__btn {
    font-size: 11px;
    padding-left: 10px;
    padding-right: 10px;
  }
}


/* WooCommerce notices — success button */
.woocommerce .woocommerce-message .button,
.woocommerce-page .woocommerce-message .button,
.single-product .woocommerce-message .button,
.woocommerce-notices-wrapper .woocommerce-message .button,
.woocommerce .woocommerce-message a.button,
.woocommerce-page .woocommerce-message a.button,
.single-product .woocommerce-message a.button,
.woocommerce-notices-wrapper .woocommerce-message a.button {
  background: var(--success) !important;
  color: #fff !important;
  border: none !important;
}

.woocommerce .woocommerce-message .button:hover,
.woocommerce-page .woocommerce-message .button:hover,
.single-product .woocommerce-message .button:hover,
.woocommerce-notices-wrapper .woocommerce-message .button:hover,
.woocommerce .woocommerce-message a.button:hover,
.woocommerce-page .woocommerce-message a.button:hover,
.single-product .woocommerce-message a.button:hover,
.woocommerce-notices-wrapper .woocommerce-message a.button:hover {
  background: #256730 !important;
  color: #fff !important;
}


/* Sidebar shop widget — product cover fix */
.article-sidebar .sidebar-shop-item {
  align-items: flex-start;
}

.article-sidebar .sidebar-shop-cover {
  width: 128px;
  height: auto;
  min-height: 0;
  background: #fff;
  border: var(--border);
  flex-shrink: 0;
  overflow: visible;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.article-sidebar .sidebar-shop-cover .lo-lazy-media,
.article-sidebar .sidebar-shop-cover picture,
.article-sidebar .sidebar-shop-cover img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

.article-sidebar .sidebar-shop-cover img {
  object-fit: contain;
  object-position: center top;
}

@media (max-width: 900px) {
  .article-sidebar .sidebar-shop-cover {
    width: 96px;
  }
}

/* ═══════════════════════════════════════════════════════════
   42. WOOCOMMERCE — PANIER
   Habillage natif WooCommerce, sans surcharge de template
   ═══════════════════════════════════════════════════════════ */

.woocommerce-cart .page-layout {
  max-width: var(--container-max);
  padding: 32px var(--gutter-desktop) 80px;
}

.woocommerce-cart .page-body {
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  color: var(--gray-900);
}

.woocommerce-cart .page-body > .woocommerce {
  width: 100%;
}

.woocommerce-cart .page-hero {
  margin-bottom: 28px;
}

.woocommerce-cart .woocommerce-cart-form {
  width: min(100%, 820px);
  float: left;
}

.woocommerce-cart .cart-collaterals {
  width: calc(100% - 860px);
  max-width: 360px;
  float: right;
  margin-left: 40px;
}

.woocommerce-cart table.shop_table {
  width: 100%;
  border: var(--border) !important;
  border-collapse: collapse;
  border-radius: 0 !important;
  margin: 0 0 28px !important;
  background: var(--white);
  font-family: var(--sans);
}

.woocommerce-cart table.shop_table thead {
  background: var(--gray-100);
}

.woocommerce-cart table.shop_table th {
  padding: 14px 16px !important;
  border-bottom: var(--border) !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--gray-700);
  line-height: 1.3;
}

.woocommerce-cart table.shop_table td {
  padding: 18px 16px !important;
  border-top: none !important;
  border-bottom: var(--border) !important;
  font-size: 14px;
  color: var(--gray-700);
  vertical-align: middle;
}

.woocommerce-cart table.shop_table tr:last-child td {
  border-bottom: none !important;
}

.woocommerce-cart table.cart img {
  width: 64px !important;
  height: auto !important;
  max-height: 92px;
  object-fit: contain;
  border: var(--border);
  background: var(--white);
  display: block;
}

.woocommerce-cart table.cart .product-name a {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--black);
  border: none;
}

.woocommerce-cart table.cart .product-name a:hover {
  color: var(--red);
}

.woocommerce-cart table.cart .product-price,
.woocommerce-cart table.cart .product-subtotal {
  font-weight: 700;
  color: var(--black);
  white-space: nowrap;
}

.woocommerce-cart table.cart .product-remove a.remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 0;
  color: var(--gray-500) !important;
  background: var(--gray-100);
  font-size: 20px;
  font-weight: 400;
  line-height: 1;
  border: none;
}

.woocommerce-cart table.cart .product-remove a.remove:hover {
  color: #fff !important;
  background: var(--red) !important;
}

.woocommerce-cart .quantity .qty {
  width: 72px;
  min-height: 42px;
  border: var(--border);
  background: var(--white);
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  outline: none;
}

.woocommerce-cart .quantity .qty:focus {
  border-color: var(--black);
}

.woocommerce-cart table.cart td.actions {
  padding: 18px !important;
  background: var(--white);
}

.woocommerce-cart table.cart td.actions .coupon {
  display: flex;
  gap: 10px;
  align-items: center;
}

.woocommerce-cart table.cart td.actions .coupon .input-text {
  width: 220px !important;
  min-height: 44px;
  border: var(--border);
  background: var(--white);
  padding: 0 14px;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--gray-900);
  outline: none;
}

.woocommerce-cart table.cart td.actions .coupon .input-text:focus {
  border-color: var(--black);
}

.woocommerce-cart .button,
.woocommerce-cart a.button,
.woocommerce-cart button.button,
.woocommerce-cart input.button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: var(--sans) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
  padding: 14px 20px !important;
  background: var(--black) !important;
  color: #fff !important;
  transition: background 0.25s ease, opacity 0.25s ease;
}

.woocommerce-cart .button:hover,
.woocommerce-cart a.button:hover,
.woocommerce-cart button.button:hover,
.woocommerce-cart input.button:hover {
  background: var(--red) !important;
  color: #fff !important;
}

.woocommerce-cart button.button:disabled,
.woocommerce-cart button.button:disabled[disabled] {
  opacity: 0.45 !important;
  cursor: not-allowed;
}

.woocommerce-cart .cart_totals {
  width: 100% !important;
  float: none !important;
  border: var(--border);
  background: var(--white);
  padding: 0;
}

.woocommerce-cart .cart_totals h2 {
  margin: 0;
  padding: 16px 20px;
  border-bottom: var(--border);
  background: var(--gray-100);
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--black);
}

.woocommerce-cart .cart_totals table.shop_table {
  border: none !important;
  margin: 0 !important;
}

.woocommerce-cart .cart_totals table.shop_table th,
.woocommerce-cart .cart_totals table.shop_table td {
  padding: 14px 20px !important;
  border-bottom: var(--border) !important;
  font-size: 14px;
}

.woocommerce-cart .cart_totals table.shop_table th {
  background: transparent;
  letter-spacing: 0;
  text-transform: none;
  font-weight: 600;
  color: var(--gray-700);
}

.woocommerce-cart .cart_totals table.shop_table td {
  text-align: right;
  color: var(--black);
  font-weight: 700;
}

.woocommerce-cart .cart_totals .order-total th,
.woocommerce-cart .cart_totals .order-total td {
  font-size: 16px;
  color: var(--black);
}

.woocommerce-cart .wc-proceed-to-checkout {
  padding: 20px !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0 !important;
  background: var(--red) !important;
  font-size: 13px !important;
  padding: 16px 20px !important;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
  background: var(--red-dark) !important;
}

.woocommerce-cart .return-to-shop .button,
.woocommerce-cart .wc-backward {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: var(--red) !important;
}

.woocommerce-cart .return-to-shop .button:hover,
.woocommerce-cart .wc-backward:hover {
  background: var(--red-dark) !important;
}

.woocommerce-cart .cross-sells {
  clear: both;
  padding-top: 40px;
}

.woocommerce-cart .cross-sells h2 {
  margin: 0 0 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--black);
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--black);
}

.woocommerce-cart .cart-empty.woocommerce-info {
  margin-bottom: 24px !important;
}

@media (max-width: 1100px) {
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .cart-collaterals {
    width: 100%;
    max-width: none;
    float: none;
    margin-left: 0;
  }

  .woocommerce-cart .cart-collaterals {
    margin-top: 28px;
  }
}

@media (max-width: 900px) {
  .woocommerce-cart .page-layout {
    padding: 24px var(--gutter-tablet) 60px;
  }
}

@media (max-width: 768px) {
  .woocommerce-cart table.shop_table_responsive tr,
  .woocommerce-page.woocommerce-cart table.shop_table_responsive tr {
    border-bottom: var(--border);
  }

  .woocommerce-cart table.shop_table_responsive tr td,
  .woocommerce-page.woocommerce-cart table.shop_table_responsive tr td {
    display: block;
    text-align: right !important;
    padding: 14px 16px !important;
    border-bottom: 1px solid rgba(226,221,216,0.65) !important;
  }

  .woocommerce-cart table.shop_table_responsive tr td::before,
  .woocommerce-page.woocommerce-cart table.shop_table_responsive tr td::before {
    font-weight: 700;
    color: var(--gray-700);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 11px;
  }

  .woocommerce-cart table.cart .product-thumbnail {
    display: block !important;
    text-align: left !important;
  }

  .woocommerce-cart table.cart .product-thumbnail::before {
    display: none;
  }

  .woocommerce-cart table.cart img {
    width: 82px !important;
    margin-left: auto;
  }

  .woocommerce-cart table.cart td.actions .coupon {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    padding-bottom: 12px;
  }

  .woocommerce-cart table.cart td.actions .coupon .input-text,
  .woocommerce-cart table.cart td.actions .coupon .button,
  .woocommerce-cart table.cart td.actions > .button {
    width: 100% !important;
  }
}

@media (max-width: 600px) {
  .woocommerce-cart .page-layout {
    padding: 16px var(--gutter-mobile) 48px;
  }

  .woocommerce-cart .page-title {
    font-size: 30px;
  }

  .woocommerce-cart table.shop_table th,
  .woocommerce-cart table.shop_table td {
    font-size: 13px;
  }
}

/* ═══════════════════════════════════════════════════════════
   42. WOO — Rappel panier + liens boutique menu
   ═══════════════════════════════════════════════════════════ */

.nav-link--shop {
  color: var(--red);
}

.mobile-menu-link--shop {
  color: var(--red);
  font-weight: 700;
}

.lo-cart-reminder {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin: 0 0 32px;
  padding: 22px 24px;
  border: var(--border);
  border-left: 3px solid var(--red);
  background: var(--gray-100);
}

.lo-cart-reminder__content {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.lo-cart-reminder__eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
}

.lo-cart-reminder__title {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.25;
  color: var(--black);
}

.lo-cart-reminder__total {
  font-size: 14px;
  font-weight: 700;
  color: var(--gray-700);
}

.lo-cart-reminder__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  flex-shrink: 0;
}

.lo-cart-reminder__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 11px 18px;
  border: 1px solid var(--red);
  color: var(--red);
  background: var(--white);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.lo-cart-reminder__link:hover {
  background: var(--red-light);
  color: var(--red-dark);
  border-color: var(--red-dark);
}

.lo-cart-reminder__link--dark {
  background: var(--black);
  border-color: var(--black);
  color: var(--white);
}

.lo-cart-reminder__link--dark:hover {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
}

@media (max-width: 768px) {
  .lo-cart-reminder {
    align-items: stretch;
    flex-direction: column;
    padding: 20px;
  }

  .lo-cart-reminder__actions {
    justify-content: stretch;
    flex-direction: column;
    align-items: stretch;
  }

  .lo-cart-reminder__link {
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════════
   WooCommerce — panier et menu mobile boutique
   ═══════════════════════════════════════════════════════════ */

.mobile-menu-shop-panel {
  margin-top: auto;
  padding: 18px 24px;
  border-top: var(--border);
  background: var(--gray-100);
}

.mobile-menu-shop-panel__main,
.mobile-menu-shop-panel__account {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  font-size: 13px;
  color: var(--gray-700);
}

.mobile-menu-shop-panel__main {
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: var(--border);
}

.mobile-menu-shop-panel__main span,
.mobile-menu-shop-panel__account {
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.mobile-menu-shop-panel__main strong {
  font-size: 12px;
  color: var(--red);
  white-space: nowrap;
}

.mobile-menu-shop-panel__main:hover,
.mobile-menu-shop-panel__account:hover {
  color: var(--red);
}

.woocommerce-cart .woocommerce,
.woocommerce-page.woocommerce-cart .woocommerce {
  max-width: var(--container-max);
  margin: 0 auto;
}

.lo-cart-reminder {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 22px 24px;
  margin: 0 0 32px;
  border: var(--border);
  border-top: 3px solid var(--red);
  background: var(--gray-100);
}

.lo-cart-reminder__content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.lo-cart-reminder__eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
}

.lo-cart-reminder__title {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.25;
  color: var(--black);
}

.lo-cart-reminder__total {
  font-size: 13px;
  font-weight: 700;
  color: var(--gray-700);
}

.lo-cart-reminder__actions,
.lo-empty-cart-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.lo-cart-reminder__link,
.woocommerce .lo-empty-cart-button,
.woocommerce-page .lo-empty-cart-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border: var(--border);
  background: var(--white);
  color: var(--gray-700);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.lo-cart-reminder__link:hover,
.woocommerce .lo-empty-cart-button:hover,
.woocommerce-page .lo-empty-cart-button:hover {
  border-color: var(--red);
  color: var(--red);
  background: var(--white);
}

.lo-cart-reminder__link--dark,
.woocommerce .lo-empty-cart-button--account,
.woocommerce-page .lo-empty-cart-button--account {
  background: var(--black);
  border-color: var(--black);
  color: var(--white);
}

.lo-cart-reminder__link--dark:hover,
.woocommerce .lo-empty-cart-button--account:hover,
.woocommerce-page .lo-empty-cart-button--account:hover {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
}

.woocommerce-cart .cart-empty.woocommerce-info {
  border-top-color: var(--red);
  background: var(--white);
  color: var(--black);
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 700;
  line-height: 1.25;
  padding: 24px 0 24px 0;
  margin: 0 0 28px;
  border-left: 0;
  border-right: 0;
  border-bottom: var(--border);
}

@media (max-width: 900px) {
  .lo-cart-reminder {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .lo-cart-reminder__actions,
  .lo-empty-cart-actions {
    align-items: stretch;
  }

  .lo-cart-reminder__link,
  .woocommerce .lo-empty-cart-button,
  .woocommerce-page .lo-empty-cart-button {
    width: 100%;
  }
}

/* Correctif z-index menu responsive : le contenu de page ne doit jamais passer au-dessus. */
.mobile-menu-overlay {
  z-index: 1000000;
}

.mobile-menu {
  z-index: 1000001;
  isolation: isolate;
}

.mobile-menu.open {
  z-index: 1000001;
}

/* Panier rendu par le thème quand la page WooCommerce utilise un contenu instable ou mis en cache. */
.lo-cart-form,
.lo-cart-collaterals {
  position: relative;
  z-index: 1;
}

.lo-cart-form {
  width: min(100%, 820px);
  float: left;
}

.lo-cart-collaterals {
  width: 340px;
  float: right;
}

.lo-cart-table .product-thumbnail img {
  width: 72px;
  height: auto;
  object-fit: contain;
}

.lo-cart-table .product-name dl.variation {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--gray-500);
}

@media (max-width: 1100px) {
  .lo-cart-form,
  .lo-cart-collaterals {
    width: 100%;
    max-width: none;
    float: none;
  }

  .lo-cart-collaterals {
    margin-top: 28px;
  }
}

/* Correctif panier — largeur conteneur + clearing des colonnes WooCommerce */
.woocommerce-cart .page-body > .woocommerce::after,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce::after {
  content: '';
  display: table;
  clear: both;
}

@media (min-width: 1101px) {
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .woocommerce-cart-form {
    width: calc(100% - 400px);
    max-width: none;
  }

  .woocommerce-cart .cart-collaterals,
  .woocommerce-page.woocommerce-cart .cart-collaterals {
    width: 360px;
    max-width: 360px;
    margin-left: 40px;
  }
}

/* Correctif panier — suppression des floats WooCommerce et vraie grille de conteneur */
.woocommerce-cart .page-body,
.woocommerce-page.woocommerce-cart .page-body {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow: visible;
}

.woocommerce-cart .page-body > .woocommerce,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 32px;
  align-items: start;
  width: 100%;
  max-width: 100%;
  margin: 0;
  clear: both;
}

.woocommerce-cart .lo-cart-reminder,
.woocommerce-page.woocommerce-cart .lo-cart-reminder,
.woocommerce-cart .woocommerce-notices-wrapper,
.woocommerce-page.woocommerce-cart .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
}

.woocommerce-cart .woocommerce-cart-form,
.woocommerce-page.woocommerce-cart .woocommerce-cart-form,
.woocommerce-cart .lo-cart-form,
.woocommerce-page.woocommerce-cart .lo-cart-form {
  grid-column: 1;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  min-width: 0;
}

.woocommerce-cart .cart-collaterals,
.woocommerce-page.woocommerce-cart .cart-collaterals,
.woocommerce-cart .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .lo-cart-collaterals {
  grid-column: 2;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  min-width: 0;
}

.woocommerce-cart .cart-collaterals .cart_totals,
.woocommerce-page.woocommerce-cart .cart-collaterals .cart_totals {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
}

.woocommerce-cart .shop_table,
.woocommerce-page.woocommerce-cart .shop_table {
  width: 100% !important;
  max-width: 100%;
}

.woocommerce-cart .footer-support-outer,
.woocommerce-page.woocommerce-cart .footer-support-outer {
  clear: both;
}

@media (max-width: 768px) {
  .woocommerce-cart .page-body > .woocommerce,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .lo-cart-form,
  .woocommerce-page.woocommerce-cart .lo-cart-form,
  .woocommerce-cart .cart-collaterals,
  .woocommerce-page.woocommerce-cart .cart-collaterals,
  .woocommerce-cart .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .lo-cart-collaterals {
    grid-column: 1;
  }
}


/* v1.9.4 — Panier : deux colonnes jusqu’à 768px + produit aligné */
@media (min-width: 769px) {
  .woocommerce-cart .page-body > .woocommerce,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 360px !important;
    gap: 32px !important;
    align-items: start !important;
  }

  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .lo-cart-form,
  .woocommerce-page.woocommerce-cart .lo-cart-form {
    grid-column: 1 !important;
  }

  .woocommerce-cart .cart-collaterals,
  .woocommerce-page.woocommerce-cart .cart-collaterals,
  .woocommerce-cart .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .lo-cart-collaterals {
    grid-column: 2 !important;
  }
}

@media (max-width: 768px) {
  .woocommerce-cart .page-body > .woocommerce,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .lo-cart-form,
  .woocommerce-page.woocommerce-cart .lo-cart-form,
  .woocommerce-cart .cart-collaterals,
  .woocommerce-page.woocommerce-cart .cart-collaterals,
  .woocommerce-cart .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .lo-cart-collaterals {
    grid-column: 1 !important;
  }
}

/* v1.9.5 — Panier : grille appliquée au vrai conteneur rendu par page.php */
.woocommerce-cart .page-body,
.woocommerce-page.woocommerce-cart .page-body {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap: 32px !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
}

.woocommerce-cart .page-body > .lo-cart-reminder,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-reminder,
.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
.woocommerce-cart .page-body > .cart-empty,
.woocommerce-page.woocommerce-cart .page-body > .cart-empty,
.woocommerce-cart .page-body > .return-to-shop,
.woocommerce-page.woocommerce-cart .page-body > .return-to-shop {
  grid-column: 1 / -1 !important;
}

.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-form {
  grid-column: 1 !important;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  min-width: 0 !important;
}

.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-cart .page-body > .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
  grid-column: 2 !important;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  min-width: 0 !important;
}

@media (max-width: 768px) {
  .woocommerce-cart .page-body,
  .woocommerce-page.woocommerce-cart .page-body {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-cart .page-body > .lo-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-form,
  .woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-cart .page-body > .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
    grid-column: 1 !important;
  }
}

/* v1.9.6 — Panier : breakpoints progressifs + actions code promo / mise à jour */
.woocommerce-cart .page-body,
.woocommerce-page.woocommerce-cart .page-body {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 28px !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 100% !important;
}

@media (min-width: 1024px) {
  .woocommerce-cart .page-body,
  .woocommerce-page.woocommerce-cart .page-body {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 360px) !important;
    gap: 32px !important;
  }

  .woocommerce-cart .page-body > .lo-cart-reminder,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-reminder,
  .woocommerce-cart .page-body > .woocommerce-notices-wrapper,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
  .woocommerce-cart .page-body > .cart-empty,
  .woocommerce-page.woocommerce-cart .page-body > .cart-empty,
  .woocommerce-cart .page-body > .return-to-shop,
  .woocommerce-page.woocommerce-cart .page-body > .return-to-shop {
    grid-column: 1 / -1 !important;
  }

  .woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-cart .page-body > .lo-cart-form {
    grid-column: 1 !important;
  }

  .woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-cart .page-body > .lo-cart-collaterals {
    grid-column: 2 !important;
  }
}

.woocommerce-cart .lo-cart-form,
.woocommerce-page.woocommerce-cart .lo-cart-form,
.woocommerce-cart .cart-collaterals,
.woocommerce-page.woocommerce-cart .cart-collaterals,
.woocommerce-cart .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .lo-cart-collaterals {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
  min-width: 0 !important;
}

.woocommerce-cart .lo-cart-table,
.woocommerce-page.woocommerce-cart .lo-cart-table {
  table-layout: fixed;
}

.woocommerce-cart .lo-cart-table th.product-remove,
.woocommerce-page.woocommerce-cart .lo-cart-table th.product-remove,
.woocommerce-cart .lo-cart-table td.product-remove,
.woocommerce-page.woocommerce-cart .lo-cart-table td.product-remove {
  width: 48px;
}

.woocommerce-cart .lo-cart-table th.product-thumbnail,
.woocommerce-page.woocommerce-cart .lo-cart-table th.product-thumbnail,
.woocommerce-cart .lo-cart-table td.product-thumbnail,
.woocommerce-page.woocommerce-cart .lo-cart-table td.product-thumbnail {
  width: 84px;
}

.woocommerce-cart .lo-cart-table th.product-price,
.woocommerce-page.woocommerce-cart .lo-cart-table th.product-price,
.woocommerce-cart .lo-cart-table td.product-price {
  width: 150px;
}

.woocommerce-cart .lo-cart-table th.product-quantity,
.woocommerce-page.woocommerce-cart .lo-cart-table th.product-quantity,
.woocommerce-cart .lo-cart-table td.product-quantity {
  width: 120px;
}

.woocommerce-cart .lo-cart-table th.product-subtotal,
.woocommerce-page.woocommerce-cart .lo-cart-table th.product-subtotal,
.woocommerce-cart .lo-cart-table td.product-subtotal {
  width: 145px;
}

.woocommerce-cart .lo-cart-table td.product-name,
.woocommerce-page.woocommerce-cart .lo-cart-table td.product-name {
  min-width: 0;
}

.woocommerce-cart .lo-cart-table td.product-name a,
.woocommerce-page.woocommerce-cart .lo-cart-table td.product-name a {
  overflow-wrap: anywhere;
}

.woocommerce-cart .lo-cart-table td.actions,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 24px !important;
}

.woocommerce-cart .lo-cart-table td.actions .coupon,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
  display: grid !important;
  grid-template-columns: minmax(180px, 1fr) auto;
  gap: 14px;
  align-items: center;
  float: none !important;
  width: 100%;
  max-width: 520px;
}

.woocommerce-cart .lo-cart-table td.actions .coupon::before,
.woocommerce-cart .lo-cart-table td.actions .coupon::after,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon::before,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon::after {
  content: none !important;
}

.woocommerce-cart .lo-cart-table td.actions .input-text,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .input-text,
.woocommerce-cart .lo-cart-table td.actions .button,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .button {
  width: 100% !important;
  min-height: 48px;
  margin: 0 !important;
  float: none !important;
  white-space: nowrap;
}

.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
  justify-self: end;
  min-width: 240px;
}

@media (min-width: 900px) and (max-width: 1179px) {
  .woocommerce-cart .page-body,
  .woocommerce-page.woocommerce-cart .page-body {
    gap: 24px !important;
  }

  .woocommerce-cart .lo-cart-table th,
  .woocommerce-page.woocommerce-cart .lo-cart-table th,
  .woocommerce-cart .lo-cart-table td,
  .woocommerce-page.woocommerce-cart .lo-cart-table td {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .woocommerce-cart .lo-cart-table th.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-thumbnail,
  .woocommerce-cart .lo-cart-table td.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.product-thumbnail {
    width: 62px;
  }

  .woocommerce-cart .lo-cart-table .product-thumbnail img,
  .woocommerce-page.woocommerce-cart .lo-cart-table .product-thumbnail img {
    width: 48px;
  }

  .woocommerce-cart .lo-cart-table th.product-price,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-price,
  .woocommerce-cart .lo-cart-table td.product-price {
    width: 118px;
  }

  .woocommerce-cart .lo-cart-table th.product-quantity,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-quantity,
  .woocommerce-cart .lo-cart-table td.product-quantity {
    width: 100px;
  }

  .woocommerce-cart .lo-cart-table th.product-subtotal,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-subtotal,
  .woocommerce-cart .lo-cart-table td.product-subtotal {
    width: 120px;
  }

  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    grid-template-columns: 1fr;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    max-width: none;
  }

  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    justify-self: stretch;
    min-width: 0;
  }
}

@media (max-width: 899px) {
  .woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-cart .page-body > .lo-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-form,
  .woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-cart .page-body > .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
    grid-column: 1 !important;
  }

  .woocommerce-cart .lo-cart-table,
  .woocommerce-page.woocommerce-cart .lo-cart-table,
  .woocommerce-cart .lo-cart-table tbody,
  .woocommerce-page.woocommerce-cart .lo-cart-table tbody,
  .woocommerce-cart .lo-cart-table tr,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr,
  .woocommerce-cart .lo-cart-table td,
  .woocommerce-page.woocommerce-cart .lo-cart-table td {
    display: block;
    width: 100% !important;
  }

  .woocommerce-cart .lo-cart-table thead,
  .woocommerce-page.woocommerce-cart .lo-cart-table thead {
    display: none;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item {
    display: grid;
    grid-template-columns: 42px 74px minmax(0, 1fr);
    gap: 12px 14px;
    padding: 18px;
    border-bottom: var(--border);
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td {
    padding: 0 !important;
    border: 0 !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-remove,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-remove {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: start;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail {
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-name,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-name {
    grid-column: 3;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-price,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-price,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal {
    grid-column: 3;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 10px !important;
    border-top: var(--border) !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-price::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-price::before,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity::before,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal::before {
    content: attr(data-title);
    font-family: var(--sans);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--gray-500);
  }

  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 18px !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    justify-self: stretch;
    min-width: 0;
  }
}

@media (max-width: 520px) {
  .woocommerce-cart .lo-cart-table tr.cart_item,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item {
    grid-template-columns: 36px 64px minmax(0, 1fr);
    padding: 14px;
    gap: 10px;
  }

  .woocommerce-cart .lo-cart-table .product-thumbnail img,
  .woocommerce-page.woocommerce-cart .lo-cart-table .product-thumbnail img {
    width: 58px;
  }
}

/* Page produit : premier passage en une colonne harmonisé avec le panier. */
@media (min-width: 769px) and (max-width: 899px) {
  .product-layout {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
}

/* v1.9.7 — Panier : grille fiable + actions coupon/update + cartes mobiles */
.woocommerce-cart .page-body,
.woocommerce-page.woocommerce-cart .page-body {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 28px !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
}

.woocommerce-cart .page-body > .lo-cart-reminder,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-reminder,
.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
.woocommerce-cart .page-body > .cart-empty,
.woocommerce-page.woocommerce-cart .page-body > .cart-empty,
.woocommerce-cart .page-body > .return-to-shop,
.woocommerce-page.woocommerce-cart .page-body > .return-to-shop,
.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-cart .page-body > .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
  grid-column: 1 !important;
  min-width: 0 !important;
}

.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-cart .page-body > .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  margin: 0 !important;
}

@media (min-width: 1080px) {
  .woocommerce-cart .page-body,
  .woocommerce-page.woocommerce-cart .page-body {
    grid-template-columns: minmax(0, 1fr) clamp(320px, 29vw, 360px) !important;
    gap: 32px !important;
  }

  .woocommerce-cart .page-body > .lo-cart-reminder,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-reminder,
  .woocommerce-cart .page-body > .woocommerce-notices-wrapper,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-notices-wrapper,
  .woocommerce-cart .page-body > .cart-empty,
  .woocommerce-page.woocommerce-cart .page-body > .cart-empty,
  .woocommerce-cart .page-body > .return-to-shop,
  .woocommerce-page.woocommerce-cart .page-body > .return-to-shop {
    grid-column: 1 / -1 !important;
  }

  .woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
  .woocommerce-cart .page-body > .lo-cart-form,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-form {
    grid-column: 1 !important;
  }

  .woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .cart-collaterals,
  .woocommerce-cart .page-body > .lo-cart-collaterals,
  .woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals {
    grid-column: 2 !important;
  }
}

@media (min-width: 1080px) and (max-width: 1239px) {
  .woocommerce-cart .lo-cart-table,
  .woocommerce-page.woocommerce-cart .lo-cart-table {
    table-layout: fixed !important;
  }

  .woocommerce-cart .lo-cart-table th.product-remove,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-remove,
  .woocommerce-cart .lo-cart-table td.product-remove,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.product-remove {
    width: 44px !important;
  }

  .woocommerce-cart .lo-cart-table th.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-thumbnail,
  .woocommerce-cart .lo-cart-table td.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.product-thumbnail {
    width: 76px !important;
  }

  .woocommerce-cart .lo-cart-table .product-thumbnail img,
  .woocommerce-page.woocommerce-cart .lo-cart-table .product-thumbnail img {
    width: 56px !important;
  }

  .woocommerce-cart .lo-cart-table th.product-price,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-price,
  .woocommerce-cart .lo-cart-table td.product-price {
    width: 130px !important;
  }

  .woocommerce-cart .lo-cart-table th.product-quantity,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-quantity,
  .woocommerce-cart .lo-cart-table td.product-quantity {
    width: 110px !important;
  }

  .woocommerce-cart .lo-cart-table th.product-subtotal,
  .woocommerce-page.woocommerce-cart .lo-cart-table th.product-subtotal,
  .woocommerce-cart .lo-cart-table td.product-subtotal {
    width: 132px !important;
  }

  .woocommerce-cart .lo-cart-table th,
  .woocommerce-page.woocommerce-cart .lo-cart-table th,
  .woocommerce-cart .lo-cart-table td,
  .woocommerce-page.woocommerce-cart .lo-cart-table td {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

.woocommerce-cart .lo-cart-table td.actions,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(220px, auto) !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 20px 18px !important;
}

.woocommerce-cart .lo-cart-table td.actions .coupon,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
  display: grid !important;
  grid-template-columns: minmax(160px, 1fr) auto !important;
  gap: 12px !important;
  align-items: center !important;
  width: 100% !important;
  max-width: 520px !important;
  float: none !important;
}

.woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
.woocommerce-cart .lo-cart-table td.actions .coupon .button,
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .button,
.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
  width: 100% !important;
  min-height: 48px !important;
  margin: 0 !important;
  float: none !important;
  white-space: nowrap !important;
}

.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
.woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
  justify-self: end !important;
  min-width: 230px !important;
}

@media (max-width: 1179px) {
  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    max-width: none !important;
  }

  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    justify-self: stretch !important;
    min-width: 0 !important;
  }
}

@media (max-width: 1079px) {
  .woocommerce-cart .lo-cart-table,
  .woocommerce-page.woocommerce-cart .lo-cart-table,
  .woocommerce-cart .lo-cart-table tbody,
  .woocommerce-page.woocommerce-cart .lo-cart-table tbody,
  .woocommerce-cart .lo-cart-table tr,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr,
  .woocommerce-cart .lo-cart-table td,
  .woocommerce-page.woocommerce-cart .lo-cart-table td {
    display: block !important;
    width: 100% !important;
  }

  .woocommerce-cart .lo-cart-table thead,
  .woocommerce-page.woocommerce-cart .lo-cart-table thead {
    display: none !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item {
    display: grid !important;
    grid-template-columns: 38px 76px minmax(0, 1fr) !important;
    gap: 12px 14px !important;
    padding: 18px !important;
    border-bottom: var(--border) !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td {
    padding: 0 !important;
    border: 0 !important;
    text-align: left !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-remove,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-remove {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-thumbnail::before {
    content: none !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-name,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-name {
    grid-column: 3 !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-price,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-price,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal {
    grid-column: 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    padding-top: 10px !important;
    border-top: var(--border) !important;
  }

  .woocommerce-cart .lo-cart-table tr.cart_item td.product-price::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-price::before,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-quantity::before,
  .woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal::before,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item td.product-subtotal::before {
    content: attr(data-title) !important;
    font-family: var(--sans) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--gray-500) !important;
  }

  .woocommerce-cart .lo-cart-table .product-thumbnail img,
  .woocommerce-page.woocommerce-cart .lo-cart-table .product-thumbnail img {
    width: 64px !important;
    max-width: 64px !important;
    margin: 0 !important;
  }
}

@media (max-width: 640px) {
  .woocommerce-cart .lo-cart-table tr.cart_item,
  .woocommerce-page.woocommerce-cart .lo-cart-table tr.cart_item {
    grid-template-columns: 34px 64px minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 14px !important;
  }

  .woocommerce-cart .lo-cart-table .product-thumbnail img,
  .woocommerce-page.woocommerce-cart .lo-cart-table .product-thumbnail img {
    width: 56px !important;
    max-width: 56px !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 1079px) {
  .product-layout {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
}

/* v1.9.8 — Panier : actions stables + réduction des espacements */
.woocommerce-cart .woocommerce-notices-wrapper:empty,
.woocommerce-page.woocommerce-cart .woocommerce-notices-wrapper:empty {
  display: none !important;
}

.woocommerce-cart .page-body,
.woocommerce-page.woocommerce-cart .page-body {
  row-gap: 22px !important;
}

.woocommerce-cart .page-body > .lo-cart-reminder,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-reminder {
  margin-bottom: 0 !important;
}

.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-form,
.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-page.woocommerce-cart .page-body > .woocommerce-cart-form,
.woocommerce-cart .page-body > .lo-cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .lo-cart-collaterals,
.woocommerce-cart .page-body > .cart-collaterals,
.woocommerce-page.woocommerce-cart .page-body > .cart-collaterals {
  margin-top: 0 !important;
}

.woocommerce-cart table.shop_table,
.woocommerce-page.woocommerce-cart table.shop_table {
  margin-bottom: 0 !important;
}

@media (min-width: 1080px) {
  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    display: grid !important;
    grid-template-columns: minmax(170px, 1fr) max-content max-content !important;
    gap: 12px !important;
    align-items: center !important;
    padding: 18px !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    display: contents !important;
    width: auto !important;
    max-width: none !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .input-text {
    grid-column: 1 !important;
    min-width: 0 !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon .button,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .button {
    grid-column: 2 !important;
    width: auto !important;
    min-width: 0 !important;
  }

  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    grid-column: 3 !important;
    justify-self: end !important;
    width: auto !important;
    min-width: 0 !important;
  }
}

@media (min-width: 1080px) and (max-width: 1220px) {
  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    grid-template-columns: minmax(150px, 1fr) max-content !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .input-text {
    grid-column: 1 !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon .button,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .button {
    grid-column: 2 !important;
  }

  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    grid-column: 1 / -1 !important;
    justify-self: end !important;
    width: auto !important;
  }
}

@media (max-width: 1079px) {
  .woocommerce-cart .page-body,
  .woocommerce-page.woocommerce-cart .page-body {
    row-gap: 20px !important;
  }

  .woocommerce-cart .lo-cart-table td.actions,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 16px !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    max-width: none !important;
  }

  .woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .input-text,
  .woocommerce-cart .lo-cart-table td.actions .coupon .button,
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions .coupon .button,
  .woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"],
  .woocommerce-page.woocommerce-cart .lo-cart-table td.actions > .button[name="update_cart"] {
    width: 100% !important;
    justify-self: stretch !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   42. WOOCOMMERCE ACCOUNT OVERRIDES
   ═══════════════════════════════════════════════════════════ */

.lo-myaccount-login-page,
.lo-myaccount-page {
  width: 100%;
  padding-top: 0;
}

.lo-myaccount-page .woocommerce-MyAccount-content > *:first-child,
.lo-myaccount-login-page > *:first-child {
  margin-top: 0;
}

.account-empty-note {
  font-family: var(--body-serif);
  font-size: 15px;
  color: var(--gray-500);
  border: var(--border);
  padding: 20px;
  margin: 0 0 24px;
}

.account-sidebar.woocommerce-MyAccount-navigation {
  float: none;
  width: auto;
}

.account-content.woocommerce-MyAccount-content {
  float: none;
  width: auto;
}

.account-content .woocommerce-Addresses,
.account-content .woocommerce-address-fields,
.account-content .woocommerce-EditAccountForm,
.account-content .woocommerce-MyAccount-orders,
.account-content .woocommerce-order-details,
.account-content .woocommerce-customer-details {
  border: var(--border);
  padding: 24px;
  margin-top: 20px;
}

.account-content fieldset {
  border: var(--border);
  padding: 20px;
  margin: 24px 0;
}

.account-content legend {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--red);
  padding: 0 8px;
}

.account-content .form-row {
  margin-bottom: 16px;
}

.account-content label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
  margin-bottom: 6px;
}

.account-content input.input-text,
.account-content textarea,
.account-content select,
.login-card input.input-text {
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--gray-900);
  background: var(--white);
  border: var(--border);
  outline: none;
}

.account-content textarea {
  padding-top: 12px;
  min-height: 120px;
}

.account-content input.input-text:focus,
.account-content textarea:focus,
.account-content select:focus,
.login-card input.input-text:focus {
  border-color: var(--black);
}

.account-content .button,
.login-card .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  background: var(--red);
  color: white;
  border: none;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 22px;
  cursor: pointer;
  transition: background 0.3s ease;
}

.account-content .button:hover,
.login-card .button:hover {
  background: var(--red-dark);
}

.account-content .woocommerce-info,
.account-content .woocommerce-message,
.account-content .woocommerce-error,
.login-card .woocommerce-info,
.login-card .woocommerce-message,
.login-card .woocommerce-error {
  border: var(--border);
  border-top: 3px solid var(--red);
  background: var(--gray-100);
  padding: 16px 20px;
  margin: 0 0 24px;
  list-style: none;
}

.product-tab-content .desc-body ul,
.product-tab-content .desc-body ol {
  margin: 1em 0 1.4em 1.4em;
}

.product-tab-content .desc-body li {
  margin-bottom: 0.45em;
}

.product-tab-content .desc-body blockquote {
  border-left: 3px solid var(--red);
  padding: 14px 20px;
  margin: 1.4em 0;
  background: var(--gray-100);
  font-style: italic;
  color: var(--gray-700);
}

.product-tab-content .desc-body a {
  color: var(--red);
  border-bottom: 1px solid transparent;
}

.product-tab-content .desc-body a:hover {
  border-bottom-color: var(--red);
}

@media (max-width: 900px) {
  .account-content .woocommerce-Addresses,
  .account-content .woocommerce-address-fields,
  .account-content .woocommerce-EditAccountForm,
  .account-content .woocommerce-MyAccount-orders,
  .account-content .woocommerce-order-details,
  .account-content .woocommerce-customer-details {
    padding: 20px;
  }
}

@media (max-width: 600px) {
  .orders-table,
  .orders-table thead,
  .orders-table tbody,
  .orders-table th,
  .orders-table td,
  .orders-table tr {
    display: block;
  }

  .orders-table thead {
    display: none;
  }

  .orders-table tr {
    border: var(--border);
    margin-bottom: 12px;
    padding: 12px;
  }

  .orders-table td {
    border-bottom: none;
    padding: 6px 0;
  }

  .orders-table td::before {
    content: attr(data-title);
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--gray-500);
    margin-bottom: 2px;
  }
}

/* Correctif dur Mon compte : on rend uniquement WooCommerce, jamais le contenu statique de la page WP. */
.lo-account-shell {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 32px 40px 80px;
  background: var(--white);
}

.lo-account-shell .account-page,
.lo-account-shell .login-page {
  max-width: none;
  padding: 0;
}

.lo-account-shell .account-layout {
  margin-top: 32px;
}

.lo-account-shell .cart-icon-link .cart-badge:empty {
  display: none;
}

@media (max-width: 900px) {
  .lo-account-shell {
    padding: 24px 20px 60px;
  }
}

@media (max-width: 600px) {
  .lo-account-shell {
    padding: 16px 16px 48px;
  }
}

/* ═══════════════════════════════════════════════════════════
   INPUT FIELDS — FRONT & ESPACE CLIENT
   ═══════════════════════════════════════════════════════════ */
:root {
  --input-bg: #FFFDE7;
}

body:not(.wp-admin) input[type="text"],
body:not(.wp-admin) input[type="email"],
body:not(.wp-admin) input[type="url"],
body:not(.wp-admin) input[type="tel"],
body:not(.wp-admin) input[type="password"],
body:not(.wp-admin) input[type="search"],
body:not(.wp-admin) input[type="number"],
body:not(.wp-admin) textarea,
body:not(.wp-admin) select,
.woocommerce-account input.input-text,
.woocommerce-account textarea,
.woocommerce-account select,
.woocommerce-cart input.input-text,
.woocommerce-cart .quantity .qty,
.woocommerce-cart textarea,
.woocommerce-cart select,
.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select {
  background-color: var(--input-bg) !important;
}

body:not(.wp-admin) input[type="checkbox"],
body:not(.wp-admin) input[type="radio"] {
  background-color: initial !important;
}

.header-search-input,
.search-input,
.single-newsletter-input,
.newsletter-input {
  background-color: transparent !important;
}

/* Correctif galerie produit — vignettes sans marges internes */
.product-thumbnails {
  align-items: flex-start;
}

.product-thumb {
  display: block;
  padding: 0;
  line-height: 0;
  background: var(--white);
}

.product-thumb img,
.product-thumb picture img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ═══════════════════════════════════════════════════════════
   PRODUCT CARDS — RATIOS RÉELS + ALIGNEMENT BAS
   ═══════════════════════════════════════════════════════════ */
.books-grid {
  align-items: stretch;
}

.book-card,
.lo-shop-product-card {
  height: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.book-cover,
.woocommerce-shop-page .lo-shop-product-card__cover,
.related-products .lo-shop-product-card__cover {
  aspect-ratio: auto;
  height: auto;
  min-height: 0;
  background: var(--white);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  overflow: hidden;
}

.book-cover > img,
.book-cover .book-cover-img,
.book-cover picture,
.book-cover picture img,
.woocommerce-shop-page .lo-shop-product-card__cover img,
.related-products .lo-shop-product-card__cover img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
}

.book-cover picture {
  line-height: 0;
}

.book-cover-spine {
  z-index: 1;
}

.book-title,
.lo-shop-product-card__title {
  margin-top: 0;
}

.book-price,
.woocommerce-shop-page .book-price,
.related-products .book-price {
  margin-top: auto;
  padding-top: 10px;
}

.book-btn,
.lo-shop-product-card__btn {
  margin-top: 10px;
}

.book-cover .book-cover-placeholder,
.lo-shop-product-card__cover .book-cover-placeholder {
  aspect-ratio: 2 / 3;
  min-height: 240px;
}

@media (max-width: 900px) {
  .book-cover .book-cover-placeholder,
  .lo-shop-product-card__cover .book-cover-placeholder {
    min-height: 200px;
  }
}

/* Clickable cards */
.lo-clickable-card { cursor: pointer; }
.lo-clickable-card:focus-visible { outline: 2px solid var(--red); outline-offset: 3px; }
.sidebar-recent-item { display: block; color: inherit; cursor: pointer; }
.sidebar-recent-item * { cursor: pointer; }
.sidebar-recent-item:hover .sidebar-recent-title { color: var(--red); }

/* Clickable zones — comportement standardisé */
.lo-clickable-card,
.lo-clickable-card :where(a, img, picture, div, article, section, h1, h2, h3, h4, p, span, time, strong, em) {
  cursor: pointer;
}

/* ═══════════════════════════════════════════════════════════
   WooCommerce — Checkout page
   ═══════════════════════════════════════════════════════════ */

.checkout-page-body {
  max-width: none;
}

.lo-checkout-wrap {
  margin-top: 32px;
}

.lo-checkout-wrap .woocommerce-notices-wrapper,
.lo-checkout-wrap .woocommerce-form-coupon-toggle,
.lo-checkout-wrap .woocommerce-form-login-toggle {
  margin-bottom: 20px;
}

.lo-checkout-wrap .woocommerce-info,
.lo-checkout-wrap .woocommerce-error,
.lo-checkout-wrap .woocommerce-message {
  border: var(--border);
  border-top: 3px solid var(--red);
  background: var(--gray-100);
  color: var(--gray-700);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.55;
  margin: 0 0 20px;
  padding: 16px 20px;
}

.lo-checkout-wrap .woocommerce-info::before,
.lo-checkout-wrap .woocommerce-error::before,
.lo-checkout-wrap .woocommerce-message::before {
  display: none;
}

.lo-checkout-wrap .woocommerce-info a,
.lo-checkout-wrap .woocommerce-error a,
.lo-checkout-wrap .woocommerce-message a {
  color: var(--red);
  font-weight: 700;
}

.lo-checkout-wrap form.checkout {
  display: grid;
  grid-template-columns: minmax(0, 62fr) minmax(0, 38fr);
  gap: var(--gutter-desktop);
  align-items: start;
}

.lo-checkout-wrap #customer_details,
.lo-checkout-wrap #order_review {
  min-width: 0;
}

.lo-checkout-wrap #customer_details {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

.lo-checkout-wrap .col2-set,
.lo-checkout-wrap .col2-set .col-1,
.lo-checkout-wrap .col2-set .col-2 {
  width: auto;
  float: none;
}

.lo-checkout-wrap .woocommerce-billing-fields,
.lo-checkout-wrap .woocommerce-shipping-fields,
.lo-checkout-wrap .woocommerce-additional-fields,
.lo-checkout-wrap #order_review {
  border: var(--border);
  background: var(--white);
}

.lo-checkout-wrap .woocommerce-billing-fields > h3,
.lo-checkout-wrap .woocommerce-shipping-fields > h3,
.lo-checkout-wrap .woocommerce-additional-fields > h3,
.lo-checkout-wrap #order_review_heading {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--black);
  background: var(--gray-100);
  border-bottom: var(--border);
  margin: 0;
  padding: 20px 24px;
}

.lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
.lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
.lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
  padding: 24px;
}

.lo-checkout-wrap .form-row {
  margin: 0 0 18px;
  padding: 0;
}

.lo-checkout-wrap .form-row:last-child {
  margin-bottom: 0;
}

.lo-checkout-wrap label {
  display: block;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
  margin-bottom: 6px;
}

.lo-checkout-wrap .required {
  color: var(--red);
  text-decoration: none;
}

.lo-checkout-wrap input.input-text,
.lo-checkout-wrap textarea,
.lo-checkout-wrap select,
.lo-checkout-wrap .select2-container--default .select2-selection--single {
  width: 100%;
  min-height: 46px;
  background: #FFFDE7;
  border: var(--border);
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 14px;
  padding: 10px 14px;
  outline: none;
  border-radius: 0;
}

.lo-checkout-wrap textarea {
  min-height: 120px;
  resize: vertical;
}

.lo-checkout-wrap input.input-text:focus,
.lo-checkout-wrap textarea:focus,
.lo-checkout-wrap select:focus,
.lo-checkout-wrap .select2-container--open .select2-selection--single {
  border-color: var(--black);
}

.lo-checkout-wrap .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--gray-900);
  line-height: 24px;
  padding: 0;
}

.lo-checkout-wrap .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 44px;
}

.lo-checkout-wrap .woocommerce-invalid input.input-text,
.lo-checkout-wrap .woocommerce-invalid textarea,
.lo-checkout-wrap .woocommerce-invalid select,
.lo-checkout-wrap .woocommerce-invalid .select2-selection {
  border-color: var(--red) !important;
}

.lo-checkout-wrap .woocommerce-validated input.input-text,
.lo-checkout-wrap .woocommerce-validated textarea,
.lo-checkout-wrap .woocommerce-validated select,
.lo-checkout-wrap .woocommerce-validated .select2-selection {
  border-color: #d8d2ca;
}

.lo-checkout-wrap #order_review {
  position: sticky;
  top: 140px;
}

.lo-checkout-wrap #order_review_heading {
  display: block;
}

.lo-checkout-wrap .shop_table.woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
  border: none;
}

.lo-checkout-wrap .shop_table th,
.lo-checkout-wrap .shop_table td {
  border: none;
  border-bottom: var(--border);
  padding: 16px 24px;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--gray-700);
  vertical-align: top;
}

.lo-checkout-wrap .shop_table th {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gray-700);
}

.lo-checkout-wrap .shop_table td:last-child,
.lo-checkout-wrap .shop_table th:last-child {
  text-align: right;
  font-weight: 700;
  color: var(--black);
}

.lo-checkout-wrap .shop_table .order-total th,
.lo-checkout-wrap .shop_table .order-total td {
  font-size: 15px;
  color: var(--black);
}

.lo-checkout-wrap #payment {
  background: var(--white);
  border-radius: 0;
}

.lo-checkout-wrap #payment ul.payment_methods {
  border-bottom: var(--border);
  padding: 20px 24px;
}

.lo-checkout-wrap #payment ul.payment_methods li {
  list-style: none;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--gray-700);
  margin: 0 0 12px;
}

.lo-checkout-wrap #payment ul.payment_methods li:last-child {
  margin-bottom: 0;
}

.lo-checkout-wrap #payment div.payment_box {
  background: var(--gray-100);
  color: var(--gray-700);
  font-size: 13px;
  line-height: 1.6;
  margin: 12px 0 0;
  padding: 14px 16px;
}

.lo-checkout-wrap #payment div.payment_box::before {
  border-bottom-color: var(--gray-100);
}

.lo-checkout-wrap #payment div.form-row {
  padding: 24px;
}

.lo-checkout-wrap .woocommerce-privacy-policy-text {
  font-family: var(--body-serif);
  font-size: 13px;
  line-height: 1.6;
  color: var(--gray-500);
  margin-bottom: 18px;
}

.lo-checkout-wrap .woocommerce-privacy-policy-text a {
  color: var(--red);
}

.lo-checkout-wrap #place_order,
.lo-checkout-wrap .button,
.lo-checkout-wrap button.button,
.lo-checkout-wrap a.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: 0;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 14px 28px;
  cursor: pointer;
  transition: background 0.25s ease;
}

.lo-checkout-wrap #place_order {
  width: 100%;
}

.lo-checkout-wrap #place_order:hover,
.lo-checkout-wrap .button:hover,
.lo-checkout-wrap button.button:hover,
.lo-checkout-wrap a.button:hover {
  background: var(--red-dark);
  color: #fff;
}

.lo-checkout-wrap .woocommerce-form-coupon,
.lo-checkout-wrap .woocommerce-form-login {
  border: var(--border);
  background: var(--white);
  padding: 24px;
  margin: 0 0 24px;
}

.lo-checkout-wrap .woocommerce-form-coupon p,
.lo-checkout-wrap .woocommerce-form-login p {
  margin-bottom: 16px;
}

@media (max-width: 1080px) {
  .lo-checkout-wrap form.checkout {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .lo-checkout-wrap #order_review {
    position: static;
  }
}

@media (max-width: 600px) {
  .lo-checkout-wrap {
    margin-top: 24px;
  }

  .lo-checkout-wrap .woocommerce-billing-fields > h3,
  .lo-checkout-wrap .woocommerce-shipping-fields > h3,
  .lo-checkout-wrap .woocommerce-additional-fields > h3,
  .lo-checkout-wrap #order_review_heading {
    font-size: 21px;
    padding: 18px 20px;
  }

  .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
  .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
  .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper,
  .lo-checkout-wrap #payment ul.payment_methods,
  .lo-checkout-wrap #payment div.form-row,
  .lo-checkout-wrap .shop_table th,
  .lo-checkout-wrap .shop_table td {
    padding-left: 18px;
    padding-right: 18px;
  }
}


/* ═══════════════════════════════════════════════════════════
   CHECKOUT — ajustements conteneur, structure et champs
   Version: 2026-05-09-2100
   ═══════════════════════════════════════════════════════════ */

.woocommerce-checkout .page-layout {
  max-width: var(--container-max);
  padding: 32px var(--gutter-desktop) 80px;
}

.woocommerce-checkout .page-article,
.woocommerce-checkout .page-body,
.woocommerce-checkout .lo-checkout-wrap {
  width: 100%;
}

.woocommerce-checkout .page-body {
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  color: var(--gray-900);
}

.woocommerce-checkout .lo-checkout-wrap form.checkout {
  display: grid;
  grid-template-columns: minmax(0, 62fr) minmax(0, 38fr);
  column-gap: var(--gutter-desktop);
  row-gap: 0;
  align-items: start;
}

.woocommerce-checkout .lo-checkout-wrap #customer_details {
  grid-column: 1;
  grid-row: 1 / span 2;
  min-width: 0;
}

.woocommerce-checkout .lo-checkout-wrap #order_review_heading {
  grid-column: 2;
  grid-row: 1;
  border: var(--border);
  border-bottom: none;
}

.woocommerce-checkout .lo-checkout-wrap #order_review {
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  border-top: none;
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
.woocommerce-checkout .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
}

.woocommerce-checkout .lo-checkout-wrap .form-row,
.woocommerce-checkout .lo-checkout-wrap .form-row-first,
.woocommerce-checkout .lo-checkout-wrap .form-row-last,
.woocommerce-checkout .lo-checkout-wrap .form-row-wide {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-checkout .lo-checkout-wrap .form-row-wide,
.woocommerce-checkout .lo-checkout-wrap #billing_company_field,
.woocommerce-checkout .lo-checkout-wrap #billing_country_field,
.woocommerce-checkout .lo-checkout-wrap #billing_address_1_field,
.woocommerce-checkout .lo-checkout-wrap #billing_address_2_field,
.woocommerce-checkout .lo-checkout-wrap #billing_postcode_field,
.woocommerce-checkout .lo-checkout-wrap #billing_city_field,
.woocommerce-checkout .lo-checkout-wrap #billing_phone_field,
.woocommerce-checkout .lo-checkout-wrap #billing_email_field,
.woocommerce-checkout .lo-checkout-wrap #order_comments_field {
  grid-column: 1 / -1;
}

.woocommerce-checkout .lo-checkout-wrap input.input-text,
.woocommerce-checkout .lo-checkout-wrap textarea,
.woocommerce-checkout .lo-checkout-wrap select,
.woocommerce-checkout .lo-checkout-wrap .select2-container,
.woocommerce-checkout .lo-checkout-wrap .select2-container--default .select2-selection--single {
  width: 100% !important;
  max-width: 100%;
  box-sizing: border-box;
}

.woocommerce-checkout .lo-checkout-wrap input.input-text,
.woocommerce-checkout .lo-checkout-wrap textarea,
.woocommerce-checkout .lo-checkout-wrap select,
.woocommerce-checkout .lo-checkout-wrap .select2-container--default .select2-selection--single {
  min-height: 48px;
  background-color: var(--input-bg, #FFFDE7) !important;
  border: 1px solid #D8D2CA;
  box-shadow: none;
  border-radius: 0;
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.4;
  padding: 11px 14px;
}

.woocommerce-checkout .lo-checkout-wrap textarea {
  min-height: 130px;
}

.woocommerce-checkout .lo-checkout-wrap input.input-text:focus,
.woocommerce-checkout .lo-checkout-wrap textarea:focus,
.woocommerce-checkout .lo-checkout-wrap select:focus,
.woocommerce-checkout .lo-checkout-wrap .select2-container--open .select2-selection--single {
  border-color: var(--black);
  outline: none;
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon-toggle,
.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-login-toggle {
  width: 100%;
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon,
.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-login {
  width: 100%;
  border: var(--border);
  background: var(--white);
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-first,
.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-last {
  display: inline-block;
  vertical-align: top;
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-first {
  width: calc(100% - 220px) !important;
  margin-right: 16px !important;
}

.woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-last {
  width: 200px !important;
}

@media (max-width: 1080px) {
  .woocommerce-checkout .lo-checkout-wrap form.checkout {
    grid-template-columns: 1fr;
    row-gap: 28px;
  }

  .woocommerce-checkout .lo-checkout-wrap #customer_details,
  .woocommerce-checkout .lo-checkout-wrap #order_review_heading,
  .woocommerce-checkout .lo-checkout-wrap #order_review {
    grid-column: 1;
    grid-row: auto;
  }

  .woocommerce-checkout .lo-checkout-wrap #order_review_heading {
    border-bottom: none;
  }
}

@media (max-width: 900px) {
  .woocommerce-checkout .page-layout {
    padding: 24px var(--gutter-tablet) 60px;
  }
}

@media (max-width: 600px) {
  .woocommerce-checkout .page-layout {
    padding: 16px var(--gutter-mobile) 48px;
  }

  .woocommerce-checkout .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
  .woocommerce-checkout .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
  .woocommerce-checkout .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
    grid-template-columns: 1fr;
  }

  .woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-first,
  .woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-last {
    display: block;
    width: 100% !important;
    margin-right: 0 !important;
  }

  .woocommerce-checkout .lo-checkout-wrap .woocommerce-form-coupon .form-row-first {
    margin-bottom: 12px !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   CHECKOUT — correction ciblée layout / champs / structure
   Version: 2026-05-09-2145
   ═══════════════════════════════════════════════════════════ */

.page-layout--checkout,
.woocommerce-checkout .page-layout {
  max-width: var(--container-max) !important;
  width: 100%;
  margin: 0 auto;
  padding: 32px var(--gutter-desktop) 80px !important;
}

.page-layout--checkout .page-article,
.page-layout--checkout .page-body,
.page-layout--checkout .lo-checkout-wrap {
  width: 100%;
  max-width: none !important;
}

.page-layout--checkout .page-hero {
  margin-bottom: 32px;
}

.page-layout--checkout .page-title {
  max-width: 100%;
}

.page-layout--checkout .lo-checkout-wrap {
  margin-top: 0;
  font-family: var(--sans);
}

.page-layout--checkout .lo-checkout-wrap form.checkout {
  display: grid !important;
  grid-template-columns: minmax(0, 62fr) minmax(0, 38fr) !important;
  gap: var(--gutter-desktop) !important;
  align-items: start;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-form-coupon-toggle,
.page-layout--checkout .lo-checkout-wrap .woocommerce-form-login-toggle {
  width: 100%;
  margin-bottom: 26px;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-info,
.page-layout--checkout .lo-checkout-wrap .woocommerce-error,
.page-layout--checkout .lo-checkout-wrap .woocommerce-message {
  width: 100%;
  margin: 0;
  padding: 18px 24px;
  border: var(--border);
  border-left: 4px solid var(--gray-500);
  border-top: var(--border);
  background: var(--gray-100);
}

.page-layout--checkout .lo-checkout-wrap #customer_details {
  grid-column: 1;
  min-width: 0;
}

.page-layout--checkout .lo-checkout-wrap #order_review_heading {
  grid-column: 2;
  grid-row: 1;
  margin: 0;
  border: var(--border);
  border-bottom: none;
  background: var(--gray-100);
}

.page-layout--checkout .lo-checkout-wrap #order_review {
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  border: var(--border);
  border-top: none;
  background: var(--white);
  position: sticky;
  top: 140px;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-billing-fields,
.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields,
.page-layout--checkout .lo-checkout-wrap .woocommerce-additional-fields {
  width: 100%;
  border: var(--border);
  background: var(--white);
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-billing-fields > h3,
.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields > h3,
.page-layout--checkout .lo-checkout-wrap .woocommerce-additional-fields > h3,
.page-layout--checkout .lo-checkout-wrap #order_review_heading {
  font-size: 24px;
  padding: 20px 24px;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
.page-layout--checkout .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
  padding: 24px;
}

.page-layout--checkout .lo-checkout-wrap .form-row,
.page-layout--checkout .lo-checkout-wrap .form-row-first,
.page-layout--checkout .lo-checkout-wrap .form-row-last,
.page-layout--checkout .lo-checkout-wrap .form-row-wide {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.page-layout--checkout .lo-checkout-wrap .form-row-wide,
.page-layout--checkout .lo-checkout-wrap #billing_company_field,
.page-layout--checkout .lo-checkout-wrap #billing_country_field,
.page-layout--checkout .lo-checkout-wrap #billing_address_1_field,
.page-layout--checkout .lo-checkout-wrap #billing_address_2_field,
.page-layout--checkout .lo-checkout-wrap #billing_postcode_field,
.page-layout--checkout .lo-checkout-wrap #billing_city_field,
.page-layout--checkout .lo-checkout-wrap #billing_phone_field,
.page-layout--checkout .lo-checkout-wrap #billing_email_field,
.page-layout--checkout .lo-checkout-wrap #order_comments_field {
  grid-column: 1 / -1;
}

.page-layout--checkout .lo-checkout-wrap input.input-text,
.page-layout--checkout .lo-checkout-wrap textarea,
.page-layout--checkout .lo-checkout-wrap select,
.page-layout--checkout .lo-checkout-wrap .select2-container--default .select2-selection--single {
  width: 100% !important;
  min-height: 48px;
  background: #FFFDE7 !important;
  border: 1px solid #D8D2CA !important;
  color: var(--gray-900);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.4;
  padding: 11px 14px;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none;
}

.page-layout--checkout .lo-checkout-wrap input.input-text:focus,
.page-layout--checkout .lo-checkout-wrap textarea:focus,
.page-layout--checkout .lo-checkout-wrap select:focus,
.page-layout--checkout .lo-checkout-wrap .select2-container--open .select2-selection--single {
  border-color: var(--black) !important;
}

.page-layout--checkout .lo-checkout-wrap .select2-container {
  width: 100% !important;
}

@media (max-width: 1180px) {
  .page-layout--checkout .lo-checkout-wrap form.checkout {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .page-layout--checkout .lo-checkout-wrap #customer_details,
  .page-layout--checkout .lo-checkout-wrap #order_review_heading,
  .page-layout--checkout .lo-checkout-wrap #order_review {
    grid-column: 1;
    grid-row: auto;
  }

  .page-layout--checkout .lo-checkout-wrap #order_review {
    position: static;
  }
}

@media (max-width: 900px) {
  .page-layout--checkout,
  .woocommerce-checkout .page-layout {
    padding: 24px var(--gutter-tablet) 60px !important;
  }
}

@media (max-width: 600px) {
  .page-layout--checkout,
  .woocommerce-checkout .page-layout {
    padding: 16px var(--gutter-mobile) 48px !important;
  }

  .page-layout--checkout .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
  .page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
  .page-layout--checkout .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
    grid-template-columns: 1fr;
    padding: 20px;
  }
}

/* ═══════════════════════════════════════════════════════════
   CHECKOUT — ajustements espacement / structure / empilement
   Version: 2026-05-09-2205
   ═══════════════════════════════════════════════════════════ */

header {
  z-index: 3000;
}

.page-layout--checkout,
.woocommerce-checkout .page-layout {
  max-width: var(--container-max) !important;
  padding-top: 48px !important;
}

.page-layout--checkout .page-hero {
  position: relative;
  z-index: 0;
  margin-bottom: 28px;
  padding-bottom: 28px;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-form-coupon-toggle,
.page-layout--checkout .lo-checkout-wrap .woocommerce-form-login-toggle {
  margin-bottom: 32px;
}

.page-layout--checkout .lo-checkout-wrap form.checkout {
  grid-template-columns: minmax(0, 1fr) 420px !important;
  column-gap: 40px !important;
  row-gap: 0 !important;
  align-items: start;
}

.page-layout--checkout .lo-checkout-wrap #customer_details {
  grid-column: 1;
  grid-row: 1 / span 2;
}

.page-layout--checkout .lo-checkout-wrap #order_review_heading {
  grid-column: 2;
  grid-row: 1;
  align-self: start;
}

.page-layout--checkout .lo-checkout-wrap #order_review {
  grid-column: 2;
  grid-row: 2;
  align-self: start;
  margin-top: 0;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-billing-fields__field-wrapper,
.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields__field-wrapper,
.page-layout--checkout .lo-checkout-wrap .woocommerce-additional-fields__field-wrapper {
  gap: 20px 22px;
}

.page-layout--checkout .lo-checkout-wrap input.input-text,
.page-layout--checkout .lo-checkout-wrap textarea,
.page-layout--checkout .lo-checkout-wrap select,
.page-layout--checkout .lo-checkout-wrap .select2-container--default .select2-selection--single {
  min-height: 50px;
  background: #FFFDE7 !important;
  border: var(--border) !important;
}

@media (max-width: 1180px) {
  .page-layout--checkout .lo-checkout-wrap form.checkout {
    grid-template-columns: 1fr !important;
  }

  .page-layout--checkout .lo-checkout-wrap #customer_details,
  .page-layout--checkout .lo-checkout-wrap #order_review_heading,
  .page-layout--checkout .lo-checkout-wrap #order_review {
    grid-column: 1;
    grid-row: auto;
  }

  .page-layout--checkout .lo-checkout-wrap #order_review {
    margin-top: 0;
  }
}

/* ═══════════════════════════════════════════════════════════
   GLOBAL PAGES — largeur, z-index page-hero, H1 34px
   Version: 2026-05-09-2215
   ═══════════════════════════════════════════════════════════ */

.page-layout:not(.page-layout--checkout) {
  max-width: var(--container-max) !important;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gutter-desktop) !important;
  padding-right: var(--gutter-desktop) !important;
}

.page-layout:not(.page-layout--checkout) .page-article {
  max-width: 860px;
  width: 100%;
}

.page-hero {
  position: relative;
  z-index: 0;
}

.page-title,
.category-title,
.archive-title,
.search-query-title,
.shop-title,
.woocommerce-shop-page .shop-title,
.single-title,
.product-title,
.legal-title,
.donation-hero h1,
.author-name {
  font-size: 34px !important;
  line-height: 1.12 !important;
}

@media (max-width: 900px) {
  .page-layout:not(.page-layout--checkout) {
    padding-left: var(--gutter-tablet) !important;
    padding-right: var(--gutter-tablet) !important;
  }
}

@media (max-width: 600px) {
  .page-layout:not(.page-layout--checkout) {
    padding-left: var(--gutter-mobile) !important;
    padding-right: var(--gutter-mobile) !important;
  }

  .page-title,
  .category-title,
  .archive-title,
  .search-query-title,
  .shop-title,
  .woocommerce-shop-page .shop-title,
  .single-title,
  .product-title,
  .legal-title,
  .donation-hero h1,
  .author-name {
    font-size: 30px !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   SHOP HEADER — z-index fix
   Version: 2026-05-09-2225
   ═══════════════════════════════════════════════════════════ */

.shop-header,
.woocommerce-shop-page .shop-header {
  position: relative;
  z-index: 0;
}


/* ═══════════════════════════════════════════════════════════
   HEADER COMMERCIAL BANNER — sous ticker
   Version: 2026-05-10-ads-widget
   ═══════════════════════════════════════════════════════════ */

.commercial-banner-area {
  max-width: var(--container-max);
  margin: -32px auto 48px;
  padding: 0 var(--gutter-desktop);
  position: relative;
  z-index: 0;
}

.commercial-banner-inner {
  width: 100%;
}

.commercial-banner-widget {
  width: 100%;
}

.commercial-banner-widget img,
.commercial-banner-widget a img {
  display: block;
  width: 100%;
  height: auto;
}

.commercial-banner-widget a {
  display: block;
}

.commercial-banner-widget p {
  margin: 0;
}

@media (max-width: 900px) {
  .commercial-banner-area {
    margin: -32px auto 40px;
    padding: 0 var(--gutter-tablet);
  }
}

@media (max-width: 600px) {
  .commercial-banner-area {
    margin: -28px auto 32px;
    padding: 0 var(--gutter-mobile);
  }
}

/* ═══════════════════════════════════════════════════════════
   CART — restauration largeur conteneur après harmonisation globale
   Version: 2026-05-10-cart-width-restore
   ═══════════════════════════════════════════════════════════ */

.woocommerce-cart .page-layout:not(.page-layout--checkout) .page-article,
.woocommerce-page.woocommerce-cart .page-layout:not(.page-layout--checkout) .page-article {
  max-width: none !important;
  width: 100% !important;
}

.woocommerce-cart .page-layout,
.woocommerce-page.woocommerce-cart .page-layout {
  max-width: var(--container-max) !important;
  width: 100% !important;
}


/* ═══════════════════════════════════════════════════════════
   CHECKOUT — correction structure panneau commande
   Version: 2026-05-10-1325
   ═══════════════════════════════════════════════════════════ */

.page-layout--checkout .lo-checkout-wrap form.checkout {
  grid-template-columns: minmax(0, 1fr) 420px !important;
  column-gap: 40px !important;
  row-gap: 0 !important;
  align-items: start !important;
}

.page-layout--checkout .lo-checkout-wrap #customer_details {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

.page-layout--checkout .lo-checkout-wrap .lo-order-review-panel {
  grid-column: 2 !important;
  grid-row: 1 !important;
  align-self: start !important;
  min-width: 0;
  position: sticky;
  top: 140px;
}

.page-layout--checkout .lo-checkout-wrap .lo-order-review-panel #order_review_heading {
  margin: 0 !important;
  border: var(--border) !important;
  border-bottom: none !important;
}

.page-layout--checkout .lo-checkout-wrap .lo-order-review-panel #order_review {
  margin: 0 !important;
  border: var(--border) !important;
  border-top: none !important;
  position: static !important;
  top: auto !important;
}

@media (max-width: 1180px) {
  .page-layout--checkout .lo-checkout-wrap form.checkout {
    grid-template-columns: 1fr !important;
    row-gap: 28px !important;
  }

  .page-layout--checkout .lo-checkout-wrap #customer_details,
  .page-layout--checkout .lo-checkout-wrap .lo-order-review-panel {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .page-layout--checkout .lo-checkout-wrap .lo-order-review-panel {
    position: static !important;
  }
}

/* CHECKOUT — shipping fields only */
.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields {
  background: var(--gray-100) !important;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields > h3 {
  display: flex;
  align-items: center;
  width: 100%;
  background: transparent !important;
}

.page-layout--checkout .lo-checkout-wrap .woocommerce-shipping-fields #ship-to-different-address-checkbox {
  position: relative;
  top: 2px;
}

/* Checkout — corrections ciblées : info paiement + privacy text */
.page-layout--checkout .lo-checkout-wrap #payment .woocommerce-info {
  padding-left: 18px !important;
}

.page-layout--checkout .lo-checkout-wrap #payment div.form-row.place-order {
  padding: 24px !important;
}

.page-layout--checkout .lo-checkout-wrap #payment .woocommerce-privacy-policy-text {
  margin: 0 0 18px;
}

/* Checkout — exception ciblée pour le message info dans les moyens de paiement */
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_methods .woocommerce-info {
  margin-bottom: 0 !important;
}

/* ═══════════════════════════════════════════════════════════
   CHECKOUT — page de confirmation de commande
   Version: 2026-05-10-thankyou
   ═══════════════════════════════════════════════════════════ */

.woocommerce-order-received .page-layout--checkout .page-article {
  max-width: 920px !important;
  margin-left: auto;
  margin-right: auto;
}

.woocommerce-order-received .page-layout--checkout .lo-checkout-wrap {
  font-family: var(--sans);
}

.lo-thankyou {
  border: var(--border);
  background: var(--white);
}

.lo-thankyou-hero {
  padding: 42px 48px 38px;
  background: var(--gray-100);
  border-bottom: var(--border);
}

.lo-thankyou-hero--failed {
  border-left: 5px solid var(--red);
}

.lo-thankyou-kicker {
  margin: 0 0 12px;
  color: var(--red);
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lo-thankyou-title {
  margin: 0;
  color: var(--black);
  font-family: var(--serif);
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.5px;
  line-height: 1.12;
}

.lo-thankyou-text {
  max-width: 680px;
  margin: 18px 0 0;
  color: var(--gray-700);
  font-family: var(--body-serif);
  font-size: 20px;
  line-height: 1.55;
}

.lo-thankyou-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-bottom: var(--border);
}

.lo-thankyou-summary-item {
  min-width: 0;
  padding: 24px;
  border-right: var(--border);
}

.lo-thankyou-summary-item:last-child {
  border-right: 0;
}

.lo-thankyou-summary-item span {
  display: block;
  margin-bottom: 8px;
  color: var(--gray-500);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.lo-thankyou-summary-item strong {
  display: block;
  color: var(--black);
  font-family: var(--sans);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.3;
  word-break: break-word;
}

.lo-thankyou .woocommerce-order-details,
.lo-thankyou .woocommerce-customer-details {
  padding: 34px 48px 0;
}

.lo-thankyou .woocommerce-order-details__title,
.lo-thankyou .woocommerce-column__title {
  margin: 0 0 28px;
  color: var(--black);
  font-family: var(--sans);
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.25;
  text-transform: uppercase;
}

.lo-thankyou table.shop_table {
  width: 100%;
  margin: 0;
  border: var(--border);
  border-collapse: collapse;
  background: var(--white);
  font-family: var(--sans);
}

.lo-thankyou table.shop_table th,
.lo-thankyou table.shop_table td {
  padding: 18px 20px;
  border: var(--border);
  color: var(--gray-800);
  font-size: 15px;
  line-height: 1.45;
  text-align: left;
  vertical-align: top;
}

.lo-thankyou table.shop_table th {
  background: var(--gray-100);
  color: var(--black);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.lo-thankyou table.shop_table tfoot th,
.lo-thankyou table.shop_table tfoot td {
  font-weight: 800;
}

.lo-thankyou table.shop_table a {
  color: var(--black);
  text-decoration: none;
}

.lo-thankyou table.shop_table a:hover {
  color: var(--red);
}

.lo-thankyou .woocommerce-customer-details address {
  margin: 0;
  padding: 22px 24px;
  border: var(--border);
  background: var(--gray-100);
  color: var(--gray-700);
  font-family: var(--body-serif);
  font-size: 17px;
  font-style: normal;
  line-height: 1.6;
}

.lo-thankyou-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.lo-thankyou-actions--bottom {
  margin: 0;
  padding: 34px 48px 42px;
}

.lo-thankyou-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 14px 22px;
  border: var(--border);
  background: var(--white);
  color: var(--black);
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-decoration: none;
  text-transform: uppercase;
  transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease;
}

.lo-thankyou-button:hover,
.lo-thankyou-button:focus-visible {
  background: var(--black);
  border-color: var(--black);
  color: #fff;
}

.lo-thankyou-button--primary {
  background: var(--red);
  border-color: var(--red);
  color: #fff !important;
}

.lo-thankyou-button--primary:hover,
.lo-thankyou-button--primary:focus-visible {
  background: var(--black);
  border-color: var(--black);
  color: #fff;
}

@media (max-width: 900px) {
  .lo-thankyou-hero,
  .lo-thankyou .woocommerce-order-details,
  .lo-thankyou .woocommerce-customer-details,
  .lo-thankyou-actions--bottom {
    padding-left: 32px;
    padding-right: 32px;
  }

  .lo-thankyou-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lo-thankyou-summary-item:nth-child(2n) {
    border-right: 0;
  }
}

@media (max-width: 600px) {
  .lo-thankyou-hero {
    padding: 30px 22px 28px;
  }

  .lo-thankyou-title {
    font-size: 28px;
  }

  .lo-thankyou-text {
    font-size: 18px;
  }

  .lo-thankyou-summary {
    grid-template-columns: 1fr;
  }

  .lo-thankyou-summary-item,
  .lo-thankyou-summary-item:nth-child(2n) {
    border-right: 0;
    border-bottom: var(--border);
  }

  .lo-thankyou-summary-item:last-child {
    border-bottom: 0;
  }

  .lo-thankyou .woocommerce-order-details,
  .lo-thankyou .woocommerce-customer-details,
  .lo-thankyou-actions--bottom {
    padding-left: 22px;
    padding-right: 22px;
  }

  .lo-thankyou table.shop_table th,
  .lo-thankyou table.shop_table td {
    padding: 14px;
    font-size: 14px;
  }

  .lo-thankyou-actions,
  .lo-thankyou-button {
    width: 100%;
  }
}

/* Checkout — suppression ciblée du cadre autour du bloc Stripe */
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .payment_box,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .wc-stripe-elements-field {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Checkout — Stripe Elements : neutralisation ciblée de la bordure injectée */
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe #wc-stripe-cc-form,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .wc-stripe-cc-form,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .stripe-card-group,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .wc-stripe-elements-field,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .StripeElement,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe #stripe-card-element,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe #stripe-exp-element,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe #stripe-cvc-element {
  border-color: var(--gray-100) !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Checkout — Stripe Elements : suppression ciblée du cadre fieldset */
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe fieldset,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe #wc-stripe-cc-form,
.page-layout--checkout .lo-checkout-wrap #payment .wc_payment_method.payment_method_stripe .wc-credit-card-form {
  border: 0 !important;
  border-color: var(--gray-100) !important;
  box-shadow: none !important;
  outline: 0 !important;
}

/* Thank you page: spacing between stacked address cards */
.lo-thankyou .woocommerce-column--billing-address + .woocommerce-column--shipping-address .woocommerce-column__title {
  margin-top: 32px;
}

/* WooCommerce — normalisation largeur conteneur confirmation + produit */
.woocommerce-order-received .page-layout--checkout .page-article {
  max-width: none !important;
  width: 100% !important;
}

.single-product .product-main {
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Footer social icons */
.site-footer .footer-widget-col-3 a[href*="x.com"],
.site-footer .footer-widget-col-3 a[href*="twitter.com"],
.site-footer .footer-widget-col-3 a[href*="facebook.com"],
.site-footer .footer-widget-col-3 a[href*="fb.com"],
.site-footer .footer-widget-col-3 a[href*="t.me"],
.site-footer .footer-widget-col-3 a[href*="telegram.me"],
.site-footer .footer-widget-col-3 a[href*="telegram.org"] {
  display: inline-flex;
  align-items: center;
  column-gap: 0;
}

.site-footer .footer-widget-col-3 a[href*="x.com"]::before,
.site-footer .footer-widget-col-3 a[href*="twitter.com"]::before,
.site-footer .footer-widget-col-3 a[href*="facebook.com"]::before,
.site-footer .footer-widget-col-3 a[href*="fb.com"]::before,
.site-footer .footer-widget-col-3 a[href*="t.me"]::before,
.site-footer .footer-widget-col-3 a[href*="telegram.me"]::before,
.site-footer .footer-widget-col-3 a[href*="telegram.org"]::before {
  content: "";
  display: inline-block;
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  margin-right: 10px;
  background: currentColor;
  opacity: 0.95;
  transform: translateY(1px);
}

.site-footer .footer-widget-col-3 a[href*="x.com"]::before,
.site-footer .footer-widget-col-3 a[href*="twitter.com"]::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817-5.966 6.817H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231 5.45-6.231Zm-1.161 17.52h1.833L7.084 4.126H5.117L17.083 19.77Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817-5.966 6.817H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231 5.45-6.231Zm-1.161 17.52h1.833L7.084 4.126H5.117L17.083 19.77Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer .footer-widget-col-3 a[href*="facebook.com"]::before,
.site-footer .footer-widget-col-3 a[href*="fb.com"]::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12.061C22 6.505 17.523 2 12 2S2 6.505 2 12.061C2 17.083 5.657 21.245 10.438 22v-7.03H7.898v-2.909h2.54V9.845c0-2.522 1.493-3.915 3.777-3.915 1.094 0 2.238.196 2.238.196v2.475h-1.261c-1.243 0-1.63.776-1.63 1.572v1.888h2.773l-.443 2.909h-2.33V22C18.343 21.245 22 17.083 22 12.061Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 12.061C22 6.505 17.523 2 12 2S2 6.505 2 12.061C2 17.083 5.657 21.245 10.438 22v-7.03H7.898v-2.909h2.54V9.845c0-2.522 1.493-3.915 3.777-3.915 1.094 0 2.238.196 2.238.196v2.475h-1.261c-1.243 0-1.63.776-1.63 1.572v1.888h2.773l-.443 2.909h-2.33V22C18.343 21.245 22 17.083 22 12.061Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer .footer-widget-col-3 a[href*="t.me"]::before,
.site-footer .footer-widget-col-3 a[href*="telegram.me"]::before,
.site-footer .footer-widget-col-3 a[href*="telegram.org"]::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21.944 4.667 18.74 19.78c-.242 1.067-.872 1.332-1.767.83l-4.88-3.596-2.355 2.266c-.26.26-.478.478-.98.478l.35-4.97 9.046-8.175c.393-.35-.085-.545-.61-.195L6.36 13.46l-4.817-1.506c-1.047-.327-1.067-1.047.218-1.55L20.6 3.145c.872-.327 1.636.195 1.344 1.522Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21.944 4.667 18.74 19.78c-.242 1.067-.872 1.332-1.767.83l-4.88-3.596-2.355 2.266c-.26.26-.478.478-.98.478l.35-4.97 9.046-8.175c.393-.35-.085-.545-.61-.195L6.36 13.46l-4.817-1.506c-1.047-.327-1.067-1.047.218-1.55L20.6 3.145c.872-.327 1.636.195 1.344 1.522Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* =========================================================
   Carte oEmbed entièrement cliquable (stretched link)
   ========================================================= */
.single-body .lo-internal-embed,
.entry-content .lo-internal-embed {
  position: relative;
}
/* IMPORTANT : pas de position:relative sur le <a> du titre,
   sinon le ::after ne couvre que le titre et non toute la carte. */
.single-body .lo-internal-embed__title a::after,
.entry-content .lo-internal-embed__title a::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: transparent;
}
/* Le lien stretched doit couvrir toute la carte, image incluse.
   On force le lien au-dessus de tous les enfants, et on empêche
   l'image/le corps de capter les clics. */
.single-body .lo-internal-embed__link,
.entry-content .lo-internal-embed__link {
  position: absolute !important;
  inset: 0 !important;
  z-index: 5 !important;
  display: block;
  background: transparent;
  text-indent: -9999px;
  overflow: hidden;
}
.single-body .lo-internal-embed__image,
.entry-content .lo-internal-embed__image,
.single-body .lo-internal-embed__body,
.entry-content .lo-internal-embed__body {
  position: static !important;
  z-index: auto !important;
  pointer-events: none;
}
.single-body .lo-internal-embed__image *,
.entry-content .lo-internal-embed__image *,
.single-body .lo-internal-embed__body *,
.entry-content .lo-internal-embed__body * {
  pointer-events: none;
}

/* Neutralise le changement de bordure au survol :
   on garde uniquement le changement de couleur sur le titre. */
.single-body .lo-internal-embed:hover,
.entry-content .lo-internal-embed:hover,
.single-body .lo-internal-embed:focus-within,
.entry-content .lo-internal-embed:focus-within {
  border-color: rgba(0, 0, 0, 0.13) !important;
  background: #fbfaf8 !important;
}

/* Hover rouge sur le titre (déclenché par le survol de toute la carte
   puisque le stretched link couvre l'ensemble) */
.single-body .lo-internal-embed:hover .lo-internal-embed__title,
.entry-content .lo-internal-embed:hover .lo-internal-embed__title,
.single-body .lo-internal-embed:hover .lo-internal-embed__title a,
.entry-content .lo-internal-embed:hover .lo-internal-embed__title a,
.single-body .lo-internal-embed:focus-within .lo-internal-embed__title,
.entry-content .lo-internal-embed:focus-within .lo-internal-embed__title,
.single-body .lo-internal-embed:focus-within .lo-internal-embed__title a,
.entry-content .lo-internal-embed:focus-within .lo-internal-embed__title a {
  color: #b21f24;
}

/* Footer — lien vers les archives */
.footer-archives-slot {
  margin-top: 18px;
  padding-top: 16px;
  max-width: 360px;
  position: relative;
}

.footer-archives-slot::before {
  content: "";
  display: block;
  width: 64px;
  height: 1px;
  margin-bottom: 14px;
  background: rgba(255,255,255,0.18);
}

.footer-archives-link,
.footer-archives-widget a {
  display: inline-flex;
  align-items: center;
  gap: 0.65em;
  color: rgba(255,255,255,0.78);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
  text-decoration: none;
  transition: color 0.25s ease, opacity 0.25s ease;
}

.footer-archives-widget a::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  flex: 0 0 1em;
  background-color: currentColor;
  -webkit-mask: url('../images/archives.svg') no-repeat center;
  mask: url('../images/archives.svg') no-repeat center;
  -webkit-mask-size: contain;
  mask-size: contain;
  opacity: 0.9;
}

.footer-archives-link:hover,
.footer-archives-link:focus-visible,
.footer-archives-widget a:hover,
.footer-archives-widget a:focus-visible {
  color: rgba(255,255,255,0.96);
  text-decoration: none;
}

.footer-archives-icon {
  display: block;
  width: 1em;
  height: 1em;
  flex: 0 0 1em;
  opacity: 0.9;
  filter: none;
  transition: opacity 0.25s ease;
}

.footer-archives-link:hover .footer-archives-icon,
.footer-archives-link:focus-visible .footer-archives-icon {
  opacity: 1;
}

.footer-archives-widget {
  margin: 0;
  color: rgba(255,255,255,0.78);
  font-size: 13px;
  line-height: 1.35;
}

.footer-archives-widget p {
  margin: 0;
}

.footer-archives-widget-title {
  margin-bottom: 8px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}

/* ============================================================
   Images dans le corps d'un article : pleine largeur + ratio
   ============================================================ */
.entry-content img,
.post-content img,
.single-body img,
article .content img {
  width: 100%;
  height: auto;
  display: block;
  max-width: 100%;
}

.entry-content figure,
.entry-content .wp-block-image,
.post-content figure,
.single-body figure,
.single-body .wp-block-image {
  margin: 1.75rem 0;
  width: 100% !important;
  max-width: 100%;
}

.entry-content figure img,
.entry-content .wp-block-image img,
.post-content figure img,
.single-body figure img,
.single-body .wp-block-image img {
  width: 100%;
  height: auto;
}

/* Lien vers le fichier média : curseur zoom (lightbox) */
.entry-content a.lo-gallery-lightbox,
.post-content a.lo-gallery-lightbox,
.single-body a.lo-gallery-lightbox {
  display: block;
  cursor: zoom-in;
}

/* Search results — encart Archives */
.search-archives-notice {
  display: flex;
  align-items: flex-start;
  gap: 1.1rem;
  margin: 2.5rem 0 1.5rem;
  padding: 1.25rem 1.5rem;
  background: #f4f1ea;
  border-left: 4px solid #b21f24;
  border-radius: 4px;
}

.search-archives-notice__icon {
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  color: #b21f24;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

.search-archives-notice__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.search-archives-notice__body {
  flex: 1 1 auto;
  min-width: 0;
}

.search-archives-notice__title {
  margin: 0 0 0.35rem;
  font-family: var(--sans, inherit);
  font-weight: 700;
  font-size: 1.05rem;
  color: #1a1a1a;
  line-height: 1.35;
}

.search-archives-notice__text {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.55;
  color: #3a3a3a;
}

.search-archives-notice__link {
  color: #b21f24;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}

.search-archives-notice__link:hover,
.search-archives-notice__link:focus-visible {
  text-decoration: underline;
}

@media (max-width: 600px) {
  .search-archives-notice {
    padding: 1rem 1.1rem;
    gap: 0.85rem;
  }
  .search-archives-notice__icon {
    flex-basis: 26px;
    width: 26px;
    height: 26px;
  }
  .search-archives-notice__title {
    font-size: 1rem;
  }
}

/* ============================================================
   Brèves carousel (home) — horizontal, manual scroll, no autoplay
   ============================================================ */
.breves-carousel {
  border: var(--border);
  background: var(--gray-hover);
  margin-bottom: 56px;
  padding: 16px 20px 20px;
  border-left: 3px solid var(--red);
}
.breves-carousel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.breves-carousel-heading {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.breves-carousel-tick {
  align-self: center;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
}
.breves-carousel-title {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.95rem;
  color: var(--ink, #1a1a1a);
}
.breves-carousel-sub {
  font-size: 0.8rem;
  color: #6b6b6b;
}
.breves-carousel-nav {
  display: flex;
  gap: 8px;
}
.breves-carousel-btn {
  width: 32px;
  height: 32px;
  line-height: 1;
  font-size: 1.25rem;
  border: var(--border);
  background: #fff;
  color: #1a1a1a;
  cursor: pointer;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, color 0.15s ease;
}
.breves-carousel-btn:hover {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.breves-carousel-btn:disabled {
  opacity: 0.35;
  cursor: default;
  background: #fff;
  color: #1a1a1a;
  border-color: #E2DDD8;
}
.breves-carousel-track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.breves-carousel-track::-webkit-scrollbar { display: none; }
.breves-card {
  flex: 0 0 230px;
  background: #fff;
  border: var(--border);
  border-top: 3px solid var(--red);
  border-radius: 4px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  cursor: pointer;
  transition: box-shadow 0.15s ease;
}
.breves-card:hover {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}
.breves-card-cat {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--red);
}
.breves-card-title {
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.35;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.breves-card-title a { color: inherit; text-decoration: none; }
.breves-card-title a:hover { color: var(--red); }
.breves-card-meta {
  font-size: 0.75rem;
  color: #6b6b6b;
  margin-top: auto;
}

@media (max-width: 768px) {
  .breves-carousel { margin-bottom: 40px; padding: 14px 16px 16px; }
  .breves-card { flex-basis: 78%; }
  .breves-carousel-sub { display: none; }
}
