:root{
  --navy:#091444;
  --royal:#125FDC;
  --blue:#1A5C99;
  --sky:#3EA1FF;
  --cyan:#42D7F4;
  --green:#61A73D;
  --cream:#FAF7F0;         /* warm off-white */
  --cream-2:#F4EFDE;
  --blue-pale:#EEF4FC;     /* bleu pâle brand */
  --green-pale:#EEF3E5;    /* vert très doux */
  --ink:#0B0E1A;
  --ink-2:#1E2537;
  --muted:#5B6472;
  --line:#D8D4C6;          /* warm border */
  --line-blue:#CEDDF1;
  --line-green:#D3DFC2;
  --line-ink:rgba(11,14,26,.12);
  --amber:#D98E2B;
  --serif:'Space Grotesk',ui-sans-serif,system-ui,sans-serif;
  --sans:'Space Grotesk',ui-sans-serif,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
/* Garde-fou global : évite tout débordement horizontal accidentel (runner, iframes, long strings) */
html,body{overflow-x:hidden;max-width:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:17px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--navy);color:var(--cream)}

.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
@media(min-width:1025px){.wrap{padding:0 40px}}

/* ============= Type ============= */
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono);letter-spacing:.02em}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--ink);margin:0;line-height:1.05;letter-spacing:-.025em}
h1{font-size:clamp(2.8rem,6.5vw,5.6rem);font-weight:300}
h2{font-size:clamp(2rem,4vw,3.4rem);font-weight:300}
h3{font-size:1.4rem;font-weight:400}
.kicker{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:"";display:inline-block;width:24px;height:1px;background:currentColor;opacity:.6}
.kicker.on-dark{color:rgba(255,255,255,.7)}
em.ital,.ital{font-style:normal;font-weight:500;color:var(--royal)}
.lead{font-family:var(--sans);font-size:1.12rem;color:var(--muted);max-width:58ch;line-height:1.6;text-wrap:pretty}

