/*
Theme Name: 7e-republique
Theme URI: https://7e-republique.fr/
Author: Elian Arif
Author URI: https://7e-republique.fr/
Description: Thème officiel 7e-republique.fr — Apple Material Design v3
Version: 3.0
License: GNU General Public License v2 or later
Text Domain: 7e-republique
*/

/* ════════════════════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════════════════════ */
:root {
  /* ── Palette crimson ── */
  --c-crimson:        #7b1620;
  --c-crimson-dk:     #5a0f17;
  --c-crimson-lt:     #a82030;
  --c-crimson-mid:    #8e1a25;
  --c-crimson-glow:   rgba(123, 22, 32, .20);
  --c-crimson-glow2:  rgba(123, 22, 32, .10);
  --c-crimson-tint:   rgba(123, 22, 32, .06);
  --c-crimson-tint2:  rgba(123, 22, 32, .03);
  --c-crimson-grad:   linear-gradient(135deg, var(--c-crimson-dk) 0%, var(--c-crimson) 50%, var(--c-crimson-lt) 100%);

  /* ── Neutrals ── */
  --c-white:          #ffffff;
  --c-bg:             #f7f6f4;
  --c-bg2:            #f0eeeb;
  --c-bg3:            #e8e5e1;
  --c-glass:          rgba(255, 255, 255, .80);
  --c-glass-sm:       rgba(255, 255, 255, .55);
  --c-border:         rgba(0, 0, 0, .07);
  --c-border-md:      rgba(0, 0, 0, .12);
  --c-border-dk:      rgba(0, 0, 0, .18);
  --c-overlay:        rgba(0, 0, 0, .45);

  /* ── Text ── */
  --c-text:           #181818;
  --c-text-2:         #444444;
  --c-text-3:         #888888;
  --c-text-inv:       #ffffff;
  --c-text-inv-2:     rgba(255, 255, 255, .80);
  --c-text-inv-3:     rgba(255, 255, 255, .55);

  /* ── Semantic ── */
  --c-success:        #16a34a;
  --c-success-bg:     #f0fdf4;
  --c-success-border: #bbf7d0;
  --c-error:          #dc2626;
  --c-error-bg:       #fef2f2;
  --c-error-border:   #fecaca;

  /* ── Typography ── */
  --f-brand:          'Bebas Neue', sans-serif;      /* logo / badge seulement */
  --f-display:        var(--f-sans);                 /* headings → Inter */
  --f-sans:           'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --f-serif:          'Lora', Georgia, 'Times New Roman', serif;
  --f-body:           var(--f-sans);
  --fw-light:         300;
  --fw-normal:        400;
  --fw-medium:        500;
  --fw-semibold:      600;
  --fw-bold:          700;
  --fw-black:         800;
  --ls-display:       .12em;                         /* Bebas brand uniquement */
  --ls-heading:       -0.02em;                       /* Inter grands titres */
  --ls-subheading:    -0.01em;                       /* Inter titres moyens */
  --ls-wide:          .18em;
  --ls-tight:         .04em;
  --ls-body:          -.012em;

  /* ── Font sizes — fluid, mobile first ── */
  --fs-2xs:           0.625rem;                                  /* 10px */
  --fs-xs:            0.75rem;                                   /* 12px */
  --fs-sm:            0.875rem;                                  /* 14px */
  --fs-base:          1rem;                                      /* 16px */
  --fs-md:            clamp(1rem, 0.95rem + 0.25vw, 1.125rem);  /* 16→18px */
  --fs-lg:            clamp(1.125rem, 1rem + 0.5vw, 1.3rem);    /* 18→21px */
  --fs-xl:            clamp(1.25rem, 1rem + 0.8vw, 1.5rem);     /* 20→24px */
  --fs-2xl:           clamp(1.5rem, 1.2rem + 1vw, 1.875rem);    /* 24→30px */
  --fs-3xl:           clamp(1.875rem, 1.4rem + 1.5vw, 2.375rem);/* 30→38px */
  --fs-4xl:           clamp(2.25rem, 1.5rem + 2vw, 3rem);       /* 36→48px */
  --fs-hero:          clamp(2.5rem, 1.5rem + 3.5vw, 4.25rem);   /* 40→68px */
  --fs-hero-sub:      clamp(1rem, 0.9rem + 0.5vw, 1.25rem);     /* 16→20px */

  /* ── Line heights ── */
  --lh-tight:         1.1;
  --lh-snug:          1.25;
  --lh-normal:        1.5;
  --lh-relaxed:       1.75;
  --lh-prose:         1.85;

  /* ── Radii ── */
  --r-xs:             4px;
  --r-sm:             8px;
  --r-md:             14px;
  --r-lg:             22px;
  --r-xl:             32px;
  --r-2xl:            44px;
  --r-3xl:            60px;
  --r-pill:           999px;
  --r-circle:         50%;

  /* ── Shadows ── */
  --sh-xs:            0 1px 4px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --sh-sm:            0 4px 14px rgba(0,0,0,.09), 0 2px 5px rgba(0,0,0,.05);
  --sh-md:            0 8px 32px rgba(0,0,0,.11), 0 4px 12px rgba(0,0,0,.06);
  --sh-lg:            0 20px 64px rgba(0,0,0,.13), 0 8px 24px rgba(0,0,0,.08);
  --sh-xl:            0 40px 90px rgba(0,0,0,.15), 0 16px 40px rgba(0,0,0,.09);
  --sh-crimson:       0 8px 32px rgba(123,22,32,.28), 0 2px 8px rgba(123,22,32,.14);
  --sh-crimson-lg:    0 16px 48px rgba(123,22,32,.35), 0 4px 16px rgba(123,22,32,.18);
  --sh-inner:         inset 0 1px 3px rgba(0,0,0,.08);
  --sh-focus:         0 0 0 4px var(--c-crimson-glow);
  --sh-text:          0 1px 3px rgba(0,0,0,.18);            /* text-shadow dark on light */
  --sh-text-inv:      0 1px 6px rgba(0,0,0,.4), 0 2px 16px rgba(0,0,0,.2); /* text-shadow light on dark */
  --sh-hero-bottom:   0 12px 40px -8px rgba(0,0,0,.18);    /* séparation hero / contenu */

  /* ── Spacing ── */
  --sp-xs:            .25rem;
  --sp-sm:            .5rem;
  --sp-md:            1rem;
  --sp-lg:            1.5rem;
  --sp-xl:            2rem;
  --sp-2xl:           3rem;
  --sp-3xl:           4.5rem;
  --sp-4xl:           6rem;
  --sp-section:       clamp(3rem, 6vw, 6rem);

  /* ── Motion ── */
  --ease-spring:      cubic-bezier(.34, 1.56, .64, 1);
  --ease-out:         cubic-bezier(.16, 1, .3, 1);
  --ease-smooth:      cubic-bezier(.25, .46, .45, .94);
  --ease-in-out:      cubic-bezier(.45, 0, .55, 1);
  --d-instant:        .08s;
  --d-fast:           .18s;
  --d-mid:            .36s;
  --d-slow:           .65s;
  --d-lazy:           .9s;

  /* ── Nav ── */
  --nav-h:            72px;
  --nav-h-scrolled:   62px;

  /* ── Circles ── */
  --circle-size:      clamp(80px, 11vw, 125px);
  --circle-font:      clamp(11px, 1.1vw, 15px);

  /* ── Layout ── */
  --max-content:      900px;
  --max-wide:         1140px;
  --max-contact:      1060px;

  /* ── Blur ── */
  --blur-glass:       blur(24px) saturate(180%);
  --blur-sm:          blur(10px);
}

/* ════════════════════════════════════════════════════
   KEYFRAMES
════════════════════════════════════════════════════ */
@keyframes fadeUp    { from { opacity:0; transform:translateY(40px) scale(.97) } to { opacity:1; transform:none } }
@keyframes fadeIn    { from { opacity:0 } to { opacity:1 } }
@keyframes scaleIn   { from { opacity:0; transform:scale(.88) } to { opacity:1; transform:none } }
@keyframes slideDown { from { opacity:0; transform:translateY(-12px) } to { opacity:1; transform:none } }
@keyframes gradShift { 0%,100% { background-position:0% 50% } 50% { background-position:100% 50% } }
@keyframes float     { 0%,100% { transform:translateY(0) } 50% { transform:translateY(-8px) } }
@keyframes floatSlow { 0%,100% { transform:translateY(0) rotate(0deg) } 50% { transform:translateY(-14px) rotate(3deg) } }
@keyframes pulse     { 0%,100% { transform:scale(1); opacity:.7 } 50% { transform:scale(1.08); opacity:1 } }
@keyframes shimmer   { from { background-position:-500px 0 } to { background-position:500px 0 } }
@keyframes spin      { to { transform:rotate(360deg) } }
@keyframes accordionOpen {
  from { opacity:0; transform:translateY(-6px) }
  to   { opacity:1; transform:none }
}
@keyframes ripple {
  to { transform:scale(4); opacity:0 }
}
@keyframes orbPulse  { 0%,100% { opacity:.4; transform:scale(1) } 50% { opacity:.7; transform:scale(1.12) } }

/* ════════════════════════════════════════════════════
   SCROLL REVEAL
════════════════════════════════════════════════════ */
.reveal, .reveal-scale, .reveal-left, .reveal-right {
  opacity: 0;
  transition:
    opacity var(--d-slow) var(--ease-out),
    transform var(--d-slow) var(--ease-out);
}
.reveal       { transform: translateY(44px) scale(.98); }
.reveal-scale { transform: scale(.90); }
.reveal-left  { transform: translateX(-48px); }
.reveal-right { transform: translateX(48px); }
.reveal.visible, .reveal-scale.visible,
.reveal-left.visible, .reveal-right.visible {
  opacity: 1; transform: none;
}
.delay-1 { transition-delay: .08s }
.delay-2 { transition-delay: .16s }
.delay-3 { transition-delay: .24s }
.delay-4 { transition-delay: .32s }
.delay-5 { transition-delay: .40s }
.delay-6 { transition-delay: .48s }

/* ════════════════════════════════════════════════════
   BASE RESET
════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0 }
html  { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-size-adjust: 100% }
body  { font-family: var(--f-sans); font-size: var(--fs-base); color: var(--c-text); background: var(--c-bg); line-height: var(--lh-relaxed); overflow-x: hidden; letter-spacing: var(--ls-body) }
h1,h2,h3,h4,h5,h6 { font-family: var(--f-sans); font-weight: var(--fw-bold); line-height: var(--lh-snug); letter-spacing: var(--ls-heading) }
h1 { font-size: var(--fs-4xl) }
h2 { font-size: var(--fs-3xl) }
h3 { font-size: var(--fs-2xl) }
h4 { font-size: var(--fs-xl); font-weight: var(--fw-semibold) }
h5 { font-size: var(--fs-lg); font-weight: var(--fw-semibold) }
h6 { font-size: var(--fs-md); font-weight: var(--fw-semibold) }
p     { font-family: var(--f-sans); font-size: var(--fs-md); line-height: var(--lh-prose); margin-bottom: var(--sp-lg) }
a     { color: inherit; text-decoration: none }
img   { max-width: 100%; height: auto; display: block }
button, input, select, textarea { font-family: var(--f-sans) }

/* ════════════════════════════════════════════════════
   NAVIGATION
════════════════════════════════════════════════════ */
.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 500;
  height: var(--nav-h);
  background: transparent;
  border-bottom: 1px solid transparent;
  transition:
    height       var(--d-mid) var(--ease-smooth),
    background   var(--d-mid) var(--ease-smooth),
    border-color var(--d-mid) var(--ease-smooth),
    box-shadow   var(--d-mid) var(--ease-smooth);
}
.site-nav.scrolled {
  height: var(--nav-h-scrolled);
  background: var(--c-glass);
  backdrop-filter: var(--blur-glass);
  -webkit-backdrop-filter: var(--blur-glass);
  border-color: var(--c-border);
  box-shadow: var(--sh-sm);
}

.nav-inner {
  max-width: var(--max-wide);
  height: 100%;
  margin: 0 auto;
  padding: 0 var(--sp-xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-lg);
}

