:root{
  --foret:#16302B;--foret-2:#1E3A33;--encre:#10221E;
  --creme:#F1ECE2;--beige:#E7DFCE;--menthe:#8FF0A4;--menthe-fonce:#4CBB6C;
  --blanc:#FFFFFF;--radius:18px;--radius-lg:28px;--maxw:1180px;
  --font-display:"Bricolage Grotesque",sans-serif;--font-body:"Inter",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--creme);color:var(--encre);line-height:1.6;font-size:16px;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;font-weight:700;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:88px 0}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--menthe-fonce);margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:14px 26px;border-radius:999px;border:none;cursor:pointer;transition:transform .25s cubic-bezier(.2,.9,.3,1.4),box-shadow .25s}
.btn:hover{transform:translateY(-3px)}
.btn:focus-visible{outline:3px solid var(--menthe-fonce);outline-offset:3px}
.btn-menthe{background:var(--menthe);color:var(--encre)}
.btn-menthe:hover{box-shadow:0 12px 28px rgba(143,240,164,.45)}
.btn-ghost{background:transparent;color:var(--creme);border:1.5px solid rgba(241,236,226,.4)}
.btn-ghost:hover{border-color:var(--menthe);color:var(--menthe)}
.btn-fonce{background:var(--foret);color:var(--creme)}
.btn .fleche{transition:transform .25s}
.btn:hover .fleche{transform:translateX(4px)}

