
:root{--bg:#0D1526;--surf:#141E33;--surf2:#101A2D;--ink:#E8EDF8;--mut:#9AA8C4;
--acc:#F5A623;--acc-dk:#FFC85C;--acc-rgb:245,166,35;--hi:#FFC85C;--dark:#080E1B;
--dark-ink:#C9D4E8;--ok:#1a9e5c;--rad:14px;--maxw:1160px;
--fh:'Outfit',serif;--fb:'Public Sans',system-ui,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}
 *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
body{font:18px/1.65 var(--fb);color:var(--ink);background:var(--bg);
 -webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--acc-dk)}
.skip{position:absolute;left:-999px;top:0;background:var(--dark);color:#fff;
 padding:.6rem 1rem;z-index:9999;border-radius:0 0 8px 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--acc);outline-offset:2px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
h1,h2,h3{font-family:var(--fh);line-height:1.18;text-wrap:balance}
h1{font-size:clamp(1.9rem,4.6vw,3.1rem)}
h2{font-size:clamp(1.45rem,3vw,2.1rem);margin-bottom:.6rem}
h3{font-size:1.14rem}
.eye{display:inline-block;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
 font-size:.78rem;color:var(--acc-dk);margin-bottom:.55rem}
section{padding:clamp(3rem,7vw,5rem) 0}
.lead{color:var(--mut);max-width:46rem}
/* ---------- header ---------- */
.top{position:sticky;top:0;z-index:900;background:color-mix(in srgb,var(--bg) 88%,transparent);
 backdrop-filter:blur(10px);border-bottom:1px solid color-mix(in srgb,var(--ink) 10%,transparent)}
.top .wrap{display:flex;align-items:center;gap:1rem;min-height:68px}
.logo{display:flex;align-items:center;gap:.6rem;font-family:var(--fh);font-weight:800;
 font-size:1.22rem;color:var(--ink);text-decoration:none}
.logo svg{width:34px;height:34px;flex:none}
.nav{margin-left:auto;display:flex;gap:1.15rem;align-items:center}
.nav a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.95rem}
.nav a:hover{color:var(--acc-dk)}
.tel-top{display:inline-flex;align-items:center;gap:.5rem;background:var(--acc);
 color:#fff;padding:.62rem 1.05rem;border-radius:999px;font-weight:800;text-decoration:none;
 white-space:nowrap;box-shadow:0 4px 14px rgba(var(--acc-rgb),.35)}
.tel-top:hover{background:var(--acc-dk)}
.tel-top svg{width:17px;height:17px}
@media(max-width:920px){.nav a:not(.tel-top){display:none}}
/* ---------- hero ---------- */
.hero{position:relative;background:var(--dark);color:var(--dark-ink);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:2.6rem;align-items:center;
 padding-top:clamp(3rem,7vw,5.5rem);padding-bottom:clamp(3rem,7vw,5.5rem)}
.hero .eye{color:var(--hi)}
.hero h1{color:#fff}
.hero p.sub{margin:.9rem 0 1.5rem;color:color-mix(in srgb,var(--dark-ink) 82%,transparent);
 font-size:1.06rem;max-width:34rem}
.hero-img{border-radius:var(--rad);box-shadow:0 24px 60px rgba(0,0,0,.45);
 aspect-ratio:4/3;object-fit:cover;width:100%}
.hero-pts{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.4rem;padding:0;list-style:none}
.hero-pts li{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
 padding:.42rem .8rem;border-radius:999px;font-size:.86rem;font-weight:600}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr}.hero-img{aspect-ratio:16/10}}
/* ---------- boutons ---------- */
.btns{display:flex;gap:.8rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.5rem;border-radius:12px;
 font-weight:800;text-decoration:none;font-size:1.02rem;transition:transform .15s}
