/*
Theme Name: FeuForme FSE
Author: Julien
Description: CSS consolidée — menu desktop / mobile séparés proprement
Version: 0.7
*/

/* =========================================================
   COUCHE 0 — RESET LOCAL (ANTI-FSE / ANTI-IMPLICITE)
   ========================================================= */

.menu-panel,
.menu-panel__nav,
.menu-panel__link {
  margin: 0;
  padding: 0;
}

.menu-panel__nav {
  list-style: none;
}

/* =========================================================
   COUCHE 1 — HEADER & ÉLÉMENTS GÉNÉRAUX
   ========================================================= */

.site-top-row {
  position: relative;
}

.site-top-row .header-branding {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.site-top-row .header-text > * {
  margin: 0;
  line-height: 1.15;
}

.site-top-row .header-icon img {
  display: block;
  transform: translateY(1px);
}

/* =========================================================
   COUCHE 2 — LAYOUT
   ========================================================= */
      
/*--- Pagination */
.wp-block-query-pagination {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 2rem;
}

.wp-block-query-pagination a,
.wp-block-query-pagination-numbers .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin: 0 2px;
  font-size: 15px;
  text-decoration: none;
  color: #2a4861;
  background: #ededef;
  border: 1px solid #d0d0d0;
}

.wp-block-query-pagination-numbers .page-numbers.current {
  color: #ffffff;
  background: #2a4861;
  border-color: #2a4861;
}

.wp-block-query-pagination a:hover,
.wp-block-query-pagination a:focus-visible {
  background: #e0e0e2;
  text-decoration: underline;
  text-underline-offset: 0.25em;
}

.wp-block-query-pagination-previous.is-disabled,
.wp-block-query-pagination-next.is-disabled {
  opacity: 0.4;
  pointer-events: none;
}

/*--- listes sur page 404 */
.error-404-links a {
  text-decoration: none;
}

.error-404-links a:hover,
.error-404-links a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.25em;
}

ul.wp-block-latest-posts.error-404-links {
  list-style: disc;
  padding-left: 1.2rem;
}

/*--- Formatage bouton commentaire */
.wp-block-post-comments-form .wp-block-button__link {
  border-radius: 0 !important; /* supprime l’ovale core WP */
  padding: var(--wp--preset--spacing--30) !important;
}

:root :where(
  .wp-element-button:hover,
  .wp-block-button__link:hover,
  .wp-block-read-more:hover
) {
  background-color: #5d7b94 !important;
}

/*--- Home — hover titres articles */
body.home .wp-block-post-title a:hover {
  color: #5d7b94;
}

/*--- CSS legendes featured images */
.single-featured-caption {
    margin-top: 0.5rem;
    text-align: center;
    font-style: italic;
    font-size: 0.95em;
    color: #555;
}

.single-featured-caption a {
    text-decoration: none;
}

.single-featured-caption a{
  opacity: 0.75;
  transition: opacity 160ms ease;
}

.single-featured-caption a:hover{
  opacity: 1;
}

/* Lien footer : hover + alignement */
footer.wp-block-group {
  isolation: isolate;
}

footer .has-small-font-size a {
  text-decoration: none;
}

footer .has-small-font-size a:hover {
  color: rgba(255,255,255,0.5);
  text-decoration: underline;
}



/* =========================================================
   COUCHE 3 — CATEGORIES
   ========================================================= */

/* Bloc racine : neutre */
.sidebar .wp-block-categories {
    margin: 0;
    padding: 0;
}

/* Liste = conteneur de layout */
.sidebar .wp-block-categories-list {
    display: flex;
    flex-wrap: wrap;

    /* Alignement strict avec Bienvenue */
    margin: 0;
    padding: 0;

    /* Espacement ENTRE boutons */
    gap: 0.4em;

    list-style: none;
}

/* Items = neutres */
.sidebar .wp-block-categories-list .cat-item {
    margin: 0;
    padding: 0;
}

