/*
Theme Name: Twenty Twenty-Four Child - Clair et pratique
Template: twentytwentyfour
Version: 1.0
*/

/* =========================================================
   Clair et pratique — Style “Guide papier” (Option A)
   Final CSS (nettoyé + cohérent)
========================================================= */

/* === Debug (décommente au besoin) === */
/* .test-css { outline: 4px solid red !important; } */

:root{
  --cp-radius: 16px;
  --cp-radius-pill: 999px;
  --cp-shadow: 0 10px 22px rgba(30,41,51,.08);
  --cp-shadow-hover: 0 14px 30px rgba(30,41,51,.12);
}

/* ---------- Base / fond / texte ---------- */
.wp-site-blocks{
  background: var(--wp--preset--color--cp-paper);
  color: var(--wp--preset--color--cp-ink);
}

body{
  font-family: var(--wp--preset--font-family--cp-sans);
  line-height: 1.65;
}

/* Titres : serif éditorial */
h1, h2, h3{
  font-family: var(--wp--preset--font-family--cp-serif);
  letter-spacing: -0.02em;
  margin-top: 0;
}
h1{ font-size: clamp(2.4rem, 4.2vw, 3.5rem); line-height: 1.05; }
h2{ font-size: clamp(1.7rem, 2.6vw, 2.3rem); line-height: 1.15; }
h3{ font-size: 1.25rem; line-height: 1.2; }

/* Liens */
a{
  color: var(--wp--preset--color--cp-petrol);
  text-underline-offset: 0.18em;
}
a:hover{ text-decoration-thickness: 2px; }

/* ---------- Largeur globale (si cp-page utilisé) ---------- */
.cp-page{
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ---------- Sections ---------- */
.cp-section{
  padding: clamp(56px, 7vw, 96px) 0;
}

/* Ligne fine “guide papier” sous les titres de section */
.cp-section > h2,
.cp-section h2{
  padding-bottom: 12px;
  border-bottom: 1px solid var(--wp--preset--color--cp-line);
  margin-bottom: 28px;
}

/* Renforcer la première section (Besoins fréquents) */
.cp-section:first-of-type h2{
  font-size: clamp(2.1rem, 3.2vw, 2.7rem);
}
.cp-section:first-of-type{
  padding-bottom: 110px;
}

/* ---------- HERO (couverture) ---------- */
/* IMPORTANT : on force le style sur le conteneur cp-hero même s'il est imbriqué */
.wp-site-blocks .cp-hero{
  padding: clamp(56px, 7vw, 96px) 0;
  background: linear-gradient(180deg, #EFE9DD 0%, #F8F5EF 100%);
  border-bottom: 2px solid var(--wp--preset--color--cp-line);
  margin-bottom: 10px;
}

/* Encadrer le bloc texte du hero (si présent) */
.wp-site-blocks .cp-hero .wp-block-group:first-child{
  background: #F0ECE3;
  padding: 28px;
  border-radius: var(--cp-radius);
  border: 1px solid var(--wp--preset--color--cp-line);
}

/* Recherche dans le hero */
.wp-site-blocks .cp-hero .wp-block-search__input{
  border-radius: var(--cp-radius-pill);
  padding: 14px 16px;
  border: 1px solid var(--wp--preset--color--cp-line);
  background: #fff;
}
.wp-site-blocks .cp-hero .wp-block-search__button{
  border-radius: var(--cp-radius-pill);
  background: var(--wp--preset--color--cp-petrol);
  color: #fff;
  border: none;
}
.wp-site-blocks .cp-hero .wp-block-search__button:hover{
  filter: brightness(0.95);
}

/* ---------- Cartes (encarts guide) ---------- */
.wp-site-blocks .cp-card{
  background: #fff;
  border: 1px solid var(--wp--preset--color--cp-line);
  border-radius: var(--cp-radius);
  padding: 22px;
  box-shadow: var(--cp-shadow);
  height: 100%;
  transition: transform .16s ease, box-shadow .16s ease;
}
.wp-site-blocks .cp-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--cp-shadow-hover);
}
.wp-site-blocks .cp-card h3{
  margin: 0;
  word-break: normal;
  hyphens: none;
}

/* ---------- Colonnes : respiration + anti-compression ---------- */
.wp-site-blocks .wp-block-columns{
  gap: clamp(16px, 2.4vw, 28px);
}
.wp-site-blocks .wp-block-column{
  min-width: 240px;
}

/* ---------- Boutons (cohérence) ---------- */
.wp-site-blocks .wp-element-button,
.wp-site-blocks .wp-block-button__link{
  background: var(--wp--preset--color--cp-petrol);
  color: #fff;
  border: none;
  border-radius: var(--cp-radius-pill);
  padding: 10px 14px;
}
.wp-site-blocks .wp-element-button:hover,
.wp-site-blocks .wp-block-button__link:hover{
  filter: brightness(0.95);
}

