/*
Theme Name: Comprendre et aider son enfant
Description: Thème enfant GeneratePress — pilier parentalité. Direction « cahier d'observation » : trame de cahier, marge corail, souligné crayon, Fraunces en display.
Template: generatepress
Version: 2.1.0
*/

/* ===== Fonte display (self-hostée, latin, variable 600-700) ===== */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 600 700;
  font-display: swap;
  src: url(fonts/fraunces-latin.woff2) format('woff2');
}

/* ===== Tokens ===== */
:root {
  --papier: #fdf8f0;         /* papier chaud (réchauffé 07-03, demande Jim) */
  --encre: #2b3a55;          /* encre d'écolier */
  --encre-pale: #6b7891;
  --corail: #e4644b;         /* le crayon */
  --corail-fonce: #c44a33;
  --verteau: #7fb5a4;        /* vert d'eau */
  --verteau-pale: #eaf4f0;
  --craie: #f7d488;          /* jaune craie */
  --ligne: #e9e4da;          /* réglure du cahier */
  --display: 'Fraunces', Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  /* réglure de cahier réutilisable */
  --reglure: repeating-linear-gradient(to bottom, transparent 0, transparent 31px, rgba(43, 58, 85, 0.07) 31px, rgba(43, 58, 85, 0.07) 32px);
  /* souligné crayon (SVG inline) */
  --crayon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='7' viewBox='0 0 120 7'%3E%3Cpath d='M2 5 Q 15 1.5 30 4 T 60 4 T 90 4 T 118 3' fill='none' stroke='%23e4644b' stroke-width='2.4' stroke-linecap='round'/%3E%3C/svg%3E");
}

body {
  background-color: var(--papier);
  color: var(--encre);
  font-family: var(--sans);
  font-size: 17.5px;
  line-height: 1.75;
}

h1, h2, h3, h4, .entry-title, .main-title {
  font-family: var(--display);
  font-weight: 650;
  color: var(--encre);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

a { color: var(--corail-fonce); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--corail); }
a:focus-visible, button:focus-visible { outline: 2px solid var(--corail); outline-offset: 2px; }

/* ===== Header : bord de cahier ===== */
.site-header {
  background-color: var(--papier);
  border-bottom: 1px solid var(--ligne);
  position: relative;
}
/* la marge du cahier : filet corail vertical à gauche, sur toute la page */
body::before {
  content: "";
  position: fixed;
  top: 0; bottom: 0; left: 26px;
  width: 1.5px;
  background: rgba(228, 100, 75, 0.35);
  pointer-events: none;
  z-index: 5;
}
/* la marge du cahier disparaît sur mobile (parasite en petit écran) */
@media (max-width: 768px) { body::before { display: none; } }

.main-title { font-weight: 700; }
.main-title a { color: var(--encre); font-size: 1.35em; text-decoration: none; }
.site-description { color: var(--encre-pale); font-size: 0.9em; }

/* logo (pictogramme) à côté du titre */
.site-header .inside-header {
  display: flex;
  align-items: center;
  gap: 18px;
}
.site-logo { flex: 0 0 auto; }
.site-logo img { height: 58px; width: auto; display: block; }
@media (max-width: 768px) {
  .site-header .inside-header { gap: 12px; }
  .site-logo img { height: 44px; }
}

.main-navigation { background-color: transparent; }
.main-navigation .main-nav ul li a {
  color: var(--encre);
  font-weight: 600;
  font-size: 0.95em;
  padding-left: 0;
  padding-right: 0;
  margin: 0 16px;
  background-color: transparent;
  transition: color 0.15s ease;
}
.main-navigation .main-nav ul li:first-child a { margin-left: 0; }
/* neutralise les pavés sombres GP (hover/actif) → souligné crayon à la place.
   GP utilise li:not([class*="current-menu-"]):hover → il faut répliquer sa forme exacte. */