/* ============= Header ============= */
.header{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:1px solid var(--line)}
.header-in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:64px}
.brand-text{display:none;flex-direction:column;line-height:1;gap:2px}
@media(min-width:769px){.brand-text{display:flex}}
.brand-text .t{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:var(--ink);letter-spacing:-.01em}
.brand-text .s{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.nav{display:none;align-items:center;gap:2px}
@media(min-width:1025px){.nav{display:flex}}
.nav a{padding:10px 14px;border-radius:8px;font-size:.92rem;color:var(--ink);font-weight:400;transition:color .2s,background .2s}
.nav a:hover,.nav a.on{color:var(--royal)}
.nav a.on{font-weight:500}

/* Sous-menu desktop (dropdown au survol) */
.nav .menu-item.has-sub{position:relative}
.nav .menu-link{display:inline-flex;align-items:center;gap:6px}
.nav .menu-link .chev-desktop{font-size:.62rem;opacity:.55;transition:transform .2s,opacity .2s}
.nav .menu-item.has-sub:hover .menu-link .chev-desktop,
.nav .menu-item.has-sub:focus-within .menu-link .chev-desktop{transform:rotate(180deg);opacity:1}
.nav .menu-item.has-sub.on > .menu-link{color:var(--royal);font-weight:500}
.nav .menu-item.has-sub::after{content:"";position:absolute;top:100%;left:0;right:0;height:12px}
.nav .submenu-toggle{display:none}
.nav .submenu{position:absolute;top:100%;left:0;min-width:260px;background:#fff;border:1px solid var(--line-blue);border-radius:6px;padding:8px 0;margin-top:10px;display:none;flex-direction:column;box-shadow:0 14px 36px rgba(9,20,68,.10);z-index:100}
.nav .menu-item.has-sub:hover .submenu,
.nav .menu-item.has-sub:focus-within .submenu{display:flex}
.nav .submenu-item{padding:10px 20px;font-size:.92rem;color:var(--ink);font-weight:400;border-radius:0;text-decoration:none;transition:background .15s,color .15s}
.nav .submenu-item:hover{background:var(--cream);color:var(--royal)}
.nav .submenu-item.on{color:var(--royal);background:var(--cream);font-weight:500}
.header-cta{display:flex;align-items:center;gap:14px}
.header-cta .tel{display:none;font-family:var(--mono);font-size:.85rem;letter-spacing:.02em;color:var(--ink)}
@media(min-width:769px){.header-cta .tel{display:inline-flex;align-items:center;gap:8px}}
.header-cta .tel i{color:var(--royal);font-size:.78rem}
.burger{width:42px;height:42px;border:1px solid var(--line-ink);border-radius:8px;background:transparent;cursor:pointer;display:inline-grid;place-items:center}
@media(min-width:1025px){.burger{display:none}}

/* ============= Buttons ============= */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:9999px;font-family:var(--sans);font-weight:500;font-size:.92rem;border:1px solid transparent;cursor:pointer;transition:transform .25s ease,background .2s ease,color .2s ease,border-color .2s ease;text-decoration:none;white-space:nowrap;letter-spacing:-.005em}
.btn-primary{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-primary:hover{background:var(--royal);border-color:var(--royal)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--cream)}
.btn-light{background:transparent;color:var(--cream);border-color:rgba(255,255,255,.3)}
.btn-light:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-filled-light{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-filled-light:hover{background:var(--cyan);border-color:var(--cyan)}
.btn i{font-size:.78rem}
.btn-text{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:500;color:var(--royal);font-size:.92rem;border-bottom:1px solid currentColor;padding-bottom:2px;transition:gap .2s}
.btn-text:hover{gap:14px}

/* ============= Sections shared ============= */
section{padding:96px 0;position:relative}
@media(min-width:1025px){section{padding:128px 0}}
.bg-cream{background:var(--cream)}
.bg-blue{background:var(--blue-pale)}
.bg-green{background:var(--green-pale)}
.bg-navy{background:var(--navy);color:var(--cream)}
.bg-navy h1,.bg-navy h2,.bg-navy h3{color:var(--cream)}
.bg-navy .lead{color:rgba(255,255,255,.7)}
.sec-rule{border-top:1px solid var(--line)}
.bg-blue.sec-rule{border-top-color:var(--line-blue)}
.bg-green.sec-rule{border-top-color:var(--line-green)}
.bg-navy.sec-rule{border-top-color:rgba(255,255,255,.08)}
.sec-head{max-width:800px;margin-bottom:64px}
.sec-head.center{margin:0 auto 64px;text-align:center}

/* Tiny meta strip under kickers */
.sec-head .title-block{margin-top:18px}
.sec-head h2 .ital{font-style:normal;color:var(--royal);font-weight:500}
.bg-green .sec-head h2 .ital{color:#476f25}
.bg-navy .sec-head h2 .ital{color:var(--cyan)}

/* ============= Hero ============= */
.hero{padding:56px 0 120px;position:relative;overflow:hidden}
.hero-bottom{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:40px;margin-top:72px;border-top:1px solid var(--line);font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero-bottom .item{display:inline-flex;align-items:center;gap:10px}
.hero-bottom .item i{color:var(--royal);font-size:.82rem}
.hero-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:900px){.hero-grid{grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);gap:64px}}
/* Layout full-text quand aucune image hero n'est uploadée (feedback client 19/04) */
@media(min-width:900px){.hero-grid-solo{grid-template-columns:minmax(0,1fr)!important;max-width:900px}}
.hero-grid-solo .hero-lead{max-width:56ch}
.hero h1{max-width:14ch}
.hero h1 .a{font-style:normal;font-weight:500;color:var(--royal)}
.hero h1 .b{display:inline-block;position:relative}
.hero h1 .b::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:.32em;background:rgba(97,167,61,.28);z-index:-1;border-radius:2px}
.hero-meta{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.hero-lead{margin:24px 0 36px;max-width:46ch}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-right{display:flex;flex-direction:column;gap:20px}
.hero-img{aspect-ratio:4/5;overflow:hidden;border-radius:2px;background:var(--cream-2)}
.hero-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.02)}
.hero-caption{display:flex;justify-content:space-between;gap:16px;align-items:baseline;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-top:8px;border-top:1px solid var(--line)}
.hero-caption .n{color:var(--ink)}

