/*
Theme Name: Que Faire - Thème Enfant
Template: twentytwentyfive
Version: 3.0.0
*/

/* ─── POLICES ─────────────────────────────── */
@font-face {
  font-family: 'Poppins';
  font-weight: 300; font-style: normal; font-display: swap;
  src: url('./assets/fonts/poppins-v24-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Poppins';
  font-weight: 400; font-style: normal; font-display: swap;
  src: url('./assets/fonts/poppins-v24-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Poppins';
  font-weight: 400; font-style: italic; font-display: swap;
  src: url('./assets/fonts/poppins-v24-latin-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Poppins';
  font-weight: 700; font-style: normal; font-display: swap;
  src: url('./assets/fonts/poppins-v24-latin-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Poppins';
  font-weight: 900; font-style: normal; font-display: swap;
  src: url('./assets/fonts/poppins-v24-latin-900.woff2') format('woff2');
}

/* ─── VARIABLES ───────────────────────────── */
:root {
  --qf-orange:      #e45404;
  --qf-orange-dark: #c04303;
  --qf-noir:        #111111;
  --qf-texte:       #2d2d2d;
  --qf-gris:        #888888;
  --qf-fond:        #ffffff;
  --qf-neu-bg:      #e8eaee;

  /* Neumorphisme — réservé boutons + CTA */
  --neu-btn:
    0 0 12px 3px rgba(228,84,4,.32),
    0 0  4px 1px rgba(255,200,150,.25);
  --neu-btn-hover:
    0 0 20px 5px rgba(228,84,4,.45),
    0 0  6px 2px rgba(255,200,150,.30);
  --neu-cta:
    0 0 28px 8px rgba(228,84,4,.35),
    0 0  8px 2px rgba(255,200,150,.20);

  --r-sm: 8px;
  --r:    12px;
  --r-lg: 16px;
  --t:    .2s ease;
}

/* ─── BASE ────────────────────────────────── */
body {
  font-family: 'Poppins', sans-serif;
  background: var(--qf-fond);
  color: var(--qf-texte);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--qf-orange); }
img { display: block; max-width: 100%; height: auto; }

/* ─── ALIGNEMENT GAUCHE GLOBAL ───────────── */
.wp-block-post-terms,
.wp-block-post-date,
.wp-block-post-date time {
  text-align: left !important;
  display: block !important;
}

/* ─── BADGE CATÉGORIE ─────────────────────── */
.wp-block-post-terms a {
  display: inline-block;
  background: var(--qf-orange);
  color: #fff !important;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  text-decoration: none;
  line-height: 1.6;
}
/* Badge outline (grille carrée) */
.qf-badge-outline .wp-block-post-terms a {
  background: transparent !important;
  color: var(--qf-orange) !important;
  border: 1.5px solid var(--qf-orange);
  padding: 2px 7px;
}

/* ─── TITRE DE SECTION ────────────────────── */
h2.qf-titre-section {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--qf-noir) !important;
  margin: 32px 0 14px !important;
  padding: 0 !important;
  max-width: var(--wp--style--global--content-size) !important;
  box-sizing: border-box !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
h2.qf-titre-section::before {
  content: '' !important;
  display: block !important;
  width: 3px !important;
  height: 16px !important;
  background: var(--qf-orange) !important;
  border-radius: 2px !important;
  flex-shrink: 0 !important;
}


/* ══════════════════════════════════════════════
   HERO — FORMAT 4:5 PORTRAIT
   Classe  qf-hero  sur le Query Loop (1 article épinglé)
   ══════════════════════════════════════════════ */

.qf-hero ul.wp-block-post-template {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Le Cover natif prend tout */
.qf-hero .wp-block-cover {
  aspect-ratio: 4 / 5 !important;
  min-height: unset !important;
  width: 100% !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

/* Overlay texte en bas */
.qf-hero .wp-block-cover__inner-container {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  height: 100% !important;
  padding: 24px 16px !important;
}

.qf-hero .wp-block-post-title {
  font-size: clamp(1.3rem, 5vw, 2rem) !important;
  font-weight: 900 !important;
  line-height: 1.15 !important;
  color: #fff !important;
  margin: 8px 0 6px !important;
}
.qf-hero .wp-block-post-title a { color: #fff !important; }
.qf-hero .wp-block-post-date  { color: rgba(255,255,255,.6) !important; font-size: .72rem !important; }

/* Sur desktop : max 600px centré */
@media (min-width: 768px) {
  .qf-hero .wp-block-cover {
    aspect-ratio: 16 / 7 !important;
    border-radius: var(--r-lg) !important;
  }
}


/* ══════════════════════════════════════════════
   SCROLL HORIZONTAL — FORMAT STORIES 4:5
   Classe  qf-stories  sur le Query Loop
   ══════════════════════════════════════════════ */

/* STORIES — même présentation que qf-grid */
.qf-stories ul.wp-block-post-template {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}

.qf-stories ul.wp-block-post-template > li,
.qf-stories ul.wp-block-post-template > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}

.qf-stories li.wp-block-post {
  width: 100% !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
  background: #fff !important;
  border: .5px solid rgba(0,0,0,.06) !important;
  display: flex !important;
  flex-direction: column !important;
}

.qf-stories .wp-block-post-featured-image img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  display: block !important;
}

.qf-stories .wp-block-post-title {
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  color: var(--qf-noir) !important;
  margin: 6px 0 4px !important;
  padding: 0 10px !important;
}
.qf-stories .wp-block-post-title a { color: var(--qf-noir) !important; }
.qf-stories .wp-block-post-title a:hover { color: var(--qf-orange) !important; }

.qf-stories .wp-block-post-terms { padding: 8px 10px 0 !important; }
.qf-stories .wp-block-post-date {
  font-size: .68rem !important;
  color: var(--qf-gris) !important;
  padding: 0 10px 10px !important;
  display: block !important;
}

/* TABLETTE + DESKTOP : 3 colonnes */
@media (min-width: 600px) {
  .qf-stories ul.wp-block-post-template {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    grid-auto-rows: auto !important;
    align-items: stretch !important;
  }
  .qf-stories li.wp-block-post {
    width: 100% !important;
  }
}




/* ══════════════════════════════════════════════
   GRILLE 2 COLONNES — FORMAT CARRÉ 1:1
   Classe  qf-grid  sur le Query Loop
   ══════════════════════════════════════════════ */

.qf-grid ul.wp-block-post-template {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
}

/* Annule marges WordPress is-layout-flow */
.qf-grid ul.wp-block-post-template > li,
.qf-grid ul.wp-block-post-template > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}

.qf-grid li.wp-block-post {
  width: 100% !important;
  border-radius: var(--r) !important;
  overflow: hidden !important;
  background: #fff !important;
  border: .5px solid rgba(0,0,0,.06) !important;
  display: flex !important;
  flex-direction: column !important;
}

.qf-grid .wp-block-post-featured-image img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  display: block !important;
}

.qf-grid .wp-block-post-title {
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  color: var(--qf-noir) !important;
  margin: 6px 0 4px !important;
  padding: 0 10px !important;
}
.qf-grid .wp-block-post-title a { color: var(--qf-noir) !important; }
.qf-grid .wp-block-post-title a:hover { color: var(--qf-orange) !important; }

.qf-grid .wp-block-post-terms { padding: 8px 10px 0 !important; }
.qf-grid .wp-block-post-date {
  font-size: .68rem !important;
  color: var(--qf-gris) !important;
  padding: 0 10px 10px !important;
  display: block !important;
}

/* TABLETTE + DESKTOP : 3 colonnes */
@media (min-width: 600px) {
  .qf-grid ul.wp-block-post-template {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    grid-auto-rows: auto !important;
    align-items: stretch !important;
  }
}


/* ══════════════════════════════════════════════
   VIDÉO VERTICALE — FORMAT 9:16
   Classe  qf-video  sur le Query Loop
   ══════════════════════════════════════════════ */

.qf-video ul.wp-block-post-template {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.qf-video .wp-block-cover {
  aspect-ratio: 9 / 16 !important;
  min-height: unset !important;
  max-height: 520px !important;
  width: 100% !important;
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
}
.qf-video .wp-block-cover__inner-container {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  height: 100% !important;
  padding: 20px 16px !important;
}
.qf-video .wp-block-post-title {
  font-size: 1.05rem !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: 1.25 !important;
  margin: 8px 0 5px !important;
}
.qf-video .wp-block-post-title a { color: #fff !important; }
.qf-video .wp-block-post-date { color: rgba(255,255,255,.6) !important; font-size: .72rem !important; }

@media (min-width: 768px) {
  .qf-video .wp-block-cover {
    aspect-ratio: 16 / 9 !important;
    max-height: none !important;
    border-radius: var(--r-lg) !important;
  }
}


/* ══════════════════════════════════════════════
   LISTE AVEC VIGNETTE CARRÉE
   Classe  qf-liste  sur le Query Loop
   ══════════════════════════════════════════════ */

.qf-liste ul.wp-block-post-template {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.qf-liste li.wp-block-post {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  gap: 0 !important;
  border-bottom: .5px solid rgba(0,0,0,.07) !important;
  overflow: hidden !important;
  border-radius: var(--r) !important;
  margin-bottom: 10px !important;
}
.qf-liste li.wp-block-post:last-child { margin-bottom: 0 !important; border-bottom: none !important; }

/* Image pleine hauteur du li */
.qf-liste .wp-block-post-featured-image {
  flex: 0 0 120px !important;
  margin: 0 !important;
  overflow: hidden !important;
}
.qf-liste .wp-block-post-featured-image a {
  display: block !important;
  height: 100% !important;
}
.qf-liste .wp-block-post-featured-image img {
  width: 120px !important;
  height: 100% !important;
  min-height: 110px !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  display: block !important;
}

/* Contenu texte */
.qf-liste .wp-block-group {
  flex: 1 !important;
  padding: 12px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.qf-liste .wp-block-post-title {
  font-size: .88rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  color: var(--qf-noir) !important;
  margin: 4px 0 !important;
}
.qf-liste .wp-block-post-title a { color: var(--qf-noir) !important; }
.qf-liste .wp-block-post-title a:hover { color: var(--qf-orange) !important; }

.qf-liste .wp-block-post-excerpt {
  font-size: .75rem !important;
  color: var(--qf-gris) !important;
  line-height: 1.45 !important;
  margin: 4px 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.qf-liste .wp-block-post-excerpt .wp-block-post-excerpt__excerpt { margin: 0 !important; }
.qf-liste .wp-block-post-excerpt .wp-block-post-excerpt__more-link { display: none !important; }

.qf-liste .taxonomy-category,
.qf-liste .wp-block-post-date {
  margin: 0 !important;
  text-align: left !important;
}


/* ══════════════════════════════════════════════
   CTA NEWSLETTER — NEUMORPHISME ORANGE
   Classe  qf-newsletter  sur un bloc Groupe
   ══════════════════════════════════════════════ */

.qf-newsletter {
  background: var(--qf-orange) !important;
  border-radius: 20px !important;
  padding: 28px 24px !important;
  text-align: center !important;
  box-shadow: var(--neu-cta) !important;
  border: none !important;
}
.qf-newsletter .wp-block-heading,
.qf-newsletter h2,
.qf-newsletter h3 {
  color: #fff !important;
  font-size: 1.15rem !important;
  font-weight: 900 !important;
  margin-bottom: 8px !important;
}
.qf-newsletter p {
  color: rgba(255,255,255,.85) !important;
  font-size: .88rem !important;
  line-height: 1.55 !important;
  margin-bottom: 20px !important;
}
/* Bouton dans le CTA : blanc neumorphique */
.qf-newsletter .wp-block-button__link {
  background: #fff !important;
  color: var(--qf-orange) !important;
  font-weight: 700 !important;
  border-radius: 100px !important;
  box-shadow:
    0 0 12px 3px rgba(255,255,255,.25),
    0 0  4px 1px rgba(255,255,255,.15) !important;
  transition: box-shadow var(--t), transform var(--t) !important;
}
.qf-newsletter .wp-block-button__link:hover {
  box-shadow:
    0 0 20px 5px rgba(255,255,255,.35),
    0 0  6px 2px rgba(255,255,255,.20) !important;
  transform: translateY(-1px) !important;
}


/* ══════════════════════════════════════════════
   BOUTONS GLOBAUX — NEUMORPHISME ORANGE
   ══════════════════════════════════════════════ */

.wp-block-button__link.wp-element-button {
  font-family: 'Poppins', sans-serif !important;
  background: var(--qf-orange) !important;
  color: #fff !important;
  border-radius: 100px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  box-shadow: var(--neu-btn) !important;
  transition: background var(--t), box-shadow var(--t), transform var(--t) !important;
  border: none !important;
}
.wp-block-button__link.wp-element-button:hover {
  background: var(--qf-orange-dark) !important;
  box-shadow: var(--neu-btn-hover) !important;
  transform: translateY(-1px) !important;
}


/* ══════════════════════════════════════════════
   SIDEBAR POPULAIRES
   Classe  qf-populaires  sur le Query Loop
   ══════════════════════════════════════════════ */

.qf-populaires ul.wp-block-post-template {
  list-style: none !important;
  counter-reset: qf-top !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}
.qf-populaires li.wp-block-post {
  counter-increment: qf-top !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 10px 0 !important;
  border-bottom: .5px solid rgba(0,0,0,.07) !important;
}
.qf-populaires li.wp-block-post:last-child { border-bottom: none !important; }
.qf-populaires li.wp-block-post::before {
  content: counter(qf-top) !important;
  font-size: 1.1rem !important;
  font-weight: 900 !important;
  color: var(--qf-orange) !important;
  min-width: 20px !important;
  line-height: 1.2 !important;
  flex-shrink: 0 !important;
}
.qf-populaires .wp-block-post-title {
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  color: var(--qf-noir) !important;
}
.qf-populaires .wp-block-post-title a { color: var(--qf-noir) !important; }
.qf-populaires .wp-block-post-title a:hover { color: var(--qf-orange) !important; }


/* ══════════════════════════════════════════════
   CARTES CATÉGORIES
   Classe  qf-cat  sur chaque bloc Groupe
   ══════════════════════════════════════════════ */

.qf-cat {
  background: #fff !important;
  border-radius: var(--r) !important;
  border: .5px solid rgba(0,0,0,.07) !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: border-color var(--t), transform var(--t) !important;
}
.qf-cat:hover {
  border-color: var(--qf-orange) !important;
  transform: translateY(-2px) !important;
}
.qf-cat .wp-block-image img {
  width: 44px !important;
  height: 44px !important;
  margin: 0 auto !important;
}
.qf-cat .wp-block-heading {
  font-size: .85rem !important;
  font-weight: 700 !important;
  color: var(--qf-noir) !important;
  text-align: center !important;
  margin: 0 0 3px !important;
}
.qf-cat p {
  font-size: .68rem !important;
  color: var(--qf-gris) !important;
  text-align: center !important;
  margin: 0 !important;
}


/* ══════════════════════════════════════════════
   AGENDA / EVENTS — 4 CARTES
   Classe  qf-agenda  sur le Query Loop
   ══════════════════════════════════════════════ */

.qf-agenda ul.wp-block-post-template {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.qf-agenda ul.wp-block-post-template > li,
.qf-agenda ul.wp-block-post-template > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}

.qf-agenda li.wp-block-post {
  border-radius: var(--r) !important;
  overflow: hidden !important;
  background: #fff !important;
  border: .5px solid rgba(0,0,0,.06) !important;
  display: flex !important;
  flex-direction: column !important;
}

.qf-agenda .wp-block-post-featured-image img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  display: block !important;
}

/* Date en bandeau orange */
.qf-agenda .wp-block-post-date {
  background: var(--qf-orange) !important;
  color: #fff !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  padding: 7px 12px !important;
  margin: 0 !important;
  text-align: left !important;
}
.qf-agenda .wp-block-post-date time { color: #fff !important; }

.qf-agenda .taxonomy-category {
  margin: 0 !important;
  padding: 8px 10px 0 !important;
  text-align: left !important;
}

.qf-agenda .wp-block-post-title {
  font-size: .82rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  color: var(--qf-noir) !important;
  padding: 4px 10px 12px !important;
  margin: 0 !important;
}
.qf-agenda .wp-block-post-title a { color: var(--qf-noir) !important; }
.qf-agenda .wp-block-post-title a:hover { color: var(--qf-orange) !important; }

@media (min-width: 600px) {
  .qf-agenda ul.wp-block-post-template {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}



/* ══════════════════════════════════════════════
   MÉGA MENU — HEADER FIXE
   ══════════════════════════════════════════════ */

:root {
  --qf-menu-h:      4rem;
  --qf-menu-ease:   .38s cubic-bezier(.4,0,.2,1);
  --qf-menu-border: rgba(0,0,0,.07);
}


/* ── Header fixe ─────────────────────────────── */

header.wp-block-template-part {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  background: var(--qf-fond) !important;
  height: var(--qf-menu-h);
  border-bottom: .5px solid var(--qf-menu-border);
  box-shadow: none !important;
}

.wp-site-blocks > main {
  margin-top: var(--qf-menu-h) !important;
}

/* ── Wrapper externe — neutralise has-global-padding ── */

header.wp-block-template-part > .wp-block-group {
  height: var(--qf-menu-h) !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  box-sizing: border-box !important;
}

/* ── Conteneur flex interne — centré, contraint, 3 colonnes ──
   max-width = largeur du contenu WP (780px par défaut ici)
   padding latéral pour respiration
   ─────────────────────────────────────────────────────────── */

header.wp-block-template-part > .wp-block-group > .wp-block-group {
  width: 100% !important;
  max-width: calc(var(--wp--style--global--content-size) + 3rem) !important;
  margin: 0 auto !important;
  padding: 0 1.5rem !important;
  height: var(--qf-menu-h) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 0 !important;
  box-sizing: border-box !important;
}

/* ── Colonne gauche : hamburger + recherche ──────
   flex: 1 pour occuper l'espace disponible à gauche
   et pousser le logo au centre
   ─────────────────────────────────────────────── */

header.wp-block-template-part > .wp-block-group > .wp-block-group > .wp-block-group {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .5rem !important;
  padding: 0 !important;
  margin: 0 !important;
  height: auto !important;
}

/* ── Colonne centre : logo + ville ───────────────
   flex: 0 0 auto → prend juste sa largeur naturelle
   Le logo est donc centré entre les deux flex: 1
   ─────────────────────────────────────────────── */

.qf-logo-stack {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  line-height: 1;
  /* Pas de position absolute */
}

.qf-logo-lien {
  font-family: 'Poppins', sans-serif;
  font-weight: 900;
  font-size: 1.2rem;
  color: var(--qf-noir) !important;
  letter-spacing: .05em;
  text-transform: uppercase;
  text-decoration: none !important;
  line-height: 1;
  display: block;
  white-space: nowrap;
}

.qf-logo-accent {
  color: var(--qf-orange);
}

.qf-city-trigger {
  display: flex;
  align-items: center;
  gap: .25rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-top: .1rem;
  font-family: 'Poppins', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  color: var(--qf-gris);
  text-transform: uppercase;
  letter-spacing: .12em;
  line-height: 1;
  transition: color var(--t);
  user-select: none;
  white-space: nowrap;
}

.qf-city-trigger svg {
  flex-shrink: 0;
  transition: transform var(--qf-menu-ease), color var(--t);
}

.qf-city-trigger:hover,
.qf-city-trigger.qf-open {
  color: var(--qf-orange);
}

.qf-city-trigger.qf-open svg {
  transform: rotate(180deg);
}

/* ── Colonne droite : réseaux sociaux ────────────
   flex: 1 + justify-content: flex-end pour coller à droite
   ─────────────────────────────────────────────── */

header.wp-block-template-part .wp-block-social-links {
  flex: 1 !important;
  justify-content: flex-end !important;
  gap: .56rem !important;
  flex-shrink: 0;
  flex-wrap: nowrap !important;
}

header.wp-block-template-part .wp-block-social-links .wp-social-link {
  background: transparent !important;
  color: var(--qf-texte) !important;
  transition: color var(--t) !important;
  padding: 0 !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
}

header.wp-block-template-part .wp-block-social-links .wp-social-link:hover {
  color: var(--qf-orange) !important;
  background: transparent !important;
}

header.wp-block-template-part .wp-block-social-links .wp-social-link svg {
  width: 1.0625rem !important;
  height: 1.0625rem !important;
  fill: currentColor !important;
}


/* ── Hamburger ───────────────────────────────── */

.wp-block-navigation__responsive-container-open {
  display: flex !important;
  flex-direction: column;
  gap: .32rem;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  cursor: pointer;
  padding: .375rem;
  width: auto !important;
  height: auto !important;
  flex-shrink: 0;
}

.wp-block-navigation__responsive-container-open svg {
  display: none !important;
}

.wp-block-navigation__responsive-container-open::before,
.wp-block-navigation__responsive-container-open .qf-line,
.wp-block-navigation__responsive-container-open::after {
  content: '';
  display: block;
  width: 1.375rem;
  height: .125rem;
  background: var(--qf-noir);
  border-radius: .0625rem;
  transition: transform var(--qf-menu-ease), opacity var(--qf-menu-ease);
}

body.qf-menu-open .wp-block-navigation__responsive-container-open::before {
  transform: translateY(calc(.32rem + .125rem)) rotate(45deg);
}

body.qf-menu-open .wp-block-navigation__responsive-container-open .qf-line {
  opacity: 0;
}

body.qf-menu-open .wp-block-navigation__responsive-container-open::after {
  transform: translateY(calc(-1 * (.32rem + .125rem))) rotate(-45deg);
}

.wp-block-navigation__responsive-container.is-menu-open,
.wp-block-navigation__responsive-container-close {
  display: none !important;
}


/* ── Bouton recherche ────────────────────────── */

#qf-search-toggle,
button#qf-search-toggle,
header #qf-search-toggle,
.wp-site-blocks header #qf-search-toggle {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  padding: .25rem;
  color: var(--qf-noir) !important;
  transition: color var(--t);
  flex-shrink: 0;
}

#qf-search-toggle:hover {
  color: var(--qf-orange) !important;
}

#qf-search-toggle svg,
header #qf-search-toggle svg,
.wp-site-blocks header #qf-search-toggle svg {
  display: block !important;
  width: 1.125rem !important;
  height: 1.125rem !important;
  stroke: var(--qf-noir) !important;
  fill: none !important;
  transition: stroke var(--t);
}

#qf-search-toggle:hover svg {
  stroke: var(--qf-orange) !important;
}


/* ── Panel villes — pleine largeur ───────────── */

#qf-city-panel {
  position: fixed;
  top: var(--qf-menu-h);
  left: 0; right: 0;
  background: var(--qf-fond);
  border-bottom: .5px solid var(--qf-menu-border);
  z-index: 9998;
  max-height: 0;
  visibility: hidden;
  overflow: hidden;
  transition: max-height var(--qf-menu-ease), visibility var(--qf-menu-ease);
}

#qf-city-panel.qf-open {
  max-height: calc(var(--qf-menu-h) + .5px);
  visibility: visible;
}

.qf-city-panel-inner {
  display: flex;
  align-items: center;
  max-width: calc(var(--wp--style--global--content-size) + 3rem);
  margin: 0 auto;
  padding: 0 1.5rem;
  height: var(--qf-menu-h);
  box-sizing: border-box;
}

.qf-city-list {
  display: flex;
  align-items: center;
  gap: .125rem;
  flex-wrap: wrap;
}

.qf-city-list a {
  font-family: 'Poppins', sans-serif;
  font-size: .75rem;
  font-weight: 600;
  color: var(--qf-gris);
  text-decoration: none !important;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: .375rem 1rem;
  border-bottom: 2px solid transparent;
  transition: color var(--t), border-color var(--t);
  white-space: nowrap;
}

.qf-city-list a:hover {
  color: var(--qf-noir);
  border-bottom-color: var(--qf-orange);
}

.qf-city-list a.qf-current {
  color: var(--qf-orange);
  border-bottom-color: var(--qf-orange);
}


/* ── Overlay recherche ───────────────────────── */

#qf-search-overlay {
  position: fixed;
  top: var(--qf-menu-h);
  left: 0; right: 0;
  background: var(--qf-fond);
  border-bottom: .5px solid var(--qf-menu-border);
  z-index: 9997;
  max-height: 0;
  visibility: hidden;
  overflow: hidden;
  transition: max-height var(--qf-menu-ease), visibility var(--qf-menu-ease);
}

#qf-search-overlay.qf-open {
  max-height: calc(var(--qf-menu-h) + .5px);
  visibility: visible;
}