/* Brand */
.nav-brand   { display:flex; align-items:center; gap:var(--sp-md); flex-shrink:0 }
.nav-logo    { display:flex; align-items:center; gap:var(--sp-md); text-decoration:none }
.nav-logo-badge {
  width: 48px; height: 48px; border-radius: var(--r-circle);
  background: var(--c-crimson); display:flex; align-items:center; justify-content:center;
  box-shadow: var(--sh-crimson);
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.nav-logo:hover .nav-logo-badge {
  transform: scale(1.1) rotate(-5deg);
  box-shadow: var(--sh-crimson-lg);
}
.nav-logo-badge span {
  color: #fff; font-family: var(--f-brand); font-size: 1.5rem; line-height: 1; letter-spacing:.04em
}
.nav-logo-badge sup { font-size:.58rem; font-weight:700; vertical-align:super }
.nav-logo-text { font-family:var(--f-brand); font-size:1.45rem; color:var(--c-crimson); letter-spacing:var(--ls-wide) }
.site-nav:not(.scrolled) .nav-logo-text { color:#fff }

/* Socials */
.nav-socials { display:flex; gap:6px }
.nav-social-btn {
  width:30px; height:30px; border-radius:var(--r-circle);
  display:flex; align-items:center; justify-content:center;
  color: var(--c-text-3);
  transition: color var(--d-fast), background var(--d-fast), transform var(--d-fast) var(--ease-spring);
}
.site-nav:not(.scrolled) .nav-social-btn { color: var(--c-text-inv-3) }
.nav-social-btn:hover { color:var(--c-crimson); background:var(--c-crimson-tint); transform:translateY(-2px) }
.site-nav:not(.scrolled) .nav-social-btn:hover { background:rgba(255,255,255,.15); color:#fff }

/* Desktop container */
.nav-desktop { display:flex; align-items:center; gap:var(--sp-xl) }

/* Nav links */
.nav-links { list-style:none; display:flex; align-items:center; gap:2px }
.nav-item  { position:relative }
.nav-link  {
  display:flex; align-items:center; gap:5px;
  padding: 7px 13px; border-radius: var(--r-pill);
  font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--c-text-2);
  transition: color var(--d-fast), background var(--d-fast);
  position: relative;
  white-space: nowrap;
}
.nav-link::after {
  content: ''; position:absolute; bottom:5px; left:50%;
  transform: translateX(-50%) scaleX(0);
  width: calc(100% - 22px); height: 2px;
  background: var(--c-crimson); border-radius: var(--r-pill);
  transition: transform var(--d-mid) var(--ease-spring);
}
.nav-link:hover, .nav-link.is-active { color:var(--c-crimson); background:var(--c-crimson-tint) }
.nav-link:hover::after, .nav-link.is-active::after { transform:translateX(-50%) scaleX(1) }
.site-nav:not(.scrolled) .nav-link { color: rgba(255,255,255,.88) }
.site-nav:not(.scrolled) .nav-link:hover { color:#fff; background:rgba(255,255,255,.15) }
.site-nav:not(.scrolled) .nav-link:hover::after,
.site-nav:not(.scrolled) .nav-link.is-active::after { background:#fff }

/* Nav chevron */
.nav-chevron {
  flex-shrink:0;
  transition: transform var(--d-mid) var(--ease-spring);
}
.nav-item.has-dropdown:hover .nav-chevron { transform:rotate(180deg) }

/* Dropdown */
.nav-dropdown {
  list-style:none;
  position:absolute; top:calc(100% + 10px); left:50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 200px;
  background: var(--c-glass);
  backdrop-filter: var(--blur-glass);
  -webkit-backdrop-filter: var(--blur-glass);
  border: 1px solid var(--c-border-md);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-lg);
  padding: var(--sp-sm);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--d-mid) var(--ease-smooth),
    transform var(--d-mid) var(--ease-out);
  z-index: 100;
}
.nav-dropdown::before {
  content:''; position:absolute; top:-6px; left:50%; transform:translateX(-50%);
  width:12px; height:12px; background:var(--c-glass); border:1px solid var(--c-border-md);
  border-bottom:none; border-right:none; transform:translateX(-50%) rotate(45deg);
}
.nav-item.has-dropdown:hover .nav-dropdown {
  opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.nav-dropdown-link {
  display:block; padding: 8px 14px; border-radius: var(--r-md);
  font-size:var(--fs-sm); font-weight:var(--fw-medium); color:var(--c-text-2);
  transition: color var(--d-fast), background var(--d-fast), padding-left var(--d-fast) var(--ease-spring);
}
.nav-dropdown-link:hover { color:var(--c-crimson); background:var(--c-crimson-tint); padding-left:20px }

/* Nav actions */
.nav-actions { display:flex; align-items:center; gap:var(--sp-sm) }

/* CTA button nav */
.nav-cta {
  display: inline-flex; align-items:center; gap:7px;
  padding: 8px 18px; border-radius: var(--r-pill);
  background: var(--c-crimson);
  color: #fff!important;
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
  box-shadow: var(--sh-crimson);
  position: relative; overflow: hidden;
  transition: background var(--d-fast), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.nav-cta::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.15) 50%, transparent 60%);
  background-size: 300%; background-position:-100% 0;
  transition: background-position .5s;
}
.nav-cta:hover::before { background-position:200% 0 }
.nav-cta:hover {
  background: var(--c-crimson-dk);
  transform: translateY(-2px) scale(1.03);
  box-shadow: var(--sh-crimson-lg);
}
.site-nav:not(.scrolled) .nav-cta { background:rgba(255,255,255,.2); backdrop-filter:var(--blur-sm); border:1px solid rgba(255,255,255,.3) }
.site-nav:not(.scrolled) .nav-cta:hover { background:rgba(255,255,255,.35) }

/* Search btn */
.nav-search-btn {
  width:36px; height:36px; border-radius:var(--r-circle);
  border:1.5px solid var(--c-border-md);
  background:transparent; color:var(--c-text-2); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--d-fast) var(--ease-spring);
}
.nav-search-btn:hover { background:var(--c-crimson); border-color:var(--c-crimson); color:#fff; transform:scale(1.08); box-shadow:var(--sh-crimson) }
.site-nav:not(.scrolled) .nav-search-btn { border-color:rgba(255,255,255,.35); color:rgba(255,255,255,.85) }
.site-nav:not(.scrolled) .nav-search-btn:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.5); color:#fff }

/* Search box */
#desktop-search-box {
  position:absolute; left:0; right:0; top:100%;
  background:var(--c-glass); backdrop-filter:var(--blur-glass); -webkit-backdrop-filter:var(--blur-glass);
  border-bottom:1px solid var(--c-border); box-shadow:var(--sh-md);
  transition: opacity var(--d-mid) var(--ease-smooth), transform var(--d-mid) var(--ease-out);
  transform-origin: top;
}
#desktop-search-box.hidden { display:none }
#desktop-search-box.opacity-0 { opacity:0; transform:scaleY(.94) translateY(-8px) }
.nav-search-inner { max-width:var(--max-wide); margin:0 auto; padding:var(--sp-md) var(--sp-xl) }

/* Hamburger */
.nav-hamburger {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:36px; height:36px; background:transparent; border:none; cursor:pointer; padding:4px;
}
.nav-hamburger span {
  display:block; height:2px; border-radius:2px;
  background: var(--c-text);
  transition: transform var(--d-mid) var(--ease-spring), opacity var(--d-fast), background var(--d-fast);
}
.nav-hamburger span:nth-child(2) { width:72% }
.nav-hamburger span:nth-child(3) { width:85% }
.site-nav:not(.scrolled) .nav-hamburger span { background:#fff }
.nav-hamburger.is-open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.nav-hamburger.is-open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.nav-hamburger.is-open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

/* Mobile controls */
.nav-mobile-controls { display:none; align-items:center; gap:var(--sp-sm) }

/* ── Mobile menu drawer ── */
.nav-mobile-menu {
  position: absolute; top:100%; left:0; right:0;
  background: var(--c-glass);
  backdrop-filter: var(--blur-glass); -webkit-backdrop-filter: var(--blur-glass);
  border-bottom: 1px solid var(--c-border);
  box-shadow: var(--sh-lg);
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--d-slow) var(--ease-smooth);
}
.nav-mobile-menu.is-open { max-height: 80vh; overflow-y: auto }
.nav-mobile-inner { padding: var(--sp-md) var(--sp-lg) var(--sp-xl) }

/* Mobile links */
.nav-mobile-item { border-bottom: 1px solid var(--c-border) }
.nav-mobile-item:last-of-type { border-bottom: none }
.nav-mobile-link {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 13px 14px; border-radius: var(--r-md);
  font-size: var(--fs-base); font-weight: var(--fw-medium);
  color: var(--c-text); background: transparent; border: none; cursor: pointer; text-align: left;
  transition: background var(--d-fast), color var(--d-fast);
}
.nav-mobile-link:hover { background:var(--c-crimson-tint); color:var(--c-crimson) }
.nav-mobile-chevron { flex-shrink:0; transition:transform var(--d-mid) var(--ease-spring) }
.nav-accordion-trigger[aria-expanded="true"] .nav-mobile-chevron { transform:rotate(180deg) }

/* Accordion panel */
.nav-accordion-panel {
  padding: 0 var(--sp-md) var(--sp-sm);
  animation: accordionOpen var(--d-mid) var(--ease-out) both;
}
.nav-accordion-parent-link {
  display: block; padding: 9px 14px; border-radius: var(--r-md);
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  color: var(--c-crimson);
  transition: background var(--d-fast);
}
.nav-accordion-parent-link:hover { background:var(--c-crimson-tint) }
.nav-accordion-child-link {
  display: block; padding: 8px 14px 8px 24px; border-radius: var(--r-md);
  font-size: var(--fs-sm); color: var(--c-text-2);
  transition: background var(--d-fast), color var(--d-fast), padding-left var(--d-fast) var(--ease-spring);
}
.nav-accordion-child-link:hover { background:var(--c-crimson-tint); color:var(--c-crimson); padding-left:30px }

/* Mobile CTA */
.nav-mobile-cta-wrap { padding: var(--sp-lg) 0 var(--sp-sm) }
.nav-mobile-cta {
  display: flex; align-items: center; justify-content: center; gap: var(--sp-sm);
  width: 100%; padding: 13px var(--sp-xl);
  border-radius: var(--r-pill);
  background: var(--c-crimson); color: #fff;
  font-size: var(--fs-base); font-weight: var(--fw-semibold);
  box-shadow: var(--sh-crimson);
  transition: background var(--d-fast), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.nav-mobile-cta:hover { background:var(--c-crimson-dk); transform:translateY(-2px); box-shadow:var(--sh-crimson-lg) }

/* ════════════════════════════════════════════════════
   PAGE OFFSET (nav fixe)
════════════════════════════════════════════════════ */
.site-primary { padding-top: var(--nav-h) }

/* ════════════════════════════════════════════════════
   PRÉSENTATION — HERO
════════════════════════════════════════════════════ */
.presentation-section {
  width: 100%; max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--sp-xl) var(--sp-lg) var(--sp-2xl);
}
.presentation-card {
  background: var(--c-white);
  border-radius: var(--r-2xl); border:1px solid var(--c-border);
  box-shadow: var(--sh-lg); overflow: hidden; position: relative;
  transition: transform var(--d-slow) var(--ease-spring), box-shadow var(--d-slow);
  will-change: transform;
}
.presentation-card:hover { transform:translateY(-5px) scale(1.004); box-shadow:var(--sh-xl) }
.presentation-card::before {
  content:''; display:block; width:100%; height:4px;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  background-size: 200%; animation: gradShift 5s ease-in-out infinite;
}
.presentation-inner { padding: var(--sp-3xl) }

/* Orbe décoratif */
.hero-orb {
  position:absolute; top:-80px; right:-80px;
  width:340px; height:340px; border-radius:50%;
  background: radial-gradient(circle, var(--c-crimson-tint) 0%, transparent 65%);
  animation: orbPulse 6s ease-in-out infinite;
  pointer-events:none;
}

/* Titre hero */
.hero-title {
  font-family: var(--f-display);
  font-size: var(--fs-hero);
  letter-spacing: var(--ls-wide);
  text-align: center; line-height: 1;
  color: var(--c-text);
  margin-bottom: var(--sp-md);
  position: relative;
  text-shadow: var(--sh-text);
}
.hero-title::after {
  content:''; display:block; width:60px; height:3px;
  background: var(--c-crimson); border-radius:var(--r-pill);
  margin: var(--sp-lg) auto 0;
  animation: scaleIn var(--d-slow) var(--ease-spring) .4s both;
}
.hero-sup { font-size:.46em; letter-spacing:.04em; vertical-align:super }

.hero-tagline {
  text-align: center; font-size: var(--fs-hero-sub);
  color: var(--c-text-3); letter-spacing: .06em;
  margin-bottom: var(--sp-3xl);
  font-style: italic;
}
.hero-tagline p { font-size: var(--fs-hero-sub)!important; margin-bottom:0 }

/* Sections */
.card-section { margin-bottom: var(--sp-2xl) }
.card-section:last-of-type { margin-bottom: 0 }
.section-label {
  display: inline-flex; align-items: center; gap: var(--sp-sm);
  font-family: var(--f-display); font-size: var(--fs-xl);
  letter-spacing: -0.02em; color: var(--c-text); margin-bottom: var(--sp-lg);
  text-shadow: var(--sh-text);
}
.section-label::before {
  content:''; width:4px; height:1.4em;
  background: var(--c-crimson); border-radius:var(--r-pill); flex-shrink:0;
}
.prose-content { font-family:var(--f-serif); font-size:var(--fs-md); line-height:var(--lh-prose); color:var(--c-text-2) }
.prose-content p { font-family:var(--f-serif); font-size:var(--fs-md); line-height:var(--lh-prose); margin-bottom:var(--sp-md); color:var(--c-text-2) }
.edito-title { font-family:var(--f-display); font-size:var(--fs-2xl); letter-spacing:-0.01em; text-align:center; margin-bottom:var(--sp-lg) }
.edito-footer { text-align:center; margin-top:var(--sp-xl) }
.link-more {
  display:inline-flex; align-items:center; gap:var(--sp-sm);
  font-size:var(--fs-sm); font-weight:var(--fw-semibold);
  color:var(--c-crimson); letter-spacing:var(--ls-tight);
  transition: gap var(--d-fast) var(--ease-spring), opacity var(--d-fast);
}
.link-more::after { content:'→'; transition:transform var(--d-fast) var(--ease-spring) }
.link-more:hover { opacity:.8 }
.link-more:hover::after { transform:translateX(5px) }

/* CTA hero row */
.hero-cta-row {
  display: flex; align-items:center; justify-content:center;
  gap: var(--sp-lg); flex-wrap:wrap;
  margin-top: var(--sp-3xl); padding-top: var(--sp-2xl);
  border-top: 1px solid var(--c-border);
}

/* ════════════════════════════════════════════════════
   BOUTONS CTA
════════════════════════════════════════════════════ */
.btn-cta-primary {
  display: inline-flex; align-items:center; gap: var(--sp-sm);
  padding: 13px 28px; border-radius: var(--r-pill);
  background: var(--c-crimson); color: #fff;
  font-size: var(--fs-base); font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
  box-shadow: var(--sh-crimson);
  position: relative; overflow: hidden;
  transition: background var(--d-fast), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
  cursor: pointer; border: none;
}
.btn-cta-primary::after {
  content:''; position:absolute; inset:0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.18) 50%, transparent 60%);
  background-size:300%; background-position:-100% 0;
  transition: background-position .5s;
}
.btn-cta-primary:hover::after { background-position:200% 0 }
.btn-cta-primary:hover {
  background: var(--c-crimson-dk);
  transform: translateY(-3px) scale(1.03);
  box-shadow: var(--sh-crimson-lg);
  color: #fff;
}
.btn-cta-primary:active { transform:translateY(0) scale(.98) }