body .main-navigation .main-nav ul li:not([class*="current-menu-"]):hover > a,
body .main-navigation .main-nav ul li:not([class*="current-menu-"]):focus > a,
body .main-navigation .main-nav ul li.sfHover:not([class*="current-menu-"]) > a,
body .main-navigation .main-nav ul li[class*="current-menu-"] > a {
  background-color: transparent;
  color: var(--corail-fonce);
}
/* sous-menus déroulants : fond blanc, encre */
body .main-navigation .main-nav ul ul li:not([class*="current-menu-"]):hover > a,
body .main-navigation .main-nav ul ul li:not([class*="current-menu-"]):focus > a,
body .main-navigation .main-nav ul ul li.sfHover:not([class*="current-menu-"]) > a,
body .main-navigation .main-nav ul ul li[class*="current-menu-"] > a {
  background-color: var(--verteau-pale);
  color: var(--encre);
}
.main-navigation .main-nav ul li[class*="current-menu-"] > a {
  background-image: var(--crayon);
  background-repeat: no-repeat;
  background-position: bottom 14px center;
  background-size: 100% 5px;
}
.main-navigation ul ul { background: #fff; border: 1px solid var(--ligne); }
.main-navigation ul ul li a { margin: 0; padding-left: 16px; padding-right: 16px; }
/* menu mobile : toggle visible sur fond papier */
.main-navigation .menu-toggle,
.main-navigation .menu-toggle:hover,
.main-navigation .menu-toggle:focus,
.main-navigation.toggled .menu-toggle {
  background: transparent;
  color: var(--encre);
}
.main-navigation.toggled .main-nav ul { background: #fff; border: 1px solid var(--ligne); }
@media (max-width: 768px) {
  /* header une ligne : titre + logo à gauche, burger à droite, tagline masquée */
  .site-description { display: none; }
  .site-header .main-title a, .main-title a { font-size: 17px !important; }
  .main-title { white-space: nowrap; }
  .site-header .inside-header {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    text-align: left;
    padding: 14px 56px 14px 16px; /* place réservée au burger à droite */
    gap: 8px;
  }
  .site-branding { text-align: left; }
  .site-logo img { height: 30px; }
  #page { position: relative; }
  .main-navigation, .main-navigation .inside-navigation { position: static; } /* le burger s'ancre sur #page */
  .main-navigation .menu-toggle {
    position: absolute;
    top: 10px;
    right: 6px;
    width: auto;
    padding: 12px;
    font-weight: 700;
  }
  .menu-toggle .mobile-menu { display: none; }
  /* liste dépliée : vraies rangées cliquables */
  .main-navigation.toggled .main-nav ul {
    border-radius: 12px;
    margin: 0 12px 14px;
    overflow: hidden;
  }
  .main-navigation .main-nav ul li a {
    margin: 0;
    padding: 13px 18px;
  }
  .main-navigation .main-nav ul li + li { border-top: 1px solid var(--ligne); }
  /* item actif : filet corail à gauche (le souligné crayon rend mal en liste) */
  .main-navigation .main-nav ul li[class*="current-menu-"] > a {
    background-image: none;
    box-shadow: inset 3px 0 0 var(--corail);
  }
}

/* ===== Hero « page de cahier » (front page, via hook) ===== */
.hero-cahier {
  background-color: var(--papier);
  background-image: var(--reglure);
  border-bottom: 1px solid var(--ligne);
}
.hero-cahier .hero-inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 56px 40px 60px 64px;
  display: flex;
  align-items: center;
  gap: 48px;
}
.hero-cahier .hero-texte { flex: 1 1 auto; }
.hero-cahier .hero-kicker {
  font-size: 0.8em;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--verteau);
  margin-bottom: 10px;
}
.hero-cahier h1 {
  font-size: clamp(1.7em, 4vw, 2.6em);
  margin: 0 0 0.4em;
}
.hero-cahier h1 .souligne {
  background: var(--crayon) no-repeat bottom left / 100% 7px;
  padding-bottom: 8px;
}
.hero-cahier .hero-sub { color: var(--encre-pale); max-width: 34em; margin-bottom: 1.4em; }
.hero-cahier .hero-photo {
  flex: 0 0 auto;
  width: 210px; height: 210px;
  border-radius: 50%;
  object-fit: cover;
  border: 5px solid #fff;
  box-shadow: 0 0 0 1.5px var(--ligne), 0 10px 28px rgba(43, 58, 85, 0.14);
}
.hero-cahier .hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.bouton-corail, .bouton-ligne {
  display: inline-block;
  font-weight: 700;
  padding: 12px 24px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.95em;
}
.bouton-corail { background: var(--corail); color: #fff; }
.bouton-corail:hover { background: var(--corail-fonce); color: #fff; }
.bouton-ligne { border: 1.5px solid var(--encre); color: var(--encre); }
.bouton-ligne:hover { border-color: var(--corail-fonce); color: var(--corail-fonce); }
@media (max-width: 768px) {
  .hero-cahier .hero-inner { flex-direction: column-reverse; text-align: center; padding: 36px 22px 40px; gap: 22px; }
  .hero-cahier .hero-photo { width: 140px; height: 140px; }
  .hero-cahier .hero-actions { justify-content: center; }
  .hero-cahier .hero-sub { margin-left: auto; margin-right: auto; }
}

/* ===== Contenu ===== */
.site-content { padding-top: 34px; }
.inside-article {
  background: #fff;
  border: 1px solid var(--ligne);
  border-radius: 12px;
  padding: 42px 46px;
}
@media (max-width: 768px) { .inside-article { padding: 24px 18px; } }

.entry-title { font-size: 1.55em; }
.entry-title a { color: var(--encre); text-decoration: none; }
.entry-title a:hover { color: var(--corail-fonce); }
.entry-meta { color: var(--encre-pale); font-size: 0.8em; }

/* ===== Cartes d'articles (home + archives) — grille 2 colonnes ===== */
.blog .site-main, .archive .site-main, .search .site-main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items: stretch;
}
.blog .site-main > *, .archive .site-main > * { min-width: 0; }
.blog .site-main > .paging-navigation, .archive .site-main > .paging-navigation,
.blog .site-main > nav, .archive .site-main > nav { grid-column: 1 / -1; }
@media (max-width: 768px) { .blog .site-main, .archive .site-main, .search .site-main { grid-template-columns: 1fr; } }
.blog article, .archive article { margin-bottom: 0; display: flex; }
.blog .inside-article, .archive .inside-article, .search .inside-article {
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: 26px 30px 24px;
  transition: border-color 0.15s ease;
}
.blog footer.entry-meta, .archive footer.entry-meta { margin-top: auto; padding-top: 14px; }
/* image à la une : bandeau recadré, jamais pleine hauteur */
.blog .post-image, .archive .post-image { margin: 0 0 18px; }
.blog .post-image img, .archive .post-image img,
.blog img.wp-post-image, .archive img.wp-post-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 10px;
  display: block;
}
/* article seul : bannière raisonnable au-dessus du texte */
.single .post-image { margin: 0 0 26px; }
.single .post-image img, .single img.wp-post-image {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}
.blog .inside-article:hover, .archive .inside-article:hover { border-color: var(--verteau); }
.blog .entry-title, .archive .entry-title { font-size: 1.22em; margin-bottom: 2px; }
.blog .entry-header, .archive .entry-header, .blog .entry-summary, .archive .entry-summary { max-width: none; margin: 0; }
/* méta discrète sous le titre, espacée de l'image qui suit */
.blog .entry-meta, .archive .entry-meta {
  font-size: 0.62em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
}
/* footer de carte : catégorie en pastille, icônes et lien commentaire masqués */
.entry-summary + .entry-meta, footer.entry-meta { margin-top: 14px; }
.entry-meta .gp-icon, .entry-meta .comments-link { display: none; }
footer.entry-meta .cat-links a {
  display: inline-block;
  background: var(--verteau-pale);
  color: var(--encre);
  font-size: 0.95em;
  font-weight: 600;
  text-decoration: none;
  padding: 3px 12px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}
