/*
Theme Name:        SPIPHOTO FSE
Theme URI:         https://preprod.spiphoto.fr
Author:            SPIPHOTO
Author URI:        https://spiphoto.fr
Description:       Thème Full Site Editing pour le club photo SPIPHOTO de Gournay-en-Bray. Mode sombre, palette olive & mauve prune, optimisé pour la photographie.
Version:           1.2.0
Requires at least: 6.4
Tested up to:      6.7
Requires PHP:      8.1
License:           GNU General Public License v2 or later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       spiphoto-fse
Tags:              full-site-editing, block-themes, news, magazine, photography, dark, two-columns, featured-images, custom-colors, custom-logo, custom-menu, editor-style, wide-blocks, translation-ready, accessibility-ready
*/

/* ═══════════════════════════════════════════════
   CUSTOM PROPERTIES — Palette SPIPHOTO
═══════════════════════════════════════════════ */
:root {
  --sp-primary:        #4b5a22;
  --sp-primary-dk:     #3a4519;
  --sp-primary-lt:     #6a7e30;
  --sp-secondary:      #936893;
  --sp-secondary-dk:   #7a5579;
  --sp-secondary-lt:   #b08ab0;

  --sp-bg:             #0d0e09;
  --sp-surface:        #161a0e;
  --sp-surface-raised: #1e2412;
  --sp-surface-top:    #252c15;
  --sp-border:         #2a3118;
  --sp-border-lt:      #3a4519;
  --sp-text:           #f2efe8;
  --sp-text-sec:       #9e9a8e;
  --sp-text-muted:     #6b6860;
  --sp-text-disabled:  #3d3c38;
  --sp-card-shadow:    0 2px 8px rgba(0,0,0,.45);
  --sp-card-shadow-h:  0 8px 28px rgba(0,0,0,.65), 0 0 0 1px rgba(75,90,34,.3);
  --sp-hero-overlay:   linear-gradient(to top, rgba(13,14,9,.95) 0%, rgba(13,14,9,.55) 45%, transparent 100%);

  --sp-header-h:       110px;
  --sp-radius-sm:      4px;
  --sp-radius:         8px;
  --sp-radius-lg:      12px;
  --sp-transition:     0.22s ease;
  --sp-transition-fast:0.14s ease;
  --sp-theme-transition: background-color 0.35s ease, color 0.35s ease,
                         border-color 0.35s ease, box-shadow 0.35s ease;
}

html[data-theme="light"] {
  --sp-bg:             #f7f3ec;
  --sp-surface:        #ffffff;
  --sp-surface-raised: #eee9df;
  --sp-surface-top:    #e5dfd3;
  --sp-border:         #ddd8cb;
  --sp-border-lt:      #c4bead;
  --sp-text:           #1c1e0f !important;
  --sp-text-sec:       #3e4028;
  --sp-text-muted:     #7a7660;
  --sp-text-disabled:  #b8b4a2;
  --sp-card-shadow:    0 2px 8px rgba(0,0,0,.08);
  --sp-card-shadow-h:  0 8px 28px rgba(0,0,0,.14), 0 0 0 1px rgba(75,90,34,.2);
  --sp-hero-overlay:   linear-gradient(to top, rgba(28,30,15,.85) 0%, rgba(28,30,15,.35) 50%, transparent 100%);
}

/* ═══════════════════════════════════════════════
   BASE
═══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  overflow-x: hidden;
  background-color: var(--sp-bg);
  color: var(--sp-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, video { max-width: 100%; height: auto; display: block; }
::selection { background: rgba(147, 104, 147, 0.35); color: var(--sp-text); }

/* ═══════════════════════════════════════════════
   ACCESSIBILITÉ
═══════════════════════════════════════════════ */
.skip-to-content {
  position: absolute; top: -100%; left: 1rem; z-index: 9999;
  padding: 0.75rem 1.5rem; background: var(--sp-secondary); color: var(--sp-text);
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif);
  font-size: 0.875rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase;
  text-decoration: none; border-radius: 0 0 var(--sp-radius-sm) var(--sp-radius-sm);
  transition: top 0.15s ease;
}
.skip-to-content:focus { top: 0; }
:focus-visible { outline: 2px solid var(--sp-secondary); outline-offset: 3px; border-radius: 2px; }