.btn:active{transform:scale(.97)}
.btn svg{width:19px;height:19px}
.btn-acc{background:var(--acc);color:#fff;box-shadow:0 8px 22px rgba(var(--acc-rgb),.4)}
.btn-acc:hover{background:var(--acc-dk)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff}
.btn-line{background:transparent;color:var(--acc-dk);border:2px solid var(--acc)}
/* ---------- bandeau confiance ---------- */
.trust{background:var(--surf);border-bottom:1px solid color-mix(in srgb,var(--ink) 8%,transparent);
 padding:1.05rem 0}
.trust .wrap{display:flex;flex-wrap:wrap;gap:.6rem 2.2rem;justify-content:center}
.trust span{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.92rem}
.trust svg{width:18px;height:18px;color:var(--acc-dk);flex:none}
/* ---------- cartes services ---------- */
.grid{display:grid;gap:1.3rem}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:920px){.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.g3,.g2{grid-template-columns:1fr}}
.card{background:var(--surf);border:1px solid color-mix(in srgb,var(--ink) 9%,transparent);
 border-radius:var(--rad);padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;
 transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(0,0,0,.1)}
.card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
 background:rgba(var(--acc-rgb),.12);color:var(--acc-dk)}
.card .ic svg{width:24px;height:24px}
.card p{color:var(--mut);font-size:.95rem;flex:1}
.card a.more{font-weight:700;text-decoration:none}
/* ---------- etapes ---------- */
.steps{counter-reset:s}
.step{position:relative;padding:1.4rem 1.4rem 1.4rem 4.3rem;background:var(--surf);
 border-radius:var(--rad);border:1px solid color-mix(in srgb,var(--ink) 9%,transparent)}
.step::before{counter-increment:s;content:counter(s);position:absolute;left:1.15rem;top:1.25rem;
 width:2.15rem;height:2.15rem;border-radius:50%;background:var(--acc);color:#fff;font-weight:800;
 display:grid;place-items:center;font-size:1.05rem}
.step p{color:var(--mut);font-size:.94rem;margin-top:.25rem}
/* ---------- section sombre CTA ---------- */
.cta-band{background:var(--dark);color:var(--dark-ink);text-align:center;border-radius:var(--rad)}
.cta-band h2{color:#fff}
.cta-inner{padding:clamp(2.4rem,5vw,3.6rem) 1.4rem}
.cta-band .btns{justify-content:center;margin-top:1.4rem}
.tel-big{font-family:var(--fh);font-size:clamp(1.6rem,4.5vw,2.5rem);font-weight:800;color:var(--hi);
 text-decoration:none;display:inline-block;margin-top:.6rem}
/* ---------- zone / chips villes ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.1rem}
.chips a{background:var(--surf);border:1px solid color-mix(in srgb,var(--ink) 12%,transparent);
 border-radius:999px;padding:.44rem .9rem;text-decoration:none;color:var(--ink);
 font-weight:600;font-size:.9rem}
.chips a:hover{border-color:var(--acc);color:var(--acc-dk)}
/* ---------- tarifs ---------- */
.tbl{width:100%;border-collapse:collapse;background:var(--surf);border-radius:var(--rad);
 overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.tbl th{background:var(--dark);color:#fff;text-align:left;padding:.85rem 1.1rem;font-size:.92rem}
.tbl td{padding:.85rem 1.1rem;border-top:1px solid color-mix(in srgb,var(--ink) 8%,transparent);
 font-size:.95rem}
.tbl td:last-child{font-weight:800;white-space:nowrap;color:var(--acc-dk)}
.note-prix{margin-top:1rem;background:rgba(var(--acc-rgb),.08);border-left:4px solid var(--acc);
 padding:.9rem 1.1rem;border-radius:0 10px 10px 0;font-size:.94rem}
.tblwrap{overflow-x:auto}
/* ---------- FAQ ---------- */
.faq details{background:var(--surf);border:1px solid color-mix(in srgb,var(--ink) 9%,transparent);
 border-radius:12px;margin-bottom:.7rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1.05rem 1.2rem;font-weight:700;list-style:none;
 display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--acc-dk);flex:none;font-weight:400}
.faq details[open] summary::after{content:"\2212"}
.faq .a{padding:0 1.2rem 1.1rem;color:var(--mut);font-size:.96rem}
/* ---------- avis ---------- */
.rev{background:var(--surf);border-radius:var(--rad);padding:1.35rem;
 border:1px solid color-mix(in srgb,var(--ink) 9%,transparent)}
.rev .stars{color:#e8a812;letter-spacing:2px;font-size:.95rem}
.rev p{font-size:.94rem;color:var(--mut);margin:.6rem 0}
.rev .who{font-weight:700;font-size:.88rem}
.rev .who small{color:var(--mut);font-weight:500}
/* ---------- formulaires ---------- */
.form{background:var(--surf);border-radius:var(--rad);padding:1.8rem;
 border:1px solid color-mix(in srgb,var(--ink) 10%,transparent);max-width:620px}
.form label{display:block;font-weight:700;font-size:.9rem;margin:.9rem 0 .3rem}
.form input,.form select,.form textarea{width:100%;padding:.85rem .95rem;border-radius:10px;
 border:1.5px solid color-mix(in srgb,var(--ink) 22%,transparent);font:inherit;background:var(--bg)}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--acc);outline:none}
.form button{margin-top:1.2rem;width:100%;border:0;cursor:pointer}
.hp{position:absolute!important;left:-9999px!important;opacity:0;height:0;overflow:hidden}
/* ---------- footer ---------- */
footer{background:var(--dark);color:var(--dark-ink);padding:3rem 0 6.5rem;margin-top:2rem}
footer h3{color:#fff;font-size:1rem;margin-bottom:.7rem}
footer a{color:color-mix(in srgb,var(--dark-ink) 85%,transparent);text-decoration:none;font-size:.92rem}
footer a:hover{color:var(--hi)}
.fgrid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2rem}
@media(max-width:860px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}
.fgrid ul{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.copy{margin-top:2.2rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.12);
 font-size:.85rem;color:color-mix(in srgb,var(--dark-ink) 65%,transparent)}
/* ---------- callbar mobile (2 actions) ---------- */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:950;display:none;
 grid-template-columns:1.25fr 1fr;gap:1px;background:rgba(0,0,0,.2);
 padding-bottom:env(safe-area-inset-bottom)}