.btn-cta-light {
  background: #fff; color: var(--c-crimson)!important;
  box-shadow: var(--sh-md);
}
.btn-cta-light:hover { background:#fff; color:var(--c-crimson-dk)!important; box-shadow:var(--sh-lg) }

.btn-cta-ghost {
  display: inline-flex; align-items:center; gap: var(--sp-sm);
  padding: 13px 24px; border-radius: var(--r-pill);
  border: 2px solid var(--c-crimson-glow2);
  background: transparent;
  color: var(--c-crimson); font-size: var(--fs-base); font-weight: var(--fw-semibold);
  transition: border-color var(--d-fast), background var(--d-fast), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.btn-cta-ghost:hover {
  border-color: var(--c-crimson);
  background: var(--c-crimson-tint);
  transform: translateY(-2px);
  box-shadow: var(--sh-sm);
}
.btn-cta-ghost svg { transition: transform var(--d-fast) var(--ease-spring) }
.btn-cta-ghost:hover svg { transform: translateX(4px) }

.btn-cta-outline {
  display: inline-flex; align-items:center; gap: var(--sp-sm);
  padding: 12px 24px; border-radius: var(--r-pill);
  border: 2px solid rgba(255,255,255,.4); background: transparent;
  color: #fff; font-size: var(--fs-base); font-weight: var(--fw-semibold);
  transition: all var(--d-fast) var(--ease-spring);
}
.btn-cta-outline:hover { border-color:#fff; background:rgba(255,255,255,.15); transform:translateY(-2px) }

/* ════════════════════════════════════════════════════
   7 PILIERS
════════════════════════════════════════════════════ */
.pillars-section { padding: var(--sp-section) 0 0 }
.section-header { text-align:center; margin-bottom:var(--sp-xl) }
.pillars-heading {
  font-family: var(--f-display);
  font-size: clamp(1.5rem, 4vw, 2.4rem);
  letter-spacing: var(--ls-wide);
  margin-bottom: var(--sp-sm);
  text-shadow: var(--sh-text);
}
.pillars-sub { font-size:var(--fs-sm); color:var(--c-text-3); font-style:italic }
.pillars-sub p { font-size:var(--fs-sm)!important; margin-bottom:0 }

/* ── Cercles (positions ORIGINALES conservées) ── */
.hero-circles { min-height:30vh; display:flex; align-items:center; justify-content:center; padding:2rem 1rem }
.circle-container { position:relative; width:100%; max-width:700px; aspect-ratio:7/5 }
.circle-bubble {
  position:absolute; width:var(--circle-size); height:var(--circle-size);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  text-align:center; font-weight:bold; padding:.6rem;
  box-shadow:var(--sh-md); font-size:var(--circle-font); text-decoration:none;
  transition:transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid), background-color var(--d-fast);
}
.circle-bubble:hover { background-color:#333!important; transform:scale(1.12)!important; box-shadow:var(--sh-xl)!important; z-index:10 }
.circle-bubble.center      { top:20%; left:50%; transform:translate(-50%,-50%) }
.circle-bubble.top-left    { top:18%; left:20% }
.circle-bubble.left        { top:50%; left:5%; transform:translateY(-50%) }
.circle-bubble.bottom-left { bottom:8%; left:3% }
.circle-bubble.top-right   { top:18%; right:20% }
.circle-bubble.right       { top:50%; right:5%; transform:translateY(-50%) }
.circle-bubble.bottom-right{ bottom:8%; right:3% }
.circle-bubble.center:hover { transform:translate(-50%,-50%) scale(1.12)!important }
.circle-bubble.left:hover   { transform:translateY(-50%) scale(1.12)!important }
.circle-bubble.right:hover  { transform:translateY(-50%) scale(1.12)!important }

/* ── Thématiques (conservées) ── */
.thematiques { padding:4rem 1rem; width:100% }

/* ════════════════════════════════════════════════════
   BANDEAU CTA
════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════
   CTA BAND — VERSION BANDEAU COMPACT
══════════════════════════════════════════════ */

.cta-band {
  position: relative;
  overflow: hidden;
  border-radius: 2rem;
  margin: 6rem auto;
  max-width: 1200px;

  background: var(--c-crimson-grad);
  color: white;
}

.cta-band-inner {
  position: relative;
  z-index: 2;
  padding: 3rem 2rem;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .cta-band-inner {
    padding: 2.5rem 1.5rem;
    text-align: center;
    justify-content: center;
  }
}

/* Limite la hauteur visuelle */
.cta-band {
  min-height: 240px;
}

/* Canvas limité */
.cta-particles-canvas {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

/* Titre */
.cta-band-title {
  font-size: clamp(1.6rem, 2vw, 2.2rem);
  font-weight: 700;
  margin-bottom: 0.6rem;
}

/* Texte */
.cta-band-desc {
  font-size: 1rem;
  opacity: 0.9;
  max-width: 600px;
}

/* Actions */
.cta-band-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
/* ════════════════════════════════════════════════════
   PAGE STATIQUE
════════════════════════════════════════════════════ */
.page-wrapper { background:var(--c-bg); min-height:100vh }
.page-container { max-width:860px; margin:0 auto; padding:var(--sp-3xl) var(--sp-xl) }
.page-article {
  background:var(--c-white); border:1px solid var(--c-border);
  border-radius:var(--r-2xl); box-shadow:var(--sh-lg); overflow:hidden;
}
.page-article::before {
  content:''; display:block; width:100%; height:4px;
  background:linear-gradient(90deg,var(--c-crimson-dk),var(--c-crimson),var(--c-crimson-lt));
  background-size:200%; animation:gradShift 5s ease-in-out infinite;
}
.page-article-header { padding:var(--sp-3xl) var(--sp-2xl) var(--sp-xl); text-align:center; border-bottom:1px solid var(--c-border) }
.page-article-title  { font-family:var(--f-display); font-size:clamp(2rem,5vw,3rem); letter-spacing:-0.02em; margin-bottom:var(--sp-md) }
.page-article-meta   { font-size:var(--fs-sm); color:var(--c-text-3); margin-bottom:var(--sp-xl) }
.btn-print {
  display:inline-flex; align-items:center; gap:var(--sp-sm);
  padding:var(--sp-sm) var(--sp-xl); border-radius:var(--r-pill);
  background:var(--c-text); color:#fff; font-size:var(--fs-sm);
  font-weight:var(--fw-semibold); cursor:pointer; border:none;
  transition:all var(--d-fast) var(--ease-spring);
}
.btn-print:hover { background:var(--c-crimson); box-shadow:var(--sh-crimson); transform:translateY(-2px) }
.page-article-content { padding:var(--sp-2xl) var(--sp-3xl) }
.page-toc { background:var(--c-bg); border:1px solid var(--c-border); border-radius:var(--r-lg); padding:var(--sp-xl); margin-bottom:var(--sp-2xl) }
.page-toc h2 { font-family:var(--f-display); font-size:var(--fs-lg); letter-spacing:0; margin-bottom:var(--sp-md) }
.page-toc nav a { display:block; padding:var(--sp-xs) var(--sp-sm); color:var(--c-text-2); font-size:var(--fs-sm); border-radius:var(--r-sm); transition:color var(--d-fast),background var(--d-fast),padding-left var(--d-fast) var(--ease-spring) }
.page-toc nav a:hover { color:var(--c-crimson); background:var(--c-crimson-tint); padding-left:var(--sp-lg) }
.legal-content h2 { font-family:var(--f-display)!important; font-size:var(--fs-2xl)!important; letter-spacing:-0.01em!important; margin-top:var(--sp-3xl)!important; margin-bottom:var(--sp-lg)!important; scroll-margin-top:calc(var(--nav-h) + 16px) }
.legal-content p { font-family:var(--f-body)!important; font-size:var(--fs-base)!important; line-height:1.8; color:var(--c-text-2); margin-bottom:var(--sp-lg) }

/* ════════════════════════════════════════════════════
   SINGLE POST
════════════════════════════════════════════════════ */
.single-wrapper { background:var(--c-bg); min-height:100vh }
.single-container { max-width:860px; margin:0 auto; padding:var(--sp-3xl) var(--sp-xl) }
.single-article { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-2xl); box-shadow:var(--sh-lg); overflow:hidden }
.single-article::before { content:''; display:block; width:100%; height:4px; background:linear-gradient(90deg,var(--c-crimson-dk),var(--c-crimson),var(--c-crimson-lt)); background-size:200%; animation:gradShift 5s ease-in-out infinite }
.single-thumb { width:100%; aspect-ratio:16/6; overflow:hidden; background:var(--c-bg2) }
.single-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 8s linear }
.single-article:hover .single-thumb img { transform:scale(1.04) }
.single-header { padding:var(--sp-2xl) var(--sp-3xl) var(--sp-xl); text-align:center }
.single-title { font-family:var(--f-display); font-size:clamp(1.8rem,4vw,3rem); letter-spacing:-0.01em; margin-bottom:var(--sp-lg); line-height:1.15 }
.single-meta { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:var(--sp-md); font-size:var(--fs-sm); color:var(--c-text-3); padding-bottom:var(--sp-xl); border-bottom:1px solid var(--c-border) }
.single-meta-sep { width:3px; height:3px; border-radius:50%; background:var(--c-border-md); flex-shrink:0 }
.single-meta a { color:var(--c-crimson); font-weight:var(--fw-medium) }
.single-meta-badge { display:inline-flex; align-items:center; gap:4px; padding:2px 10px; border-radius:var(--r-pill); background:var(--c-crimson-tint); color:var(--c-crimson); font-weight:var(--fw-semibold) }
.single-content { padding:var(--sp-xl) var(--sp-2xl) }
.single-content .entry-content { font-family:var(--f-serif); font-size:var(--fs-md); line-height:var(--lh-prose); color:var(--c-text-2) }
.single-content .entry-content h2 { font-size:var(--fs-2xl); margin:var(--sp-xl) 0 var(--sp-sm) }
.single-content .entry-content h3 { font-size:var(--fs-xl); margin:var(--sp-lg) 0 var(--sp-xs) }
.single-content .entry-content p { font-family:var(--f-serif); font-size:var(--fs-md); line-height:var(--lh-prose); margin-bottom:var(--sp-md) }
.single-content .entry-content img { border-radius:var(--r-lg); margin:var(--sp-xl) auto; box-shadow:var(--sh-md) }
.single-content .entry-content blockquote { border-left:4px solid var(--c-crimson); padding:var(--sp-lg) var(--sp-xl); margin:var(--sp-xl) 0; background:var(--c-crimson-tint2); border-radius:0 var(--r-md) var(--r-md) 0; font-style:italic; color:var(--c-text-2) }
.single-content .entry-content a { color:var(--c-crimson); text-decoration:underline; text-underline-offset:3px }
.single-tags { padding:var(--sp-lg) var(--sp-3xl) var(--sp-2xl); border-top:1px solid var(--c-border) }
.tag-chip { display:inline-flex; align-items:center; padding:4px 14px; border-radius:var(--r-pill); border:1px solid var(--c-border-md); font-size:var(--fs-xs); font-weight:var(--fw-semibold); color:var(--c-text-2); transition:all var(--d-fast) var(--ease-spring) }
.tag-chip:hover { background:var(--c-crimson); border-color:var(--c-crimson); color:#fff; transform:translateY(-2px); box-shadow:var(--sh-crimson) }
.single-nav { display:grid; grid-template-columns:1fr 1fr; gap:var(--sp-lg); margin-top:var(--sp-2xl) }
.single-nav-item { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-xl); padding:var(--sp-lg) var(--sp-xl); box-shadow:var(--sh-xs); transition:transform var(--d-mid) var(--ease-spring),box-shadow var(--d-mid),border-color var(--d-mid) }
.single-nav-item:hover { transform:translateY(-3px); box-shadow:var(--sh-md); border-color:var(--c-crimson-glow) }
.single-nav-item .label { font-size:var(--fs-xs); color:var(--c-text-3); font-weight:var(--fw-medium); letter-spacing:.06em; margin-bottom:4px; display:block }
.single-nav-item a { font-size:var(--fs-sm); font-weight:var(--fw-semibold); color:var(--c-crimson); display:block; line-height:1.4 }
.single-nav-prev { text-align:left } .single-nav-next { text-align:right }
.single-comments { margin-top:var(--sp-2xl); background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-2xl); padding:var(--sp-2xl); box-shadow:var(--sh-sm) }

/* ════════════════════════════════════════════════════
   AUTHOR PAGE
════════════════════════════════════════════════════ */
.author-wrapper { background:var(--c-bg); min-height:100vh }
.author-container { max-width:1100px; margin:0 auto; padding:var(--sp-3xl) var(--sp-xl) }
.author-hero { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-2xl); box-shadow:var(--sh-md); padding:var(--sp-2xl) var(--sp-3xl); display:flex; align-items:center; gap:var(--sp-2xl); margin-bottom:var(--sp-3xl); overflow:hidden; position:relative }
.author-hero::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--c-crimson-dk),var(--c-crimson),var(--c-crimson-lt)); background-size:200%; animation:gradShift 5s ease-in-out infinite }
.author-avatar { flex-shrink:0; width:96px; height:96px; border-radius:50%; overflow:hidden; border:3px solid var(--c-crimson-glow); box-shadow:var(--sh-crimson) }
.author-avatar img { width:100%; height:100%; object-fit:cover }
.author-info h1 { font-family:var(--f-display); font-size:var(--fs-3xl); letter-spacing:-0.01em; margin-bottom:var(--sp-sm) }
.author-info p { font-size:var(--fs-sm); color:var(--c-text-2); margin-bottom:0!important }
.author-info .author-count { display:inline-flex; align-items:center; gap:6px; font-size:var(--fs-xs); color:var(--c-text-3); margin-top:var(--sp-sm) }
.author-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:var(--sp-xl) }

/* ════════════════════════════════════════════════════
   CARDS
════════════════════════════════════════════════════ */
.post-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-xl); box-shadow:var(--sh-xs); overflow:hidden; display:flex; flex-direction:column; transition:transform var(--d-mid) var(--ease-spring),box-shadow var(--d-mid),border-color var(--d-mid) }
.post-card:hover { transform:translateY(-5px) scale(1.01); box-shadow:var(--sh-lg); border-color:var(--c-crimson-glow) }
.post-card-thumb { width:100%; aspect-ratio:16/9; overflow:hidden; background:var(--c-bg2) }
.post-card-thumb img { width:100%; height:100%; object-fit:cover; transition:transform var(--d-slow) var(--ease-smooth) }
.post-card:hover .post-card-thumb img { transform:scale(1.06) }
.post-card-body { padding:var(--sp-lg) var(--sp-xl); flex:1; display:flex; flex-direction:column }
.post-card-title { font-family:var(--f-display); font-size:var(--fs-xl); letter-spacing:0; margin-bottom:var(--sp-sm); line-height:1.3 }
.post-card-title a { color:var(--c-text); transition:color var(--d-fast) }
.post-card-title a:hover { color:var(--c-crimson) }
.post-card-excerpt { font-size:var(--fs-sm); color:var(--c-text-2); line-height:1.75; flex:1; margin-bottom:var(--sp-md) }
.post-card-meta { font-size:var(--fs-xs); color:var(--c-text-3); display:flex; gap:var(--sp-md); flex-wrap:wrap }

/* ════════════════════════════════════════════════════
   SEARCH PAGE
════════════════════════════════════════════════════ */
.search-wrapper { background:var(--c-bg); min-height:100vh }
.search-container { max-width:900px; margin:0 auto; padding:var(--sp-3xl) var(--sp-xl) }
.search-header { margin-bottom:var(--sp-2xl) }
.search-title { font-family:var(--f-display); font-size:clamp(1.6rem,4vw,2.4rem); letter-spacing:-0.01em }
.search-grid { display:flex; flex-direction:column; gap:var(--sp-lg) }
.search-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-xl); box-shadow:var(--sh-xs); overflow:hidden; display:flex; transition:transform var(--d-mid) var(--ease-spring),box-shadow var(--d-mid),border-color var(--d-mid) }
.search-card:hover { transform:translateX(4px); box-shadow:var(--sh-md); border-color:var(--c-crimson-glow) }
.search-card-thumb { flex-shrink:0; width:180px; overflow:hidden; background:var(--c-bg2) }
.search-card-thumb img { width:100%; height:100%; object-fit:cover; transition:transform var(--d-slow) var(--ease-smooth) }
.search-card:hover .search-card-thumb img { transform:scale(1.06) }
.search-card-body { padding:var(--sp-lg) var(--sp-xl); flex:1; display:flex; flex-direction:column; justify-content:center }
.search-card-title { font-family:var(--f-display); font-size:var(--fs-xl); letter-spacing:0; margin-bottom:var(--sp-sm) }
.search-card-title a { color:var(--c-text); transition:color var(--d-fast) }
.search-card-title a:hover { color:var(--c-crimson) }
.search-card-excerpt { font-size:var(--fs-sm); color:var(--c-text-2); line-height:1.75 }
.search-card-meta { font-size:var(--fs-xs); color:var(--c-text-3); margin-top:var(--sp-sm); display:flex; gap:var(--sp-md) }