/* ═══════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════ */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--sp-surface);
  border-bottom: 1px solid var(--sp-border);
  box-shadow: 0 2px 12px rgba(0,0,0,.5);
  transition: box-shadow var(--sp-transition);
}
.site-header.scrolled {
  box-shadow: 0 4px 20px rgba(0,0,0,.65);
  border-bottom-color: var(--sp-border-lt);
}

/* Logo */
.wp-block-site-logo img { filter: brightness(1.1); }

/* Titre du site */
.wp-block-site-title {
  font-family: var(--wp--preset--font-family--playfair, Georgia, serif) !important;
  font-weight: 800 !important; letter-spacing: -0.02em !important; line-height: 1 !important;
}
.wp-block-site-title a { color: var(--sp-text) !important; text-decoration: none !important; transition: color var(--sp-transition-fast); }
.wp-block-site-title a:hover { color: var(--sp-primary-lt) !important; }

/* Tagline */
.wp-block-site-tagline {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.625rem !important; letter-spacing: 0.1em !important;
  text-transform: uppercase !important; color: var(--sp-text-muted) !important;
}

/* ═══════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════ */
.header-topbar {
  background: var(--sp-bg);
  border-bottom: 1px solid var(--sp-border);
}
.header-topbar-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0 clamp(1rem, 4vw, 2rem);
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; min-height: 36px;
}
.topbar-right {
  display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0;
}

/* Recherche dans la topbar */
.topbar-search .wp-block-search__input {
  background: transparent !important;
  border: 1px solid var(--sp-border-lt) !important;
  border-radius: var(--sp-radius-sm) !important;
  color: var(--sp-text) !important;
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.75rem !important;
  padding: 0.3rem 0.65rem !important;
  width: 160px;
  transition: border-color var(--sp-transition-fast), width var(--sp-transition);
}
.topbar-search .wp-block-search__input:focus {
  outline: none !important;
  border-color: var(--sp-primary) !important;
  width: 220px;
  box-shadow: none !important;
}
.topbar-search .wp-block-search__input::placeholder { color: var(--sp-text-disabled) !important; }
.topbar-search .wp-block-search__button {
  background: none !important;
  border: none !important;
  cursor: pointer;
  color: var(--sp-text-muted) !important;
  padding: 0.3rem !important;
  display: flex; align-items: center;
  transition: color var(--sp-transition-fast);
}
.topbar-search .wp-block-search__button:hover { color: var(--sp-text) !important; }

/* Navigation topbar — mode nuit */
.header-topbar .wp-block-navigation-item__content {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.6875rem !important; font-weight: 500 !important;
  letter-spacing: 0.06em !important; text-transform: uppercase !important;
  color: rgba(242,239,232,0.55) !important;
  padding: 0.5rem 0.75rem !important;
  text-decoration: none !important;
  transition: color var(--sp-transition-fast);
}
.header-topbar .wp-block-navigation-item__content:hover { color: rgba(242,239,232,0.9) !important; }
.header-topbar .wp-block-navigation-item__content::after { display: none !important; }

/* Sous-menus topbar — fond forcé */
.header-topbar .wp-block-navigation__submenu-container,
.header-topbar .wp-block-navigation__submenu-container * {
  background-color: var(--sp-surface-top) !important;
}
.header-topbar .wp-block-navigation__submenu-container {
  border: 1px solid var(--sp-border-lt) !important;
  border-top: 2px solid var(--sp-primary) !important;
  border-radius: 0 0 var(--sp-radius) var(--sp-radius) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.6) !important;
  min-width: 180px !important;
  padding: 0.4rem 0 !important;
}
.header-topbar .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  font-size: 0.8125rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  padding: 0.55rem 1.25rem !important;
  color: var(--sp-text-sec) !important;
  background: transparent !important;
}
.header-topbar .wp-block-navigation__submenu-container .wp-block-navigation-item__content::after {
  display: none !important;
}
.header-topbar .wp-block-navigation__submenu-container .wp-block-navigation-item:hover .wp-block-navigation-item__content {
  color: var(--sp-text) !important;
  background: rgba(75,90,34,.2) !important;
}

