/* ============================================================
   Douce vie de famille — feuille de style partagée
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Caveat:wght@500;600;700&family=Oswald:wght@500;600;700&display=swap');

:root{
  /* Palette tirée du logo */
  --sage:        #7e9150;   /* vert sauge principal */
  --sage-deep:   #5f6e3a;   /* vert profond (texte titres) */
  --sage-soft:   #a7b67e;   /* vert clair */
  --sage-wash:   #eef1e3;   /* fond vert très pâle */

  --pink:        #f4c9d6;   /* rose poudré */
  --pink-soft:   #fce4ea;   /* rose très pâle (rayures) */
  --pink-deep:   #e79bb0;   /* rose accent */

  --cream:       #fffbf6;   /* blanc crème de fond */
  --cream-2:     #fdf5ee;   /* crème un peu plus chaud */
  --ink:         #4a4a40;   /* texte courant, brun-vert doux */
  --ink-soft:    #7c7b6f;   /* texte secondaire */
  --line:        #ece5da;   /* filets / bordures */

  --shadow:      0 18px 40px -24px rgba(95,110,58,.35);
  --shadow-sm:   0 8px 22px -16px rgba(95,110,58,.4);

  --radius:      22px;
  --radius-lg:   34px;
  --maxw:        1180px;

  --serif: 'Lora', Georgia, 'Times New Roman', serif;
  --script: 'Caveat', cursive;
  --condensed: 'Oswald', 'Arial Narrow', sans-serif;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--serif);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{ font-family:var(--serif); color:var(--sage-deep); line-height:1.12; margin:0; font-weight:600; }
p{ margin:0 0 1em; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }

/* ---------- petites rayures roses signature ---------- */
.stripes{
  background-image:repeating-linear-gradient(
    90deg, var(--pink-soft) 0 26px, transparent 26px 52px);
}

/* eyebrow / sur-titre manuscrit */
.script{
  font-family:var(--script);
  color:var(--sage);
  font-size:1.7rem;
  font-weight:600;
  line-height:1;
}
.eyebrow{
  font-family:var(--condensed);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.78rem;
  font-weight:600;
  color:var(--sage);
}

/* ============================================================
   En-tête / navigation
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,251,246,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; gap:28px;
  max-width:var(--maxw); margin:0 auto; padding:14px 32px;
}
.brand{ display:flex; align-items:center; gap:13px; margin-right:auto; }
.brand img{ width:46px; height:46px; border-radius:50%; object-fit:cover;
  border:2px solid var(--pink); box-shadow:var(--shadow-sm); }
.brand-name{ display:flex; flex-direction:column; line-height:.95; white-space:nowrap; }
.brand-name .b1{ font-family:var(--condensed); font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; color:var(--sage-deep); font-size:1.06rem; }
.brand-name .b2{ font-family:var(--script); color:var(--sage); font-size:1.25rem; margin-top:-2px; }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-size:.95rem; color:var(--ink); padding:8px 14px; border-radius:999px;
  transition:background .2s, color .2s;
}
.nav-links a:hover{ background:var(--sage-wash); color:var(--sage-deep); }
.nav-links a.active{ color:var(--sage-deep); font-weight:600; }
.nav-links a.active::after{
  content:""; display:block; height:3px; width:60%; margin:3px auto 0;
  background:var(--pink-deep); border-radius:3px;
}

/* boutons */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--serif); font-weight:600; font-size:1rem;
  padding:13px 26px; border-radius:999px; cursor:pointer; border:0;
  transition:transform .15s, box-shadow .2s, background .2s;
  text-align:center;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--sage); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--sage-deep); }