/* ════════════════════════════════════════════════════
   PAGE CONTACT
════════════════════════════════════════════════════ */
.contact-hero {
  position: relative; overflow: hidden;
  background: var(--c-crimson-grad);
  padding: var(--sp-3xl) var(--sp-xl);
  text-align: center;
  margin-bottom: 0;
}
.contact-hero::after {
  content:''; position:absolute; bottom:-1px; left:0; right:0; height:48px;
  background: var(--c-bg);
  clip-path: ellipse(55% 100% at 50% 100%);
}
.contact-hero-bg { position:absolute; inset:0; pointer-events:none; overflow:hidden }
.contact-hero-orb { position:absolute; border-radius:50%; background:rgba(255,255,255,.08) }
.contact-hero-orb-1 { width:360px; height:360px; top:-100px; right:-80px; animation:floatSlow 9s ease-in-out infinite }
.contact-hero-orb-2 { width:200px; height:200px; bottom:-40px; left:8%; animation:floatSlow 12s ease-in-out infinite reverse }
.contact-hero-inner { position:relative; z-index:2; max-width:600px; margin:0 auto }
.contact-hero-icon {
  width:72px; height:72px; border-radius:50%;
  background:rgba(255,255,255,.18); backdrop-filter:var(--blur-sm); border:1px solid rgba(255,255,255,.3);
  display:flex; align-items:center; justify-content:center; color:#fff;
  margin:0 auto var(--sp-xl);
  animation: float 3.5s ease-in-out infinite;
}
.contact-hero-title {
  font-family: var(--f-display)!important;
  font-size: clamp(2rem,5vw,3.2rem)!important;
  letter-spacing: var(--ls-wide)!important;
  color: #fff; margin-bottom: var(--sp-md);
}
.contact-hero-sub { font-size:var(--fs-base)!important; color:var(--c-text-inv-2); line-height:1.65; margin-bottom:0!important }

/* Layout 2 colonnes */
.contact-layout {
  max-width: var(--max-contact); margin: 0 auto;
  padding: var(--sp-3xl) var(--sp-xl);
  display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--sp-2xl);
  align-items: start;
}

/* Aside */
.contact-aside { display:flex; flex-direction:column; gap:var(--sp-xl) }
.contact-info-card {
  background: var(--c-white); border:1px solid var(--c-border);
  border-radius: var(--r-xl); box-shadow: var(--sh-sm);
  padding: var(--sp-xl) var(--sp-2xl);
  position: relative; overflow:hidden;
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.contact-info-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--c-crimson-dk),var(--c-crimson),var(--c-crimson-lt)); background-size:200%; animation:gradShift 5s ease-in-out infinite }
.contact-info-card:hover { transform:translateY(-3px); box-shadow:var(--sh-md) }
.contact-info-card--sm { padding:var(--sp-lg) var(--sp-xl) }
.contact-info-title { font-family:var(--f-display)!important; font-size:var(--fs-xl)!important; letter-spacing:-0.01em; margin-bottom:var(--sp-lg) }

.contact-reasons { list-style:none; display:flex; flex-direction:column; gap:var(--sp-lg) }
.contact-reason { display:flex; align-items:flex-start; gap:var(--sp-md) }
.contact-reason-icon { flex-shrink:0; width:38px; height:38px; border-radius:50%; background:var(--c-crimson-tint); color:var(--c-crimson); display:flex; align-items:center; justify-content:center; margin-top:2px }
.contact-reason strong { display:block; font-size:var(--fs-sm); font-weight:var(--fw-semibold); color:var(--c-text); margin-bottom:3px }
.contact-reason p { font-size:var(--fs-xs)!important; color:var(--c-text-3); line-height:1.6; margin-bottom:0!important }

.contact-coord { display:flex; align-items:center; gap:var(--sp-sm); padding:var(--sp-sm) 0; font-size:var(--fs-sm); color:var(--c-text-3) }
.contact-coord svg { color:var(--c-crimson); flex-shrink:0 }
.contact-coord a { color:var(--c-crimson); font-weight:var(--fw-medium); transition:opacity var(--d-fast) }
.contact-coord a:hover { opacity:.7 }
.contact-coord + .contact-coord { border-top:1px solid var(--c-border) }

/* Formulaire card */
.contact-form-col {}
.contact-form-card {
  background: var(--c-white); border:1px solid var(--c-border);
  border-radius: var(--r-2xl); box-shadow: var(--sh-lg);
  overflow: hidden;
  transition: transform var(--d-slow) var(--ease-spring), box-shadow var(--d-slow);
}
.contact-form-card:hover { transform:translateY(-4px) scale(1.002); box-shadow:var(--sh-xl) }
.contact-form-card::before { content:''; display:block; width:100%; height:4px; background:linear-gradient(90deg,var(--c-crimson-dk),var(--c-crimson),var(--c-crimson-lt)); background-size:200%; animation:gradShift 5s ease-in-out infinite }
.contact-form-wrapper { padding:var(--sp-2xl) var(--sp-2xl) var(--sp-3xl) }

/* Alertes */
.contact-alert { display:flex; align-items:center; gap:var(--sp-md); margin:var(--sp-xl) var(--sp-2xl) 0; padding:var(--sp-md) var(--sp-xl); border-radius:var(--r-lg); font-size:var(--fs-sm); font-weight:var(--fw-medium) }
.contact-alert--success { background:var(--c-success-bg); color:var(--c-success); border:1px solid var(--c-success-border) }
.contact-alert--error   { background:var(--c-error-bg);   color:var(--c-error);   border:1px solid var(--c-error-border) }

/* ── Fields ── */
.contact-form, .contact-form-wrapper form { display:flex; flex-direction:column; gap:var(--sp-xl) }
.form-group { display:flex; flex-direction:column; gap:var(--sp-sm) }
.form-label { font-size:var(--fs-sm); font-weight:var(--fw-semibold); color:var(--c-text); letter-spacing:.03em }
.form-label .required { color:var(--c-crimson); margin-left:2px }
.form-input, .form-textarea {
  width:100%; padding:var(--sp-md) var(--sp-lg);
  border:1.5px solid var(--c-border-md); border-radius:var(--r-md);
  font-family:var(--f-body); font-size:var(--fs-base); color:var(--c-text);
  background:var(--c-bg); outline:none; -webkit-appearance:none;
  transition: border-color var(--d-fast), box-shadow var(--d-fast), background var(--d-fast), transform var(--d-fast) var(--ease-spring);
}
.form-input:hover, .form-textarea:hover { border-color:rgba(123,22,32,.3); background:var(--c-white) }
.form-input:focus, .form-textarea:focus { border-color:var(--c-crimson); background:var(--c-white); box-shadow:var(--sh-focus); transform:translateY(-1px) }
.form-textarea { min-height:140px; resize:vertical; line-height:1.7 }
.form-group.has-error .form-input,
.form-group.has-error .form-textarea { border-color:var(--c-error); box-shadow:0 0 0 3px rgba(220,38,38,.12) }
.form-group.has-error::after { content:'Ce champ est requis.'; display:block; margin-top:var(--sp-xs); font-size:var(--fs-xs); color:var(--c-error); font-weight:var(--fw-medium) }
.form-group.is-valid .form-input,
.form-group.is-valid .form-textarea { border-color:var(--c-success) }
.form-rgpd { display:flex; align-items:flex-start; gap:var(--sp-sm); padding:var(--sp-md) var(--sp-lg); background:var(--c-bg); border:1px solid var(--c-border); border-radius:var(--r-md); font-size:var(--fs-xs); color:var(--c-text-3); line-height:1.6 }
.form-rgpd svg { color:var(--c-crimson); opacity:.7; flex-shrink:0; margin-top:1px }
.form-rgpd-link { color:var(--c-crimson); text-decoration:underline; text-underline-offset:2px }
.btn-submit {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--sp-sm);
  padding:var(--sp-md) var(--sp-2xl); border-radius:var(--r-pill);
  background:var(--c-crimson); color:#fff; border:none; cursor:pointer;
  font-family:var(--f-body); font-size:var(--fs-base); font-weight:var(--fw-semibold);
  letter-spacing:var(--ls-tight); box-shadow:var(--sh-crimson); width:100%;
  position:relative; overflow:hidden;
  transition:background var(--d-fast), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.btn-submit::after { content:''; position:absolute; inset:0; background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.18) 50%,transparent 60%); background-size:300%; background-position:-100% 0; transition:background-position .5s }
.btn-submit:hover::after { background-position:200% 0 }
.btn-submit:hover { background:var(--c-crimson-dk); transform:translateY(-3px) scale(1.02); box-shadow:var(--sh-crimson-lg) }
.btn-submit:active { transform:translateY(0) scale(.98) }
.btn-submit:disabled { opacity:.6; cursor:not-allowed; transform:none!important; box-shadow:var(--sh-sm)!important }

/* ════════════════════════════════════════════════════
   PAGINATION
════════════════════════════════════════════════════ */
.pagination { display:flex; justify-content:center; gap:var(--sp-sm); flex-wrap:wrap; margin-top:var(--sp-2xl) }
.pagination a, .pagination span { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%; font-size:var(--fs-sm); font-weight:var(--fw-semibold); border:1.5px solid var(--c-border-md); transition:all var(--d-fast) var(--ease-spring) }
.pagination a { color:var(--c-text-2); background:var(--c-white) }
.pagination a:hover { background:var(--c-crimson); border-color:var(--c-crimson); color:#fff; transform:scale(1.1); box-shadow:var(--sh-crimson) }
.pagination .current { background:var(--c-crimson); border-color:var(--c-crimson); color:#fff }

/* ════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════ */
.site-footer { background:var(--c-white); border-top:1px solid var(--c-border); box-shadow:0 -4px 20px rgba(0,0,0,.04) }
.footer-inner { max-width:var(--max-wide); margin:0 auto; padding:var(--sp-2xl) var(--sp-xl) }
.footer-nav ul { list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:4px; margin-bottom:var(--sp-xl) }
.footer-nav a { display:block; padding:6px 14px; border-radius:var(--r-pill); font-size:var(--fs-sm); color:var(--c-text-2); font-weight:var(--fw-medium); transition:color var(--d-fast),background var(--d-fast) }
.footer-nav a:hover { color:var(--c-crimson); background:var(--c-crimson-tint) }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:var(--sp-lg); padding-top:var(--sp-lg); border-top:1px solid var(--c-border) }
.footer-links { display:flex; gap:var(--sp-lg); flex-wrap:wrap }
.footer-links a { font-size:var(--fs-sm); color:var(--c-text-3); transition:color var(--d-fast) }
.footer-links a:hover { color:var(--c-crimson) }
.footer-socials { display:flex; gap:var(--sp-md) }
.footer-social-btn { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:1px solid var(--c-border-md); color:var(--c-text-3); transition:all var(--d-fast) var(--ease-spring) }
.footer-social-btn:hover { background:var(--c-crimson); border-color:var(--c-crimson); color:#fff; transform:translateY(-3px); box-shadow:var(--sh-crimson) }
.footer-copyright { width:100%; text-align:center; margin-top:var(--sp-lg); font-size:var(--fs-sm); color:var(--c-text-3) }

/* ════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .contact-layout { grid-template-columns: 1fr }
  .contact-aside { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-lg) }
}

@media (max-width: 768px) {
  .nav-desktop { display: none }
  .nav-hamburger, .nav-mobile-controls { display: flex }

  .presentation-inner { padding: var(--sp-xl) var(--sp-lg) }
  .hero-cta-row { flex-direction:column; align-items:stretch }
  .btn-cta-primary, .btn-cta-ghost { justify-content:center; text-align:center }
  .cta-band-inner { flex-direction:column; text-align:center }
  .cta-band-content { flex-direction:column; align-items:center }
  .cta-band-actions { justify-content:center }

  .contact-layout { padding: var(--sp-xl) var(--sp-lg) }
  .contact-aside { grid-template-columns: 1fr }
  .contact-form-wrapper { padding: var(--sp-xl) var(--sp-lg) var(--sp-2xl) }
  .contact-alert { margin: var(--sp-lg) var(--sp-lg) 0 }

  .single-header, .single-content, .single-tags { padding-left:var(--sp-lg); padding-right:var(--sp-lg) }
  .single-nav { grid-template-columns:1fr }
  .author-hero { flex-direction:column; text-align:center; padding:var(--sp-xl) var(--sp-lg) }
  .search-card-thumb { width:120px }
  .footer-bottom { flex-direction:column; align-items:center }

  /* Cercles — positions originales */
  .circle-container { max-width:520px }
  .circle-bubble.center      { top:24%; left:50% }
  .circle-bubble.top-left    { top:20%; left:12% }
  .circle-bubble.left        { top:50%; left:2% }
  .circle-bubble.bottom-left { bottom:12%; left:5% }
  .circle-bubble.top-right   { top:20%; right:12% }
  .circle-bubble.right       { top:50%; right:2% }
  .circle-bubble.bottom-right{ bottom:12%; right:5% }
}

@media (max-width: 480px) {
  :root { --circle-size:80px; --circle-font:12px }
  .circle-container { max-width:360px }
  .circle-bubble { padding:.4rem }
  .circle-bubble.center      { top:10%; left:50% }
  .circle-bubble.top-left    { top:10%; left:18% }
  .circle-bubble.top-right   { top:10%; right:18% }
  .circle-bubble.left        { top:50%; left:2% }
  .circle-bubble.right       { top:50%; right:2% }
  .circle-bubble.bottom-left { bottom:2%; left:0 }
  .circle-bubble.bottom-right{ bottom:2%; right:0 }
  .search-card { flex-direction:column }
  .search-card-thumb { width:100%; aspect-ratio:16/7 }
  .author-grid { grid-template-columns:1fr }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.01ms!important; transition-duration:.01ms!important }

/* ════════════════════════════════════════════════════
   v5 — DESIGN SYSTEM EXTENSION
   Règles complexes · Apple/Material · Animations iOS
════════════════════════════════════════════════════ */

/* ── Tokens supplémentaires ── */
:root {
  /* Typographie enrichie */
  --lh-tight:      1.18;
  --lh-snug:       1.4;
  --lh-normal:     1.75;
  --lh-relaxed:    1.9;
  --lh-loose:      2.1;

  /* Spacing layout */
  --sp-page:       clamp(1.25rem, 4vw, 2rem);

  /* Surface en verre */
  --glass-heavy:   rgba(255,255,255,.92);
  --glass-medium:  rgba(255,255,255,.75);
  --glass-light:   rgba(255,255,255,.45);

  /* Shadows élaborées */
  --sh-float:      0 2px 8px rgba(0,0,0,.04), 0 8px 24px rgba(0,0,0,.06), 0 24px 48px rgba(0,0,0,.05);
  --sh-elevated:   0 4px 16px rgba(0,0,0,.07), 0 16px 48px rgba(0,0,0,.09);

  /* Transitions */
  --transition-ui: all var(--d-mid) var(--ease-smooth);

  /* Badge / chip */
  --badge-h:       26px;
}

/* ── Body & base typographique ── */
body {
  background-attachment: fixed;
}
body::before {
  content: '';
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 20%, rgba(123,22,32,.04) 0%, transparent 55%),
    radial-gradient(ellipse 60% 80% at 90% 80%, rgba(123,22,32,.03) 0%, transparent 55%);
  pointer-events: none; z-index: 0;
}
main { position: relative; z-index: 1 }