/* Mode jour — topbar */
html[data-theme="light"] .header-topbar {
  background: var(--sp-surface-raised) !important;
  border-bottom-color: var(--sp-border) !important;
}
html[data-theme="light"] .header-topbar .wp-block-navigation-item__content {
  color: rgba(28,30,15,0.6) !important;
}
html[data-theme="light"] .header-topbar .wp-block-navigation-item__content:hover {
  color: rgba(28,30,15,0.95) !important;
}
html[data-theme="light"] .header-topbar .wp-block-navigation__submenu-container,
html[data-theme="light"] .header-topbar .wp-block-navigation__submenu-container * {
  background-color: var(--sp-surface-top) !important;
}
html[data-theme="light"] .header-topbar .wp-block-navigation__submenu-container {
  box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
  border-color: var(--sp-border) !important;
}

/* ═══════════════════════════════════════════════
   LIGNE LOGO / TITRE
═══════════════════════════════════════════════ */
.header-brand-row {
  background: var(--sp-surface);
  border-bottom: 1px solid var(--sp-border);
}
.header-brand-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0.75rem clamp(1rem, 4vw, 2rem);
  display: flex; align-items: center; justify-content: space-between;
}
.header-brand { display: flex; align-items: center; gap: 0.75rem; }

/* ═══════════════════════════════════════════════
   BARRE CATÉGORIES + NAVIGATION FSE
═══════════════════════════════════════════════ */
.header-cats-bar {
  background: var(--sp-surface);
  border-bottom: 1px solid var(--sp-border);
}

/* Navigation catégories — conteneur */
.cats-navigation .wp-block-navigation__container {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 0 clamp(1rem, 4vw, 2rem) !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

/* Navigation catégories — liens parents */
.cats-navigation .wp-block-navigation-item__content {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.75rem !important; font-weight: 600 !important;
  letter-spacing: 0.05em !important; text-transform: uppercase !important;
  color: var(--sp-text-sec) !important;
  padding: 0.65rem 1.1rem !important;
  text-decoration: none !important;
  white-space: nowrap;
  position: relative;
  display: flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
  transition: color var(--sp-transition-fast), background var(--sp-transition-fast);
}
.cats-navigation .wp-block-navigation-item__content::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; background: var(--sp-primary);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--sp-transition);
}
.cats-navigation .wp-block-navigation-item:hover > .wp-block-navigation-item__content,
.cats-navigation .current-menu-item > .wp-block-navigation-item__content,
.cats-navigation .current-menu-ancestor > .wp-block-navigation-item__content {
  color: var(--sp-text) !important;
  background: rgba(75,90,34,.08) !important;
}
.cats-navigation .wp-block-navigation-item:hover > .wp-block-navigation-item__content::after,
.cats-navigation .current-menu-item > .wp-block-navigation-item__content::after,
.cats-navigation .current-menu-ancestor > .wp-block-navigation-item__content::after {
  transform: scaleX(1);
}

/* Chevron FSE natif */
.cats-navigation .wp-block-navigation__submenu-icon {
  opacity: 0.5;
  transition: transform var(--sp-transition-fast), opacity var(--sp-transition-fast);
}
.cats-navigation .wp-block-navigation-item:hover .wp-block-navigation__submenu-icon {
  opacity: 1;
  transform: rotate(180deg);
}

/* Sous-menus natifs FSE */
.cats-navigation .wp-block-navigation__submenu-container {
  background: var(--sp-surface-top) !important;
  border: 1px solid var(--sp-border-lt) !important;
  border-top: 2px solid var(--sp-primary) !important;
  border-radius: 0 0 var(--sp-radius) var(--sp-radius) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.6) !important;
  min-width: 200px !important;
  padding: 0.4rem 0 !important;
}
.cats-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  font-size: 0.8125rem !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  padding: 0.55rem 1.25rem !important;
  color: var(--sp-text-sec) !important;
  position: static !important;
}
.cats-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item__content::after {
  display: none !important;
}
.cats-navigation .wp-block-navigation__submenu-container .wp-block-navigation-item:hover > .wp-block-navigation-item__content {
  color: var(--sp-text) !important;
  background: rgba(75,90,34,.2) !important;
}

/* Bouton burger mobile (généré par WP) */
.cats-navigation .wp-block-navigation__responsive-container-open svg,
.cats-navigation .wp-block-navigation__responsive-container-close svg {
  color: var(--sp-text) !important;
}
.cats-navigation .wp-block-navigation__responsive-container.is-menu-open {
  background: var(--sp-surface) !important;
  padding: 1.5rem !important;
  z-index: 200 !important;
}
.cats-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  font-size: 1rem !important;
  padding: 0.75rem 0 !important;
  color: var(--sp-text) !important;
  border-bottom: 1px solid var(--sp-border) !important;
  text-transform: uppercase !important;
  background: none !important;
}
.cats-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content::after {
  display: none !important;
}