/* Bouton catégorie */
.sidebar .wp-block-categories-list .cat-item a {
    display: inline-flex;
    align-items: center;

    padding: var(--wp--preset--spacing--30);

    line-height: 1.2;
    text-decoration: none;
    border-radius: 0;

    background-color: var(--wp--preset--color--feu-forme-blue);
    color: var(--wp--preset--color--white);

    font-size: var(--wp--preset--font-size--small);
}

/* Hover harmonisé */
.sidebar .wp-block-categories-list .cat-item a:hover {
    background-color: #5d7b94;
}

/* Cacher "Non classé" */
.sidebar .wp-block-categories-list .cat-item-1 {
    display: none;
}


/* Ajustement grid*/
.wp-block-post-template.is-layout-grid {
    display: grid;
    grid-template-columns: 1fr;
}

/*--- Maximum de 2 colonnes */
.wp-block-post-template.is-layout-grid:has(> li:nth-child(4)) {
    grid-template-columns: repeat(2, minmax(260px, 1fr));
}

/* =========================================================
   COUCHE 4 — INVARIANTS MENU (TOUS DEVICES)
   ========================================================= */
   
/*--- Ajustements menu */
.menu-panel {
  display: block;
  background: none;
}

.menu-panel__nav {
  display: flex;
}

.menu-panel__link {
  font-size: 1rem;
  color: #ffffff;
}

.menu-panel__link a {
  text-decoration: none;
}

.menu-panel__link a:hover {
  color: rgba(255, 255, 255, 0.5);
  }

.menu-panel a.is-active {
  text-decoration: underline;
  text-underline-offset: 0.25em;
}

/* =========================================================
   COUCHE 5 — MENU DESKTOP
   ========================================================= */

.menu-panel--desktop {
  display: block;
}

.menu-panel--desktop .menu-panel__nav {
  flex-direction: row;
  align-items: center;
  gap: 1.5rem;
}

.menu-panel--desktop .menu-panel__link {
  padding: 0.5rem 0;
}

/* =========================================================
   COUCHE 6 — MENU MOBILE
   ========================================================= */

/*--- caché par défaut */
header .menu-panel--mobile {
  display: none;
}

.menu-toggle__label {
    display: none;
}

/*--- ouverture JS */
header .menu-panel--mobile.is-open {
  display: block;
}

/*--- NAV mobile : neutralisation stricte du layout FSE */
header .menu-panel--mobile .menu-panel__nav.is-layout-flex {
  flex-direction: column;
  align-items: stretch !important;
  gap: 0 !important;
}

/*--- Surface plein largeur */
header .menu-panel--mobile,
header .menu-panel--mobile .menu-panel--surface {
  width: 100%;
}

/*--- Panel injecté par le template-part */
header .menu-panel--mobile .menu-panel {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  background: none;
}

/*--- Navigation verticale sans gap parasite */
header .menu-panel--mobile .menu-panel__nav {
  display: flex;
  flex-direction: column;
  align-items: stretch;

  width: 100%;
  gap: 0;
  padding: 0;
  margin: 0;
}

/*--- Items = bandes pleine largeur */
header .menu-panel--mobile .menu-panel__link {
  width: 100%;
  height: 3.25rem;
  margin: 0;

  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
}

/*--- Surface décorée */
header .menu-panel--mobile .menu-panel--surface {
  background-color: #2a4861;
  border-top: 1px solid #ffffff;
  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
  box-sizing: border-box;
}

header .menu-panel--mobile .menu-panel__link:last-child {
  border-bottom: 0;
}

/*--- Zone cliquable */
header .menu-panel--mobile .menu-panel__link > a {
  display: flex;
  align-items: center;

  width: 100%;
  height: 100%;
  padding: 0 var(--wp--preset--spacing--30);
  white-space: nowrap;
}

/* =========================================================
   COUCHE 7 — FEEDBACK VISUEL
   ========================================================= */