/* Amélioration typographique globale */
p { text-align: left; orphans: 3; widows: 3 }
h1,h2,h3,h4,h5,h6 {
  font-variant-numeric: lining-nums;
  text-rendering: optimizeLegibility;
}

/* ── Sélection de texte ── */
::selection { background: var(--c-crimson); color: #fff }

/* ── Scrollbar personnalisée ── */
::-webkit-scrollbar { width: 6px; height: 6px }
::-webkit-scrollbar-track { background: var(--c-bg2) }
::-webkit-scrollbar-thumb { background: var(--c-crimson-glow); border-radius: 99px }
::-webkit-scrollbar-thumb:hover { background: var(--c-crimson) }


/* ════════════════════════════════════════════════════
   v5 — NAVIGATION v5
   Simplifiée : scrolled = verre, non scrolled = transparent
   Contrôlé par data-hero="1" sur <body>
════════════════════════════════════════════════════ */

/* État par défaut : verre dépoli (pages sans hero) */
.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 500;
  height: var(--nav-h);
  background: var(--glass-heavy);
  backdrop-filter: var(--blur-glass);
  -webkit-backdrop-filter: var(--blur-glass);
  border-bottom: 1px solid var(--c-border);
  box-shadow: var(--sh-sm);
  transition:
    height       var(--d-mid) var(--ease-smooth),
    background   var(--d-mid) var(--ease-smooth),
    border-color var(--d-mid) var(--ease-smooth),
    box-shadow   var(--d-mid) var(--ease-smooth);
}

/* État transparent : uniquement quand body[data-hero="1"] + pas encore scrollé */
body[data-hero="1"] .site-nav:not(.scrolled) {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-color: transparent;
  box-shadow: none;
}

/* État scrolled : toujours verre */
.site-nav.scrolled {
  height: var(--nav-h-scrolled);
  background: var(--glass-heavy) !important;
  backdrop-filter: var(--blur-glass) !important;
  -webkit-backdrop-filter: var(--blur-glass) !important;
  border-color: var(--c-border) !important;
  box-shadow: var(--sh-sm) !important;
}

/* Couleurs des liens : sombres par défaut */
.nav-logo-text  { color: var(--c-crimson) }
.nav-link       { color: var(--c-text-2) }
.nav-social-btn { color: var(--c-text-3) }
.nav-hamburger span { background: var(--c-text) }
.nav-search-btn { border-color: var(--c-border-md); color: var(--c-text-2) }

/* Couleurs blanches uniquement sur hero transparent */
body[data-hero="1"] .site-nav:not(.scrolled) .nav-logo-text  { color: #fff }
body[data-hero="1"] .site-nav:not(.scrolled) .nav-link       { color: rgba(255,255,255,.9) }
body[data-hero="1"] .site-nav:not(.scrolled) .nav-social-btn { color: rgba(255,255,255,.7) }
body[data-hero="1"] .site-nav:not(.scrolled) .nav-hamburger span { background: #fff }
body[data-hero="1"] .site-nav:not(.scrolled) .nav-search-btn {
  border-color: rgba(255,255,255,.35); color: rgba(255,255,255,.85)
}
body[data-hero="1"] .site-nav:not(.scrolled) .nav-cta {
  background: rgba(255,255,255,.18);
  backdrop-filter: var(--blur-sm);
  border: 1px solid rgba(255,255,255,.3);
}
body[data-hero="1"] .site-nav:not(.scrolled) .nav-cta:hover {
  background: rgba(255,255,255,.3)
}
body[data-hero="1"] .site-nav:not(.scrolled) .nav-link:hover {
  color: #fff; background: rgba(255,255,255,.12)
}
body[data-hero="1"] .site-nav:not(.scrolled) .nav-link.is-active::after { background: #fff }
body[data-hero="1"] .site-nav:not(.scrolled) .nav-search-btn:hover {
  background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.5); color: #fff
}
body[data-hero="1"] .site-nav:not(.scrolled) .nav-social-btn:hover {
  background: rgba(255,255,255,.15); color: #fff
}

/* Indicateur de nav */
body[data-hero="1"] .site-nav:not(.scrolled) .nav-link::after {
  background: #fff
}


/* ════════════════════════════════════════════════════
   v5 — PAGE HERO UNIVERSEL
   Fond crimson · orbes · découpe courbe bas
════════════════════════════════════════════════════ */

/* Les templates avec hero ne rajoutent pas de padding top */
body[data-hero="1"] .page-hero-wrap { padding-top: 0 }

.page-hero {
  position: relative;
  overflow: hidden;
  background: var(--c-crimson-grad);
  padding:
    calc(var(--nav-h) + clamp(2rem, 4.5vw, 3.5rem))
    var(--sp-page)
    clamp(3.5rem, 7vw, 5.5rem);
  text-align: center;
  isolation: isolate;
}

/* Courbe de sortie en bas */
.page-hero::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0; right: 0;
  height: 60px;
  background: var(--c-bg);
  clip-path: ellipse(55% 100% at 50% 100%);
  z-index: 2;
}

/* Overlay texture bruit subtile */
.page-hero::before {
  content: '';
  position: absolute; inset: 0; z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: .04;
  pointer-events: none;
}

/* Variante avec image de fond */
.page-hero--image {
  background-size: cover;
  background-position: center;
}
.page-hero--image .page-hero-overlay {
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(160deg,
    rgba(90,15,23,.9) 0%,
    rgba(123,22,32,.82) 50%,
    rgba(168,32,48,.75) 100%);
}

/* Orbes décoratives */
.page-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden;
}
.page-hero-orb {
  position: absolute; border-radius: 50%;
  background: rgba(255,255,255,.08);
}
.page-hero-orb-1 {
  width: clamp(260px, 35vw, 440px);
  height: clamp(260px, 35vw, 440px);
  top: -120px; right: -80px;
  animation: floatSlow 11s ease-in-out infinite;
}
.page-hero-orb-2 {
  width: clamp(140px, 18vw, 240px);
  height: clamp(140px, 18vw, 240px);
  bottom: -20px; left: 4%;
  animation: floatSlow 14s ease-in-out infinite reverse;
}
.page-hero-orb-3 {
  width: clamp(80px, 10vw, 140px);
  height: clamp(80px, 10vw, 140px);
  top: 28%; left: 38%;
  animation: pulse 6s ease-in-out infinite;
}

/* Contenu */
.page-hero-inner {
  position: relative; z-index: 3;
  max-width: 680px; margin: 0 auto;
}

/* Icône flottante */
.page-hero-icon {
  width: 68px; height: 68px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  backdrop-filter: var(--blur-sm);
  border: 1px solid rgba(255,255,255,.3);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  margin: 0 auto var(--sp-xl);
  animation: float 3.5s ease-in-out infinite;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
}

/* Titre */
.page-hero-title {
  font-family: var(--f-display) !important;
  font-size: clamp(2.2rem, 5.5vw, 3.8rem) !important;
  letter-spacing: var(--ls-wide) !important;
  line-height: var(--lh-tight) !important;
  color: #fff;
  margin-bottom: var(--sp-md);
}

/* Badge catégorie au-dessus du titre */
.page-hero-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 12px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.2);
  color: rgba(255,255,255,.92);
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  letter-spacing: .07em;
  margin-bottom: var(--sp-md);
  border: 1px solid rgba(255,255,255,.25);
}

/* Sous-titre */
.page-hero-sub {
  font-family: var(--f-body) !important;
  font-size: var(--fs-base) !important;
  color: rgba(255,255,255,.8);
  line-height: var(--lh-relaxed) !important;
  font-style: italic;
  margin-bottom: 0 !important;
  max-width: 520px; margin-left: auto; margin-right: auto;
}

/* Méta (date, auteur) */
.page-hero-meta {
  display: flex; flex-wrap: wrap;
  justify-content: center; align-items: center;
  gap: var(--sp-md);
  margin-top: var(--sp-lg);
  font-size: var(--fs-sm); color: rgba(255,255,255,.72);
}
.page-hero-meta a {
  color: rgba(255,255,255,.9);
  text-decoration: underline; text-underline-offset: 3px;
  transition: color var(--d-fast);
}
.page-hero-meta a:hover { color: #fff }
.page-hero-meta-dot {
  width: 3px; height: 3px; border-radius: 50%;
  background: rgba(255,255,255,.4); flex-shrink: 0;
}


/* ════════════════════════════════════════════════════
   v5 — TEMPLATES WRAPPER
   Règle universelle : les pages avec hero
   utilisent .page-content-wrap (pas de padding top)
════════════════════════════════════════════════════ */
.page-content-wrap {
  padding-top: 0;          /* hero gère l'espace en haut */
}
.page-content-inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.page-content-inner--narrow {
  max-width: 860px;
}
.page-content-inner--medium {
  max-width: var(--max-content);
}

/* Pour les pages sans hero (legacy) */
.site-primary { padding-top: var(--nav-h) }
.has-dark-hero .site-primary,
.page-content-wrap { padding-top: 0 }


/* ════════════════════════════════════════════════════
   v5 — SEARCH FORM REDESIGN
════════════════════════════════════════════════════ */
.search-form {
  display: flex;
  gap: var(--sp-sm);
  width: 100%;
}
.search-field {
  flex: 1;
  padding: 11px var(--sp-lg);
  border: 1.5px solid var(--c-border-md);
  border-radius: var(--r-pill);
  font-family: var(--f-body);
  font-size: var(--fs-base);
  color: var(--c-text);
  background: var(--c-bg);
  outline: none;
  transition: border-color var(--d-fast), box-shadow var(--d-fast), background var(--d-fast);
}
.search-field:focus {
  border-color: var(--c-crimson);
  background: var(--c-white);
  box-shadow: var(--sh-focus);
}
.search-submit {
  padding: 11px var(--sp-xl);
  border-radius: var(--r-pill);
  background: var(--c-crimson);
  color: #fff;
  border: none; cursor: pointer;
  font-family: var(--f-body);
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  transition: background var(--d-fast), transform var(--d-mid) var(--ease-spring);
}
.search-submit:hover {
  background: var(--c-crimson-dk);
  transform: translateY(-1px) scale(1.02);
}


/* ════════════════════════════════════════════════════
   v5 — SINGLE POST REDESIGN COMPLET
════════════════════════════════════════════════════ */
.single-wrap { min-height: 100vh }

.single-body {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 var(--sp-page) var(--sp-4xl);
}

/* Méta sous le hero */
.single-hero-meta {
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: center;
  gap: var(--sp-md);
  padding: var(--sp-xl) var(--sp-page) var(--sp-lg);
  border-bottom: 1px solid var(--c-border);
  max-width: 820px; margin: 0 auto;
}
.single-meta-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: var(--r-pill);
  background: var(--c-crimson-tint);
  color: var(--c-crimson); font-size: var(--fs-xs);
  font-weight: var(--fw-semibold); letter-spacing: .04em;
}
.single-meta-item {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: var(--fs-sm); color: var(--c-text-3);
}
.single-meta-item svg { color: var(--c-crimson); opacity: .7 }
.single-meta-item a { color: var(--c-text-2); font-weight: var(--fw-medium) }
.single-meta-item a:hover { color: var(--c-crimson) }
.single-meta-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--c-border-md) }

/* Contenu article */
.entry-content {
  font-family: var(--f-serif);
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--c-text-2);
}
.entry-content > * + * { margin-top: var(--sp-md) }

.entry-content h2 {
  font-family: var(--f-sans) !important;
  font-size: var(--fs-2xl) !important;
  font-weight: var(--fw-bold) !important;
  letter-spacing: var(--ls-subheading) !important;
  color: var(--c-text) !important;
  margin-top: var(--sp-2xl) !important;
  margin-bottom: var(--sp-sm) !important;
  padding-bottom: var(--sp-sm);
  border-bottom: 2px solid var(--c-crimson-tint);
}
.entry-content h3 {
  font-family: var(--f-sans) !important;
  font-size: var(--fs-xl) !important;
  font-weight: var(--fw-semibold) !important;
  letter-spacing: var(--ls-subheading) !important;
  color: var(--c-text) !important;
  margin-top: var(--sp-xl) !important;
  margin-bottom: var(--sp-sm) !important;
}
.entry-content h4 {
  font-family: var(--f-sans) !important;
  font-size: var(--fs-lg) !important;
  font-weight: var(--fw-semibold) !important;
  letter-spacing: 0 !important;
  color: var(--c-text) !important;
  margin-top: var(--sp-lg) !important;
  margin-bottom: var(--sp-xs) !important;
}
.entry-content p {
  font-family: var(--f-serif);
  font-size: var(--fs-md);
  line-height: var(--lh-prose);
  margin-bottom: var(--sp-md);
  text-align: justify;
  hyphens: auto;
}
.entry-content a {
  color: var(--c-crimson);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: opacity var(--d-fast);
}
.entry-content a:hover { opacity: .75 }
.entry-content strong { color: var(--c-text); font-weight: var(--fw-semibold) }
.entry-content em { font-style: italic; color: var(--c-text-2) }

/* Blockquote */
.entry-content blockquote {
  position: relative;
  border-left: 3px solid var(--c-crimson);
  padding: var(--sp-lg) var(--sp-xl);
  margin: var(--sp-xl) 0;
  background: var(--c-crimson-tint2);
  border-radius: 0 var(--r-lg) var(--r-lg) 0;
  font-style: italic;
  color: var(--c-text-2);
}
.entry-content blockquote::before {
  content: '\201C';
  position: absolute; top: -8px; left: var(--sp-md);
  font-size: 4rem; line-height: 1;
  font-family: Georgia, serif;
  color: var(--c-crimson); opacity: .25;
}

/* Listes */
.entry-content ul { list-style: none; padding-left: 0 }
.entry-content ul li {
  position: relative;
  padding-left: var(--sp-xl);
  margin-bottom: var(--sp-sm);
}
.entry-content ul li::before {
  content: '';
  position: absolute; left: 0; top: .65em;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--c-crimson);
}
.entry-content ol { padding-left: var(--sp-xl); counter-reset: item }
.entry-content ol li {
  counter-increment: item;
  position: relative;
  padding-left: var(--sp-md);
  margin-bottom: var(--sp-sm);
}
.entry-content ol li::marker {
  color: var(--c-crimson); font-weight: var(--fw-semibold);
}

/* Images */
.entry-content img {
  border-radius: var(--r-lg);
  margin: var(--sp-xl) auto;
  box-shadow: var(--sh-md);
  display: block;
}
.entry-content figure { margin: var(--sp-xl) 0 }
.entry-content figcaption {
  text-align: center;
  font-size: var(--fs-sm); color: var(--c-text-3);
  margin-top: var(--sp-sm); font-style: italic;
}