/* ═══════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════ */
.site-sidebar { position: sticky; top: calc(var(--sp-header-h) + 1.5rem); align-self: start; }
@media (max-width: 900px) { .site-sidebar { position: static; display: none; } }

/* ═══════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════ */
.featured-hero { position: relative; overflow: hidden; border-radius: var(--sp-radius); }
.featured-hero img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s cubic-bezier(.25,.46,.45,.94); display: block;
}
.featured-hero:hover img { transform: scale(1.04); }
.featured-hero-overlay { position: absolute; inset: 0; background: var(--sp-hero-overlay); pointer-events: none; }
.featured-hero-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem 2.5rem; }
.featured-hero-content .wp-block-post-title { color: var(--sp-text) !important; text-shadow: 0 2px 12px rgba(0,0,0,.5); }
.featured-hero-content .wp-block-post-title a { color: var(--sp-text) !important; text-decoration: none !important; }
.featured-hero-content .wp-block-post-title a:hover { color: var(--sp-secondary-lt) !important; }

/* ═══════════════════════════════════════════════
   BADGE CATÉGORIE
═══════════════════════════════════════════════ */
.category-badge, .wp-block-post-terms {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.6rem !important; font-weight: 700 !important;
  letter-spacing: 0.12em !important; text-transform: uppercase !important;
}
.category-badge a, .wp-block-post-terms a {
  color: var(--sp-secondary) !important; text-decoration: none !important;
  padding: 0.2rem 0.55rem; background: rgba(147,104,147,.12);
  border-radius: var(--sp-radius-sm); border: 1px solid rgba(147,104,147,.25);
  transition: all var(--sp-transition-fast); display: inline-block;
}
.category-badge a:hover, .wp-block-post-terms a:hover {
  background: var(--sp-secondary); border-color: var(--sp-secondary); color: var(--sp-text) !important;
}

/* ═══════════════════════════════════════════════
   CARTES D'ARTICLES
═══════════════════════════════════════════════ */
.post-card {
  background: var(--sp-surface); border-radius: var(--sp-radius); overflow: hidden;
  border: 1px solid var(--sp-border); box-shadow: var(--sp-card-shadow);
  transition: box-shadow var(--sp-transition), transform var(--sp-transition), border-color var(--sp-transition);
  height: 100%;
}
.post-card:hover { box-shadow: var(--sp-card-shadow-h); transform: translateY(-4px); border-color: var(--sp-border-lt); }
.post-card .wp-block-post-featured-image { overflow: hidden; }
.post-card .wp-block-post-featured-image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.55s cubic-bezier(.25,.46,.45,.94); display: block;
}
.post-card:hover .wp-block-post-featured-image img { transform: scale(1.07); }
.post-card .wp-block-post-title {
  font-family: var(--wp--preset--font-family--playfair, Georgia, serif) !important;
  font-weight: 700 !important; line-height: 1.35 !important; color: var(--sp-text) !important;
}
.post-card .wp-block-post-title a { color: var(--sp-text) !important; text-decoration: none !important; transition: color var(--sp-transition-fast); }
.post-card .wp-block-post-title a:hover { color: var(--sp-secondary-lt) !important; }
.post-card .wp-block-post-excerpt p {
  color: var(--sp-text-sec); display: -webkit-box; -webkit-line-clamp: 3;
  -webkit-box-orient: vertical; overflow: hidden; margin: 0; line-height: 1.65;
}

/* ═══════════════════════════════════════════════
   LISTE D'ARTICLES sidebar
═══════════════════════════════════════════════ */
.post-list-item { display: flex; gap: 0.875rem; align-items: flex-start; }
.post-list-item .wp-block-post-featured-image { flex-shrink: 0; border-radius: 6px; overflow: hidden; }
.post-list-item .wp-block-post-featured-image img { width: 100%; height: 100%; object-fit: cover; }
.post-list-item .wp-block-post-title a { color: var(--sp-text) !important; text-decoration: none !important; transition: color var(--sp-transition-fast); }
.post-list-item .wp-block-post-title a:hover { color: var(--sp-secondary-lt) !important; }