/* Option : bouton secondaire */
.wp-site-blocks .is-style-outline .wp-block-button__link{
  background: transparent;
  color: var(--wp--preset--color--cp-petrol);
  border: 1px solid var(--wp--preset--color--cp-line);
}

/* ---------- Encadré “info” (pages services/locales) ---------- */
.cp-info{
  background: #fff;
  border: 1px solid var(--wp--preset--color--cp-line);
  border-radius: var(--cp-radius);
  padding: 18px 20px;
  box-shadow: var(--cp-shadow);
}
.cp-info strong{
  display: inline-block;
  margin-right: 6px;
}

/* ---------- Header / Footer (cadre éditorial) ---------- */
.cp-header{
  border-bottom: 1px solid var(--wp--preset--color--cp-line);
  padding: 14px 0;
}
.cp-footer{
  border-top: 1px solid var(--wp--preset--color--cp-line);
  padding: 28px 0;
  margin-top: 40px;
}

/* ---------- Ajustements finaux ---------- */
.wp-site-blocks img{ border-radius: 8px; }

/* Petit confort : éviter un gros vide au tout début si applicable */
.cp-section:first-child h2{ margin-top: 0; }



/* Affiner la hauteur du hero */
.wp-site-blocks .cp-hero{
  padding: clamp(40px, 5.5vw, 72px) 0;
}
/* Alléger l’encart texte du hero */
.wp-site-blocks .cp-hero .wp-block-group:first-child{
  padding: 22px;
}


/* Ligne fine au-dessus aussi (effet page de guide) */
.wp-site-blocks .cp-hero::before{
  border-top: 1px solid var(--wp--preset--color--cp-line);
}
/* Texture très subtile pour papier (optionnel) */
.wp-site-blocks .cp-hero::before{
  background:
    radial-gradient(1200px 400px at 20% 0%, rgba(255,255,255,.45), transparent 55%),
    linear-gradient(180deg, #EFE9DD 0%, #F8F5EF 100%);
}


/* HERO – plus d’impact visuel */
.wp-site-blocks .cp-hero{
  padding: clamp(64px, 8vw, 120px) 0;
}

.wp-site-blocks .cp-hero h1{
  max-width: 14ch;
}

.wp-site-blocks .cp-hero p{
  max-width: 38ch;
}
/* Section Besoins fréquents – plus de structure */
.cp-section.besoins-frequents{
  padding-top: clamp(72px, 9vw, 120px);
}

.cp-section.besoins-frequents h2{
  margin-bottom: 36px;
}
/* Footer – fin de page assumée */
.cp-footer{
  font-size: 0.9rem;
  background: #F4F1EA;
}

.cp-footer h3{
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* =========================================================
   Pages internes — sections plus compactes
========================================================= */

.cp-section--compact{
  padding: clamp(28px, 4vw, 48px) 0;
}

/* Titres de sections internes */
.cp-section--compact > h2,
.cp-section--compact h2{
  margin-bottom: 18px;
  padding-bottom: 8px;
}

/* Réduire l’espace au-dessus des blocs suivants */
.cp-section--compact + .cp-section--compact{
  padding-top: 0;
}

/* =========================================================
   Rythme vertical global — réduire les espaces Gutenberg
========================================================= */

/* Réduit l'espacement entre blocs dans le contenu */
.wp-site-blocks,
.entry-content,
.wp-block-group,
.wp-block-columns{
  gap: clamp(12px, 1.6vw, 18px) !important;
}

/* Réduit les marges verticales par défaut des blocs courants */
.entry-content > *{
  margin-block-start: 0.75rem !important;
  margin-block-end: 0.75rem !important;
}

/* Titres : moins d'espace au-dessus */
.entry-content h2{ margin-top: 1.2rem !important; }
.entry-content h3{ margin-top: 1rem !important; }

/* Paragraphes/lists : un peu plus serrés */
.entry-content p,
.entry-content ul,
.entry-content ol{
  margin-block: 0.6rem !important;
}


/* Pages internes : sections moins hautes */
body:not(.home) .cp-section{
  padding: clamp(28px, 4vw, 52px) 0 !important;
}
/* Évite les paddings énormes ajoutés sur des groupes */
.wp-block-group{
  padding-top: min(var(--wp--style--block-gap, 20px), 20px) !important;
  padding-bottom: min(var(--wp--style--block-gap, 20px), 20px) !important;
}
/* Resserre le lien titre → contenu */
.entry-content h2 + *{
  margin-top: 0.5rem !important;
}

.entry-content ul,
.entry-content ol{
  padding-left: 1.2rem;
}

.entry-content li{
  margin-bottom: 0.35rem;
}

.entry-content > section:last-of-type,
.entry-content > .wp-block-group:last-of-type{
  margin-bottom: 2rem !important;
}