/* oversized scroll marker */
.hero-marker{position:absolute;left:0;right:0;bottom:24px;display:flex;justify-content:center;gap:10px;font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.hero-marker i{animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ============= Running numbers band ============= */
.runner{background:var(--ink);color:var(--cream);padding:18px 0;overflow:hidden;position:relative;white-space:nowrap}
.runner-track{display:inline-flex;gap:48px;animation:slide 36s linear infinite;font-family:var(--sans);font-style:normal;font-size:1.05rem;font-weight:400;padding-right:48px;letter-spacing:-.005em}
.runner-track span{display:inline-flex;align-items:center;gap:48px}
.runner-track span::after{content:"✦";color:var(--cyan);font-style:normal;font-size:.8rem}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============= Services (5 categories editorial) ============= */
.svc-wrap{border-top:1px solid var(--line-blue)}
.svc-row{display:grid;grid-template-columns:60px 1fr;gap:18px;padding:32px 0;border-bottom:1px solid var(--line-blue);cursor:pointer;transition:padding .3s ease}
@media(min-width:769px){.svc-row{grid-template-columns:80px minmax(260px,1fr) minmax(0,1.4fr) auto;gap:40px;padding:40px 0;align-items:start}}
.svc-row:hover{padding-left:10px;padding-right:10px}
.svc-num{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;color:var(--muted);padding-top:6px}
.svc-title{font-family:var(--serif);font-size:clamp(1.5rem,2.2vw,2rem);font-weight:300;letter-spacing:-.015em;line-height:1.1;color:var(--ink)}
.svc-title em{font-style:normal;color:var(--royal);font-weight:500}
.svc-items{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr;gap:6px;color:var(--ink)}
@media(min-width:500px){.svc-items{grid-template-columns:1fr 1fr}}
.svc-items li{font-size:.95rem;color:var(--ink);display:flex;align-items:baseline;gap:10px;line-height:1.4}
.svc-items li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--royal);flex:none;transform:translateY(-2px)}
@media(max-width:768px){.svc-items{grid-column:2}}
.svc-arrow{width:44px;height:44px;border:1px solid var(--line-ink);border-radius:50%;display:none;align-items:center;justify-content:center;color:var(--ink);transition:background .2s,color .2s,border-color .2s,transform .3s;flex:none;margin-top:4px}
@media(min-width:769px){.svc-arrow{display:inline-flex}}
.svc-row:hover .svc-arrow{background:var(--ink);color:var(--cream);border-color:var(--ink);transform:rotate(-45deg)}