/* ═══════════════════════════════════════════════
   EN-TÊTE DE SECTION
═══════════════════════════════════════════════ */
.section-header { position: relative; border-bottom: 2px solid var(--sp-border-lt); padding-bottom: 0.75rem; margin-bottom: 1.5rem; }
.section-header::after {
  content: ''; position: absolute; bottom: -2px; left: 0;
  width: 48px; height: 2px; background: var(--sp-primary); border-radius: 1px;
}

/* ═══════════════════════════════════════════════
   WIDGETS SIDEBAR
═══════════════════════════════════════════════ */
.sidebar-widget { background: var(--sp-surface) !important; border-radius: var(--sp-radius) !important; border: 1px solid var(--sp-border); }
.widget-title {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  font-size: 0.6875rem !important; font-weight: 800 !important; text-transform: uppercase !important;
  letter-spacing: 0.14em !important; color: var(--sp-text) !important; display: inline-block;
  margin-bottom: 1.25rem !important; padding-bottom: 0.65rem !important;
  border-bottom: 2px solid var(--sp-primary) !important;
}
.wp-block-tag-cloud { display: flex !important; flex-wrap: wrap !important; gap: 0.35rem !important; }
.wp-block-tag-cloud a {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important;
  padding: 0.25rem 0.7rem !important; background: rgba(75,90,34,.1) !important;
  border: 1px solid rgba(75,90,34,.3) !important; border-radius: 999px !important;
  color: var(--sp-text-sec) !important; text-decoration: none !important;
  transition: all var(--sp-transition-fast) !important; font-size: 0.75rem !important;
  font-weight: 500 !important; line-height: 1 !important;
}
.wp-block-tag-cloud a:hover { background: var(--sp-primary) !important; border-color: var(--sp-primary) !important; color: var(--sp-text) !important; }
.wp-block-categories-list { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.wp-block-categories-list li { padding: 0.45rem 0; border-bottom: 1px solid var(--sp-border); font-family: var(--wp--preset--font-family--dm-sans, sans-serif); font-size: 0.875rem; }
.wp-block-categories-list li:last-child { border-bottom: none; }
.wp-block-categories-list a { color: var(--sp-text-sec) !important; text-decoration: none !important; transition: color var(--sp-transition-fast); display: flex; justify-content: space-between; align-items: center; }
.wp-block-categories-list a:hover { color: var(--sp-secondary-lt) !important; }
.wp-block-categories__post-count { font-size: 0.6875rem; color: var(--sp-text-muted); margin-left: 0.35rem; }

/* ═══════════════════════════════════════════════
   CONTENU ARTICLE
═══════════════════════════════════════════════ */
.entry-content { font-family: var(--wp--preset--font-family--source-serif, Georgia, serif); font-size: 1.0625rem; line-height: 1.85; color: var(--sp-text); }
.entry-content p { margin-block: 1.4em; }
.entry-content p:first-child { margin-top: 0; }
.entry-content h2, .entry-content h3, .entry-content h4 {
  font-family: var(--wp--preset--font-family--playfair, Georgia, serif); color: var(--sp-text);
  margin-top: 2em; margin-bottom: 0.6em; line-height: 1.25;
}
.entry-content .wp-block-gallery { margin-block: 2.5rem; }
.entry-content .wp-block-image figcaption {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif); font-size: 0.8125rem;
  color: var(--sp-text-muted); text-align: center; font-style: italic; margin-top: 0.5rem;
}
.entry-content .wp-block-image img, .entry-content .wp-block-gallery img { border-radius: var(--sp-radius-sm); }
.entry-content blockquote, .wp-block-quote {
  border-left: 3px solid var(--sp-secondary); padding-left: 1.5rem; margin-inline: 0;
  font-family: var(--wp--preset--font-family--playfair, Georgia, serif); font-size: 1.1875rem;
  font-style: italic; color: var(--sp-text-sec); background: rgba(147,104,147,.06);
  padding-block: 1rem; border-radius: 0 var(--sp-radius-sm) var(--sp-radius-sm) 0;
}
code, pre {
  font-size: 0.875rem; background: var(--sp-surface-raised); border: 1px solid var(--sp-border-lt);
  border-radius: var(--sp-radius-sm); color: var(--sp-secondary-lt);
}
code { padding: 0.15em 0.4em; }
pre  { padding: 1rem 1.25rem; overflow-x: auto; }
.entry-content a {
  color: var(--sp-secondary); text-decoration: underline; text-decoration-color: rgba(147,104,147,.4);
  text-underline-offset: 3px; transition: color var(--sp-transition-fast), text-decoration-color var(--sp-transition-fast);
}
.entry-content a:hover { color: var(--sp-secondary-lt); text-decoration-color: var(--sp-secondary-lt); }