header .menu-panel--mobile .menu-panel__link {
  position: relative;
  overflow: hidden;
}

/*--- couche lumineuse */
header .menu-panel--mobile .menu-panel__link::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.06);
  opacity: 0;
  pointer-events: none;
  transition: opacity 80ms ease-out;
  z-index: 0;
}

/*--- contenu */
header .menu-panel--mobile .menu-panel__link > a {
  position: relative;
  z-index: 1;
}

/*--- liseré pointillé */
header .menu-panel--mobile .menu-panel__link::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px dashed rgba(255, 255, 255, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 80ms ease-out;
  z-index: 2;
}

/*--- activation */
header .menu-panel--mobile .menu-panel__link:hover::before,
header .menu-panel--mobile .menu-panel__link:focus-within::before,
header .menu-panel--mobile .menu-panel__link:active::before {
  opacity: 1;
}

header .menu-panel--mobile .menu-panel__link:hover::after,
header .menu-panel--mobile .menu-panel__link:focus-within::after,
header .menu-panel--mobile .menu-panel__link:active::after {
  opacity: 1;
}

/* =========================================================
   COUCHE 8 — MENU TOGGLE
   ========================================================= */

.menu-toggle__button {
  display: none;
  background: none;
  border: none;
  color: #ffffff;
  cursor: pointer;
}

.menu-toggle__icon svg {
  width: 30px;
  height: 20px;
  display: block;
}

.menu-toggle__icon line {
  stroke: currentColor;
  stroke-width: 3;
  stroke-linecap: round;
  transition: transform 0.2s ease, opacity 0.2s ease;
  transform-origin: center;
}

.menu-toggle__button[aria-expanded="true"] .menu-toggle__icon line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

.menu-toggle__button[aria-expanded="true"] .menu-toggle__icon line:nth-child(2) {
  opacity: 0;
}

.menu-toggle__button[aria-expanded="true"] .menu-toggle__icon line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

/* =========================================================
   COUCHE 9 — RESPONSIVE (ACTIVATION SEULEMENT)
   ========================================================= */

@media (max-width: 1280px) {

  /*--- Neutralisation banniere */
  header .header-banner {
   display: none;
   }
   
  /*--- Neutralisation des spacers Gutenberg (tablettes / Kindle) */
  .wp-site-blocks {
    --wp--preset--spacing--70: 0px !important;
  }

  /*--- Ajustement padding externe contenu */
   main > .wp-block-group, main > .wp-block-columns {
    padding-top: var(--wp--preset--spacing--50) !important;
    padding-left: var(--wp--preset--spacing--50) !important;
    padding-right: var(--wp--preset--spacing--50) !important;
  } 

  /*--- Gap entre contenu principal et sidebar */
  .wp-block-columns[class*="wp-container-core-columns-is-layout-"]{
    gap: var(--fef-columns-gap, var(--wp--preset--spacing--50)) !important;
  }

  /*--- Gap entre colonnes d'articles */
  .wp-block-post-template[class*="wp-container-core-post-template-is-layout-"]{
    gap: var(--fef-post-grid-gap, var(--wp--preset--spacing--50)) !important;
  }

  /*--- Gap entre bloc de sidebar */
  .sidebar > * {
    margin-block-start: 0;
  }
  
  .sidebar > * + * {
    margin-block-start: var(--wp--preset--spacing--50);
  }

   /*--- Contrôle du gap en fin de sidebar */
  main > .wp-block-columns {
    padding-bottom: var(--wp--preset--spacing--50) !important;
  } 
}

@media (min-width: 1025px) and (max-width: 1080px) {

  /* réduire le gap image / titre dans la sidebar */
  main
  > .wp-block-columns
  > .wp-block-column:last-child
  .wp-block-group.is-layout-flex {
    gap: var(--wp--preset--spacing--30);
  }

  /* réduire légèrement la taille des titres sidebar */
  main
  > .wp-block-columns.is-layout-flex
  > .wp-block-column:last-child
  .wp-block-post-title {
    font-size: calc(var(--wp--preset--font-size--medium) - 2px) !important;
    line-height: 1.4;
  }
}