/* ---------- Logo animé ---------- */
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.35rem;color:var(--encre)}
.logo-mark{width:34px;height:34px;flex-shrink:0}
.logo-mark .fond{transform-origin:center;animation:pop .5s cubic-bezier(.3,1.4,.5,1) both}
.logo-mark .trait{stroke-dasharray:40;stroke-dashoffset:40;animation:tracer .7s ease forwards}
.logo-mark .trait.dos{animation-delay:.2s}
.logo-mark .trait.page-h{animation-delay:.45s;transform-origin:11px 16px;transition:transform .35s cubic-bezier(.3,1.4,.5,1)}
.logo-mark .trait.page-b{animation-delay:.6s;transform-origin:11px 16px;transition:transform .35s cubic-bezier(.3,1.4,.5,1)}
.logo:hover .page-h,a.logo:focus-visible .page-h{transform:rotate(-9deg)}
.logo:hover .page-b,a.logo:focus-visible .page-b{transform:rotate(9deg)}
@keyframes tracer{to{stroke-dashoffset:0}}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.logo-slogan{display:block;font-family:var(--font-body);font-weight:500;font-size:.62rem;letter-spacing:.08em;color:#5A6963;margin-top:-3px}

/* ---------- Header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s,padding .3s;padding:18px 0}
header.scrolled{background:rgba(241,236,226,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(16,34,30,.08);padding:10px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
body.sur-fonce header:not(.scrolled) .logo,body.sur-fonce header:not(.scrolled) .nav-links a{color:var(--creme)}
body.sur-fonce header:not(.scrolled) .logo-slogan{color:rgba(241,236,226,.6)}
body.sur-fonce header:not(.scrolled) .burger span{background:var(--creme)}
.nav-links{display:flex;gap:30px;font-size:.92rem;font-weight:500}
.nav-links a{position:relative;opacity:.85}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--menthe);transition:width .25s}
.nav-links a:hover::after,.nav-links a.actif::after{width:100%}
.nav-links a.actif{opacity:1;font-weight:600}
.nav-cta{display:flex;gap:12px}
.burger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px}
.burger span{display:block;width:22px;height:2px;background:var(--encre);margin:5px auto;transition:.3s}
.menu-mobile{position:fixed;inset:0;background:var(--foret);z-index:99;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;transform:translateY(-100%);transition:transform .4s cubic-bezier(.7,0,.3,1)}
.menu-mobile.ouvert{transform:none}
.menu-mobile a{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--creme)}
.menu-mobile a:hover{color:var(--menthe)}

/* ---------- Bandeau de page intérieure ---------- */
.page-hero{padding:150px 0 70px;background:var(--creme)}
.page-hero h1{font-size:clamp(2.1rem,4.2vw,3.2rem);max-width:720px}
.page-hero p{max-width:560px;margin-top:18px;color:#4A5A54;font-size:1.02rem}
.fil{font-size:.8rem;color:#8A968F;margin-bottom:18px}
.fil a:hover{color:var(--encre)}

/* ---------- Hero accueil ---------- */
.hero{background:var(--creme);padding:120px 0 0}
.hero-panel{position:relative;background:var(--foret);border-radius:var(--radius-lg);padding:76px 64px;color:var(--creme);overflow:hidden;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero-panel h1{font-size:clamp(2.3rem,4.6vw,3.9rem);font-weight:800;color:var(--blanc)}
.hero-panel h1 .accent{color:var(--menthe)}
.hero-sub{margin:22px 0 32px;font-size:1.05rem;max-width:480px;color:rgba(241,236,226,.85)}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}
.hero-visuel{position:relative;min-height:340px}
.mockup{position:relative;background:var(--creme);border-radius:var(--radius);padding:18px;box-shadow:0 30px 60px rgba(0,0,0,.35);transform:rotate(2deg)}
.mockup-bar{display:flex;gap:6px;margin-bottom:14px}
.mockup-bar i{width:9px;height:9px;border-radius:50%;background:#D6CDBB}
.mockup-bar i:first-child{background:var(--menthe-fonce)}
.mockup-ligne{height:12px;border-radius:6px;background:var(--beige);margin-bottom:10px}
.mockup-ligne.courte{width:60%}
.mockup-carte{display:flex;align-items:center;gap:12px;background:var(--foret);color:var(--creme);border-radius:12px;padding:14px;margin-top:16px;font-size:.82rem;font-weight:600}
.mockup-carte .pastille{width:34px;height:34px;border-radius:10px;background:var(--menthe);color:var(--encre);display:grid;place-items:center;font-family:var(--font-display);font-weight:800;flex-shrink:0}
.badge-flottant{position:absolute;background:var(--blanc);border-radius:14px;padding:12px 16px;box-shadow:0 16px 36px rgba(0,0,0,.22);font-size:.8rem;font-weight:600;color:var(--encre);display:flex;align-items:center;gap:10px;animation:flotter 5s ease-in-out infinite}
.badge-1{top:-16px;right:-8px;animation-delay:.5s}
.badge-2{bottom:-14px;left:-18px}
.badge-flottant .dot{width:10px;height:10px;border-radius:50%;background:var(--menthe-fonce);flex-shrink:0}
@keyframes flotter{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.vague{position:absolute;pointer-events:none;opacity:.5}
.vague-hero{bottom:30px;left:36%;width:280px}
.hero-panel>*{opacity:0;transform:translateY(24px);animation:entree .8s ease forwards}
.hero-panel .hero-visuel{animation-delay:.35s}
@keyframes entree{to{opacity:1;transform:none}}

/* frise ndop */
.ndop{height:26px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='104' height='26' viewBox='0 0 104 26'%3E%3Cg fill='none' stroke='%2316302B' stroke-width='2'%3E%3Cpath d='M0 13 L13 2 L26 13 L13 24 Z'/%3E%3Ccircle cx='39' cy='13' r='6'/%3E%3Cpath d='M52 4 L64 4 L64 22 L52 22 Z'/%3E%3Cpath d='M52 13 L64 13 M58 4 L58 22'/%3E%3Cpath d='M78 2 L91 13 L78 24 L65 13 Z' transform='translate(13,0)'/%3E%3C/g%3E%3C/svg%3E");background-repeat:repeat-x;opacity:.28;margin:70px auto 0;max-width:var(--maxw)}

/* ---------- Marquee ---------- */
.marquee-zone{background:var(--creme);padding:44px 0 0;overflow:hidden}
.marquee{display:flex;white-space:nowrap;will-change:transform;animation:defiler 30s linear infinite}
.marquee-groupe{display:flex;align-items:center;gap:44px;padding-right:44px}
.marquee span{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--foret);display:flex;align-items:center;gap:44px}
.marquee .sep{color:var(--menthe-fonce);font-size:1.3rem}
@keyframes defiler{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Modules ---------- */
.modules-tete{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end;margin-bottom:44px}
.modules-tete h2{font-size:clamp(1.9rem,3.4vw,2.7rem);max-width:520px}
.modules-tete p{max-width:380px;color:#4A5A54;font-size:.98rem}
.grille-modules{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.carte-module{background:var(--blanc);border-radius:var(--radius);padding:30px 26px;transition:transform .3s,box-shadow .3s;position:relative;display:block}
.carte-module:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(16,34,30,.1)}
.carte-module.sombre{background:var(--foret);color:var(--creme)}
.carte-module.sombre p{color:rgba(241,236,226,.75)}
.carte-module.sombre .lire{color:var(--menthe)}
.icone{width:46px;height:46px;border-radius:13px;background:var(--beige);display:grid;place-items:center;margin-bottom:18px}
.carte-module.sombre .icone{background:rgba(143,240,164,.15)}
.icone svg{width:22px;height:22px;stroke:var(--foret);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.carte-module.sombre .icone svg{stroke:var(--menthe)}
.carte-module h3{font-size:1.12rem;margin-bottom:10px;font-weight:700}
.carte-module p{font-size:.9rem;color:#5A6963;margin-bottom:14px}
.lire{font-size:.85rem;font-weight:600;color:var(--menthe-fonce);display:inline-flex;align-items:center;gap:6px}

/* ---------- Module détaillé (page modules) ---------- */
.module-detail{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:60px 0;border-bottom:1px solid rgba(16,34,30,.08)}
.module-detail:last-of-type{border-bottom:none}
.module-detail.inverse .module-texte{order:2}
.module-detail h2{font-size:clamp(1.5rem,2.6vw,2.1rem);margin-bottom:14px}
.module-detail p{color:#4A5A54;font-size:.96rem;margin-bottom:12px}
.module-visuel{background:var(--blanc);border-radius:var(--radius-lg);padding:34px;min-height:220px;display:flex;flex-direction:column;justify-content:center;gap:12px;box-shadow:0 14px 34px rgba(16,34,30,.07)}
.module-visuel.fonce{background:var(--foret);color:var(--creme)}
.ligne-demo{display:flex;justify-content:space-between;align-items:center;background:var(--creme);border-radius:10px;padding:12px 16px;font-size:.85rem}
.module-visuel.fonce .ligne-demo{background:rgba(241,236,226,.08)}
.ligne-demo b{font-weight:600}
.pill{font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:999px;background:var(--menthe);color:var(--encre)}
.pill.alerte{background:#FDEBD2;color:#B45309}
.pill.neutre{background:var(--beige);color:var(--encre)}
.module-visuel.fonce .pill.neutre{background:rgba(241,236,226,.15);color:var(--creme)}
.liste-checks{list-style:none;margin:20px 0 26px}
.liste-checks li{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px;font-size:.94rem}
.liste-checks .coche{width:22px;height:22px;border-radius:50%;background:var(--menthe);color:var(--encre);display:grid;place-items:center;font-size:.7rem;font-weight:800;flex-shrink:0;margin-top:2px}

/* ---------- Focus / panneaux sombres ---------- */
.focus-panel{background:var(--foret);border-radius:var(--radius-lg);padding:70px 64px;color:var(--creme);display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;position:relative;overflow:hidden}
.focus-panel h2{font-size:clamp(1.8rem,3.2vw,2.5rem);color:var(--blanc);margin-bottom:20px}
.focus-panel h2 .accent{color:var(--menthe)}
.focus-panel p{color:rgba(241,236,226,.82);font-size:.98rem;margin-bottom:16px}
.scan-demo{background:var(--creme);border-radius:var(--radius);padding:24px;color:var(--encre);position:relative}
.scan-titre{font-family:var(--font-display);font-weight:700;font-size:.92rem;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.scan-etat{font-size:.72rem;background:var(--menthe);padding:4px 12px;border-radius:999px;font-weight:600;white-space:nowrap}
.scan-champ{display:flex;justify-content:space-between;align-items:center;background:var(--blanc);border-radius:10px;padding:12px 14px;margin-bottom:10px;font-size:.84rem;gap:8px;flex-wrap:wrap}
.scan-champ .valeur{font-weight:600}
.scan-champ .conf{font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:999px}
.conf-ok{background:#DCF7E3;color:#1F7A3D}
.conf-alerte{background:#FDEBD2;color:#B45309}
.scan-barre{height:4px;background:var(--beige);border-radius:4px;overflow:hidden;margin-top:14px}
.scan-barre i{display:block;height:100%;width:0;background:var(--menthe-fonce);border-radius:4px;transition:width 1.8s ease}
.scan-demo.visible .scan-barre i{width:88%}

/* ---------- Finances / stats ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:20px}
.split p.grand{color:#4A5A54;margin-bottom:26px}
.stat-cartes{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat-carte{background:var(--blanc);border-radius:var(--radius);padding:26px 22px}
.stat-carte.accent{background:var(--menthe)}
.stat-num{font-family:var(--font-display);font-weight:800;font-size:2.2rem;line-height:1}
.stat-lab{font-size:.82rem;font-weight:500;color:#4A5A54;margin-top:8px}
.stat-carte.accent .stat-lab{color:var(--encre)}
.momo-ligne{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}
.momo-badge{background:var(--blanc);border:1.5px solid var(--beige);border-radius:999px;padding:10px 20px;font-weight:600;font-size:.85rem;display:flex;align-items:center;gap:8px}
.momo-badge .puce{width:10px;height:10px;border-radius:50%}
.puce-om{background:#FF7900}.puce-momo{background:#FFCB05}.puce-sms{background:var(--menthe-fonce)}

/* ---------- Portail / téléphone ---------- */
.fond-beige{background:var(--beige)}
.tel{width:250px;margin:0 auto;background:var(--foret);border-radius:36px;padding:14px;box-shadow:0 30px 60px rgba(16,34,30,.28)}
.tel-ecran{background:var(--creme);border-radius:26px;padding:18px 14px;min-height:380px}
.tel-tete{font-family:var(--font-display);font-weight:700;font-size:.85rem;margin-bottom:14px}
.notif{background:var(--blanc);border-radius:12px;padding:12px;font-size:.72rem;margin-bottom:10px;box-shadow:0 4px 12px rgba(16,34,30,.06);opacity:0;transform:translateY(12px);transition:opacity .5s,transform .5s}
.notif.visible{opacity:1;transform:none}
.notif b{display:block;margin-bottom:2px}
.notif .heure{color:#8A968F;font-size:.64rem}
.notif.sms{border-left:3px solid var(--menthe-fonce)}
.notif.note{border-left:3px solid #B45309}

/* ---------- Tarifs ---------- */
.grille-tarifs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.carte-tarif{background:var(--blanc);border-radius:var(--radius-lg);padding:38px 32px;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.carte-tarif:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(16,34,30,.1)}
.carte-tarif.vedette{background:var(--foret);color:var(--creme);position:relative}
.tag-vedette{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--menthe);color:var(--encre);font-size:.72rem;font-weight:700;padding:6px 16px;border-radius:999px;letter-spacing:.06em;text-transform:uppercase}
.carte-tarif h3{font-size:1.25rem;margin-bottom:6px}
.carte-tarif .cible{font-size:.84rem;color:#5A6963;margin-bottom:22px}
.carte-tarif.vedette .cible{color:rgba(241,236,226,.7)}
.prix{font-family:var(--font-display);font-weight:800;font-size:2.5rem;line-height:1}
.prix small{font-size:.85rem;font-weight:500;color:#5A6963}
.carte-tarif.vedette .prix small{color:rgba(241,236,226,.7)}
.tarif-liste{list-style:none;margin:26px 0 30px;flex:1}
.tarif-liste li{display:flex;gap:10px;font-size:.88rem;margin-bottom:12px;align-items:flex-start}
.tarif-liste .coche{width:18px;height:18px;border-radius:50%;background:var(--beige);color:var(--foret);display:grid;place-items:center;font-size:.6rem;font-weight:800;flex-shrink:0;margin-top:2px}
.carte-tarif.vedette .coche{background:rgba(143,240,164,.2);color:var(--menthe)}
.centre{text-align:center}
.sous-titre{text-align:center;color:#4A5A54;max-width:560px;margin:14px auto 50px}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{background:var(--blanc);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}
.faq summary{cursor:pointer;padding:22px 26px;font-family:var(--font-display);font-weight:600;font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--menthe-fonce);transition:transform .3s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-corps{padding:0 26px 22px;font-size:.92rem;color:#4A5A54}

/* ---------- Étapes ---------- */
.etapes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.etape{background:var(--blanc);border-radius:var(--radius);padding:34px 28px}
.etape .num{font-family:var(--font-display);font-weight:800;font-size:.85rem;width:38px;height:38px;border-radius:50%;background:var(--menthe);display:grid;place-items:center;margin-bottom:18px}
.etape h3{font-size:1.1rem;margin-bottom:10px}
.etape p{font-size:.9rem;color:#5A6963}

/* ---------- Contact ---------- */
.grille-contact{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:60px}
.carte-contact{background:var(--blanc);border-radius:var(--radius-lg);padding:36px 30px;text-align:center;transition:transform .3s,box-shadow .3s}
.carte-contact:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(16,34,30,.1)}
.carte-contact .icone{margin:0 auto 18px}
.carte-contact h3{font-size:1.05rem;margin-bottom:8px}
.carte-contact p{font-size:.88rem;color:#5A6963;margin-bottom:16px}
.carte-contact .valeur-contact{font-family:var(--font-display);font-weight:700;font-size:1.05rem;display:block}
.carte-contact .valeur-contact:hover{color:var(--menthe-fonce)}

/* ---------- CTA final ---------- */
.cta-final .panel{background:var(--foret);border-radius:var(--radius-lg);padding:76px 40px;text-align:center;color:var(--creme);position:relative;overflow:hidden}
.cta-final h2{font-size:clamp(2rem,4vw,3rem);color:var(--blanc);max-width:640px;margin:0 auto 18px}
.cta-final h2 .accent{color:var(--menthe)}
.cta-final p{max-width:460px;margin:0 auto 34px;color:rgba(241,236,226,.82)}
.vague-cta{top:24px;right:40px;width:220px}

/* ---------- À propos ---------- */
.mot-kalara{font-family:var(--font-display);font-weight:800;font-size:clamp(3rem,8vw,6rem);color:var(--foret);line-height:1;letter-spacing:-.02em}
.def-bloc{background:var(--blanc);border-radius:var(--radius-lg);padding:44px 40px;max-width:680px}
.def-bloc .phonetique{font-size:.95rem;color:#8A968F;margin:6px 0 18px}
.def-bloc .sens{font-size:1.05rem;color:#4A5A54}
.valeurs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}

/* ---------- Footer ---------- */
footer{background:var(--foret);color:var(--creme);padding:60px 0 34px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-grid h4{font-size:.92rem;margin-bottom:16px;color:var(--menthe)}
.footer-grid ul{list-style:none;font-size:.88rem}
.footer-grid li{margin-bottom:10px}
.footer-grid a{opacity:.8}
.footer-grid a:hover{opacity:1;color:var(--menthe)}
.footer-desc{font-size:.88rem;color:rgba(241,236,226,.7);max-width:300px;margin-top:14px}
footer .logo{color:var(--creme)}
footer .logo-slogan{color:rgba(241,236,226,.6)}
.copy{font-size:.8rem;color:rgba(241,236,226,.5);text-align:center;padding-top:26px;border-top:1px solid rgba(241,236,226,.12)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal,.notif{opacity:1;transform:none}
  .scan-demo .scan-barre i{width:88%}
  .logo-mark .trait{stroke-dashoffset:0}
  .hero-panel>*{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-panel{grid-template-columns:1fr;padding:52px 32px}
  .grille-modules{grid-template-columns:1fr 1fr}
  .focus-panel{grid-template-columns:1fr;padding:52px 32px}
  .split{grid-template-columns:1fr}
  .grille-tarifs,.etapes,.grille-contact,.valeurs{grid-template-columns:1fr}
  .modules-tete{grid-template-columns:1fr}
  .module-detail{grid-template-columns:1fr;gap:30px}
  .module-detail.inverse .module-texte{order:0}
  .nav-links,.nav-cta{display:none}
  .burger{display:block}
  .footer-grid{grid-template-columns:1fr}
}
@media (max-width:600px){
  section{padding:60px 0}
  .grille-modules{grid-template-columns:1fr}
  .hero{padding-top:96px}
  .stat-cartes{grid-template-columns:1fr}
  .page-hero{padding:120px 0 50px}
}

/* ---- Formulaire de contact ---- */
.carte-form{background:var(--blanc);border-radius:var(--radius-lg);padding:48px 40px;margin-top:48px;box-shadow:0 20px 60px rgba(16,34,30,.08)}
.form-grille{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.champ{display:flex;flex-direction:column;gap:7px}
.champ-large{grid-column:1/-1}
.champ label{font-weight:600;font-size:.9rem;color:var(--foret)}
.champ .optionnel{font-weight:400;color:rgba(16,34,30,.5);font-size:.82rem}
.champ input,.champ textarea{font-family:var(--font-body);font-size:1rem;padding:13px 16px;border:1.5px solid var(--beige);border-radius:var(--radius);background:var(--creme);color:var(--encre);transition:border-color .2s,box-shadow .2s;width:100%}
.champ textarea{resize:vertical;min-height:120px}
.champ input:focus,.champ textarea:focus{outline:none;border-color:var(--menthe-fonce);box-shadow:0 0 0 3px rgba(76,187,108,.18)}
.champ input:user-invalid,.champ textarea:user-invalid{border-color:#c0564c}
.hp{position:absolute;left:-9999px;top:-9999px;height:1px;width:1px;overflow:hidden}
.form-pied{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:26px}
.form-retour{font-size:.92rem;font-weight:500;margin:0}
.form-retour.ok{color:var(--menthe-fonce)}
.form-retour.erreur{color:#c0564c}
#btnEnvoyer[disabled]{opacity:.6;cursor:wait;transform:none}
@media(max-width:640px){.carte-form{padding:32px 22px}.form-grille{grid-template-columns:1fr}}

/* ---------- Bandeau image (page modules) ---------- */
.hero-bandeau{max-width:var(--maxw);margin:0 auto;padding:26px 24px 0}
.hero-bandeau .cadre{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 24px 60px rgba(16,34,30,.16);aspect-ratio:16/6}
.hero-bandeau img{width:100%;height:100%;object-fit:cover;display:block}
.hero-bandeau .cadre::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,48,43,.72),rgba(16,48,43,.10))}
.hero-bandeau .legende{position:absolute;left:30px;bottom:26px;color:var(--creme);z-index:2;max-width:64%}
.hero-bandeau .legende b{font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,2.4vw,1.5rem);display:block;margin-bottom:6px}
.hero-bandeau .legende span{font-size:.92rem;opacity:.9}

/* ---------- Photos dans les modules ---------- */
.module-visuel.avec-photo{padding:0;overflow:hidden;gap:0;background:var(--blanc)}
.module-visuel.avec-photo.fonce{background:var(--foret)}
.avec-photo .toile{position:relative;line-height:0}
.avec-photo .toile img{width:100%;height:250px;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.2,.9,.3,1)}
.avec-photo:hover .toile img{transform:scale(1.05)}
.avec-photo .toile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,48,43,0) 45%,rgba(16,48,43,.5) 100%)}
.photo-badge{position:absolute;z-index:2;background:var(--blanc);border-radius:13px;padding:10px 15px;box-shadow:0 14px 32px rgba(0,0,0,.28);font-size:.8rem;font-weight:600;color:var(--encre);display:flex;align-items:center;gap:9px;line-height:1.3}
.photo-badge .dot{width:9px;height:9px;border-radius:50%;background:var(--menthe-fonce);flex-shrink:0}
.photo-badge.bg{bottom:16px;left:16px}
.photo-badge.hd{top:16px;right:16px}
.avec-photo .lignes{padding:20px 22px;display:flex;flex-direction:column;gap:11px}

/* ---------- Portail : téléphone dans un module ---------- */
.module-tel{display:flex;justify-content:center;align-items:center}
.notif.resultat{border-left:3px solid #1F7A3D}
.notif.examen{border-left:3px solid #6C6CE0}
.notif.frais{border-left:3px solid var(--menthe-fonce)}
.notif .etiq{display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--menthe-fonce);margin-bottom:3px}