/* ═══════════════════════════════════════════════
   PAGINATION
═══════════════════════════════════════════════ */
.wp-block-query-pagination { display: flex; align-items: center; justify-content: center; gap: 0.3rem; font-family: var(--wp--preset--font-family--dm-sans, sans-serif); }
.wp-block-query-pagination-numbers a,
.wp-block-query-pagination-numbers span,
.wp-block-query-pagination-previous a,
.wp-block-query-pagination-next a {
  display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px;
  padding-inline: 0.6rem; font-size: 0.875rem; font-weight: 500; border: 1px solid var(--sp-border-lt);
  border-radius: var(--sp-radius-sm); color: var(--sp-text-sec); text-decoration: none;
  background: var(--sp-surface); transition: all var(--sp-transition-fast);
}
.wp-block-query-pagination-numbers a:hover,
.wp-block-query-pagination-previous a:hover,
.wp-block-query-pagination-next a:hover { border-color: var(--sp-primary); color: var(--sp-text); background: rgba(75,90,34,.15); }
.wp-block-query-pagination-numbers .current { background: var(--sp-primary); border-color: var(--sp-primary); color: var(--sp-text); font-weight: 700; }

/* ═══════════════════════════════════════════════
   BOUTONS
═══════════════════════════════════════════════ */
.wp-block-button .wp-block-button__link, .wp-element-button {
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important; font-size: 0.8125rem !important;
  font-weight: 600 !important; letter-spacing: 0.05em !important; text-transform: uppercase !important;
  border-radius: var(--sp-radius-sm) !important;
  transition: background var(--sp-transition), transform var(--sp-transition-fast), box-shadow var(--sp-transition) !important;
}
.wp-block-button .wp-block-button__link:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(75,90,34,.4); }
.is-style-outline .wp-block-button__link { background: transparent !important; border: 1.5px solid var(--sp-primary) !important; color: var(--sp-text) !important; }
.is-style-outline .wp-block-button__link:hover { background: rgba(75,90,34,.2) !important; }
.is-style-ghost .wp-block-button__link { background: transparent !important; border: 1.5px solid var(--sp-secondary) !important; color: var(--sp-secondary) !important; }
.is-style-ghost .wp-block-button__link:hover { background: rgba(147,104,147,.15) !important; color: var(--sp-secondary-lt) !important; box-shadow: 0 4px 12px rgba(147,104,147,.3) !important; }

/* ═══════════════════════════════════════════════
   FORMULAIRES
═══════════════════════════════════════════════ */
input[type="text"], input[type="email"], input[type="search"], input[type="url"], textarea, select {
  background: var(--sp-surface-raised); border: 1px solid var(--sp-border-lt); border-radius: var(--sp-radius-sm);
  color: var(--sp-text); font-family: var(--wp--preset--font-family--source-serif, Georgia, serif);
  font-size: 0.9375rem; padding: 0.7rem 1rem; width: 100%;
  transition: border-color var(--sp-transition-fast), box-shadow var(--sp-transition-fast);
}
input:focus, textarea:focus, select:focus { outline: none; border-color: var(--sp-primary); box-shadow: 0 0 0 3px rgba(75,90,34,.2); }
input::placeholder, textarea::placeholder { color: var(--sp-text-muted); }