/* Colonnes empilées sur tablettes */
@media (max-width: 1024px) {
  .wp-block-columns {
    flex-direction: column !important;
  }

  .wp-block-columns > .wp-block-column {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: auto !important;
  }
}

/* Neutraliser définitivement la logique flex de Columns */
@media (min-width: 783px) {  
  body.search .wp-block-post-template .wp-block-columns {
    display: grid !important;
    grid-template-columns: 200px 1fr;
    column-gap: var(--wp--preset--spacing--50);
    align-items: center;
  }

  body.search .wp-block-post-template .wp-block-column {
    flex: none !important;
    width: auto !important;
  }
}

@media (max-width: 782px) {

  /* desktop OFF */
  header .menu-panel--desktop {
    display: none;
  }

  /* toggle ON */
  header .menu-toggle__button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
  }

  /* mobile visible quand ouvert */
  header .menu-panel--mobile {
    background-color: #2a4861;
  }
  
  .menu-toggle__label {
    display: inline;
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.02em;
    padding-left: 0.5rem;
  }  
   
   /*--- Ajustement padding externe contenu */
   main > .wp-block-group, main > .wp-block-columns {
    padding-top: var(--wp--preset--spacing--40) !important;
    padding-left: var(--wp--preset--spacing--40) !important;
    padding-right: var(--wp--preset--spacing--40) !important;
  } 

  /*--- Gap entre colonnes d'articles */
  .wp-block-post-template[class*="wp-container-core-post-template-is-layout-"]{
    gap: var(--fef-post-grid-gap, var(--wp--preset--spacing--40)) !important;
  }
    
  /*--- Gap entre bloc de sidebar */
  .sidebar > * {
    margin-block-start: 0;
  }

  .sidebar > * + * {
    margin-block-start: var(--wp--preset--spacing--40);
  }

   /* Contrôle du gap en fin de sidebar */
  main > .wp-block-columns {
    padding-bottom: var(--wp--preset--spacing--40) !important;
  }
  
  main .wp-block-column:last-child > .wp-block-group {
     margin-bottom: var(--wp--preset--spacing--40);
  }

  main .wp-block-column:last-child > .wp-block-group:last-child {
    margin-bottom: 0;
  }  

  /*--- Formatage résultats de recherche*/
  body.search .wp-block-post-template .wp-block-post-featured-image {
    width: 100% !important;
    height: auto !important;
  }

  body.search .wp-block-post-template .wp-block-post-featured-image > a {
    height: auto !important;
    display: block;
  }

  body.search .wp-block-post-template .wp-block-post-featured-image img {
    width: 100%;
    height: auto !important;
    aspect-ratio: 3 / 2;
    object-fit: cover;
  }
}

@media (max-width: 428px) {
  header .wp-block-site-tagline {
    max-width: 22ch;
    white-space: normal;
  }
  .menu-toggle__label {
    display: none;
  }
}

@media (max-width: 384px) {

  /* réduire le gap image / titre dans la sidebar */
  main
  > .wp-block-columns
  > .wp-block-column:last-child
  .wp-block-group.is-layout-flex {
    gap: var(--wp--preset--spacing--30);
  }

  /* réduire légèrement la taille des titres sidebar */
  main
  > .wp-block-columns.is-layout-flex
  > .wp-block-column:last-child
  .wp-block-post-title {
    font-size: calc(var(--wp--preset--font-size--medium) - 2px) !important;
    line-height: 1.4;
  }
}

@media (max-width: 375px) {
  header .wp-block-site-title {
    font-size: 20px !important;
  }

  header .wp-block-site-tagline {
    font-size: 13px !important;
  }
}