/* ============= Founder split ============= */
.founder-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:900px){.founder-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:72px}}
/* Layout full-text quand aucune image n'est uploadée (feedback client 19/04) */
@media(min-width:900px){.founder-grid-solo{grid-template-columns:minmax(0,1fr)!important;max-width:820px;margin:0 auto}}
.founder-photo{aspect-ratio:4/5;overflow:hidden;border-radius:2px}
.founder-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.founder-text .quote{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.4rem);font-weight:300;line-height:1.2;letter-spacing:-.015em;margin:24px 0 32px;max-width:20ch}
.founder-text .quote em{font-style:normal;color:var(--green);font-weight:500}
.founder-sig{display:flex;align-items:center;gap:16px;padding-top:24px;border-top:1px solid var(--line-ink)}
.founder-sig .name{font-family:var(--sans);font-size:1.15rem;font-style:normal;font-weight:500;color:var(--ink);letter-spacing:-.015em}
.founder-sig .role{font-family:var(--mono);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ============= Stats / ledger ============= */
.ledger{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line-blue);border-bottom:1px solid var(--line-blue)}
@media(min-width:769px){.ledger{grid-template-columns:repeat(4,1fr)}}
.ledger-cell{padding:40px 24px;border-right:1px solid var(--line-blue);position:relative}
.ledger-cell:nth-child(2n){border-right:0}
@media(min-width:769px){.ledger-cell:nth-child(2n){border-right:1px solid var(--line-blue)}.ledger-cell:last-child{border-right:0}}
.ledger-cell:nth-child(1),.ledger-cell:nth-child(2){border-bottom:1px solid var(--line-blue)}
@media(min-width:769px){.ledger-cell:nth-child(1),.ledger-cell:nth-child(2){border-bottom:0}}
.ledger-n{font-family:var(--serif);font-size:clamp(2.6rem,4.5vw,4.2rem);font-weight:300;line-height:1;letter-spacing:-.03em;color:var(--ink)}
.ledger-n em{font-style:normal;color:var(--royal);font-weight:500}
.ledger-l{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ============= Why / Process ============= */
.proc-grid{display:grid;grid-template-columns:1fr;gap:2px;border:1px solid var(--line-green);border-radius:2px;overflow:hidden;background:var(--line-green)}
@media(min-width:769px){.proc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1025px){.proc-grid{grid-template-columns:repeat(4,1fr)}}
.proc-cell{background:var(--green-pale);padding:36px 32px;display:flex;flex-direction:column;gap:16px;min-height:260px;transition:background .3s}
.proc-cell:hover{background:#E5EDD5}
.proc-icon{font-size:1.4rem;color:#476f25;margin-bottom:-2px;opacity:.85}
.proc-n{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;color:#476f25}
.proc-cell h3{font-family:var(--serif);font-weight:400;font-size:1.35rem;letter-spacing:-.01em}
.proc-cell h3 em{font-style:normal;color:#476f25;font-weight:600}
.proc-cell p{color:var(--muted);font-size:.94rem;line-height:1.6;margin:0}

/* ============= Zone map ============= */
.zone-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:start}
@media(min-width:900px){.zone-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:56px}}
.zone-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:28px}
.zone-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line-blue);border-radius:9999px;font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:#fff;transition:all .2s}
.zone-chip:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.zone-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--royal)}
.zone-chip:hover .dot{background:var(--cyan)}
.zone-search{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#fff;border:1px solid var(--line-blue);border-radius:2px;margin-top:20px;text-decoration:none;color:var(--ink);transition:background .2s,border-color .2s,color .2s}
.zone-search input{flex:1;border:0;outline:0;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:transparent}
.zone-search i{color:var(--royal);transition:color .2s}
.zone-search-label{flex:1;font-family:var(--sans);font-size:.95rem;color:var(--ink)}
.zone-search-arrow{margin-left:auto;font-size:.85rem;opacity:.7;transition:transform .2s,opacity .2s}
.zone-search:hover{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.zone-search:hover .zone-search-label{color:var(--cream)}
.zone-search:hover i{color:var(--cyan)}
.zone-search:hover .zone-search-arrow{transform:translateX(4px);opacity:1}
.map{aspect-ratio:4/3;background:#fff;border:1px solid var(--line-blue);position:relative;overflow:hidden;border-radius:2px}
.map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.35) contrast(.95) saturate(.85)}
.map-overlay{position:absolute;left:16px;bottom:16px;background:var(--cream);border:1px solid var(--line);padding:10px 14px;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:10px;box-shadow:0 2px 0 rgba(11,14,26,.06)}
.map-overlay i{color:var(--royal)}
.map-legend{display:flex;gap:18px;margin-top:14px;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-items:center}
.map-legend .sw{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px;vertical-align:middle}

/* ============= Testimonials ============= */
.test-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-top:48px}
@media(min-width:769px){.test-grid{grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:2px}}
.test-card{background:var(--cream);padding:36px 32px;display:flex;flex-direction:column;gap:20px;position:relative;min-height:300px}
.test-card .tag{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:3px 8px;border:1px solid var(--line-ink);border-radius:2px}
.test-card .qmark{font-family:var(--sans);font-style:normal;font-size:3.2rem;line-height:.7;color:var(--royal);height:.5em;font-weight:500}
.test-card p{font-family:var(--sans);font-size:1.05rem;font-weight:400;color:var(--ink);line-height:1.5;margin:0;font-style:normal;letter-spacing:-.005em}
.test-author{margin-top:auto;padding-top:20px;border-top:1px solid var(--line-ink);display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}
.test-author .n{font-family:var(--sans);font-size:1rem;font-style:normal;font-weight:500;letter-spacing:-.01em}
.test-author .r{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* ============= CTA navy ============= */
.cta-nav{padding:72px 0}
@media(min-width:1025px){.cta-nav{padding:112px 0}}
.cta-nav .wrap{display:grid;grid-template-columns:minmax(0,1fr);gap:32px;align-items:end}
@media(min-width:900px){.cta-nav .wrap{grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:40px}}
.cta-nav>*,.cta-nav .wrap>*{min-width:0}
.cta-nav h2{max-width:16ch;font-size:clamp(1.7rem,3.6vw,2.6rem);line-height:1.1;word-wrap:break-word}
.cta-nav h2 em{font-style:normal;color:var(--cyan);font-weight:500}
.cta-nav .actions{display:flex;flex-direction:column;gap:12px;min-width:0;max-width:100%}
.cta-nav .actions .btn{justify-content:center;max-width:100%;white-space:normal;word-break:break-word}
.cta-tel{display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);padding-top:16px;border-top:1px solid rgba(255,255,255,.12);min-width:0;max-width:100%}
.cta-tel strong{font-family:var(--mono);font-style:normal;font-weight:500;font-size:.82rem;letter-spacing:.02em;text-transform:none;color:var(--cream);word-break:break-all;overflow-wrap:anywhere;max-width:100%}