.qf-search-inner {
  display: flex;
  align-items: center;
  gap: .875rem;
  max-width: calc(var(--wp--style--global--content-size) + 3rem);
  margin: 0 auto;
  padding: 0 1.5rem;
  height: var(--qf-menu-h);
  box-sizing: border-box;
}

.qf-search-inner > svg {
  flex-shrink: 0;
  stroke: #ccc;
}

.qf-search-inner input {
  flex: 1;
  border: none !important;
  outline: none !important;
  background: none !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--qf-noir) !important;
}

.qf-search-inner input::placeholder {
  color: #ddd;
}

.qf-search-close {
  background: none;
  border: none;
  font-size: 1.125rem;
  color: #bbb;
  cursor: pointer;
  padding: .25rem .5rem;
  line-height: 1;
  transition: color var(--t);
}

.qf-search-close:hover {
  color: var(--qf-noir);
}


/* ── Méga menu ───────────────────────────────── */

#qf-mega {
  position: fixed;
  top: var(--qf-menu-h);
  left: 0; right: 0;
  background: var(--qf-fond);
  border-bottom: .5px solid var(--qf-menu-border);
  z-index: 9996;
  max-height: 0;
  visibility: hidden;
  overflow: hidden;
  transition: max-height var(--qf-menu-ease), visibility var(--qf-menu-ease);
}