/* ═══════════════════════════════════════════════
   COMMENTAIRES
═══════════════════════════════════════════════ */
.wp-block-comments-title { font-family: var(--wp--preset--font-family--playfair, Georgia, serif) !important; color: var(--sp-text) !important; }
.comment-body { background: var(--sp-surface); border: 1px solid var(--sp-border); border-radius: var(--sp-radius); padding: 1.25rem; margin-bottom: 1rem; }
.comment-author b { font-family: var(--wp--preset--font-family--dm-sans, sans-serif); color: var(--sp-text); font-weight: 600; }
.comment-content p { font-family: var(--wp--preset--font-family--source-serif, Georgia, serif); font-size: 0.9375rem; color: var(--sp-text-sec); }
.comment-reply-link { font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important; font-size: 0.75rem !important; font-weight: 600 !important; color: var(--sp-secondary) !important; text-decoration: none !important; text-transform: uppercase; letter-spacing: 0.05em; }
.comment-reply-link:hover { color: var(--sp-secondary-lt) !important; }

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
.site-footer {
  background: var(--sp-bg) !important;
  border-top: 1px solid var(--sp-border);
  color: var(--sp-text-sec);
}
.site-footer p { color: var(--sp-text-sec); }
.site-footer a { color: var(--sp-text-muted); text-decoration: none; transition: color var(--sp-transition-fast); }
.site-footer a:hover { color: var(--sp-secondary-lt) !important; }
.site-footer .wp-block-site-title a { color: var(--sp-text) !important; }
.site-footer .wp-block-site-tagline { color: var(--sp-text-muted) !important; }
.site-footer .footer-partners-label { color: var(--sp-text-disabled) !important; }
.site-footer .footer-copyright,
.site-footer .footer-license { color: var(--sp-text-muted) !important; }
.site-footer .wp-block-navigation-item__content { color: var(--sp-text-sec) !important; font-family: var(--wp--preset--font-family--dm-sans, sans-serif) !important; font-size: 0.875rem !important; text-transform: none !important; letter-spacing: 0 !important; }
.site-footer .wp-block-navigation-item__content:hover { color: var(--sp-secondary-lt) !important; }
.site-footer .wp-block-navigation-item__content::after { display: none !important; }
.site-footer .wp-block-categories-list a { color: var(--sp-text-sec) !important; }
.site-footer .wp-block-categories-list a:hover { color: var(--sp-secondary-lt) !important; }
.site-footer .wp-block-categories-list li { border-color: var(--sp-border); }

/* ═══════════════════════════════════════════════
   BARRE PROGRESSION + RETOUR EN HAUT
═══════════════════════════════════════════════ */
.reading-progress-bar { position: fixed; top: 0; left: 0; width: 0; height: 3px; background: linear-gradient(90deg, var(--sp-primary) 0%, var(--sp-secondary) 100%); z-index: 9999; transition: width 0.1s linear; }
.back-to-top {
  position: fixed; bottom: 2rem; right: 2rem; width: 42px; height: 42px;
  background: var(--sp-primary); color: var(--sp-text); border: none; border-radius: 50%;
  cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.5), 0 0 0 1px rgba(75,90,34,.4);
  opacity: 0; visibility: hidden; transform: translateY(10px); transition: all var(--sp-transition); z-index: 500;
}
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: none; }
.back-to-top:hover { background: var(--sp-primary-dk); box-shadow: 0 6px 20px rgba(0,0,0,.6), 0 0 12px rgba(75,90,34,.35); transform: translateY(-2px); }

/* ═══════════════════════════════════════════════
   SÉPARATEUR + SCROLLBAR
═══════════════════════════════════════════════ */
.wp-block-separator { border-color: var(--sp-border-lt) !important; opacity: 1; }
hr { border-color: var(--sp-border); }
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--sp-bg); }
::-webkit-scrollbar-thumb { background: var(--sp-border-lt); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--sp-primary-dk); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width: 900px) {
  .wp-block-columns { flex-direction: column; }
  :root { --sp-header-h: 72px; }
  .header-topbar { display: none; }
  .theme-toggle { top: 8px; right: 60px; }
}
@media (max-width: 600px) {
  .wp-block-post-template.is-layout-grid { grid-template-columns: 1fr !important; }
  .featured-hero-content { padding: 1.25rem 1.5rem; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } }
