:root{
  --pri:#3a7ae0; --acc:#e07a3a; --ink:#000; --mut:#6b7280; --ln:#e6e9ef; --soft:#f7fafc;
  --rad:18px; --rad-sm:12px; --shadow:0 16px 50px rgba(0,0,0,.08);
}
*{box-sizing:border-box} html,body{background:#fff;color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial}
img{max-width:100%;height:auto}

/* ---------- Header (glass) ---------- */
.hd{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.72);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid rgba(230,233,239,.6);transition:box-shadow .2s ease}
.hd[data-shadow="1"]{box-shadow:0 10px 30px rgba(0,0,0,.05)}
.hd__bar{height:76px;display:flex;align-items:center;justify-content:space-between}
.nav{display:flex;align-items:center}
.nav a{display:flex;align-items:center;height:44px;margin-left:24px;text-decoration:none;color:#0b0b0b;font-weight:600;line-height:1}
.btn--ghost{border:1px solid var(--ln);padding:10px 14px;border-radius:999px;color:#111;background:#fff}
.btn--ghost:hover{background:var(--pri);color:#fff;border-color:var(--pri)}
.hd__burger{background:transparent;border:0;display:inline-flex;flex-direction:column;gap:5px}
.hd__burger span{display:block;width:28px;height:2px;background:#111}
.mnav{display:flex;flex-direction:column;padding:12px 0;border-top:1px solid var(--ln)}
.mnav a{padding:12px 0;text-decoration:none;color:#111;border-bottom:1px solid var(--ln)}
.mnav a:last-child{border-bottom:0}

/* ---------- Hero bespoke ---------- */
.hero{position:relative;overflow:hidden;padding:84px 0 56px}
.hero__bg{position:absolute;inset:0;pointer-events:none}
.hero__angle{position:absolute;top:-80px;right:-60px;width:460px;opacity:.11}
.glow{position:absolute;border-radius:50%;filter:blur(50px);opacity:.35}
.glow--1{width:380px;height:380px;background:radial-gradient(circle at 40% 40%, #3a7ae0, transparent 60%);top:-60px;left:-40px}
.glow--2{width:420px;height:420px;background:radial-gradient(circle at 60% 60%, #e07a3a, transparent 60%);bottom:-120px;right:-120px}

.xxl{font-size: clamp(2.2rem, 2.6vw + 1.4rem, 3.2rem);font-weight:800;letter-spacing:-.02em}
.lead{font-size:1.125rem;color:#0f172a}
.grad{background:linear-gradient(90deg,var(--pri),var(--acc));-webkit-background-clip:text;background-clip:text;color:transparent}

.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{border:1px solid var(--ln);border-radius:999px;padding:8px 12px;font-weight:600;background:#fff}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.lnk{font-weight:700;text-decoration:none}
.lnk:hover{text-decoration:underline}
.delivery{color:#0f172a}

/* Stats */
.statbar{display:flex;gap:14px;flex-wrap:wrap}
.stat{border:1px solid var(--ln);border-radius:14px;padding:12px 14px;background:#fff}
.stat span{display:block;font-weight:800;color:var(--pri);font-size:1.25rem;line-height:1}
.stat small{color:var(--mut)}

.mockup{position:relative}
.mockup__img{border-radius:var(--rad);box-shadow:var(--shadow)}
.mockup__card{position:absolute;right:-10px;background:#fff;border:1px solid var(--ln);border-radius:12px;padding:10px 12px;box-shadow:0 10px 24px rgba(0,0,0,.06);font-weight:600}
.a1{top:10%}.a2{top:42%}.a3{bottom:8%}

/* ---------- Sections ---------- */
.sect{padding:72px 0}
.sect--alt{background:var(--soft)}
.sect__head{max-width:820px;margin:0 auto 24px;text-align:center}
.sect__head p{color:var(--mut)}

/* grid util */
.grid{display:grid;gap:18px}
.grid--4{grid-template-columns:repeat(4, minmax(0,1fr))}
@media (max-width:991.98px){.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:575.98px){.grid--4{grid-template-columns:1fr}}

/* tiles */
.tile{background:#fff;border:1px solid var(--ln);border-radius:18px;padding:20px;transition:transform .16s ease, box-shadow .2s ease}
.tile:hover{box-shadow:var(--shadow)}
.tile--up{transform:translateY(-10px)}
.icn{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--pri),var(--acc));position:relative;margin-bottom:8px}
.icn::after{content:"";position:absolute;inset:0;margin:auto}
.icn--home::after{width:22px;height:14px;background:#fff;border-radius:3px;transform:translateY(4px)}
.icn--shield::after{width:22px;height:22px;border-radius:6px;background:#fff;box-shadow:inset 0 0 0 4px rgba(255,255,255,.35)}
.icn--auto::after{width:20px;height:10px;background:#fff;border-radius:10px 10px 0 0;transform:translateY(8px);box-shadow:0 14px 0 0 #fff, 24px 14px 0 0 #fff}
.icn--edu::after{width:22px;height:12px;background:#fff;border-radius:2px;box-shadow:0 12px 0 0 rgba(255,255,255,.35)}
.icn--euro::after{content:'€';display:block;width:100%;height:100%;color:#fff;font:800 16px/46px Inter,system-ui;text-align:center}
.icn--health::after{width:18px;height:18px;background:#fff;clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.icn--energy::after{width:14px;height:22px;background:#fff;border-radius:8px 8px 2px 2px;transform:skewX(-6deg)}
.icn--spark::after{width:4px;height:22px;background:#fff;box-shadow:-8px -8px 0 0 rgba(255,255,255,.5),8px 8px 0 0 rgba(255,255,255,.5)}

/* rail timeline */
.rail{position:relative;margin:0 auto;max-width:860px}
.rail::before{content:"";position:absolute;left:20px;top:0;bottom:0;width:2px;background:linear-gradient(var(--pri),var(--acc))}
.rail__step{position:relative;display:flex;gap:16px;padding-bottom:18px}
.rail__dot{position:relative;z-index:1;margin-top:4px;display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--pri),var(--acc));color:#fff;font-weight:800}
.rail__card{background:#fff;border:1px solid var(--ln);border-radius:16px;padding:16px 18px;flex:1}

/* stripes commitments */
.sect--stripes{background:linear-gradient(180deg,#fff,#f9fbff)}
.stripes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:991.98px){.stripes{grid-template-columns:1fr}}
.stripe{background:#fff;border:1px solid var(--ln);border-radius:18px;padding:22px;text-align:center}
.stripe h5{margin:8px 0 6px}
.ico{width:56px;height:56px;margin:0 auto 6px;border-radius:14px;background:linear-gradient(135deg,var(--pri),var(--acc));position:relative}
.ico::after{content:"";position:absolute;inset:0;margin:auto}
.ico--exclusive::after{width:22px;height:22px;background:#fff;border-radius:50%;box-shadow:0 0 0 6px rgba(255,255,255,.35)}
.ico--transparency::after{width:26px;height:16px;border:3px solid #fff;border-radius:12px;box-shadow:inset 12px 0 0 0 #fff}
.ico--support::after{width:24px;height:24px;border:3px solid #fff;border-radius:50%;box-shadow:inset 0 0 0 3px rgba(255,255,255,.35)}

/* mosaic testimonials */
.mosaic{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:991.98px){.mosaic{grid-template-columns:1fr 1fr}}
@media (max-width:575.98px){.mosaic{grid-template-columns:1fr}}
.q{background:#fff;border:1px solid var(--ln);border-radius:18px;padding:20px}
.q--accent{border-color:rgba(224,122,58,.4);box-shadow:0 14px 34px rgba(224,122,58,.15)}
.q__id{display:flex;gap:10px;align-items:center;margin-top:10px}
.a{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--pri),var(--acc));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}

/* CTA */
.cta{padding:60px 0;background:linear-gradient(180deg,#fff,#f8fbff)}
.cta__card{background:#fff;border:1px solid var(--ln);border-radius:18px;padding:24px;box-shadow:var(--shadow)}

/* Form */
.form-shell{max-width:720px;margin:0 auto}
.form .lbl{display:block;font-weight:700;margin-bottom:6px}
.in{display:block;width:100%;border:1px solid var(--ln);border-radius:12px;padding:12px 14px;background:#fff;box-shadow:none}
.in:focus{outline:0;border-color:var(--pri);box-shadow:0 0 0 3px rgba(58,122,224,.18)}
.ck{display:flex;align-items:center;gap:10px;font-weight:600}

/* Buttons */
.btn{display:inline-block;border-radius:999px;text-decoration:none;font-weight:800;letter-spacing:.01em}
.btn--primary{background:var(--pri);color:#fff;padding:12px 18px;box-shadow:0 14px 30px rgba(58,122,224,.25)}
.btn--primary:hover{opacity:.96}

/* Footer */
.ft{border-top:1px solid var(--ln);padding:22px 0;background:#fff}
.muted{color:var(--mut)}


/* === Global selection behavior === */
body, body * { user-select: none; }
input, textarea, select { user-select: text; }

/* === Custom carousel styles === */
.caro{position:relative}
.caro__viewport{overflow:hidden;border:1px solid var(--ln);border-radius:18px;background:#fff}
.caro__track{display:flex;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.caro__slide{flex:0 0 100%;padding:24px}
.caro__quote{font-size:1.05rem;color:#111;margin:0 0 14px}
.caro__id{display:flex;gap:12px;align-items:center}
.caro__avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--pri),var(--acc));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}
.caro__meta b{display:block}
.caro__nav{position:absolute;inset-block-start:50%;inset-inline:0;display:flex;justify-content:space-between;pointer-events:none}
.caro__btn{pointer-events:auto;border:1px solid var(--ln);background:#fff;border-radius:999px;width:42px;height:42px;display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,.08)}
.caro__btn:hover{border-color:#cfd5e3}
.caro__btn svg{width:20px;height:20px}
.caro__dots{display:flex;gap:8px;justify-content:center;margin-top:12px}
.caro__dot{width:8px;height:8px;border-radius:50%;background:#d5dbe6}
.caro__dot[aria-current="true"]{background:#3a7ae0}


/* === Carousel: 3-up layout with responsive fallbacks === */
.caro__slide{flex:0 0 33.3333%} /* desktop: 3 per view */
@media (max-width:991.98px){ .caro__slide{flex:0 0 50%} } /* tablet: 2 per view */
@media (max-width:575.98px){ .caro__slide{flex:0 0 100%} } /* mobile: 1 per view */

/* Fix sectors alignment: remove raised offset */
.tile--up{transform:none}


/* === Tweaks v15 === */
/* Smaller titles in 'Secteurs couverts' tiles */
.tile h3 { font-size: 1.05rem; line-height: 1.2; margin-top: 6px; }

/* Match the same smaller size for 'Méthode claire' step titles */
.rail__card h4 { font-size: 1.05rem; line-height: 1.2; margin: 0 0 6px; }

/* Mobile menu: drop the 'Demander un devis' button by 10px */
.mnav .btn--ghost { margin-top: 10px; }

/* Inline CTA blocks at the bottom of sections */
.cta-inline { text-align: center; margin-top: 18px; }
.cta-inline .btn--primary { padding: 12px 18px; }


/* === Tweaks v16 === */
/* Sector titles in bold */
.tile h3 { font-weight: 700; }

/* Extra spacing under mobile menu button */
.mnav .btn--ghost { margin-top: 10px; margin-bottom: 10px; }


/* === Tweaks v17 === */
/* Method step titles bold */
.rail__card h4 { font-weight: 700; }


/* === Tweaks v18 === */
/* Mobile menu: white background */
.mnav { background:#fff; }

/* Secteurs couverts: add 5px space above tile titles */
.tile h3 { margin-top: 11px; } /* was ~6px; +5px */

/* Mobile menu button spacing: reduce 5px under CTA */
.mnav .btn--ghost { margin-bottom: 5px; } /* was 10px */

/* Méthode claire: vertically center content inside cards */
.rail__card { display:flex; flex-direction:column; justify-content:center; }