footer.entry-meta .cat-links a:hover { background: var(--craie); }
/* lien lire la suite */
.lire-suite { margin: 12px 0 0; }
.lire-suite a {
  font-weight: 700;
  font-size: 0.9em;
  text-decoration: none;
  color: var(--corail-fonce);
}
.lire-suite a:hover { text-decoration: underline; text-underline-offset: 4px; }

/* ===== Portrait flottant (page À propos) ===== */
.portrait-flottant {
  float: right;
  width: 240px;
  margin: 4px 0 16px 26px;
}
.portrait-flottant img { width: 100%; height: auto; border-radius: 12px; box-shadow: 0 6px 20px rgba(43, 58, 85, 0.12); }
@media (max-width: 600px) {
  .portrait-flottant { float: none; width: 200px; margin: 0 auto 18px; display: block; }
}

.entry-content { max-width: 45em; margin-left: auto; margin-right: auto; }
.entry-header { max-width: 45em; margin-left: auto; margin-right: auto; }

/* h2 d'article : souligné crayon */
.entry-content h2 {
  margin-top: 1.7em;
  display: inline-block;
  background: var(--crayon) no-repeat bottom left / 100% 6px;
  padding-bottom: 10px;
}
.entry-content h3 { margin-top: 1.3em; }

blockquote {
  border-left: 3px solid var(--verteau);
  background: var(--verteau-pale);
  border-radius: 0 10px 10px 0;
  padding: 14px 20px;
  font-style: normal;
}