#qf-mega.qf-open {
  max-height: 26rem;
  visibility: visible;
}

.qf-mega-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: calc(26rem - 1px);
  max-width: calc(var(--wp--style--global--content-size) + 3rem);
  margin: 0 auto;
  padding: 0 1.5rem;
  box-sizing: border-box;
}

.qf-mega-cats {
  padding: 1.75rem 2rem 1.75rem 0;
  border-right: .5px solid var(--qf-menu-border);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.qf-mega-cats a {
  display: block;
  font-family: 'Poppins', sans-serif !important;
  font-size: clamp(2.25rem, 5.2vw, 3.25rem);
  font-weight: 900;
  color: rgba(0,0,0,.07);
  text-decoration: none !important;
  text-transform: uppercase;
  letter-spacing: -.02em;
  line-height: 1.12;
  transition: color var(--t);
}

.qf-mega-cats a:hover,
.qf-mega-cats a.qf-cat-active {
  color: var(--qf-orange);
}

.qf-preview-pane {
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none !important;
}

.qf-preview-pane img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity .2s ease, transform .35s ease;
}

.qf-preview-pane.qf-fading img {
  opacity: 0;
  transform: scale(1.03);
}

.qf-preview-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.08) 55%, transparent 100%);
  transition: opacity .2s ease;
}

