/* ============================================================
   Tiré à Part — système de design du prototype
   Source unique pour toutes les pages (accueil, approche, offre, contact)
   et pour le brand book. Concept : « épreuve d'imprimeur ».
   Voir cahier-design.md. Polices web de substitution
   (Archivo + Cormorant Garamond italique) ; à remplacer par les
   polices de marque retenues.
   ============================================================ */

:root{
  --cream:#F4EFE3; --paper:#EAE3D2; --ink:#1A1A1A; --terra:#B8503D;
  --espresso:#14110D; --muted:#6B6256; --line:#C9BDA6; --terra-on-dark:#E0937A; --terre:#43291D;
  --f-disp:"Archivo",system-ui,sans-serif; --f-acc:"Cormorant Garamond",Georgia,serif;
}
*{box-sizing:border-box}
html{overflow-x:hidden}
body{
  margin:0; font-family:var(--f-disp); color:var(--ink); font-size:17px; line-height:1.55;
  overflow-x:hidden;
  background:
    repeating-linear-gradient(90deg, rgba(96,78,52,.10) 0 92px, rgba(96,78,52,0) 92px 184px),
    var(--cream);
}
a{color:inherit; text-decoration:none}
.wrap{max-width:1280px; margin:0 auto; padding:0 56px}
/* La « page » : feuille crème posée sur les bandes ; marges hautes/basses pour l'effet livre */
.page{position:relative; max-width:1280px; margin:46px auto 34px; padding:18px 60px 48px; background:var(--cream); border:1px solid var(--line); box-shadow:0 3px 30px rgba(20,17,13,.08)}
/* Repères d'impression dans les marges : 4 traits de coupe (angles) + 4 mires (milieu des bords) */
.marks{position:absolute; inset:0; pointer-events:none}
/* Traits de coupe : deux traits décalés vers l'extérieur, avec un écart (fond perdu) */
.marks .crop{position:absolute; width:0; height:0}
.marks .crop::before, .marks .crop::after{content:""; position:absolute; background:var(--muted)}
.marks .crop::before{width:16px; height:1px}
.marks .crop::after{width:1px; height:16px}
.marks .crop.tl{top:0; left:0}
.marks .crop.tl::before{left:-22px; top:0}
.marks .crop.tl::after{left:0; top:-22px}
.marks .crop.tr{top:0; right:0}
.marks .crop.tr::before{right:-22px; top:0}
.marks .crop.tr::after{right:0; top:-22px}
.marks .crop.bl{bottom:0; left:0}
.marks .crop.bl::before{left:-22px; bottom:0}
.marks .crop.bl::after{left:0; bottom:-22px}
.marks .crop.br{bottom:0; right:0}
.marks .crop.br::before{right:-22px; bottom:0}
.marks .crop.br::after{right:0; bottom:-22px}
/* Mire de repérage : cercle + croix qui dépasse (cible/fleur) */
.marks .reg{position:absolute; width:13px; height:13px; border:1px solid var(--muted); border-radius:50%}
.marks .reg::before, .marks .reg::after{content:""; position:absolute; background:var(--muted)}
.marks .reg::before{left:50%; top:-6px; width:1px; height:25px; transform:translateX(-50%)}
.marks .reg::after{top:50%; left:-6px; height:1px; width:25px; transform:translateY(-50%)}
.marks .reg.t{top:-26px; left:50%; transform:translateX(-50%)}
.marks .reg.b{bottom:-26px; left:50%; transform:translateX(-50%)}
.marks .reg.l{left:-27px; top:50%; transform:translateY(-50%)}
.marks .reg.r{right:-27px; top:50%; transform:translateY(-50%)}
/* Copyright en pied */
.copyright{text-align:center; padding:8px 0 28px; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.label{font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--terra); font-weight:600}
.muted{color:var(--muted)} .ink{color:var(--ink)}
.acc{font-family:var(--f-acc); font-style:italic; color:var(--terra); font-weight:600}