/* ============= Footer ============= */
footer{background:var(--cream);padding:96px 0 36px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:769px){.foot-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1025px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.foot-col h4{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 20px}
.foot-col a{display:block;padding:4px 0;color:var(--ink);font-size:.95rem}
.foot-col a:hover{color:var(--royal)}
.foot-about img{height:44px;margin-bottom:20px}
.foot-about p{margin:0 0 20px;color:var(--muted);font-size:.95rem;line-height:1.6;max-width:34ch}
.foot-bottom{margin-top:72px;padding-top:24px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:12px;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
@media(min-width:769px){.foot-bottom{flex-direction:row;justify-content:space-between}}
.foot-bottom a{color:var(--muted)}
.foot-bottom a:hover{color:var(--ink)}

/* Mobile sticky & fab */
.mob-sticky{position:fixed;left:0;right:0;bottom:0;display:flex;gap:8px;padding:10px 12px;background:var(--cream);border-top:1px solid var(--line);z-index:45}
.mob-sticky .btn{flex:1;justify-content:center;padding:13px 18px;font-size:.88rem}
@media(min-width:769px){.mob-sticky{display:none}}
@media(max-width:768px){body{padding-bottom:72px}}

/* Mobile drawer */
.drawer{position:fixed;inset:0;background:rgba(11,14,26,.5);z-index:60;display:none;opacity:0;transition:opacity .3s}
.drawer.open{display:block;opacity:1}
.drawer-panel{position:absolute;right:0;top:0;bottom:0;width:88%;max-width:380px;background:var(--cream);padding:24px;transform:translateX(100%);transition:transform .3s}
.drawer.open .drawer-panel{transform:translateX(0)}
.drawer-close{border:1px solid var(--line-ink);background:transparent;width:42px;height:42px;border-radius:8px;cursor:pointer;margin-bottom:16px}
.drawer nav a{display:block;padding:14px 0;font-family:var(--serif);font-size:1.3rem;color:var(--ink);border-bottom:1px solid var(--line)}

/* Sous-menu drawer mobile (accordéon : fermé par défaut, toggle via bouton) */
.drawer .menu-item.has-sub{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:8px;border-bottom:1px solid var(--line)}
.drawer .menu-item.has-sub > .menu-link{grid-column:1;border-bottom:0}
.drawer .menu-link .chev-desktop{display:none}
.drawer .submenu-toggle{grid-column:2;display:inline-grid;place-items:center;width:42px;height:42px;background:transparent;border:0;cursor:pointer;color:var(--ink)}
.drawer .submenu-toggle i{font-size:.95rem;transition:transform .25s}
.drawer .menu-item.has-sub.open .submenu-toggle i{transform:rotate(180deg)}
.drawer .submenu{grid-column:1/-1;display:none;flex-direction:column;padding:4px 0 10px 18px}
.drawer .menu-item.has-sub.open .submenu{display:flex}
.drawer .submenu-item{padding:10px 0;font-family:var(--sans);font-size:.95rem;color:var(--muted);border-bottom:0}
.drawer .submenu-item:hover{color:var(--royal)}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============= Fluent Forms — inputs stylés (design éditorial) ============= */
.frm-fluent-form .ff-el-input--label label{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.frm-fluent-form .ff-el-is-required .ff-el-input--label label::after{content:" *";color:var(--royal);margin-left:2px}
.frm-fluent-form .ff-el-form-control,
.frm-fluent-form input[type="text"],
.frm-fluent-form input[type="email"],
.frm-fluent-form input[type="tel"],
.frm-fluent-form input[type="url"],
.frm-fluent-form input[type="number"],
.frm-fluent-form input[type="password"],
.frm-fluent-form input[type="date"],
.frm-fluent-form select,
.frm-fluent-form textarea{
  font-family:var(--sans)!important;
  font-size:.98rem!important;
  color:var(--ink)!important;
  padding:14px 16px!important;
  border:1px solid var(--line-ink)!important;
  border-radius:2px!important;
  background:var(--cream)!important;
  outline:0!important;
  transition:border-color .2s,background .2s,box-shadow .2s!important;
  width:100%;box-shadow:none!important;
  line-height:1.4!important;
}
.frm-fluent-form .ff-el-form-control:focus,
.frm-fluent-form input:focus,
.frm-fluent-form select:focus,
.frm-fluent-form textarea:focus{border-color:var(--royal)!important;background:#fff!important}
.frm-fluent-form textarea{resize:vertical;min-height:140px}
.frm-fluent-form select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235B6472' stroke-width='1.5' fill='none'/%3E%3C/svg%3E")!important;
  background-repeat:no-repeat!important;background-position:right 16px center!important;padding-right:40px!important;cursor:pointer
}

/* Nom composite : prénom | nom côte à côte sur ≥600px */
.frm-fluent-form .ff-name-field-wrapper .ff-t-container{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:600px){.frm-fluent-form .ff-name-field-wrapper .ff-t-container{grid-template-columns:1fr 1fr}}

/* Chips pour les groupes checkbox multi (ff-list-inline) */
/* Spec (0,3,1) pour battre FF default : classe .ff-default + classe + tag.class */
.ff-default .ff-el-group.ff-list-inline .ff-el-input--content{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.ff-default .ff-list-inline .ff-el-form-check{display:inline-flex;margin:0!important}
.ff-default .ff-list-inline label.ff-el-form-check-label{
  cursor:pointer;
  font-family:var(--sans)!important;
  font-size:.9rem!important;
  font-weight:400!important;
  letter-spacing:0!important;
  text-transform:none!important;
  padding:10px 16px!important;
  border:1px solid var(--line-ink)!important;
  border-radius:9999px!important;
  background:var(--cream)!important;
  color:var(--ink)!important;
  transition:all .2s!important;
  user-select:none;
  display:inline-flex;align-items:center;gap:0;line-height:1.3;
  margin:0!important;
}
.ff-default .ff-list-inline label.ff-el-form-check-label:hover{border-color:var(--ink)!important}
/* Masque le checkbox natif à l'intérieur du chip */
.ff-default .ff-list-inline label.ff-el-form-check-label>input[type="checkbox"],
.ff-default .ff-list-inline label.ff-el-form-check-label>input[type="radio"]{
  position:absolute!important;opacity:0!important;width:1px!important;height:1px!important;pointer-events:none!important;margin:0!important
}
/* État sélectionné : navy */
.ff-default .ff-list-inline label.ff-el-form-check-label:has(input:checked){
  background:var(--ink)!important;color:var(--cream)!important;border-color:var(--ink)!important
}

/* Checkbox simple (RGPD) : affichage natif discret */
.ff-default .ff-el-group:not(.ff-list-inline) label.ff-el-form-check-label{
  background:transparent!important;border:0!important;padding:0!important;border-radius:0!important;
  font-family:var(--sans)!important;font-size:.88rem!important;font-weight:400!important;
  letter-spacing:0!important;text-transform:none!important;
  color:var(--muted)!important;line-height:1.5;
  display:flex!important;align-items:flex-start!important;gap:12px!important;margin:0!important;cursor:pointer
}
.ff-default .ff-el-group.ff-el-form-hide_label label.ff-el-form-check-label input[type="checkbox"],
.ff-default .ff-el-group:not(.ff-list-inline) label.ff-el-form-check-label input[type="checkbox"]{
  position:static!important;opacity:1!important;width:auto!important;height:auto!important;
  pointer-events:auto!important;accent-color:var(--royal);margin:4px 0 0 0!important;flex:none
}

/* Espacement global du form */
.frm-fluent-form .ff-el-group{margin-bottom:20px}

/* ============= Fluent Forms — branding boutons ============= */
/* !important nécessaire pour override les règles .ff-default .ff-btn-secondary du plugin */
.ff-default .ff-btn,
.frm-fluent-form .ff-btn{
  display:inline-flex!important;align-items:center;gap:10px;
  padding:13px 26px!important;
  border-radius:9999px!important;
  font-family:var(--sans)!important;font-weight:500!important;font-size:.9rem!important;
  letter-spacing:-.005em;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s ease,background .2s ease,color .2s ease,border-color .2s ease;
  box-shadow:none!important;
  text-shadow:none;
  line-height:1.2;
}
/* Next + Submit : style primary navy */
.ff-default .ff-btn-next,
.ff-default .ff-btn-next.ff-btn-secondary,
.ff-default .ff-btn-submit,
.frm-fluent-form .ff-btn-next,
.frm-fluent-form .ff-btn-next.ff-btn-secondary,
.frm-fluent-form .ff-btn-submit{
  background:var(--ink)!important;color:var(--cream)!important;border-color:var(--ink)!important;
}
.ff-default .ff-btn-next:hover,
.ff-default .ff-btn-submit:hover,
.frm-fluent-form .ff-btn-next:hover,
.frm-fluent-form .ff-btn-submit:hover{
  background:var(--royal)!important;border-color:var(--royal)!important;color:var(--cream)!important;
}
/* Previous : style ghost */
.ff-default .ff-btn-prev,
.ff-default .ff-btn-prev.ff-btn-secondary,
.frm-fluent-form .ff-btn-prev,
.frm-fluent-form .ff-btn-prev.ff-btn-secondary{
  background:transparent!important;color:var(--ink)!important;border-color:var(--line-ink)!important;
}
.ff-default .ff-btn-prev:hover,
.frm-fluent-form .ff-btn-prev:hover{
  background:var(--ink)!important;color:var(--cream)!important;border-color:var(--ink)!important;
}

/* section tag (shown above the section title) */
.sec-meta{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:18px;margin-bottom:36px;border-bottom:1px solid var(--line-ink);font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.bg-blue .sec-meta{border-color:var(--line-blue)}
.bg-green .sec-meta{border-color:var(--line-green)}
.bg-navy .sec-meta{border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.6)}