@media print { body { background: #fff !important; color: #000 !important; } .site-header, .site-sidebar, .site-footer, .back-to-top, .reading-progress-bar { display: none !important; } a { color: #000; text-decoration: underline; } }

/* ═══════════════════════════════════════════════
   TRANSITIONS THÈME
═══════════════════════════════════════════════ */
body, .site-header, .header-topbar, .header-brand-row, .header-cats-bar,
.site-footer, .post-card, .sidebar-widget,
.wp-block-navigation__submenu-container { transition: var(--sp-theme-transition); }

html[data-theme="light"] .site-header { box-shadow: 0 2px 12px rgba(0,0,0,.10); }
html[data-theme="light"] .site-header.scrolled { box-shadow: 0 4px 20px rgba(0,0,0,.16); }
html[data-theme="light"] .header-topbar { background: var(--sp-surface-top) !important; border-bottom-color: var(--sp-border) !important; }
html[data-theme="light"] .header-brand-row { background: var(--sp-surface); border-bottom-color: var(--sp-border); }
html[data-theme="light"] .header-cats-bar { background: #fff; border-bottom-color: var(--sp-border); }
html[data-theme="light"] .section-header { border-bottom-color: var(--sp-primary) !important; }
html[data-theme="light"] .post-card { box-shadow: var(--sp-card-shadow); border-color: var(--sp-border); }
html[data-theme="light"] .post-card:hover { box-shadow: var(--sp-card-shadow-h); }
html[data-theme="light"] .sidebar-widget { background: var(--sp-surface) !important; border: 1px solid var(--sp-border); }
html[data-theme="light"] .site-footer { background-color: var(--sp-surface-top) !important; border-top: 1px solid var(--sp-border); }
html[data-theme="light"] { scrollbar-color: var(--sp-border-lt) var(--sp-bg); }
html[data-theme="light"] .cats-navigation .wp-block-navigation__submenu-container { box-shadow: 0 8px 24px rgba(0,0,0,.12) !important; background: var(--sp-surface-top) !important; }

/* ═══════════════════════════════════════════════
   TOGGLE JOUR/NUIT
═══════════════════════════════════════════════ */
.theme-toggle {
  position: fixed; top: 6px; right: clamp(1rem, 4vw, 2rem); z-index: 101;
  display: flex; align-items: center; justify-content: center;
  background: none; border: 1px solid var(--sp-border-lt); border-radius: 20px;
  cursor: pointer; padding: 0.3rem 0.65rem; gap: 0.4rem; color: var(--sp-text-muted);
  font-family: var(--wp--preset--font-family--dm-sans, sans-serif);
  font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase;
  white-space: nowrap;
  transition: color var(--sp-transition-fast), border-color var(--sp-transition-fast), background var(--sp-transition-fast);
}
.theme-toggle:hover { color: var(--sp-text); border-color: var(--sp-primary); background: rgba(75,90,34,.1); }
.theme-toggle svg { width: 13px; height: 13px; flex-shrink: 0; }
.theme-toggle .icon-sun  { display: block; }
.theme-toggle .icon-moon { display: none; }
html[data-theme="light"] .theme-toggle .icon-sun  { display: none; }
html[data-theme="light"] .theme-toggle .icon-moon { display: block; }
.theme-toggle .toggle-label-dark  { display: inline; }
.theme-toggle .toggle-label-light { display: none; }
html[data-theme="light"] .theme-toggle .toggle-label-dark  { display: none; }
html[data-theme="light"] .theme-toggle .toggle-label-light { display: inline; }
@media (max-width: 900px) { .theme-toggle .toggle-label-dark, .theme-toggle .toggle-label-light { display: none !important; } }

/* ═══════════════════════════════════════════════
   FIX FOND SUBMENU — override WP block CSS
═══════════════════════════════════════════════ */
.header-topbar .wp-block-navigation__submenu-container {
  background-color: var(--sp-surface-top) !important;
  color: var(--sp-text) !important;
}
.header-topbar .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  background-color: transparent !important;
  color: var(--sp-text-sec) !important;
}
.header-cats-bar .wp-block-navigation__submenu-container {
  background-color: var(--sp-surface-top) !important;
  color: var(--sp-text) !important;
}
.header-cats-bar .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  background-color: transparent !important;
  color: var(--sp-text-sec) !important;
}
html[data-theme="light"] .wp-block-post-title,
html[data-theme="light"] .wp-block-post-title a,
html[data-theme="light"] .wp-block-query-title,
html[data-theme="light"] .wp-block-heading,
html[data-theme="light"] .entry-content h1,
html[data-theme="light"] .entry-content h2,
html[data-theme="light"] .entry-content h3,
html[data-theme="light"] .entry-content h4 {
  color: var(--sp-text);
}

html[data-theme="light"] .wp-block-post-excerpt p,
html[data-theme="light"] .wp-block-post-author__name {
  color: var(--sp-text-sec);
}

html[data-theme="light"] .wp-block-post-date,
html[data-theme="light"] .wp-block-post-date a {
  color: var(--sp-text-muted) !important;
}

/* Cache uniquement la recherche qui n'est pas dans le header */
body > .search-overlay,
footer .search-overlay {
    display: none !important;
}