/* ── Bandeau charte ── */
.topbar{position:sticky; top:0; z-index:50; background:var(--cream); display:flex; align-items:center; gap:18px; padding:9px 22px; border-bottom:1px solid var(--line); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}
.topbar .cross{color:var(--terra)}
.topbar .epreuve{white-space:nowrap}
.colorbar{display:flex; flex:1; height:7px; min-width:120px}
.colorbar span{flex:1}
.brandmark{font-weight:900; font-size:16px; letter-spacing:.01em; text-transform:none; color:var(--ink); white-space:nowrap}
.brandmark .acc{font-family:var(--f-acc); font-style:italic; font-weight:600; color:var(--terra); padding:0 1px}
.brandmark .dot{color:var(--terra)}
.tagline{text-transform:none; font-family:var(--f-acc); font-style:italic; font-size:15px; color:var(--muted); white-space:nowrap}
/* Sous-titres de section en terracotta (pas en gris) */
.section .runhead > span:first-child, .sommaire .runhead > span:first-child{color:var(--terra); font-weight:600}
/* Bandeau d'appel : contenu réparti, pas de vide à droite */
.cta-band{display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap}
.cta-band > div{flex:1; min-width:280px}
.cta-band .lead{font-family:var(--f-acc); font-style:italic; font-size:22px; margin:6px 0 0}
/* Fondu d'apparition de la page au chargement (léger). Sans JS / reduced-motion : visible. */
html.fade .page{opacity:0; transform:translateY(8px)}
html.fade.ready .page{opacity:1; transform:none; transition:opacity .55s ease, transform .55s ease}
@media (prefers-reduced-motion: reduce){ html.fade .page{opacity:1; transform:none} }
/* Formulaire de contact */
.contact-form{max-width:640px}
.radios{display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:4px}
.radios label{display:flex; gap:8px; align-items:center; font-size:15px; color:var(--ink); text-transform:none; letter-spacing:0; font-weight:400}
nav.main{display:flex; gap:18px; white-space:nowrap}
nav.main b{color:var(--terra); margin-right:4px}
nav.main a.is-active{color:var(--ink); font-weight:600}
/* Menu burger (mobile/tablette) — masqué par défaut, sans JS */
.burger{display:none; flex-direction:column; justify-content:center; gap:5px; width:30px; height:30px; margin-left:auto; padding:4px; cursor:pointer}
.burger span{display:block; height:2px; width:22px; background:var(--ink); transition:transform .2s, opacity .2s}
.nav-toggle:checked ~ .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle:checked ~ .burger span:nth-child(2){opacity:0}
.nav-toggle:checked ~ .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Folio / section labels ── */
.runhead{display:flex; align-items:center; gap:16px; padding:26px 0 8px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted)}
.runhead .ln{flex:1; height:1px; background:var(--line)}