/* Code */
.entry-content code {
  font-family: 'SF Mono', 'Fira Code', 'Fira Mono', monospace;
  font-size: .88em;
  background: var(--c-bg2);
  color: var(--c-crimson);
  padding: 2px 6px; border-radius: var(--r-xs);
}
.entry-content pre {
  background: #1a1a2e;
  color: #e8e8f0;
  border-radius: var(--r-md);
  padding: var(--sp-xl);
  overflow-x: auto;
  font-size: var(--fs-sm);
  line-height: 1.7;
  margin: var(--sp-xl) 0;
}
.entry-content pre code { background: none; color: inherit; padding: 0 }

/* Séparateur */
.entry-content hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--c-crimson-glow), transparent);
  margin: var(--sp-2xl) 0;
}

/* Table */
.entry-content table {
  width: 100%; border-collapse: collapse;
  margin: var(--sp-xl) 0;
  font-size: var(--fs-sm);
}
.entry-content th {
  background: var(--c-bg2);
  font-family: var(--f-display);
  letter-spacing: .06em;
  padding: var(--sp-sm) var(--sp-md);
  text-align: left; border-bottom: 2px solid var(--c-crimson);
}
.entry-content td {
  padding: var(--sp-sm) var(--sp-md);
  border-bottom: 1px solid var(--c-border);
  vertical-align: top;
}
.entry-content tr:hover td { background: var(--c-crimson-tint2) }

/* Tags en bas */
.single-tags-wrap {
  padding: var(--sp-lg) 0 var(--sp-xl);
  border-top: 1px solid var(--c-border);
  margin-top: var(--sp-xl);
  display: flex; flex-wrap: wrap; gap: var(--sp-sm); align-items: center;
}
.single-tags-label {
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  color: var(--c-text-3); letter-spacing: 0;
  margin-right: var(--sp-xs);
}

/* Navigation article suivant/précédent */
.single-post-nav {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-lg); margin-top: var(--sp-2xl);
}
.single-post-nav-item {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--sp-lg) var(--sp-xl);
  box-shadow: var(--sh-xs);
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid), border-color var(--d-mid);
  display: flex; flex-direction: column; gap: var(--sp-xs);
}
.single-post-nav-item:hover {
  transform: translateY(-3px); box-shadow: var(--sh-md);
  border-color: var(--c-crimson-glow);
}
.single-post-nav-item--prev { text-align: left }
.single-post-nav-item--next { text-align: right }
.single-post-nav-dir {
  font-size: var(--fs-xs); color: var(--c-text-3);
  font-weight: var(--fw-medium); letter-spacing: .06em;
}
.single-post-nav-title {
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  color: var(--c-crimson); line-height: var(--lh-snug);
}

/* Commentaires */
.single-comments-wrap {
  margin-top: var(--sp-2xl);
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-2xl);
  padding: var(--sp-2xl);
  box-shadow: var(--sh-sm);
}
.comments-title {
  font-family: var(--f-display);
  font-size: var(--fs-2xl);
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-xl);
  display: flex; align-items: center; gap: var(--sp-sm);
}
.comments-title::before {
  content: '';
  width: 4px; height: 1.3em;
  background: var(--c-crimson); border-radius: var(--r-pill);
}


/* ════════════════════════════════════════════════════
   v5 — ARCHIVE REDESIGN
════════════════════════════════════════════════════ */
.archive-wrap { min-height: 100vh }
.archive-body {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
  gap: var(--sp-xl);
}


/* ════════════════════════════════════════════════════
   v5 — AUTHOR REDESIGN
════════════════════════════════════════════════════ */
.author-wrap { min-height: 100vh }

.author-profile-card {
  max-width: var(--max-wide);
  margin: -2rem auto 0;
  padding: 0 var(--sp-page);
  position: relative; z-index: 10;
}
.author-profile-inner {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-float);
  padding: var(--sp-xl) var(--sp-2xl);
  display: flex; align-items: center; gap: var(--sp-xl);
  overflow: hidden; position: relative;
}
.author-profile-inner::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  background-size: 200%; animation: gradShift 5s ease-in-out infinite;
}
.author-avatar-lg {
  width: 88px; height: 88px; flex-shrink: 0;
  border-radius: 50%; overflow: hidden;
  border: 3px solid rgba(123,22,32,.15);
  box-shadow: var(--sh-crimson);
}
.author-avatar-lg img { width: 100%; height: 100%; object-fit: cover }
.author-info-block {}
.author-info-name {
  font-family: var(--f-display);
  font-size: var(--fs-3xl); letter-spacing: -0.01em;
  margin-bottom: var(--sp-xs);
}
.author-info-bio {
  font-size: var(--fs-sm); color: var(--c-text-2);
  line-height: var(--lh-snug);
  margin-bottom: 0 !important;
}
.author-info-count {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: var(--sp-sm);
  font-size: var(--fs-xs); color: var(--c-text-3);
}
.author-info-count svg { color: var(--c-crimson) }

.author-articles-body {
  max-width: var(--max-wide);
  margin: var(--sp-2xl) auto 0;
  padding: 0 var(--sp-page) var(--sp-4xl);
}
.author-section-title {
  font-family: var(--f-display);
  font-size: var(--fs-2xl); letter-spacing: -0.01em;
  margin-bottom: var(--sp-xl);
  display: flex; align-items: center; gap: var(--sp-sm);
}
.author-section-title::before {
  content: '';
  width: 4px; height: 1.3em;
  background: var(--c-crimson); border-radius: var(--r-pill);
}


/* ════════════════════════════════════════════════════
   v5 — SEARCH PAGE REDESIGN
════════════════════════════════════════════════════ */
.search-wrap { min-height: 100vh }
.search-body {
  max-width: 920px;
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.search-form-wrap {
  margin-bottom: var(--sp-2xl);
}
.search-results-grid { display: flex; flex-direction: column; gap: var(--sp-lg) }

/* Search card redesign */
.search-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  display: flex;
  box-shadow: var(--sh-xs);
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid), border-color var(--d-mid);
}
.search-card:hover {
  transform: translateX(5px);
  box-shadow: var(--sh-md);
  border-color: var(--c-crimson-glow);
}
.search-card-left {
  display: flex; flex-direction: column; flex: 1;
}
.search-card-thumb-wrap {
  flex-shrink: 0; width: 200px; overflow: hidden;
  background: var(--c-bg2);
}
.search-card-thumb-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--d-slow) var(--ease-smooth);
}
.search-card:hover .search-card-thumb-wrap img { transform: scale(1.05) }
.search-card-body {
  padding: var(--sp-lg) var(--sp-xl);
  flex: 1; display: flex; flex-direction: column; justify-content: center;
}
.search-card-cat {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 10px; border-radius: var(--r-pill);
  background: var(--c-crimson-tint); color: var(--c-crimson);
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-sm);
  width: fit-content;
}
.search-card-title {
  font-family: var(--f-display);
  font-size: clamp(1rem, 2.5vw, 1.3rem);
  letter-spacing: .07em; line-height: var(--lh-snug);
  margin-bottom: var(--sp-sm);
}
.search-card-title a { color: var(--c-text); transition: color var(--d-fast) }
.search-card-title a:hover { color: var(--c-crimson) }
.search-card-excerpt {
  font-size: var(--fs-sm); color: var(--c-text-2);
  line-height: var(--lh-normal); flex: 1;
  margin-bottom: var(--sp-sm);
}
.search-card-meta {
  display: flex; gap: var(--sp-md); flex-wrap: wrap;
  font-size: var(--fs-xs); color: var(--c-text-3);
}

/* Barre de recherche inline */
.search-inline-wrap {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  padding: var(--sp-lg) var(--sp-xl);
  box-shadow: var(--sh-xs);
  margin-bottom: var(--sp-2xl);
}
.search-inline-label {
  font-family: var(--f-display);
  font-size: var(--fs-base); letter-spacing: 0;
  color: var(--c-text-3); margin-bottom: var(--sp-sm);
  display: block;
}


/* ════════════════════════════════════════════════════
   v5 — PAGE STATIQUE REDESIGN
════════════════════════════════════════════════════ */
.page-body {
  max-width: 860px;
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.page-article-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-lg); overflow: hidden;
}
.page-article-card::before {
  content: ''; display: block; width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  background-size: 200%; animation: gradShift 5s ease-in-out infinite;
}
.page-article-actions {
  padding: var(--sp-lg) var(--sp-2xl);
  border-bottom: 1px solid var(--c-border);
  display: flex; justify-content: flex-end;
}
.page-article-body {
  padding: var(--sp-xl) clamp(1.5rem, 5vw, 3.5rem) var(--sp-2xl);
}
.legal-content h2 {
  font-family: var(--f-display) !important;
  font-size: clamp(1.3rem, 3vw, 1.8rem) !important;
  letter-spacing: -0.01em !important;
  margin-top: var(--sp-3xl) !important;
  margin-bottom: var(--sp-lg) !important;
  scroll-margin-top: calc(var(--nav-h) + 16px);
  color: var(--c-text) !important;
  padding-bottom: var(--sp-sm);
  border-bottom: 1px solid var(--c-border);
}
.legal-content p {
  font-family: var(--f-body) !important;
  font-size: var(--fs-base) !important;
  line-height: var(--lh-relaxed);
  color: var(--c-text-2);
  margin-bottom: var(--sp-lg);
  text-align: justify; hyphens: auto;
}

/* TOC */
.page-toc {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-xl);
  margin-bottom: var(--sp-2xl);
}
.page-toc-title {
  font-family: var(--f-display) !important;
  font-size: var(--fs-lg) !important;
  letter-spacing: 0;
  margin-bottom: var(--sp-md);
  display: flex; align-items: center; gap: var(--sp-sm);
}
.page-toc-title::before {
  content: ''; width: 3px; height: 1.2em;
  background: var(--c-crimson); border-radius: var(--r-pill);
}
.page-toc nav a {
  display: block; padding: var(--sp-xs) var(--sp-sm);
  color: var(--c-text-2); font-size: var(--fs-sm);
  border-radius: var(--r-sm);
  transition: color var(--d-fast), background var(--d-fast), padding-left var(--d-fast) var(--ease-spring);
}
.page-toc nav a:hover {
  color: var(--c-crimson); background: var(--c-crimson-tint);
  padding-left: var(--sp-lg);
}


/* ════════════════════════════════════════════════════
   v5 — 404 REDESIGN
════════════════════════════════════════════════════ */
.notfound-wrap { min-height: 100vh }
.notfound-body {
  max-width: 600px; margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.notfound-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-lg); overflow: hidden;
  text-align: center;
}
.notfound-card::before {
  content: ''; display: block; width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  background-size: 200%; animation: gradShift 5s ease-in-out infinite;
}
.notfound-inner { padding: var(--sp-3xl) var(--sp-2xl) var(--sp-2xl) }
.notfound-glyph {
  font-family: var(--f-display);
  font-size: clamp(5rem, 15vw, 9rem);
  letter-spacing: -0.01em; color: var(--c-crimson);
  line-height: 1; margin-bottom: var(--sp-md);
  opacity: .16; user-select: none;
}
.notfound-heading {
  font-family: var(--f-display);
  font-size: var(--fs-3xl); letter-spacing: -0.01em;
  margin-bottom: var(--sp-lg);
}
.notfound-text {
  font-size: var(--fs-base) !important;
  color: var(--c-text-2);
  margin-bottom: var(--sp-2xl) !important;
  line-height: var(--lh-normal);
}
.notfound-actions {
  display: flex; justify-content: center;
  gap: var(--sp-md); flex-wrap: wrap;
}


/* ════════════════════════════════════════════════════
   v5 — REVEAL ANIMATIONS
   fade · zoom · blur · left · right · up
════════════════════════════════════════════════════ */
.reveal-fade {
  opacity: 0;
  transition: opacity .8s var(--ease-out);
}
.reveal-fade.visible { opacity: 1 }

.reveal-up {
  opacity: 0; transform: translateY(32px) scale(.99);
  transition: opacity .7s var(--ease-out), transform .7s var(--ease-spring);
}
.reveal-up.visible { opacity: 1; transform: none }

.reveal-zoom {
  opacity: 0; transform: scale(.88);
  transition: opacity .75s var(--ease-out), transform .75s var(--ease-spring);
}
.reveal-zoom.visible { opacity: 1; transform: scale(1) }

.reveal-blur {
  opacity: 0; filter: blur(8px); transform: translateY(20px);
  transition: opacity .8s var(--ease-out), filter .8s var(--ease-out), transform .8s var(--ease-spring);
}
.reveal-blur.visible { opacity: 1; filter: blur(0); transform: none }


/* ════════════════════════════════════════════════════
   v5 — POST CARD REDESIGN
════════════════════════════════════════════════════ */
.post-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-xs); overflow: hidden;
  display: flex; flex-direction: column;
  transition:
    transform var(--d-mid) var(--ease-spring),
    box-shadow var(--d-mid),
    border-color var(--d-mid);
}
.post-card:hover {
  transform: translateY(-6px) scale(1.01);
  box-shadow: var(--sh-lg);
  border-color: rgba(123,22,32,.12);
}
.post-card-thumb {
  width: 100%; aspect-ratio: 16/9; overflow: hidden;
  background: var(--c-bg2); position: relative;
}
.post-card-thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--d-slow) var(--ease-smooth);
}
.post-card:hover .post-card-thumb img { transform: scale(1.07) }
.post-card-thumb-cat {
  position: absolute; top: var(--sp-md); left: var(--sp-md);
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--c-crimson); color: #fff;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  letter-spacing: .04em;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.post-card-body {
  padding: var(--sp-lg) var(--sp-xl);
  flex: 1; display: flex; flex-direction: column;
}
.post-card-title {
  font-family: var(--f-display);
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  letter-spacing: .07em; line-height: var(--lh-snug);
  margin-bottom: var(--sp-sm);
}
.post-card-title a { color: var(--c-text); transition: color var(--d-fast) }
.post-card-title a:hover { color: var(--c-crimson) }
.post-card-excerpt {
  font-size: var(--fs-sm); color: var(--c-text-2);
  line-height: var(--lh-normal); flex: 1;
  margin-bottom: var(--sp-md);
}
.post-card-footer {
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap;
  gap: var(--sp-sm); padding-top: var(--sp-md);
  border-top: 1px solid var(--c-border);
}
.post-card-meta {
  font-size: var(--fs-xs); color: var(--c-text-3);
  display: flex; align-items: center; gap: var(--sp-sm);
}
.post-card-link {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--fs-xs); font-weight: var(--fw-semibold);
  color: var(--c-crimson);
  transition: gap var(--d-fast) var(--ease-spring);
}
.post-card-link:hover { gap: 8px }