/* Bloc « En bref » — réponse directe en tête d'article (GEO/snippet) */
.en-bref {
  background: var(--verteau-pale);
  border-left: 5px solid var(--verteau);
  border-radius: 0 12px 12px 0;
  padding: 18px 24px;
  margin: 0 0 1.8em;
}
.en-bref .en-bref-label {
  display: block;
  font-family: var(--display);
  font-weight: 700;
  font-size: 0.85em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--verteau);
  margin-bottom: 6px;
}
.en-bref p { margin: 0; }

/* Encadré « À retenir » : le post-it du cahier */
.a-retenir {
  background: #fdf3d7;
  border: 1px solid var(--craie);
  border-radius: 4px 14px 4px 14px;
  padding: 20px 24px;
  margin: 1.6em 0;
  box-shadow: 2px 3px 0 rgba(43, 58, 85, 0.06);
}
.a-retenir > :first-child { margin-top: 0; }
.a-retenir > :last-child { margin-bottom: 0; }

/* Encart capture email */
.encart-newsletter {
  background: var(--verteau-pale);
  background-image: var(--reglure);
  border: 1.5px solid var(--verteau);
  border-radius: 14px;
  padding: 28px 30px;
  margin: 2em 0 1em;
  text-align: center;
}
.encart-newsletter h3, .encart-newsletter h4 { margin-top: 0; }
.encart-newsletter .button, .encart-newsletter input[type="submit"] { background: var(--corail); color: #fff; border-radius: 999px; font-weight: 700; }

.button, button, input[type="submit"] { background: var(--corail); color: #fff; border-radius: 999px; }
.button:hover, button:hover, input[type="submit"]:hover { background: var(--corail-fonce); color: #fff; }

/* ===== Cartes d'offre (page accompagnement) ===== */
.offre-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin: 1.6em 0;
}
@media (max-width: 900px) { .offre-grid { grid-template-columns: 1fr; } }
.offre-card {
  background: #fff;
  border: 1.5px solid var(--ligne);
  border-radius: 14px;
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  position: relative;
}
.offre-card.mise-en-avant { border-color: var(--verteau); background: var(--verteau-pale); }
.offre-badge {
  position: absolute;
  top: -12px; left: 22px;
  background: var(--verteau);
  color: #fff;
  font-size: 0.72em;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 999px;
}
.offre-card h3 { margin: 0 0 4px; font-size: 1.15em; }
.offre-duree { color: var(--encre-pale); font-size: 0.85em; margin: 0 0 12px; }
.offre-prix {
  font-family: var(--display);
  font-size: 1.9em;
  font-weight: 700;
  line-height: 1.15;
  color: var(--corail-fonce);
  margin: 0 0 2px;
}
.offre-prix small { display: block; font-size: 0.45em; font-weight: 600; color: var(--encre-pale); margin-top: 3px; }
.offre-card ul { padding-left: 1.1em; margin: 12px 0 18px; font-size: 0.93em; }
.offre-card ul li { margin-bottom: 6px; }
.offre-card .bouton-corail, .offre-card .bouton-ligne { margin-top: auto; text-align: center; }
.offre-note { font-size: 0.85em; color: var(--encre-pale); }

/* Étapes numérotées (déroulé de l'accompagnement) */
.entry-content ol.etapes-offre { counter-reset: etape; list-style: none; padding-left: 0; }
.entry-content ol.etapes-offre > li {
  counter-increment: etape;
  position: relative;
  padding-left: 54px;
  margin-bottom: 1.1em;
}
.entry-content ol.etapes-offre > li::before {
  content: counter(etape);
  position: absolute;
  left: 0; top: -3px;
  width: 38px; height: 38px;
  background: var(--corail);
  color: #fff;
  font-family: var(--display);
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ===== Section « Par où commencer ? » (accueil) ===== */
.univers { max-width: 1120px; margin: 40px auto 20px; padding: 0 20px; }
/* dans la grille d'articles, la section édito et le bandeau auteur prennent toute la largeur */
.site-main > .univers, .site-main > .author-hero { grid-column: 1 / -1; }
/* on masque la boîte auteur par défaut de GP (doublon avec notre bandeau) */
.author .page-header { display: none; }
.univers-titre {
  display: inline-block;
  background: var(--crayon) no-repeat bottom left / 100% 6px;
  padding-bottom: 10px;
  font-size: 1.6em;
}
.univers-intro { color: var(--encre-pale); max-width: 42em; }
.univers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin: 22px 0;
}
@media (max-width: 900px) { .univers-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .univers-grid { grid-template-columns: 1fr; } }
.univers-carte {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--ligne);
  border-radius: 12px;
  padding: 20px 22px;
  text-decoration: none;
  color: var(--encre);
  transition: border-color 0.15s ease;
}
.univers-carte:hover { border-color: var(--verteau); color: var(--encre); }
.univers-carte h3 { margin: 0 0 8px; font-size: 1.05em; }
.univers-carte p { margin: 0 0 12px; font-size: 0.86em; color: var(--encre-pale); line-height: 1.6; }
.univers-carte .univers-lien { margin-top: auto; font-weight: 700; font-size: 0.85em; color: var(--corail-fonce); }
.univers-rassure {
  background: var(--verteau-pale);
  border-radius: 12px;
  padding: 16px 22px;
  font-size: 0.95em;
}
.univers-rassure p { margin: 0; }

/* ===== Bandeau page auteur ===== */
.author-hero {
  display: flex;
  gap: 24px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--ligne);
  border-radius: 14px;
  padding: 26px 30px;
  margin: 0 0 26px;
}
.author-hero img { width: 130px; height: 130px; border-radius: 50%; object-fit: cover; border: 4px solid var(--craie); flex-shrink: 0; }
.author-hero h1 { margin: 0 0 2px; font-size: 1.5em; }
.author-hero-role { color: var(--verteau); font-weight: 700; font-size: 0.82em; text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 10px; }
.author-hero p { margin: 0; font-size: 0.95em; }
@media (max-width: 600px) { .author-hero { flex-direction: column; text-align: center; } }