.qf-preview-text {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 1.375rem 1.625rem;
  transition: opacity .2s ease;
}

.qf-preview-pane.qf-fading .qf-preview-gradient,
.qf-preview-pane.qf-fading .qf-preview-text {
  opacity: 0;
}

.qf-preview-label {
  font-size: .5625rem;
  font-weight: 700;
  color: var(--qf-orange);
  text-transform: uppercase;
  letter-spacing: .16em;
  margin-bottom: .4375rem;
}

.qf-preview-title {
  font-size: 1.125rem;
  font-weight: 900;
  color: #fff;
  line-height: 1.3;
}

.qf-preview-date {
  font-size: .6875rem;
  color: rgba(255,255,255,.5);
  margin-top: .3125rem;
}


/* ── Overlay sombre ──────────────────────────── */

#qf-overlay {
  position: fixed;
  top: var(--qf-menu-h);
  left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,.25);
  z-index: 9995;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--qf-menu-ease);
}

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

body.qf-menu-open {
  overflow: hidden;
}


/* ── Mobile ──────────────────────────────────── */

@media (max-width: 768px) {

  .qf-mega-inner {
    grid-template-columns: 1fr;
    height: auto;
    max-width: 100%;
    padding: 0;
  }

  .qf-preview-pane {
    height: 13.75rem;
  }

  .qf-mega-cats {
    padding: 1.25rem 1.5rem;
  }

  .qf-mega-cats a {
    font-size: 2.25rem;
  }

  #qf-mega.qf-open {
    max-height: 80vh;
    overflow-y: auto;
  }

  #qf-city-panel.qf-open {
    max-height: 8rem;
  }

  .qf-city-panel-inner {
    flex-direction: column;
    align-items: flex-start;
    height: auto;
    padding: .875rem 1.5rem;
    gap: .5rem;
    max-width: 100%;
  }

}