.btn-pink{ background:var(--pink-deep); color:#fff; box-shadow:var(--shadow-sm); }
.btn-pink:hover{ background:#d77f97; }
.btn-ghost{ background:transparent; color:var(--sage-deep); border:1.5px solid var(--sage-soft); }
.btn-ghost:hover{ background:var(--sage-wash); }
.btn-sm{ padding:9px 18px; font-size:.9rem; }

/* ============================================================
   Sections génériques
   ============================================================ */
section{ position:relative; }
.section{ padding:84px 0; }
.section-head{ max-width:680px; margin:0 0 46px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size:2.6rem; margin:.18em 0 .35em; }
.section-head p{ color:var(--ink-soft); font-size:1.12rem; }

/* placeholder illustration */
.illus{
  position:relative; border-radius:var(--radius);
  background:
    repeating-linear-gradient(45deg, var(--sage-wash) 0 12px, #fff 12px 24px);
  border:1.5px dashed var(--sage-soft);
  display:flex; align-items:center; justify-content:center; text-align:center;
  color:var(--sage-deep); min-height:200px; overflow:hidden;
}
.illus .tag{
  font-family:'Courier New', monospace; font-size:.74rem; letter-spacing:.04em;
  background:rgba(255,251,246,.9); padding:7px 12px; border-radius:8px;
  border:1px solid var(--sage-soft); max-width:80%;
}

/* cartes */
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .25s;
  display:flex; flex-direction:column;
}
a.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.card .body{ padding:22px 24px 26px; }
.card h3{ font-size:1.32rem; margin-bottom:.4em; }
.card p{ color:var(--ink-soft); font-size:.98rem; margin-bottom:0; }
.chip{
  display:inline-block; font-family:var(--condensed); text-transform:uppercase;
  letter-spacing:.12em; font-size:.68rem; font-weight:600;
  color:var(--sage-deep); background:var(--sage-wash);
  padding:5px 11px; border-radius:999px;
}
.chip.pink{ color:#b65b75; background:var(--pink-soft); }

/* coeur signature */
.heart{ color:var(--pink-deep); }

/* ============================================================
   Pied de page
   ============================================================ */
.site-footer{
  background:var(--sage-deep); color:#eef1e3; margin-top:0;
}
.site-footer .wrap{ padding-top:64px; padding-bottom:40px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.4fr; gap:40px; }
.site-footer h4{ color:#fff; font-size:1.05rem; margin-bottom:1em;
  font-family:var(--condensed); text-transform:uppercase; letter-spacing:.12em; font-weight:600; }
.site-footer a{ color:#d7dec3; display:block; padding:4px 0; font-size:.96rem; }
.site-footer a:hover{ color:#fff; }
.foot-brand .script{ color:var(--pink); }
.foot-brand p{ color:#c4cdab; font-size:.96rem; }
.foot-mini-form{ display:flex; gap:8px; margin-top:12px; }
.foot-mini-form input{ flex:1; min-width:0; padding:11px 14px; border-radius:999px;
  border:1px solid #6f7e48; background:#697a43; color:#fff; font-family:var(--serif); }
.foot-mini-form input::placeholder{ color:#c4cdab; }
.foot-bottom{ border-top:1px solid #6f7e48; margin-top:48px; padding-top:24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:.86rem; color:#c4cdab; }

/* ============================================================
   Bandeau newsletter réutilisable
   ============================================================ */
.news-band{
  background:linear-gradient(180deg, var(--pink-soft), #fff);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.news-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:54px 56px; text-align:center;
  max-width:760px; margin:0 auto; position:relative;
}
.news-card h2{ font-size:2.3rem; margin-bottom:.3em; }
.news-card p{ color:var(--ink-soft); max-width:520px; margin:0 auto 1.6em; }
.subscribe{ display:flex; gap:10px; max-width:480px; margin:0 auto; }
.subscribe input{ flex:1; min-width:0; padding:14px 20px; border-radius:999px;
  border:1.5px solid var(--line); font-family:var(--serif); font-size:1rem; background:var(--cream); }
.subscribe input:focus{ outline:none; border-color:var(--sage-soft); }

/* ============================================================
   Hero (accueil)
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:54px;
  align-items:center; padding:78px 0 90px; }
.hero h1{ font-size:3.7rem; letter-spacing:-.01em; margin:.2em 0 .4em; }
.hero h1 em{ font-style:normal; color:var(--sage); }
.hero p.lead{ font-size:1.22rem; color:var(--ink-soft); max-width:520px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.hero-figure{ position:relative; }
.hero-figure .logo-frame{
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow);
  border:6px solid #fff; rotate:1.5deg;
}
.hero-badge{
  position:absolute; bottom:-22px; left:-22px; background:#fff;
  border-radius:18px; padding:14px 18px; box-shadow:var(--shadow); rotate:-3deg;
  display:flex; align-items:center; gap:10px; border:1px solid var(--line);
}
.hero-badge .script{ font-size:1.5rem; }

/* grilles */
.grid{ display:grid; gap:26px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }

/* piliers (liens vers sections) */
.pillar{ position:relative; padding:30px 26px; border-radius:var(--radius);
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm);
  transition:transform .2s, box-shadow .25s; display:block; }
.pillar:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.pillar .num{ font-family:var(--condensed); font-weight:700; font-size:1rem;
  color:var(--pink-deep); }
.pillar h3{ font-size:1.45rem; margin:.3em 0 .35em; }
.pillar p{ color:var(--ink-soft); font-size:.97rem; margin:0; }
.pillar .arrow{ margin-top:16px; color:var(--sage); font-weight:600; font-size:.95rem; }

/* bandeau page (titre de page intérieure) */
.page-hero{ padding:70px 0 18px; text-align:center; }
.page-hero h1{ font-size:3rem; margin:.15em 0 .3em; }
.page-hero p{ color:var(--ink-soft); font-size:1.15rem; max-width:620px; margin:0 auto; }

/* liste de ressources / produits */
.product{ display:flex; flex-direction:column; }
.product .illus{ min-height:190px; border-radius:0; border:0;
  border-bottom:1px solid var(--line); }
.product .body{ padding:20px 22px 24px; flex:1; display:flex; flex-direction:column; }
.product .price{ font-family:var(--condensed); font-weight:600; color:var(--sage-deep);
  letter-spacing:.04em; }
.product .btn{ margin-top:auto; }
.aff-note{ font-size:.82rem; color:var(--ink-soft); font-style:italic; }

/* étapes / âges */
.age-tabs{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:40px; }
.age-tabs .chip{ cursor:pointer; padding:9px 18px; font-size:.8rem; border:1px solid var(--line); background:#fff; }
.age-tabs .chip.on{ background:var(--sage); color:#fff; border-color:var(--sage); }

/* À propos */
.about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:54px; align-items:center; }
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:14px; }
.value{ text-align:center; padding:24px 16px; border-radius:var(--radius);
  background:var(--sage-wash); }
.value .dot{ width:42px; height:42px; border-radius:50%; margin:0 auto 12px;
  background:var(--pink); display:flex; align-items:center; justify-content:center; font-size:1.2rem; }
.value h4{ color:var(--sage-deep); font-family:var(--serif); font-size:1.05rem; margin-bottom:.3em; }
.value p{ font-size:.9rem; color:var(--ink-soft); margin:0; }

/* divers */
.center{ text-align:center; }
.mt-40{ margin-top:40px; }
.tag-row{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-inner{ grid-template-columns:1fr; gap:40px; }
  .hero h1{ font-size:2.9rem; }
  .about-grid{ grid-template-columns:1fr; gap:34px; }
  .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .nav-links{ display:none; }
  .values{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  body{ font-size:17px; }
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .news-card{ padding:38px 26px; }
  .subscribe{ flex-direction:column; }
  .section{ padding:60px 0; }
  .hero h1{ font-size:2.4rem; }
  .foot-grid{ grid-template-columns:1fr; }
}