/* ════════════════════════════════════════════════════
   v5 — TILT SHINE (3D hover)
════════════════════════════════════════════════════ */
.tilt-shine {
  position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(
    circle at var(--mx, 50%) var(--my, 50%),
    rgba(255,255,255,.14) 0%, transparent 58%
  );
  pointer-events: none; z-index: 1;
  opacity: 0; transition: opacity .3s;
}
.presentation-card:hover .tilt-shine,
.contact-form-card:hover .tilt-shine,
.post-card:hover .tilt-shine { opacity: 1 }


/* ════════════════════════════════════════════════════
   v5 — BOUTONS
════════════════════════════════════════════════════ */
/* Amélioration des transitions */
.btn-cta-primary,
.btn-cta-ghost,
.btn-cta-light,
.btn-cta-outline,
.btn-submit,
.nav-cta {
  will-change: transform;
  transition:
    background var(--d-fast),
    color var(--d-fast),
    transform var(--d-mid) var(--ease-spring),
    box-shadow var(--d-mid),
    border-color var(--d-fast);
}


/* ════════════════════════════════════════════════════
   v5 — PRÉSENTATION HOME — mise à jour
════════════════════════════════════════════════════ */
.presentation-section {
  padding: var(--sp-xl) var(--sp-page) var(--sp-2xl);
  max-width: var(--max-content); margin: 0 auto;
}
.presentation-card {
  background: var(--c-white);
  border-radius: var(--r-2xl); border: 1px solid var(--c-border);
  box-shadow: var(--sh-float);
  overflow: hidden; position: relative;
  will-change: transform;
}
.presentation-card::before {
  content: ''; display: block; width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  background-size: 200%; animation: gradShift 5s ease-in-out infinite;
}
/* Texture noise subtile */
.presentation-card::after {
  content: '';
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: .022; pointer-events: none; border-radius: inherit; z-index: 0;
}
.presentation-inner {
  position: relative; z-index: 1;
  padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3.5rem);
}
/* ════════════════════════════════════════════════════
   HERO BANNER STYLE
════════════════════════════════════════════════════ */

/* Styles de base pour la section hero */
.contact-hero {
  position: relative;
  width: 100%; /* La section doit être pleine largeur */
  height: 100vh; /* Une hauteur de viewport complète pour une bannière pleine page */
  overflow: hidden;
  background: var(--c-crimson-grad); /* Fond dégradé ou autre selon ton choix */
  padding-top: var(--nav-h); /* Pour compenser la hauteur de la navbar si nécessaire */
  text-align: center;
  isolation: isolate; /* Pour s’assurer que l’élément se superpose correctement */
}

.contact-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.contact-hero-orb {
  position: absolute;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.07); /* Ombre subtile pour les orbites */
}

.contact-hero-orb-1 {
  width: clamp(280px, 38vw, 460px);
  height: clamp(280px, 38vw, 460px);
  top: -120px;
  right: -80px;
  animation: floatSlow 11s ease-in-out infinite;
}

.contact-hero-orb-2 {
  width: clamp(150px, 20vw, 260px);
  height: clamp(150px, 20vw, 260px);
  bottom: -30px;
  left: 4%;
  animation: floatSlow 14s ease-in-out infinite reverse;
}

.contact-hero-orb-3 {
  width: clamp(90px, 11vw, 150px);
  height: clamp(90px, 11vw, 150px);
  top: 28%;
  left: 38%;
  animation: pulse 7s ease-in-out infinite;
}

/* Structure interne du Hero */
.contact-hero-inner {
  position: relative;
  z-index: 3;
  max-width: 700px;
  margin: 0 auto;
  color: #fff;
}

.contact-hero-title {
  font-family: var(--f-display) !important;
  font-size: clamp(3rem, 7.5vw, 5.2rem) !important;
  letter-spacing: var(--ls-wide) !important;
  color: #fff;
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-lg);
}

.contact-hero-sup {
  font-size: 0.46em;
  vertical-align: super;
  letter-spacing: 0.04em;
}

.contact-hero-sub {
  font-size: clamp(1rem, 2vw, 1.15rem) !important;
  color: rgba(255, 255, 255, 0.82);
  line-height: var(--lh-relaxed);
  font-style: italic;
  margin-bottom: 0 !important;
}

/* Animation des éléments */
@keyframes floatSlow {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}

/* Animation du texte */
.reveal-up {
  opacity: 0;
  animation: revealUp 1.5s forwards;
}

@keyframes revealUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ════════════════════════════════════════════════════
   v5 — CONTACT HERO HARMONISÉ
════════════════════════════════════════════════════ */
.contact-hero {
  position: relative; overflow: hidden;
  background: var(--c-crimson-grad);
  padding:
    calc(var(--nav-h) + clamp(2.2rem, 4.5vw, 3.8rem))
    var(--sp-page)
    clamp(3.5rem, 7vw, 5.5rem);
  text-align: center; isolation: isolate;
}
.contact-hero::after {
  content: '';
  position: absolute; bottom: -1px; left: 0; right: 0; height: 60px;
  background: var(--c-bg);
  clip-path: ellipse(55% 100% at 50% 100%); z-index: 2;
}
.contact-hero-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none }
.contact-hero-orb { position: absolute; border-radius: 50%; background: rgba(255,255,255,.07) }
.contact-hero-orb-1 { width: clamp(260px,35vw,420px); height: clamp(260px,35vw,420px); top:-100px; right:-70px; animation: floatSlow 10s ease-in-out infinite }
.contact-hero-orb-2 { width: clamp(130px,17vw,210px); height: clamp(130px,17vw,210px); bottom:-40px; left:6%; animation: floatSlow 13s ease-in-out infinite reverse }
.contact-hero-inner { position: relative; z-index: 3; max-width: 620px; margin: 0 auto }
.contact-hero-icon {
  width: 68px; height: 68px; border-radius: 50%;
  background: rgba(255,255,255,.2); backdrop-filter: var(--blur-sm);
  border: 1px solid rgba(255,255,255,.3);
  display: flex; align-items: center; justify-content: center; color: #fff;
  margin: 0 auto var(--sp-xl); animation: float 3.5s ease-in-out infinite;
}
.contact-hero-title {
  font-family: var(--f-display) !important;
  font-size: clamp(2.2rem, 5vw, 3.5rem) !important;
  letter-spacing: var(--ls-wide) !important;
  color: #fff; margin-bottom: var(--sp-md);
}
.contact-hero-sub {
  font-size: var(--fs-base) !important;
  color: rgba(255,255,255,.8);
  line-height: var(--lh-relaxed); margin-bottom: 0 !important;
  font-style: italic;
}


/* ════════════════════════════════════════════════════
   v5 — CONTACT FORM — paddings définitifs
════════════════════════════════════════════════════ */
.contact-form-card { overflow: hidden }
.contact-alert {
  margin: var(--sp-lg) var(--sp-2xl) 0 !important;
  padding: var(--sp-md) var(--sp-lg) !important;
}
.contact-form-wrapper {
  padding: var(--sp-xl) var(--sp-2xl) var(--sp-2xl) !important;
}
.contact-form,
.contact-form-wrapper form { gap: var(--sp-lg) !important }
.form-input  { padding: 12px var(--sp-lg) 11px !important }
.form-textarea { padding: 12px var(--sp-lg) !important }
.form-group  { gap: 5px !important }
.contact-info-card     { padding: var(--sp-xl) var(--sp-xl) }
.contact-info-card--sm { padding: var(--sp-lg) var(--sp-xl) }


/* ════════════════════════════════════════════════════
   v5 — FOOTER REDESIGN
════════════════════════════════════════════════════ */
.site-footer {
  background: var(--c-white);
  border-top: 1px solid var(--c-border);
  position: relative;
}
.site-footer::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg,
    transparent, rgba(123,22,32,.2), var(--c-crimson), rgba(123,22,32,.2), transparent);
}
.footer-inner {
  max-width: var(--max-wide); margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-xl);
}
.footer-brand {
  text-align: center; margin-bottom: var(--sp-xl);
  padding-bottom: var(--sp-xl);
  border-bottom: 1px solid var(--c-border);
}
.footer-logo {
  display: inline-flex; align-items: center; gap: var(--sp-md);
  margin-bottom: var(--sp-sm); text-decoration: none;
}
.footer-logo-badge {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--c-crimson); display: flex; align-items: center; justify-content: center;
  box-shadow: var(--sh-crimson);
}
.footer-logo-badge span {
  color: #fff; font-family: var(--f-brand); font-size: 1.35rem; line-height: 1;
}
.footer-logo-text {
  font-family: var(--f-brand); font-size: 1.4rem;
  color: var(--c-crimson); letter-spacing: var(--ls-wide);
}
.footer-tagline {
  font-size: var(--fs-sm) !important;
  color: var(--c-text-3); font-style: italic;
  margin: 0 !important;
}
.footer-nav { margin-bottom: var(--sp-xl) }
.footer-nav ul {
  list-style: none; display: flex; flex-wrap: wrap;
  justify-content: center; gap: 4px;
}
.footer-nav a {
  display: block; padding: 6px 14px; border-radius: var(--r-pill);
  font-size: var(--fs-sm); color: var(--c-text-2); font-weight: var(--fw-medium);
  transition: color var(--d-fast), background var(--d-fast);
}
.footer-nav a:hover { color: var(--c-crimson); background: var(--c-crimson-tint) }
.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--sp-lg);
  padding-top: var(--sp-lg); border-top: 1px solid var(--c-border);
}
.footer-links { display: flex; align-items: center; gap: var(--sp-md) }
.footer-links a {
  font-size: var(--fs-sm); color: var(--c-text-3);
  transition: color var(--d-fast);
}
.footer-links a:hover { color: var(--c-crimson) }
.footer-sep { color: var(--c-border-dk) }
.footer-socials { display: flex; gap: var(--sp-md) }
.footer-social-btn {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--c-border-md); color: var(--c-text-3);
  transition: all var(--d-fast) var(--ease-spring);
}
.footer-social-btn:hover {
  background: var(--c-crimson); border-color: var(--c-crimson);
  color: #fff; transform: translateY(-3px); box-shadow: var(--sh-crimson);
}
.footer-copyright {
  width: 100%; text-align: center;
  margin-top: var(--sp-lg); font-size: var(--fs-sm); color: var(--c-text-3);
}


/* ════════════════════════════════════════════════════
   v5 — UI HELPERS
════════════════════════════════════════════════════ */
.page-progress-bar {
  position: fixed; top: 0; right: 0; width: 3px; height: 0%;
  background: linear-gradient(180deg, var(--c-crimson-dk), var(--c-crimson), var(--c-crimson-lt));
  z-index: 599; border-radius: 0 0 var(--r-pill) var(--r-pill);
  transition: height .1s linear; pointer-events: none;
}
.back-to-top {
  position: fixed; bottom: 28px; right: 24px;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--c-crimson); color: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--sh-crimson); z-index: 490;
  opacity: 0; transform: translateY(14px) scale(.88);
  transition: opacity var(--d-mid) var(--ease-smooth), transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
  pointer-events: none;
}
.back-to-top.visible { opacity: 1; transform: none; pointer-events: all }
.back-to-top:hover {
  background: var(--c-crimson-dk); box-shadow: var(--sh-crimson-lg);
  transform: translateY(-3px) scale(1.07);
}

.cta-particles-canvas {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 0; opacity: .5;
}
.cta-band-inner, .cta-band-deco { position: relative; z-index: 2 }

/* Blob morphing */
@keyframes morphBlob {
  0%,100% { border-radius: 60% 40% 30% 70% / 60% 30% 70% 40% }
  33%     { border-radius: 40% 60% 65% 35% / 50% 55% 35% 60% }
  66%     { border-radius: 65% 35% 50% 50% / 35% 65% 50% 60% }
}
.hero-orb { animation: morphBlob 12s ease-in-out infinite, orbPulse 6s ease-in-out infinite }


/* ════════════════════════════════════════════════════
   v5 — RESPONSIVE COMPLET
════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .contact-layout { grid-template-columns: 1fr }
  .contact-aside  { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-lg) }
  .author-profile-inner { gap: var(--sp-lg) }
}

@media (max-width: 768px) {
  .nav-desktop { display: none }
  .nav-hamburger, .nav-mobile-controls { display: flex }

  .single-post-nav { grid-template-columns: 1fr }
  .search-card { flex-direction: column }
  .search-card-thumb-wrap { width: 100%; aspect-ratio: 16/8 }
  .author-profile-inner { flex-direction: column; text-align: center }
  .contact-aside { grid-template-columns: 1fr }

  .contact-alert        { margin: var(--sp-md) var(--sp-lg) 0 !important }
  .contact-form-wrapper { padding: var(--sp-lg) var(--sp-lg) var(--sp-xl) !important }
  .contact-info-card    { padding: var(--sp-lg) }

  .footer-bottom { flex-direction: column; align-items: center; text-align: center }
  .footer-links  { flex-direction: column; align-items: center; gap: var(--sp-sm) }

  .hero-cta-row { flex-direction: column; align-items: stretch }
  .btn-cta-primary, .btn-cta-ghost { justify-content: center }
  .cta-band-inner { flex-direction: column; text-align: center }
  .cta-band-content { flex-direction: column; align-items: center }
  .cta-band-actions { justify-content: center }

  .back-to-top { bottom: 18px; right: 14px; width: 40px; height: 40px }
  .page-progress-bar { width: 2px }

  /* Circles */
  .circle-container { max-width: 520px }
  .circle-bubble.center       { top:24%; left:50% }
  .circle-bubble.top-left     { top:20%; left:12% }
  .circle-bubble.left         { top:50%; left:2% }
  .circle-bubble.bottom-left  { bottom:12%; left:5% }
  .circle-bubble.top-right    { top:20%; right:12% }
  .circle-bubble.right        { top:50%; right:2% }
  .circle-bubble.bottom-right { bottom:12%; right:5% }
}

@media (max-width: 480px) {
  :root { --circle-size: 80px; --circle-font: 12px }
  .circle-container { max-width: 360px }
  .circle-bubble.center       { top:10%; left:50% }
  .circle-bubble.top-left     { top:10%; left:18% }
  .circle-bubble.top-right    { top:10%; right:18% }
  .circle-bubble.left         { top:50%; left:2% }
  .circle-bubble.right        { top:50%; right:2% }
  .circle-bubble.bottom-left  { bottom:2%; left:0 }
  .circle-bubble.bottom-right { bottom:2%; right:0 }

  .contact-alert        { margin: var(--sp-sm) var(--sp-md) 0 !important }
  .contact-form-wrapper { padding: var(--sp-md) var(--sp-md) var(--sp-lg) !important }
  .notfound-actions { flex-direction: column }
  .author-profile-inner { padding: var(--sp-xl) var(--sp-lg) }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
}


/* ════════════════════════════════════════════════════
   v6 — NOUVEAUX KEYFRAMES
════════════════════════════════════════════════════ */

/* Zoom d'entrée pour les sections hero */
@keyframes heroBgZoom {
  from { transform: scale(1.08); opacity: .7 }
  to   { transform: scale(1);    opacity: 1 }
}