/* Author box */
.author-box {
  display: flex;
  gap: 18px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--ligne);
  border-radius: 12px;
  padding: 18px 22px;
  margin-top: 2em;
}
.author-box img { border-radius: 50%; width: 72px; height: 72px; object-fit: cover; border: 3px solid var(--craie); flex-shrink: 0; }
.author-box p { margin: 0; font-size: 0.9em; color: var(--encre-pale); }
.author-box strong { color: var(--encre); }

.entry-content img { border-radius: 10px; max-width: 100%; height: auto; }
.entry-content .is-style-rounded img { border-radius: 50%; }

/* ===== Formulaire de contact ===== */
.form-contact { max-width: 34em; }
.form-contact label { display: block; font-weight: 700; margin-bottom: 6px; font-size: 0.92em; }
.form-contact input[type="text"], .form-contact input[type="email"], .form-contact textarea {
  width: 100%;
  background: #fff;
  border: 1.5px solid var(--ligne);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: var(--sans);
  font-size: 0.95em;
  color: var(--encre);
}
.form-contact input:focus, .form-contact textarea:focus {
  outline: none;
  border-color: var(--verteau);
  box-shadow: 0 0 0 3px var(--verteau-pale);
}
.form-contact .hp-field { position: absolute; left: -9999px; top: -9999px; }
.form-succes { background: var(--verteau-pale); border: 1.5px solid var(--verteau); border-radius: 12px; padding: 16px 22px; margin-bottom: 1.2em; }
.form-erreur { background: #fdf0ee; border: 1.5px solid var(--corail); border-radius: 12px; padding: 16px 22px; margin-bottom: 1.2em; }
.form-succes p, .form-erreur p { margin: 0; }

/* ===== Footer ===== */
.site-footer { background-color: transparent; }
.site-info {
  background-color: transparent;
  color: var(--encre-pale);
  font-size: 0.85em;
  border-top: 1px solid var(--ligne);
  padding-top: 18px;
}
.site-info a { color: var(--encre-pale); }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}