.callbar a{display:flex;align-items:center;justify-content:center;gap:.5rem;
 padding:.95rem .5rem;font-weight:800;text-decoration:none;font-size:1rem}
.callbar .c1{background:var(--acc);color:#fff}
.callbar .c2{background:var(--dark);color:#fff}
.callbar svg{width:18px;height:18px}
@media(max-width:860px){.callbar{display:grid}}
@keyframes ring{0%,100%{transform:rotate(0)}10%{transform:rotate(14deg)}
 20%{transform:rotate(-12deg)}30%{transform:rotate(9deg)}40%{transform:rotate(-6deg)}
 50%{transform:rotate(0)}}
.ringy{animation:ring 1.6s ease-in-out infinite;transform-origin:50% 20%}
/* ---------- FAB desktop ---------- */
.fab{position:fixed;right:24px;bottom:24px;z-index:940;display:none;align-items:center;gap:.6rem;
 background:var(--acc);color:#fff;font-weight:800;padding:.9rem 1.35rem;border-radius:999px;
 text-decoration:none;box-shadow:0 12px 30px rgba(var(--acc-rgb),.45)}
.fab:hover{background:var(--acc-dk)}
.fab svg{width:19px;height:19px}
@media(min-width:861px){.fab{display:inline-flex}}
/* ---------- reveal ---------- */
.rv{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.rv.on{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}}
/* ---------- divers ---------- */
.badge66{display:inline-flex;align-items:center;gap:.45rem;background:rgba(var(--acc-rgb),.1);
 color:var(--acc-dk);font-weight:800;font-size:.82rem;border-radius:999px;padding:.35rem .85rem;
 border:1px solid rgba(var(--acc-rgb),.25)}
.prose{max-width:46rem}
.prose p{margin-bottom:1rem}
.prose h2{margin-top:2.2rem}
.prose ul{margin:0 0 1rem 1.2rem}
.prose li{margin-bottom:.4rem}
.crumbs{font-size:.85rem;color:var(--mut);padding:1rem 0 0}
.crumbs a{color:var(--mut)}
.phero{background:var(--dark);color:var(--dark-ink);padding:clamp(2.4rem,5vw,3.6rem) 0}
.phero h1{color:#fff}
.phero .eye{color:var(--hi)}
.phero p{max-width:44rem;margin-top:.7rem;color:color-mix(in srgb,var(--dark-ink) 82%,transparent)}
.btn-acc{color:#151004}.tel-top{color:#151004}.callbar .c1{color:#151004}.fab{color:#151004}.card:hover{box-shadow:0 16px 38px rgba(0,0,0,.5)}.tbl th{background:#1B2741}