/* Entrée hero contenu */
@keyframes heroContentSlide {
  from { opacity: 0; transform: translateY(30px) scale(.98) }
  to   { opacity: 1; transform: none }
}

/* Shimmer sur texte blanc */
@keyframes textShimmer {
  0%   { background-position: -200% center }
  100% { background-position:  200% center }
}

/* Scintillement border */
@keyframes borderPulse {
  0%,100% { opacity: .6 }
  50%     { opacity: 1 }
}

/* Slide latéral pour footer liens */
@keyframes slideRight {
  from { opacity: 0; transform: translateX(-12px) }
  to   { opacity: 1; transform: none }
}

/* Éclatement d'orbe */
@keyframes orbExpand {
  0%   { transform: scale(0.6); opacity: 0 }
  60%  { opacity: .6 }
  100% { transform: scale(1); opacity: 1 }
}

/* Compte à rebours upward */
@keyframes countUp {
  from { opacity: 0; transform: translateY(14px) }
  to   { opacity: 1; transform: none }
}


/* ════════════════════════════════════════════════════
   v6 — HERO ENTRÉE — ZOOM BACKGROUND
════════════════════════════════════════════════════ */

/* Zoom animé sur le fond des heros au chargement */
.home-hero-bg,
.page-hero-bg,
.contact-hero-bg {
  animation: heroBgZoom 1.8s var(--ease-out) both;
  will-change: transform;
}

/* Orbe 3 du contact-hero */
.contact-hero-orb-3 {
  position: absolute;
  width: clamp(60px, 8vw, 110px);
  height: clamp(60px, 8vw, 110px);
  border-radius: 50%;
  background: rgba(255,255,255,.05);
  bottom: 20%; right: 10%;
  animation: pulse 5s ease-in-out infinite 1.5s;
}

/* Animation d'entrée du contenu hero */
.contact-hero-inner,
.home-hero-inner {
  animation: heroContentSlide 1s var(--ease-out) .2s both;
}

/* Shimmer sur les titres hero */
.contact-hero-title,
.home-hero-title {
  position: relative;
}
.contact-hero-title::after,
.home-hero-title::after,
.page-hero-title::after {
  content: '';
  display: block;
  width: 60px; height: 3px;
  background: rgba(255,255,255,.5);
  border-radius: var(--r-pill);
  margin: var(--sp-md) auto 0;
  animation: borderPulse 2.5s ease-in-out infinite;
}

/* Page hero content entrance */
.page-hero-inner {
  animation: heroContentSlide .9s var(--ease-out) .1s both;
}




/* ════════════════════════════════════════════════════
   v6 — IMAGE PARALLAX
   Utilisé sur les thumbnails des cartes
════════════════════════════════════════════════════ */
.post-card-thumb img,
.search-card-thumb-wrap img {
  will-change: transform;
  /* La transformation est contrôlée par JS */
}

/* Conteneur parallax générique */
.parallax-img { overflow: hidden }
.parallax-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.12); /* marge pour le mouvement */
  will-change: transform;
  transition: transform var(--d-slow) var(--ease-smooth);
}


/* ════════════════════════════════════════════════════
   v6 — FOOTER DARK REDESIGN
════════════════════════════════════════════════════ */

/* Vague de transition page→footer */
.footer-wave {
  line-height: 0;
  position: relative; z-index: 1;
  background: var(--c-bg); /* couleur de la page au-dessus */
  overflow: hidden;
}
.footer-wave svg {
  display: block;
  width: 100%; height: auto;
}

/* Footer principal — fond sombre crimson */
.site-footer {
  background: linear-gradient(160deg, #1a0406 0%, #2d0a10 45%, #1e0508 100%);
  color: rgba(255,255,255,.7);
  border-top: none;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}

/* Override l'ancien ::before crimson line */
.site-footer::before {
  background: none !important;
}

/* Orbes décoratifs arrière-plan footer */
.footer-deco {
  position: absolute; inset: 0;
  pointer-events: none; overflow: hidden;
  z-index: 0;
}
.footer-orb {
  position: absolute; border-radius: 50%;
  background: var(--c-crimson);
  filter: blur(70px);
  opacity: .18;
}
.footer-orb-1 {
  width: 500px; height: 500px;
  top: -150px; right: -100px;
  animation: floatSlow 14s ease-in-out infinite;
}
.footer-orb-2 {
  width: 300px; height: 300px;
  bottom: -80px; left: -60px;
  animation: floatSlow 18s ease-in-out infinite reverse;
}
.footer-orb-3 {
  width: 180px; height: 180px;
  top: 30%; left: 40%;
  animation: pulse 8s ease-in-out infinite;
  opacity: .1;
}

/* Grille principale footer */
.footer-main {
  position: relative; z-index: 2;
  max-width: var(--max-wide); margin: 0 auto;
  padding: var(--sp-3xl) var(--sp-page) var(--sp-2xl);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1.4fr;
  gap: var(--sp-2xl);
  padding-bottom: var(--sp-2xl);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* ── Colonne Brand ── */
.footer-brand {
  display: flex; flex-direction: column;
  gap: var(--sp-lg);
}

.footer-logo {
  display: inline-flex; align-items: center;
  gap: var(--sp-md); text-decoration: none;
  width: fit-content;
}

.footer-logo-badge {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--c-crimson);
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--sh-crimson);
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.footer-logo:hover .footer-logo-badge {
  transform: scale(1.1) rotate(-5deg);
  box-shadow: var(--sh-crimson-lg);
}
.footer-logo-badge span {
  color: #fff; font-family: var(--f-brand);
  font-size: 1.5rem; line-height: 1; letter-spacing: .04em;
}
.footer-logo-badge sup { font-size: .58rem; font-weight: 700; vertical-align: super }

.footer-logo-text {
  font-family: var(--f-brand); font-size: 1.5rem;
  color: rgba(255,255,255,.92); letter-spacing: var(--ls-wide);
}

.footer-tagline {
  font-size: var(--fs-md) !important;
  font-family: var(--f-serif);
  font-style: italic;
  color: rgba(255,255,255,.72);
  line-height: 1.6;
  margin: 0 !important;
  letter-spacing: 0.01em;
}


.footer-socials {
  display: flex; gap: var(--sp-sm);
}

.footer-social-btn {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.45);
  transition: all var(--d-fast) var(--ease-spring);
}
.footer-social-btn:hover {
  background: var(--c-crimson);
  border-color: var(--c-crimson);
  color: #fff;
  transform: translateY(-4px) scale(1.1);
  box-shadow: var(--sh-crimson);
}

/* ── Colonne Navigation ── */
.footer-col-title {
  font-family: var(--f-display) !important;
  font-size: var(--fs-sm) !important;
  letter-spacing: var(--ls-wide);
  color: rgba(255,255,255,.55) !important;
  margin-bottom: var(--sp-lg) !important;
  text-transform: uppercase;
}

.footer-nav {
  display: flex; flex-direction: column; gap: 0;
}

.footer-nav ul {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 0;
  justify-content: flex-start;
}

.footer-nav a {
  display: inline-flex; align-items: center; gap: var(--sp-sm);
  padding: 7px 0;
  font-size: var(--fs-sm); color: rgba(255,255,255,.55);
  font-weight: var(--fw-medium);
  transition:
    color var(--d-fast),
    padding-left var(--d-fast) var(--ease-spring),
    gap var(--d-fast) var(--ease-spring);
  position: relative;
}
.footer-nav a::before {
  content: '';
  display: inline-block; flex-shrink: 0;
  width: 0; height: 1px;
  background: var(--c-crimson-lt);
  transition: width var(--d-mid) var(--ease-spring);
}
.footer-nav a:hover {
  color: rgba(255,255,255,.92);
  padding-left: var(--sp-sm);
}
.footer-nav a:hover::before { width: 12px }

/* Pas de border-bottom sur les liens du footer nav */
.footer-nav li { border-bottom: none }

/* ── Colonne Mission ── */
.footer-mission {
  display: flex; flex-direction: column; gap: var(--sp-md);
}

.footer-mission-text {
  font-size: var(--fs-sm) !important;
  color: rgba(255,255,255,.45);
  line-height: 1.8; margin: 0 !important;
}

.footer-cta-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-sm); font-weight: var(--fw-semibold);
  color: var(--c-crimson-lt);
  letter-spacing: var(--ls-tight);
  transition:
    gap var(--d-fast) var(--ease-spring),
    color var(--d-fast);
  width: fit-content;
}
.footer-cta-link:hover { color: #fff; gap: 14px }


/* ── Barre du bas ── */
.footer-bottom-bar {
  position: relative; z-index: 2;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.25);
}

.footer-bottom-inner {
  max-width: var(--max-wide); margin: 0 auto;
  padding: var(--sp-lg) var(--sp-page);
  display: flex; align-items: center;
  justify-content: space-between;
  flex-wrap: wrap; gap: var(--sp-md);
}

.footer-links {
  display: flex; gap: var(--sp-lg);
  flex-wrap: wrap;
}
.footer-links a {
  font-size: var(--fs-xs); color: rgba(255,255,255,.3);
  transition: color var(--d-fast);
}
.footer-links a:hover { color: rgba(255,255,255,.72) }
.footer-sep { color: rgba(255,255,255,.2) }

.footer-copyright {
  font-size: var(--fs-xs); color: rgba(255,255,255,.28);
  white-space: nowrap;
}
.footer-copyright sup { font-size: .72em }

/* ── Footer responsive ── */
@media (max-width: 1024px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
  .footer-mission {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: var(--sp-xl);
  }
  .footer-mission-text { flex: 1 1 300px }
  .footer-mission .footer-col-title { width: 100% }
}

@media (max-width: 640px) {
  .footer-grid       { grid-template-columns: 1fr }
  .footer-mission    { flex-direction: column; grid-column: auto }
  .footer-bottom-inner { flex-direction: column; align-items: center; text-align: center }
  .footer-links      { justify-content: center }
  .footer-copyright  { text-align: center }
  .footer-brand      { align-items: center; text-align: center }
  .footer-contact-info { align-items: center }
  .footer-socials    { justify-content: center }
  .footer-nav ul     { align-items: center }
  .footer-mission    { align-items: center; text-align: center }
  .footer-cta-link   { margin: 0 auto }
}


/* ════════════════════════════════════════════════════
   v6 — PARALLAX CLASSE
════════════════════════════════════════════════════ */
.reveal-parallax {
  will-change: transform;
  transition: transform .1s linear;
}


/* ════════════════════════════════════════════════════
   v6 — NAV — LIGNE DE PROGRESSION SCROLL
════════════════════════════════════════════════════ */
.nav-scroll-line {
  position: absolute; bottom: 0; left: 0;
  height: 2px; width: 0%;
  background: linear-gradient(90deg, var(--c-crimson-dk), var(--c-crimson-lt));
  transition: width .1s linear;
  pointer-events: none;
  border-radius: 0 var(--r-pill) var(--r-pill) 0;
  z-index: 1;
}
.site-nav.scrolled .nav-scroll-line { opacity: 1 }


/* ════════════════════════════════════════════════════
   v6 — HERO ZOOM CLASSES (appliqués par JS)
════════════════════════════════════════════════════ */
.hero-zoom-active {
  animation: heroBgZoom 2s var(--ease-out) both;
}


/* ════════════════════════════════════════════════════
   v6 — FORM CARD — PARTICULES FOND
════════════════════════════════════════════════════ */
.contact-form-card {
  position: relative;
}

/* ════════════════════════════════════════════════════
   v6 — RESPONSIVE COMPLÉMENTS
════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .footer-wave { display: block }
}

@media (max-width: 480px) {
  .footer-wave svg { height: 40px }
}


/* ════════════════════════════════════════════════════
   v5 — TEMPLATES WRAPPER
   Règle universelle : les pages avec hero
   utilisent .page-content-wrap (pas de padding top)
════════════════════════════════════════════════════ */
.page-content-wrap {
  padding-top: 0;          /* hero gère l'espace en haut */
}
.page-content-inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-page) var(--sp-4xl);
}
.page-content-inner--narrow {
  max-width: 860px;
}
.page-content-inner--medium {
  max-width: var(--max-content);
}

html { scroll-behavior: smooth; }

body {
  @apply bg-gray-50 text-gray-900 antialiased;
}

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

.prose h2 {
  scroll-margin-top: 120px;
}

/* ════════════════════════════════════════════════════
   SHADOWS SYSTEM — v7.1
   Text-shadows sur fonds sombres (hero crimson)
   Renforcement shadows cards et sections
════════════════════════════════════════════════════ */

/* ── Text-shadow : titres blancs sur fond crimson ── */
.contact-hero-title,
.page-hero-title,
.home-hero-title,
.single.php h1,
[style*="--c-crimson-grad"] h1,
[style*="background: var(--c-crimson-grad)"] h1 {
  text-shadow: var(--sh-text-inv) !important;
}

/* Couverture large : tous les h1 dans les sections hero crimson */
.relative.overflow-hidden.text-white h1,
.relative.overflow-hidden.text-white h2 {
  text-shadow: var(--sh-text-inv);
}

/* ── Cards — ombre renforcée au repos ── */
.post-card    { box-shadow: var(--sh-sm) }
.search-card  { box-shadow: var(--sh-sm) }

/* ── Presentation card ── */
.presentation-card { box-shadow: var(--sh-lg) }

/* ── CTA band ── */
.cta-band { box-shadow: var(--sh-lg) }

/* ── Contact stats ── */
.contact-stat {
  box-shadow: var(--sh-sm);
  transition: transform var(--d-mid) var(--ease-spring), box-shadow var(--d-mid);
}
.contact-stat:hover { transform: translateY(-3px); box-shadow: var(--sh-md) }

/* ── Thématiques section ── */
.thematiques .relative { box-shadow: var(--sh-md) }

/* ── Hero sections — ombre de séparation basse ── */
.contact-hero,
.page-hero {
  filter: drop-shadow(var(--sh-hero-bottom));
}

/* ── entry-content card (page, single) ── */
.bg-white.rounded-2xl { box-shadow: var(--sh-md) }

/* ── Badges / chips ── */
.tag-chip { box-shadow: var(--sh-xs) }
.nav-cta  { box-shadow: var(--sh-crimson) }

/* ── Section headings dans le contenu ── */
.entry-content h2,
.entry-content h3 {
  text-shadow: var(--sh-text);
}

/* ── Pillars circles — ombre de base ── */
.circle-bubble { box-shadow: var(--sh-md) }
.circle-bubble:hover { box-shadow: var(--sh-xl) !important }

/* ── Single nav items ── */
.single-nav-item,
.single-post-nav-item { box-shadow: var(--sh-sm) }

/* ── Comments card ── */
.single-comments { box-shadow: var(--sh-md) }

/* ── Page article container ── */
.page-article { box-shadow: var(--sh-lg) }

/* ── Author hero ── */
.author-hero { box-shadow: var(--sh-lg) }

/* ── CTA band title ── */
.cta-band-title {
  text-shadow: var(--sh-text-inv);
}

/* ── Edito title ── */
.edito-title { text-shadow: var(--sh-text) }