/* ── Hero ── */
.hero{display:grid; grid-template-columns:1.1fr .9fr; gap:56px; padding:18px 0 40px; align-items:start}
.logotype{line-height:.86}
.logotype .g{display:block; font-weight:900; font-size:clamp(72px,11vw,156px); letter-spacing:-.02em}
.logotype .p{display:block; margin-top:-.26em; margin-left:.5em; font-family:var(--f-acc); font-style:italic; font-weight:600; color:var(--terra); font-size:clamp(80px,12vw,168px)}
.logotype .dot{color:var(--terra)}
.hd{font-weight:800; font-size:clamp(30px,3.4vw,46px); line-height:1.05; letter-spacing:-.01em; margin:6px 0 18px}
.lead-p{color:#2c2620; max-width:46ch}
.tag{font-family:var(--f-acc); font-style:italic; font-size:21px; color:var(--ink); margin:20px 0 22px}
.btns{display:flex; gap:14px; flex-wrap:wrap}
.btn{display:inline-block; padding:14px 26px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; border:1.5px solid var(--ink)}
.btn.fill{background:var(--ink); color:var(--cream)}
.btn.fill:hover{background:var(--terra); border-color:var(--terra)}
.btn.ghost:hover{background:var(--ink); color:var(--cream)}

/* ── Bandeau méta ── */
.meta{display:grid; grid-template-columns:repeat(4,1fr); gap:28px; border-top:1px solid var(--line); padding:26px 0 8px}
.meta h4{margin:0 0 8px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:600}
.meta .v{font-weight:800; font-size:15px; line-height:1.4} .meta .s{color:var(--muted); font-family:var(--f-disp); font-weight:600; font-size:14px}
.badge{display:inline-flex; align-items:baseline; gap:10px; margin-top:18px; padding:7px 14px; border:1.5px solid var(--terra); color:var(--terra); font-size:12px; letter-spacing:.16em; text-transform:uppercase}
.badge b{font-size:20px; font-weight:800; letter-spacing:0; color:var(--ink)}

/* ── Titre de chapitre (grand chiffre romain + titre) ── */
.chapter{display:grid; grid-template-columns:auto 1fr; gap:34px; align-items:stretch; padding:14px 0 6px}
.chapter .rn{font-weight:900; font-size:clamp(165px,20vw,250px); line-height:.6; color:var(--line); letter-spacing:-.04em; align-self:stretch; display:flex; align-items:flex-start; margin-top:.2em}
.chapter h1{font-weight:900; font-size:clamp(40px,6vw,84px); letter-spacing:-.02em; margin:0}
.chapter .sub{font-family:var(--f-acc); font-style:italic; font-size:22px; color:var(--muted); max-width:52ch; margin:14px 0 0}

/* ── Bloc de texte éditorial ── */
.prose{max-width:62ch}
.prose h3{font-weight:800; font-size:26px; letter-spacing:-.01em; margin:34px 0 10px}
.prose p{margin:0 0 14px; color:#2c2620; text-align:justify; hyphens:auto}
.lede{font-size:20px; line-height:1.5; text-align:left}

/* Texte en deux colonnes (effet livre) */
.prose.two{max-width:none; column-count:2; column-gap:54px}
.prose.two h3{margin-top:0; break-inside:avoid; break-after:avoid}
.prose.two h3 + p, .prose.two p{break-inside:avoid}
.steps.two{column-count:2; column-gap:54px}
.steps.two .step{break-inside:avoid}

/* ── Cartes (filet terracotta à gauche) ── */
.cards{display:grid; gap:22px}
.cards.c2{grid-template-columns:1fr 1fr}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.cards.c4{grid-template-columns:repeat(4,1fr)}

/* Équipe */
.team{display:grid; grid-template-columns:repeat(4,1fr); gap:26px}
.member .avatar{aspect-ratio:1/1; background:#FBF8EF center 62%/44% no-repeat; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Ccircle cx='50' cy='40' r='16' fill='none' stroke='%236B6256' stroke-width='2'/%3E%3Cpath d='M24 84 a26 26 0 0 1 52 0' fill='none' stroke='%236B6256' stroke-width='2'/%3E%3C/svg%3E"); border:1px solid var(--line); border-left:3px solid var(--terra); margin-bottom:12px}
.member h4{margin:0 0 2px; font-weight:800; font-size:18px}
.member p{margin:0; color:var(--muted); font-size:14px}
.card{border:1px solid var(--line); border-left:3px solid var(--terra); padding:22px 24px; background:#FBF8EF}
.card h4{margin:0 0 8px; font-weight:800; font-size:19px}
.card p{margin:0; color:var(--muted)}

/* ── Liste étapes (méthode) ── */
.steps{counter-reset:step; display:grid; gap:0}
.step{display:grid; grid-template-columns:auto 1fr; gap:20px; padding:18px 0; border-bottom:1px solid var(--line); align-items:baseline}
.step .n{font-weight:900; font-size:22px; color:var(--terra); min-width:34px}
.step h4{margin:0 0 4px; font-weight:700; font-size:19px}
.step p{margin:0; color:var(--muted)}

/* ── Tableau comparatif ── */
.compare{width:100%; border-collapse:collapse; font-size:15px}
.compare th, .compare td{text-align:left; padding:13px 16px; border-bottom:1px solid var(--line); vertical-align:top}
.compare thead th{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:600}
.compare thead th.col{font-family:var(--f-disp); font-size:20px; letter-spacing:0; text-transform:none; color:var(--ink); font-weight:800}
.compare td:first-child{color:var(--muted); width:30%}
.compare .price{font-weight:800; font-size:20px; white-space:nowrap}
.compare .price .terra{color:var(--terra)}

/* ── Section sombre (contrepoint espresso) ── */
.dark{background:var(--terre); color:#EFE7D6}
.dark .label, .dark .acc{color:var(--terra-on-dark)}
.dark a.btn{border-color:var(--cream); color:var(--cream)}
.dark a.btn.fill{background:var(--cream); color:var(--espresso); border-color:var(--cream)}
.dark .muted{color:#cbb8a0}

/* ── Sommaire (effet livre) ── */
.sommaire{padding:30px 0 10px}
.sommaire h2{font-weight:900; font-size:clamp(46px,7vw,104px); letter-spacing:-.02em; margin:.1em 0 .3em}
.toc{display:grid; grid-template-columns:1fr 1fr; gap:48px 64px}
.toc .col > .label{margin-bottom:12px; display:block}
.toc-row{display:flex; align-items:baseline; gap:10px; padding:14px 0; border-bottom:1px solid var(--line)}
.toc-row .num{color:var(--muted); font-size:12px; width:34px; letter-spacing:.1em}
.toc-row .t{font-weight:600; font-size:19px}
.toc-row .ld{flex:1; border-bottom:1px dotted var(--line); transform:translateY(-4px)}
.toc-row .fo{color:var(--muted); font-size:12px; letter-spacing:.1em}
.toc-cta{background:var(--terre); color:var(--cream); padding:24px 26px; align-self:start}
.toc-row.current{color:var(--muted); cursor:default}
.toc-row.current .t{font-weight:600}
.toc-cta{color:#EFE7D6}
.toc-cta .label, .toc-cta .acc{color:var(--terra-on-dark)}
.toc-cta p{font-family:var(--f-acc); font-style:italic; font-size:22px; margin:10px 0 14px}
.toc-cta .mail{color:#cbb8a0; font-size:12px; letter-spacing:.16em; text-transform:uppercase}

/* ── Formulaire (contact) ── */
.field{display:block; margin:0 0 16px}
.field label{display:block; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin:0 0 6px; font-weight:600}
.field input, .field textarea, .field select{width:100%; border:1.5px solid var(--line); background:rgba(255,255,255,.3); padding:13px 14px; font-family:var(--f-disp); font-size:15px; color:var(--ink); outline:none}
.field input:focus, .field textarea:focus, .field select:focus{border-color:var(--ink)}
.field textarea{min-height:130px; resize:vertical}

/* ── Newsletter ── */
.news{margin:48px 0 0; border-top:2px solid var(--ink); border-bottom:1px solid var(--line); padding:34px 0}
.news-in{display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center}
.news h3{font-weight:800; font-size:30px; margin:8px 0 6px}
.news form{display:flex; gap:0; border:1.5px solid var(--ink)}
.news input{flex:1; border:0; padding:15px 16px; font-family:var(--f-disp); font-size:15px; background:transparent; outline:none}
.news button{border:0; border-left:1.5px solid var(--ink); background:var(--ink); color:var(--cream); padding:0 24px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; cursor:pointer}
.news button:hover{background:var(--terra)}

/* ── Footer ── */
footer{margin-top:8px; background:var(--cream)}
footer .colorbar{height:8px}
.foot{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; padding:58px 0 20px}
.lock{font-weight:800; font-size:22px}
.lock .a{font-family:var(--f-acc); font-style:italic; color:var(--terra)}
.lock .dot{color:var(--terra)}
.foot .base{font-family:var(--f-acc); font-style:italic; color:var(--muted); margin:12px 0 10px; max-width:34ch}
.foot h5{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin:0 0 12px; font-weight:600}
.foot ul{list-style:none; margin:0; padding:0}
.foot li{margin:7px 0}
.foot .soon{color:var(--muted); font-size:11px; letter-spacing:.12em; text-transform:uppercase}
.foot-end{display:flex; justify-content:space-between; gap:16px; border-top:1px solid var(--line); padding:14px 0 24px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}
.foot-end .fin{color:var(--terra)}

/* ── Utilitaires d'espacement de section ── */
.section{padding:30px 0}
.section.tight{padding:18px 0}

/* ============================================================
   v2 — « planche d'impression » : repères, gamme de contrôle, tampon
   ============================================================ */

/* Gamme de contrôle CMJN + gris (le moment couleur, façon barre de calage) */
.controlstrip{display:flex; align-items:center; gap:9px}
.controlstrip .patches{display:flex; box-shadow:0 0 0 1px var(--line)}
.controlstrip .patches i{width:16px; height:11px; display:block}
.controlstrip .cap{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); white-space:nowrap}

/* Plaque : un bloc cadré par des traits de coupe aux angles */
.plate{position:relative}
.plate > .cm{position:absolute; width:14px; height:14px; pointer-events:none}
.plate > .cm.tl{top:-12px; left:-12px; border-left:1px solid var(--muted); border-top:1px solid var(--muted)}
.plate > .cm.tr{top:-12px; right:-12px; border-right:1px solid var(--muted); border-top:1px solid var(--muted)}
.plate > .cm.bl{bottom:-12px; left:-12px; border-left:1px solid var(--muted); border-bottom:1px solid var(--muted)}
.plate > .cm.br{bottom:-12px; right:-12px; border-right:1px solid var(--muted); border-bottom:1px solid var(--muted)}

/* Tampon « bon à tirer » */
.stamp{display:inline-block; margin-top:34px; margin-left:18px; transform:rotate(-6deg); border:2px solid var(--terra); color:var(--terra); padding:6px 13px; font-weight:800; font-size:12px; letter-spacing:.22em; text-transform:uppercase; opacity:.9; border-radius:2px}

/* Liens en réserve : grisés mais lisibles, non cliquables */
.off{color:var(--line); pointer-events:none; cursor:default}

/* Deux colonnes génériques (contact, etc.) */
.cols2{display:grid; grid-template-columns:1fr 1fr; gap:44px}

/* Encart d'appui (ex. Amazon KDP) */
.callout{border:1px solid var(--terra); border-left:3px solid var(--terra); background:rgba(184,80,61,.06); padding:18px 22px; margin:20px 0}
.callout .label{display:block; margin-bottom:6px}
.callout p{margin:0; color:#2c2620}

/* Note de page placeholder */
.page-note{border:1px dashed var(--line); padding:14px 18px; margin:0 0 22px; color:var(--muted); font-style:italic; font-family:var(--f-acc); font-size:18px}

/* Case de consentement (formulaire) */
.consent{display:flex; gap:10px; align-items:flex-start; font-size:13px; color:var(--muted); margin:4px 0 18px}
.consent input{margin-top:3px}

/* ============================================================
   Responsive — approche mobile-first descendante.
   Points de rupture : 1180 (nav burger) · 1080 (marges) · 900 (tablette)
   · 720 (tablette portrait) · 560 (mobile) · 380 (petit mobile).
   ============================================================ */

/* ── ≤ 1180 px : la nav se replie en menu burger (sinon trop serrée) ── */
@media(max-width:1180px){
  .topbar{position:relative; flex-wrap:wrap; gap:14px}
  .burger{display:flex}
  nav.main{position:absolute; top:100%; left:0; right:0; display:none; flex-direction:column; gap:0; white-space:normal; background:var(--cream); border-bottom:1px solid var(--line); box-shadow:0 10px 24px rgba(20,17,13,.10); padding:4px 40px 14px; z-index:60}
  .nav-toggle:checked ~ nav.main{display:flex}
  nav.main a{padding:13px 0; border-bottom:1px solid var(--line); font-size:13px; letter-spacing:.14em}
  nav.main a:last-child{border-bottom:0}
}

/* ── ≤ 1080 px : on resserre les marges de la « feuille » ── */
@media(max-width:1080px){
  .wrap{padding:0 40px}
  .page{padding:18px 40px 44px; margin:38px auto 30px}
  .hero{gap:40px}
}

/* ── ≤ 900 px : tablette paysage ── */
@media(max-width:900px){
  body{font-size:16px}
  .wrap{padding:0 30px}
  .page{padding:16px 30px 40px}
  .hero{grid-template-columns:1fr; gap:24px}
  .toc{grid-template-columns:1fr; gap:28px}
  .meta{grid-template-columns:repeat(2,1fr); gap:22px}
  .cards.c4{grid-template-columns:repeat(2,1fr)}
  .news-in{grid-template-columns:1fr; gap:20px}
  /* mires gauche/droite retirées en responsive (peu lisibles à cette taille) */
  .marks .reg.l, .marks .reg.r{display:none}
  /* burger déjà actif (≤1180) ; ici on déclutte la barre */
  .tagline{display:none}
  .colorbar{display:none}
}

/* ── ≤ 720 px : tablette portrait → tout en une colonne ── */
@media(max-width:720px){
  .wrap{padding:0 22px}
  .page{padding:14px 22px 36px; margin:44px auto 40px}
  .hero,.cards.c2,.cards.c3,.cards.c4,.chapter,.cols2,.section.cols2{grid-template-columns:1fr}
  .team{grid-template-columns:repeat(2,1fr); gap:20px}
  .prose.two,.steps.two{column-count:1}
  /* le chiffre romain de chapitre passe au-dessus du titre, taille réduite */
  .chapter{gap:6px}
  .chapter .rn{font-size:96px; align-self:flex-start; margin-top:0}
  .sommaire h2{font-size:clamp(40px,12vw,72px)}
  .news form{flex-direction:column; border:0}
  .news input{border:1.5px solid var(--ink)}
  .news button{border:1.5px solid var(--ink); border-top:0; padding:14px}
  .cta-band{flex-direction:column; align-items:flex-start; gap:16px}
  .foot{grid-template-columns:repeat(2,1fr); gap:26px}
  .foot-end{flex-wrap:wrap; gap:8px}
  .controlstrip .cap{display:none}
  /* traits de coupe d'angle décalés vers l'extérieur */
  .marks .crop.tl::before,.marks .crop.bl::before{left:-12px}
  .marks .crop.tr::before,.marks .crop.br::before{right:-12px}
}

/* ── ≤ 560 px : mobile ── */
@media(max-width:560px){
  body{font-size:15px}
  .wrap{padding:0 16px}
  .page{padding:16px 18px 32px; margin:40px 14px 40px}
  /* traits de coupe d'angle décalés vers l'extérieur, dans la gouttière */
  .marks .crop.tl::before,.marks .crop.bl::before{left:-12px}
  .marks .crop.tr::before,.marks .crop.br::before{right:-12px}
  .topbar{padding:8px 14px; gap:10px; font-size:11px}
  .topbar .cross{display:none}
  .brandmark{font-size:15px}
  nav.main{gap:12px}
  .meta{grid-template-columns:1fr; gap:16px}
  .team{grid-template-columns:1fr 1fr; gap:16px}
  .member .avatar{max-width:150px}
  .foot{grid-template-columns:1fr; gap:22px}
  .foot-end{flex-direction:column; align-items:center; text-align:center; gap:6px}
  .chapter .rn{font-size:74px}
  .prose p{text-align:left; hyphens:none}
  .compare{table-layout:fixed}
  .compare th,.compare td{padding:10px 8px; font-size:13px}
  .compare td:first-child{width:34%}
  .compare .price{white-space:normal; font-size:15px}
  .runhead .patches{display:none}
  .runhead{flex-wrap:wrap}
  .btn{padding:13px 20px}
  .btns{flex-direction:column; align-items:stretch}
  .btns .btn{text-align:center}
}

/* ── ≤ 380 px : petits mobiles ── */
@media(max-width:380px){
  .chapter h1{font-size:34px}
  .chapter .rn{font-size:58px}
  .logotype .g{font-size:56px}
  .logotype .p{font-size:60px}
}

/* Confort tactile : zones cliquables un peu plus grandes au pointeur grossier */
@media(hover:none) and (pointer:coarse){
  nav.main a, .foot a, .btn{padding-top:.2em; padding-bottom:.2em}
}
