:root{--navy:#001f4b;--navy2:#062f69;--blue:#005fd1;--blue2:#0876ee;--sky:#eaf4ff;--pale:#f5f8fc;--paper:#fff;--ink:#071a34;--muted:#5c6b80;--orange:#ff7a1a;--orange2:#ff9a3d;--line:#dce6f3;--shadow:0 18px 45px rgba(0,39,89,.14);--radius:22px;--wrap:1180px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(180deg,#f7fbff 0,#fff 38%,#f4f8fd 100%);color:var(--ink);line-height:1.55}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.wrap{width:min(var(--wrap),calc(100% - 32px));margin-inline:auto}.topbar{background:var(--navy);color:#dbeafe;font-size:14px}.topbar__in{height:38px;display:flex;align-items:center;justify-content:space-between;gap:20px}.topbar a{font-weight:800;color:#fff;margin-left:14px}.top-phone{display:inline-flex;align-items:center;gap:8px}.top-phone svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(15px);box-shadow:0 5px 18px rgba(0,31,75,.08)}.nav{height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand img{height:55px;width:auto}.menu{display:flex;align-items:center;gap:7px}.navlink{padding:24px 14px;font-weight:850;color:#071a34;position:relative}.navlink:after{content:"";position:absolute;left:14px;right:14px;bottom:13px;height:3px;background:var(--blue);border-radius:10px;transform:scaleX(0);transition:.2s}.navlink:hover:after,.navlink.active:after{transform:scaleX(1)}.navdrop{position:relative}.dropdown{position:absolute;top:100%;left:0;background:#fff;min-width:270px;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:10px;display:none}.navdrop:hover .dropdown{display:grid}.dropdown a{padding:11px 12px;border-radius:12px;font-weight:750;color:#17365e}.dropdown a:hover{background:var(--sky);color:var(--blue)}.burger{display:none;background:transparent;border:0;padding:10px}.burger span{display:block;width:25px;height:3px;background:var(--navy);margin:5px;border-radius:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;font-weight:900;padding:15px 22px;border-radius:13px;box-shadow:0 14px 30px rgba(255,122,26,.28);cursor:pointer}.btn svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:2}.btn--ghost{background:rgba(0,31,75,.08);color:#fff;border:1px solid rgba(255,255,255,.45);box-shadow:none}.btn--ghost.dark{color:var(--navy);border-color:#bfd4ed;background:#fff}.btn--small{padding:10px 16px;border-radius:12px}.hero{position:relative;isolation:isolate;background:var(--navy);overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,31,75,.98) 0%,rgba(0,59,130,.88) 42%,rgba(0,59,130,.35) 70%,rgba(0,31,75,.10) 100%);z-index:-1}.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center right;z-index:-2;filter:saturate(1.1)}.hero__in{min-height:520px;display:grid;grid-template-columns:1fr .88fr;align-items:center;gap:40px;padding:70px 0 82px}.eyebrow{display:inline-flex;align-items:center;gap:8px;color:#66b3ff;font-size:13px;text-transform:uppercase;letter-spacing:.12em;font-weight:950}.hero h1{font-size:clamp(42px,6vw,78px);line-height:.96;margin:18px 0;color:#fff;letter-spacing:-.05em}.hero p{font-size:21px;color:#dbeafe;max-width:600px;margin:0 0 26px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.rating{display:flex;align-items:center;gap:10px;color:#fff;font-weight:850;margin-top:26px}.stars{color:#ffc247;letter-spacing:2px}.hero-card{justify-self:end;align-self:end;background:linear-gradient(135deg,#005fd1,#003b82);color:#fff;border-radius:24px;padding:22px;box-shadow:var(--shadow);min-width:210px}.hero-card b{font-size:44px;display:block;line-height:1}.guarantees{margin-top:-55px;position:relative;z-index:3}.guarantees__grid{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden}.guarantee{display:flex;gap:16px;padding:24px;border-right:1px solid var(--line)}.guarantee:last-child{border:0}.bubble{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,#e9f4ff,#d6eaff);color:var(--blue);display:grid;place-items:center;flex:0 0 auto}.bubble svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2}.guarantee h3{margin:0 0 4px;font-size:17px}.guarantee p{margin:0;color:var(--muted);font-size:14px}.section{padding:78px 0}.section--pale{background:linear-gradient(180deg,#f4f9ff,#ffffff)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:30px;margin-bottom:34px}.section-head h2{font-size:clamp(30px,4vw,48px);letter-spacing:-.04em;line-height:1.05;margin:8px 0 0;color:var(--navy)}.section-head p{max-width:560px;color:var(--muted);font-size:18px}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.service-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:0 12px 30px rgba(0,54,116,.08);transition:.18s}.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.service-img{height:190px;background-size:cover;background-position:center;position:relative}.service-img:after,.zone-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,59,130,.02),rgba(0,31,75,.34))}.service-body{padding:20px;position:relative}.service-icon{position:absolute;top:-28px;left:20px;width:54px;height:54px;border-radius:17px;background:var(--blue);color:white;display:grid;place-items:center;box-shadow:0 12px 24px rgba(0,95,209,.25)}.service-icon svg{width:27px;height:27px;fill:none;stroke:currentColor;stroke-width:2}.service-card h3{margin:12px 0 4px;color:var(--navy);font-size:21px}.price{font-weight:950;color:var(--blue);margin-bottom:7px}.service-card p{color:var(--muted);margin:0 0 15px}.more{font-weight:950;color:var(--blue)}.stats{background:linear-gradient(90deg,#003b82,#0067d8);color:#fff;padding:25px 0}.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}.stat{display:flex;align-items:center;gap:16px;justify-content:center;border-right:1px solid rgba(255,255,255,.25)}.stat:last-child{border:0}.stat svg{width:38px;height:38px;fill:none;stroke:#cfe8ff;stroke-width:1.8}.stat b{font-size:30px;line-height:1}.stat span{display:block;color:#d9edff}.zones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.zone-card{min-height:185px;border-radius:22px;overflow:hidden;position:relative;background-size:cover;background-position:center;color:#fff;box-shadow:0 14px 34px rgba(0,42,96,.16);isolation:isolate}.zone-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,31,75,.82),rgba(0,95,209,.30));z-index:1}.zone-card__in{position:relative;z-index:2;padding:22px;height:100%;display:flex;flex-direction:column;justify-content:space-between}.zone-card h3{margin:0;font-size:24px}.zone-card b{font-size:56px;line-height:1}.zone-card span{font-weight:800;color:#dbeafe}.cards-3{display:grid;grid-template-columns:1.05fr 1fr .95fr;gap:22px}.panel{background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:0 10px 28px rgba(0,54,116,.07)}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}.step{text-align:center}.step .bubble{margin:auto}.step strong{display:block;margin-top:12px;color:var(--navy)}.step small{color:var(--muted)}.review{border:1px solid var(--line);border-radius:18px;padding:16px;margin-top:12px;background:#fbfdff}.review-head{display:flex;align-items:center;gap:12px}.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#bfdbfe,#0b63ce)}.faq-item{border:1px solid var(--line);border-radius:14px;margin:10px 0;background:#fbfdff;overflow:hidden}.faq-q{width:100%;background:transparent;border:0;padding:14px 16px;text-align:left;font-weight:900;color:var(--navy);display:flex;justify-content:space-between}.faq-a{display:none;padding:0 16px 14px;color:var(--muted)}.faq-item.open .faq-a{display:block}.brands{display:flex;gap:12px;flex-wrap:wrap}.brand-pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:12px 16px;font-weight:900;color:#17365e}.tarif-table{width:100%;border-collapse:separate;border-spacing:0 12px}.tarif-table tr{background:#fff;box-shadow:0 8px 20px rgba(0,54,116,.07)}.tarif-table td,.tarif-table th{padding:18px;text-align:left}.tarif-table th{color:var(--blue);font-size:13px;text-transform:uppercase;letter-spacing:.1em}.tarif-table td:first-child,.tarif-table th:first-child{border-radius:15px 0 0 15px}.tarif-table td:last-child,.tarif-table th:last-child{border-radius:0 15px 15px 0;font-weight:950}.form{display:grid;gap:14px}.form input,.form textarea,.form select{width:100%;border:1px solid #cdddf0;border-radius:14px;padding:14px 16px;font:inherit;background:#fff}.form textarea{min-height:140px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.final-cta{padding:55px 0;background:linear-gradient(135deg,#004da8,#0072f0);color:#fff}.final-cta h2{font-size:40px;margin:8px 0;letter-spacing:-.04em}.final-cta p{color:#dbeafe}.final-cta__in{display:flex;align-items:center;justify-content:space-between;gap:24px}.footer{background:#001f4b;color:#dbeafe;padding:48px 0 80px}.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.2fr;gap:32px}.footer-logo{background:#fff;border-radius:14px;padding:4px;width:230px;margin-bottom:15px}.footer h3{color:#fff;text-transform:uppercase;font-size:14px;letter-spacing:.12em}.footer a,.footer span{display:block;color:#dbeafe;margin:8px 0}.socials{display:flex;gap:9px}.socials a{width:34px;height:34px;border-radius:50%;background:#0b63ce;display:grid;place-items:center;color:#fff;font-weight:900}.zone-pills{display:flex;flex-wrap:wrap;gap:9px}.zone-pills a{background:#0b63ce;color:#fff;padding:8px 12px;border-radius:999px;font-weight:850}.copyright{text-align:center;color:#9cc7ff;border-top:1px solid rgba(255,255,255,.13);margin-top:35px;padding-top:22px}.mobile-cta{display:none}.content-hero{padding:70px 0;background:linear-gradient(135deg,#003b82,#0876ee);color:#fff}.content-hero h1{font-size:clamp(38px,5vw,62px);line-height:1;margin:0 0 14px;letter-spacing:-.04em}.content-hero p{font-size:20px;color:#dbeafe;max-width:760px}.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:start}.photo-card{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);min-height:390px;background-size:cover;background-position:center}.check-list{display:grid;gap:12px;margin:20px 0}.check-list li{list-style:none;background:#fff;border:1px solid var(--line);padding:13px 15px;border-radius:14px;color:#17365e;font-weight:800}.check-list li:before{content:'✓';color:var(--blue);font-weight:950;margin-right:10px}@media(max-width:980px){.topbar__left{display:none}.menu{position:fixed;left:16px;right:16px;top:114px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px;padding:12px;display:none;flex-direction:column;align-items:stretch}.menu.open{display:flex}.navlink{padding:13px}.dropdown{position:static;display:grid;box-shadow:none;border:0;background:#f5f9ff}.burger{display:block}.hero__in{grid-template-columns:1fr;min-height:560px}.hero-card{justify-self:start}.guarantees__grid,.services-grid,.zones-grid,.stats__grid,.cards-3,.footer__grid,.two-col{grid-template-columns:1fr 1fr}.guarantee:nth-child(2){border-right:0}.stat:nth-child(2){border-right:0}.section-head{display:block}.footer__grid{gap:22px}}@media(max-width:680px){body{padding-bottom:62px}.wrap{width:min(100% - 22px,var(--wrap))}.topbar__right span{display:none}.nav{height:70px}.brand img{width:220px;height:auto}.hero__in{padding:46px 0 88px}.hero h1{font-size:43px}.hero p{font-size:18px}.guarantees{margin-top:-44px}.guarantees__grid,.services-grid,.zones-grid,.stats__grid,.cards-3,.footer__grid,.steps,.form-grid,.two-col{grid-template-columns:1fr}.guarantee,.stat{border-right:0;border-bottom:1px solid var(--line)}.stat{justify-content:flex-start;padding:14px}.section{padding:54px 0}.final-cta__in{display:block}.mobile-cta{position:fixed;display:grid;grid-template-columns:repeat(3,1fr);left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);z-index:90;box-shadow:0 -10px 28px rgba(0,39,89,.12)}.mobile-cta a{text-align:center;padding:13px 8px;font-weight:950;color:var(--blue)}.mobile-cta a:first-child{background:var(--orange);color:#fff}.footer{padding-bottom:90px}}

/* --- Corrections coordonnées, agences, barre fixe --- */
body{padding-bottom:76px}.topbar{display:none!important}.agencybar{background:linear-gradient(90deg,#001f4b,#004da8);color:#eaf4ff;font-size:13px}.agencybar__in{min-height:42px;display:flex;align-items:center;gap:18px;justify-content:center;flex-wrap:wrap}.agencybar strong{color:#fff}.agencybar a{display:inline-flex;align-items:center;gap:7px;color:#fff;font-weight:950}.agencybar svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}.site-header{top:0}.brand img{height:62px}.hero-bg{background-position:center center;filter:saturate(1.08) contrast(1.04)}.hero:before{background:linear-gradient(90deg,rgba(0,31,75,.96) 0%,rgba(0,59,130,.91) 40%,rgba(0,95,209,.48) 66%,rgba(0,31,75,.18) 100%)}.service-img{background-position:center}.footer-agencies{color:#dbeafe}.fixed-actions{position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:120;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:min(720px,calc(100% - 22px));background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border:1px solid #cfe0f5;border-radius:22px;padding:9px;box-shadow:0 -8px 36px rgba(0,31,75,.18)}.fixed-actions a{display:flex;align-items:center;justify-content:center;gap:9px;border-radius:15px;padding:13px 12px;font-weight:950;color:#003b82;background:#eaf4ff}.fixed-actions a svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:2}.fixed-actions__call{background:linear-gradient(135deg,#ff7a1a,#ff9a3d)!important;color:#fff!important}.fixed-actions__whatsapp{background:#16a34a!important;color:#fff!important}.fixed-actions__contact{background:#005fd1!important;color:#fff!important}.mobile-cta{display:none!important}.agency-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.agency-card{background:#fff;border:1px solid var(--line);border-radius:28px;overflow:hidden;box-shadow:0 14px 36px rgba(0,54,116,.10)}.agency-card__img{min-height:260px;background-size:cover;background-position:center;position:relative}.agency-card__img:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,95,209,.02),rgba(0,31,75,.32))}.agency-card__body{padding:26px}.agency-card h2,.agency-card h3{margin:8px 0 10px;color:var(--navy);font-size:clamp(24px,3vw,34px);letter-spacing:-.035em}.agency-address{display:flex;gap:8px;align-items:flex-start;color:#17365e;font-weight:850}.agency-address svg{width:20px;height:20px;flex:0 0 auto;fill:none;stroke:var(--blue);stroke-width:2}.agency-hero{position:relative;background-size:cover;background-position:center;isolation:isolate;color:#fff}.agency-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,31,75,.95),rgba(0,76,168,.68),rgba(0,31,75,.18));z-index:-1}.agency-hero__in{min-height:430px;display:flex;flex-direction:column;justify-content:center;padding:70px 0}.agency-hero h1{font-size:clamp(42px,6vw,74px);line-height:.96;margin:14px 0;letter-spacing:-.05em}.agency-hero p{font-size:21px;color:#eaf4ff;max-width:760px}.agency-panel a{color:var(--blue);font-weight:950}.map-card{background:linear-gradient(135deg,#eaf4ff,#fff);border:1px dashed #9cc7ff;border-radius:18px;padding:30px;text-align:center;color:#003b82;font-weight:900}.compact .agency-card__img{min-height:220px}
@media(max-width:980px){.agencybar__in{justify-content:flex-start}.menu{top:128px}.agency-grid{grid-template-columns:1fr}.brand img{height:56px}.fixed-actions{bottom:10px}}
@media(max-width:680px){body{padding-bottom:82px}.agencybar__in span{display:none}.agencybar__in{justify-content:space-between}.fixed-actions{width:calc(100% - 14px);gap:6px;border-radius:18px;padding:7px}.fixed-actions a{font-size:13px;padding:12px 6px}.fixed-actions a svg{width:17px;height:17px}.brand img{width:240px;height:auto}.menu{top:112px}.agency-card__body{padding:20px}.agency-hero__in{min-height:390px}.footer{padding-bottom:105px}}

/* --- FINAL IDF CLEAN PATCH --- */
.agencybar,.topbar{display:none!important}.site-header{top:0!important}.menu{top:90px}.brand img{height:66px;width:auto}.footer__grid--clean{grid-template-columns:1.4fr 1fr 1fr 1.1fr 1.2fr}.footer-btn{display:flex!important;align-items:center;gap:8px;background:#0b63ce;color:#fff!important;width:max-content;padding:9px 12px;border-radius:12px;font-weight:900}.footer-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}.btn--whatsapp{background:#16a34a;box-shadow:0 14px 30px rgba(22,163,74,.25)}.contact-buttons{display:flex;flex-wrap:wrap;gap:12px;margin:20px 0}.service-img{height:200px}.hero-bg{background-position:center right}.hero:before{background:linear-gradient(90deg,rgba(0,31,75,.98) 0%,rgba(0,59,130,.93) 46%,rgba(0,95,209,.55) 72%,rgba(0,31,75,.20) 100%)}.navlink{letter-spacing:.01em}@media(max-width:980px){.menu{top:86px}}@media(max-width:680px){.brand img{width:235px;height:auto}.menu{top:80px}.footer__grid--clean{grid-template-columns:1fr}.hero__in{padding-top:54px}.service-img{height:185px}}

/* --- SEO pages services / zones / agences --- */
.seo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.seo-grid .panel h3{margin-top:0;color:var(--navy);font-size:22px}
.local-link{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--navy)}
.local-link strong{font-weight:950}
.local-link span{background:var(--sky);color:var(--blue);padding:6px 10px;border-radius:999px;font-weight:950}
.zone-pills--large a{padding:12px 16px;margin:4px 4px 4px 0}
.btn--whatsapp{background:#16a34a!important;color:#fff!important}
@media(max-width:980px){.seo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.seo-grid{grid-template-columns:1fr}}

/* --- Patch SEO local zones --- */
.city-cloud{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0}
.city-cloud span{background:#eaf4ff;border:1px solid #cfe0f5;color:#003b82;font-weight:900;border-radius:999px;padding:9px 12px}
.muted-note{color:var(--muted);font-size:14px}
.zones-grid{grid-template-columns:repeat(4,1fr)}
.zone-card{background-position:center;background-size:cover}
.zone-card__in span{font-size:14px;line-height:1.35}
@media(max-width:1100px){.zones-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.zones-grid{grid-template-columns:1fr}.city-cloud span{font-size:13px}}

/* --- Mega SEO local clean --- */
.city-group{margin-bottom:22px}
.city-group h2,.city-group h3{color:var(--navy);margin-top:0}
.city-cloud{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0}
.city-cloud a,.city-cloud span{display:inline-flex;background:#eaf4ff;border:1px solid #cfe0f5;color:#003b82;font-weight:900;border-radius:999px;padding:9px 12px}
.seo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.local-link{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);color:var(--navy)}
.local-link strong{font-weight:950}
.local-link span{background:var(--sky);color:var(--blue);padding:6px 10px;border-radius:999px;font-weight:950}
.zone-card{background-position:center;background-size:cover}
.zone-card__in span{font-size:14px;line-height:1.35}
.btn--whatsapp{background:#16a34a!important;color:#fff!important}
@media(max-width:1100px){.seo-grid,.zones-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.seo-grid,.zones-grid{grid-template-columns:1fr}.city-cloud a,.city-cloud span{font-size:13px}}

/* --- Regroupement propre zones + villes --- */
.zones-grid--clean{margin-bottom:10px}
.department-list{display:grid;gap:22px}
.department-block{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:0 12px 30px rgba(0,54,116,.07);padding:24px}
.department-block__head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:18px}
.department-block__head h3,.department-block__head h2{font-size:clamp(26px,3vw,38px);letter-spacing:-.04em;line-height:1.05;margin:8px 0;color:var(--navy)}
.department-block__head p{max-width:760px;color:var(--muted);margin:0}
.city-cloud--links a:hover{background:var(--blue);color:#fff;transform:translateY(-1px)}
@media(max-width:760px){.department-block__head{display:block}.department-block__head .btn{margin-top:14px;width:100%}}

.department-block__cities-title{margin:10px 0 8px;color:var(--navy);font-size:16px;text-transform:uppercase;letter-spacing:.08em}
.city-cloud--links a{transition:.16s}

/* --- Agences + contact photo style --- */
.agency-card--large .agency-card__img{min-height:320px}
.agency-card__img{position:relative}
.agency-badge{position:absolute;left:18px;top:18px;background:rgba(255,255,255,.94);color:var(--blue);font-weight:950;border-radius:999px;padding:9px 13px;box-shadow:0 10px 24px rgba(0,31,75,.18)}
.agency-links{display:flex;flex-wrap:wrap;gap:9px;margin:16px 0}
.agency-links span{background:#eaf4ff;color:#003b82;border:1px solid #cfe0f5;border-radius:999px;padding:8px 10px;font-weight:900;font-size:13px}
.contact-hero{position:relative;isolation:isolate;background:var(--navy);color:#fff;overflow:hidden}
.contact-hero__photo{position:absolute;inset:0;background-size:cover;background-position:center right;z-index:-2;filter:saturate(1.08) contrast(1.04)}
.contact-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,31,75,.98),rgba(0,59,130,.86),rgba(0,95,209,.38));z-index:-1}
.contact-hero__in{min-height:500px;display:flex;align-items:center}
.contact-hero__text{max-width:720px}
.contact-hero h1{font-size:clamp(42px,6vw,76px);line-height:.96;margin:16px 0;letter-spacing:-.05em}
.contact-hero p{font-size:21px;color:#dbeafe;max-width:680px}
.contact-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}
.contact-form h2,.contact-side h2{color:var(--navy);font-size:clamp(28px,3vw,42px);line-height:1.05;letter-spacing:-.04em;margin:10px 0 18px}
.form label{font-weight:850;color:#17365e}
.form label input,.form label select,.form label textarea{margin-top:7px}
.consent{display:flex;gap:10px;align-items:center;font-size:14px}
.consent input{width:auto!important}
.contact-side{display:grid;gap:22px}
.contact-photo-card{min-height:360px;background-size:cover;background-position:center;position:relative;color:#fff;overflow:hidden;display:flex;align-items:end}
.contact-photo-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,31,75,.08),rgba(0,31,75,.88))}
.contact-photo-card>div{position:relative;z-index:1}
.contact-photo-card h2{color:#fff}
.contact-photo-card p{color:#eaf4ff}
@media(max-width:900px){.contact-layout{grid-template-columns:1fr}.contact-hero__in{min-height:430px}}

/* --- Avis Google officiel --- */
.reviews-hero{background:linear-gradient(135deg,#001f4b,#005fd1);color:#fff;position:relative;overflow:hidden}
.reviews-hero:before{content:"";position:absolute;inset:auto -10% -45% 45%;height:420px;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 62%);transform:rotate(-8deg)}
.reviews-hero__in{min-height:480px;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;position:relative;z-index:1}
.reviews-hero h1{font-size:clamp(42px,6vw,76px);line-height:.96;margin:16px 0;letter-spacing:-.05em}
.reviews-hero p{font-size:21px;color:#dbeafe;max-width:700px}
.google-review-card{background:#fff;color:var(--ink);border-radius:30px;padding:34px;box-shadow:0 24px 60px rgba(0,31,75,.28)}
.google-g{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#4285f4,#34a853);color:#fff;display:grid;place-items:center;font-size:38px;font-weight:950;margin-bottom:18px}
.google-review-card span{color:var(--blue);font-weight:950;text-transform:uppercase;letter-spacing:.12em;font-size:13px}
.google-review-card strong{display:block;color:var(--navy);font-size:34px;line-height:1.05;margin:10px 0}
.google-review-card p{color:var(--muted);font-size:17px}
.google-review-card a{color:var(--blue);font-weight:950}
@media(max-width:900px){.reviews-hero__in{grid-template-columns:1fr;padding:55px 0}.google-review-card{padding:24px}.reviews-hero__in{min-height:auto}}

/* --- Accueil avis Google officiel --- */
.rating a{color:#fff;font-weight:950;text-decoration:underline;text-underline-offset:4px}
.google-home-panel p{color:var(--muted)}
.google-mini{display:flex;align-items:center;gap:14px;background:#f5f9ff;border:1px solid var(--line);border-radius:18px;padding:14px;margin:18px 0}
.google-g.small{width:44px;height:44px;border-radius:13px;font-size:26px;margin:0}
.google-mini strong{display:block;color:var(--navy)}
.google-mini small{display:block;color:var(--muted);font-weight:850}

/* --- Page avis style Ruben, version Serrurier-Locksmith --- */
.reviews-page-hero{background:linear-gradient(135deg,#001f4b,#005fd1);color:#fff;padding:76px 0 92px;position:relative;overflow:hidden}
.reviews-page-hero:before{content:"";position:absolute;right:-140px;top:-140px;width:520px;height:520px;border-radius:50%;background:rgba(255,255,255,.10)}
.reviews-page-hero__in{position:relative;z-index:1;max-width:900px;text-align:center}
.reviews-page-hero h1{font-size:clamp(44px,7vw,86px);line-height:.95;letter-spacing:-.055em;margin:16px 0}
.reviews-page-hero p{font-size:21px;color:#dbeafe;margin-inline:auto;max-width:760px}
.review-score-box{margin:34px auto 0;background:#fff;color:var(--navy);border:1px solid #cfe0f5;box-shadow:0 24px 70px rgba(0,31,75,.24);border-radius:30px;padding:26px;width:min(520px,100%)}
.review-score-box strong{font-size:58px;line-height:1;display:block;letter-spacing:-.05em}
.review-score-box .stars{font-size:24px}
.review-score-box p{color:var(--muted);font-size:18px;margin:8px 0}
.review-score-box a{font-weight:950;color:var(--blue)}
.review-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}
.review-form h2,.review-side h2{font-size:clamp(28px,3vw,42px);line-height:1.05;letter-spacing:-.04em;color:var(--navy);margin:8px 0 14px}
.review-form small{display:block;color:var(--muted);font-weight:650;margin-top:5px}
.review-form label span{color:var(--muted);font-weight:700}
.rating-select{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.rating-select input{position:absolute;opacity:0;pointer-events:none}
.rating-select label{cursor:pointer;background:#fff7e6;border:1px solid #ffd28a;color:#f59e0b;border-radius:999px;padding:10px 13px;font-weight:950;letter-spacing:2px}
.rating-select input:checked + label{background:#f59e0b;color:#fff;border-color:#f59e0b}
.form-note{font-size:13px;color:var(--muted);margin:4px 0 0}
.review-side{display:grid;gap:22px}
.google-official-box{background:linear-gradient(180deg,#fff,#f5f9ff)}
.review-criteria .panel{position:relative;overflow:hidden}
.review-icon{width:54px;height:54px;border-radius:17px;background:var(--blue);color:#fff;display:grid;place-items:center;margin-bottom:12px}
.review-icon svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:2}
.reviews-final{margin-top:0}
@media(max-width:900px){.review-layout{grid-template-columns:1fr}.reviews-page-hero{text-align:left}.reviews-page-hero__in{text-align:left}.review-score-box{margin-left:0}}

/* --- Cleanup design pass --- */
.agency-grid--2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.agency-card--clean .agency-card__img{min-height:300px;background-size:cover;background-position:center}
.agency-card--clean .agency-card__body h2{font-size:clamp(30px,3vw,48px);line-height:1;letter-spacing:-.04em}
.agency-links a{display:inline-flex;background:#eaf4ff;color:#003b82;border:1px solid #cfe0f5;border-radius:999px;padding:8px 10px;font-weight:900;font-size:13px}
.agency-links a:hover{background:var(--blue);color:#fff}
.review-form p{color:var(--muted)}
footer .zone-pills a{margin-bottom:8px}
@media(max-width:900px){.agency-grid--2{grid-template-columns:1fr}}

/* --- Repair stable agences minimal --- */
.agency-grid--2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.agency-card--clean .agency-card__img{min-height:320px;background-size:cover;background-position:center}
.agency-card--clean .agency-card__body h2{font-size:clamp(28px,3vw,42px);line-height:1.02;letter-spacing:-.04em}
.agency-links{display:flex;flex-wrap:wrap;gap:9px;margin:16px 0}
.agency-links a{display:inline-flex;background:#eaf4ff;color:#003b82;border:1px solid #cfe0f5;border-radius:999px;padding:8px 10px;font-weight:900;font-size:13px}
.agency-links a:hover{background:var(--blue);color:#fff}
.final-cta + .final-cta{display:none!important}
@media(max-width:900px){.agency-grid--2{grid-template-columns:1fr}}

/* --- FAQ XXL SEO --- */
.faq-hero h1{max-width:980px}
.faq-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.faq-toc{padding-top:0}
.faq-list--seo{display:grid;gap:12px}
.faq-list--seo .faq-item{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 10px 24px rgba(0,54,116,.06);overflow:hidden}
.faq-list--seo .faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:20px;border:0;background:#fff;color:var(--navy);font-weight:950;text-align:left;padding:18px 20px;font-size:18px;cursor:pointer}
.faq-list--seo .faq-q span{display:grid;place-items:center;min-width:28px;height:28px;border-radius:50%;background:var(--sky);color:var(--blue)}
.faq-list--seo .faq-a{padding:0 20px 18px;color:var(--muted);line-height:1.65}
.faq-list--seo .faq-a p{margin:0}
@media(max-width:900px){.faq-intro-grid{grid-template-columns:1fr}.faq-list--seo .faq-q{font-size:16px}}

/* --- Cookies + PWA --- */
.footer .copyright a{color:#fff;font-weight:950;text-decoration:underline;text-underline-offset:3px}
.cookie-banner{position:fixed;left:22px;right:22px;bottom:92px;z-index:1000;display:none;align-items:center;justify-content:space-between;gap:18px;background:#fff;border:1px solid var(--line);box-shadow:0 22px 60px rgba(0,31,75,.22);border-radius:22px;padding:18px 20px;max-width:980px;margin:auto}
.cookie-banner.is-visible{display:flex}
.cookie-banner strong{color:var(--navy);font-size:18px}
.cookie-banner p{margin:4px 0 0;color:var(--muted);font-size:14px}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.pwa-install{position:fixed;right:22px;bottom:170px;z-index:999;display:none;align-items:center;gap:12px;background:#003b82;color:#fff;border-radius:18px;padding:14px 16px;box-shadow:0 18px 44px rgba(0,31,75,.26)}
.pwa-install.is-visible{display:flex}
.pwa-install span{font-weight:900}
.pwa-close{border:0;background:rgba(255,255,255,.16);color:#fff;width:28px;height:28px;border-radius:999px;font-size:20px;cursor:pointer}
@media(max-width:720px){
  .cookie-banner{left:12px;right:12px;bottom:86px;display:none;flex-direction:column;align-items:flex-start}
  .cookie-banner.is-visible{display:flex}
  .cookie-actions{width:100%}.cookie-actions .btn{flex:1}
  .pwa-install{left:12px;right:12px;bottom:185px;justify-content:space-between}
}

/* --- Language switch FR / EN --- */
.lang-switch{display:flex;align-items:center;gap:6px;margin:0 6px}
.lang-switch a{display:inline-flex;align-items:center;gap:4px;padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--navy);font-weight:950;font-size:13px}
.lang-switch a:hover{background:var(--sky);color:var(--blue)}
@media(max-width:980px){.lang-switch{margin:8px 0}.lang-switch a{width:auto}}

/* --- Real flag icons --- */
.lang-switch img{width:22px;height:15px;display:block;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.lang-switch a{gap:7px}




/* --- Header flags icons only --- */
.header-flags{
  display:flex!important;
  align-items:center;
  gap:8px;
  margin-left:auto;
  margin-right:14px;
  flex-shrink:0;
  position:relative;
  z-index:50;
}
.header-flag{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  padding:0;
  border:1px solid rgba(0,59,130,.14);
  border-radius:999px;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,59,130,.08);
  overflow:hidden;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.header-flag:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(0,59,130,.12);
  border-color:#0b63ce;
}
.header-flag--active{
  border-color:#0b63ce;
  box-shadow:0 0 0 3px rgba(11,99,206,.12), 0 8px 20px rgba(0,59,130,.08);
}
.header-flag img{
  display:block!important;
  width:22px!important;
  height:15px!important;
  min-width:22px!important;
  object-fit:cover;
  border-radius:2px;
  box-shadow:none;
}
.header-flag span{display:none!important}
@media(max-width:980px){
  .header-flags{margin-right:10px;gap:6px}
  .header-flag{width:36px;height:36px}
  .header-flag img{width:22px!important;height:15px!important}
}

/* --- Blog SEO --- */
.blog-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:26px;align-items:start}
.blog-article{padding:32px}
.blog-article h2{margin-top:30px;color:var(--navy);font-size:clamp(25px,2.4vw,36px);letter-spacing:-.03em}
.blog-article p{color:var(--muted);line-height:1.75;font-size:17px}
.blog-lead{font-size:19px!important;color:var(--navy)!important}
.blog-sidebar{display:grid;gap:18px;position:sticky;top:110px}
.blog-sidebar .btn{width:100%;justify-content:center;margin-top:10px}
.blog-card .service-body h3{font-size:22px}
.blog-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,31,75,.82),rgba(0,31,75,.36));}
.blog-hero .agency-hero__in{position:relative;z-index:1}
@media(max-width:980px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{position:static}.blog-article{padding:22px}}

/* --- Blog journaliste web 20.0 --- */
.journal-hero{position:relative;min-height:520px;display:flex;align-items:end;background-size:cover;background-position:center;color:#fff;overflow:hidden}
.journal-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,25,65,.92),rgba(0,25,65,.58),rgba(0,25,65,.18))}
.journal-hero__in{position:relative;z-index:1;padding:130px 0 72px;max-width:1040px}
.journal-kicker{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.14);backdrop-filter:blur(10px);color:#fff;border-radius:999px;padding:9px 13px;font-weight:950;text-transform:uppercase;letter-spacing:.08em;font-size:12px}
.journal-hero h1,.journal-home h1{font-size:clamp(42px,6vw,82px);line-height:.95;letter-spacing:-.065em;margin:18px 0}
.journal-hero p,.journal-home p{font-size:clamp(18px,2vw,24px);line-height:1.45;max-width:880px;color:rgba(255,255,255,.9)}
.journal-meta{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0}
.journal-meta span{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:8px 11px;font-weight:900}
.journal-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:28px;align-items:start}
.journal-article{display:grid;gap:22px}
.journal-card,.journal-section,.journal-summary,.journal-note{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:0 14px 34px rgba(0,54,116,.08)}
.journal-card,.journal-section{padding:30px}
.journal-intro p{font-size:21px;line-height:1.65;color:var(--navy);margin:0}
.journal-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px}
.journal-summary strong{color:var(--navy);padding:0 8px}
.journal-summary a{display:inline-flex;border-radius:999px;background:#eaf4ff;color:#003b82;font-weight:950;padding:9px 12px}
.journal-section h2{font-size:clamp(28px,3vw,44px);letter-spacing:-.045em;line-height:1.05;color:var(--navy);margin:0 0 18px}
.journal-section h3{color:var(--navy);font-size:22px;margin:0 0 8px}
.journal-section p{font-size:18px;line-height:1.78;color:var(--muted)}
.journal-note{padding:20px 24px;border-left:6px solid #ff7a1a;background:linear-gradient(135deg,#fff,#fff7ef)}
.journal-note strong{display:block;color:var(--navy);font-size:20px;margin-bottom:6px}
.journal-note p{margin:0;color:var(--muted);line-height:1.65}
.journal-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.journal-grid>div{background:#f7fbff;border:1px solid #dcecff;border-radius:20px;padding:18px}
.journal-service-links{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.journal-service-links a{display:grid;gap:5px;background:#f7fbff;border:1px solid #dcecff;border-radius:18px;padding:18px;color:var(--navy)}
.journal-service-links strong{font-size:18px}
.journal-service-links span{color:var(--muted);font-weight:800}
.journal-sidebar{position:relative}
.journal-sticky{position:sticky;top:112px;display:grid;gap:18px}
.journal-sticky .btn{width:100%;justify-content:center;margin-top:10px}
.journal-home{background:radial-gradient(circle at 15% 20%,#0b63ce 0,#003b82 35%,#001b3d 100%);color:#fff}
.journal-home__in{padding:110px 0 70px}
.blog-v20-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.blog-card-v20{overflow:hidden;padding:0}
.blog-card-v20 a{display:grid;grid-template-columns:230px 1fr;min-height:250px;color:inherit}
.blog-card-v20__img{background-size:cover;background-position:center;min-height:250px}
.blog-card-v20__body{padding:24px}
.blog-card-v20__body h2{font-size:26px;line-height:1.05;letter-spacing:-.04em;color:var(--navy);margin:10px 0}
.blog-card-v20__body p{color:var(--muted);line-height:1.55}
@media(max-width:1050px){.journal-layout{grid-template-columns:1fr}.journal-sticky{position:static}.blog-v20-grid{grid-template-columns:1fr}.blog-card-v20 a{grid-template-columns:1fr}.blog-card-v20__img{min-height:240px}}
@media(max-width:720px){.journal-hero__in{padding:110px 0 56px}.journal-card,.journal-section{padding:22px}.journal-grid,.journal-service-links{grid-template-columns:1fr}.journal-summary{align-items:flex-start}.journal-summary a{font-size:14px}.journal-hero h1,.journal-home h1{font-size:42px}}

/* --- Formulaire contact : alertes + anti-spam --- */
.form-alert{margin:14px 0 18px;padding:14px 16px;border-radius:16px;font-weight:900;line-height:1.45}
.form-alert--ok{background:#e9f9ef;color:#116b32;border:1px solid #bce7c8}
.form-alert--error{background:#fff1f0;color:#9b1c1c;border:1px solid #ffc5c0}
.hp-field{position:absolute!important;left:-10000px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}

/* --- Mentions légales renforcées --- */
.legal-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.legal-panel{padding:26px}
.legal-panel h2{color:var(--navy);font-size:clamp(24px,2.4vw,34px);line-height:1.05;letter-spacing:-.035em;margin:8px 0 14px}
.legal-panel p{color:var(--muted);line-height:1.7;margin:10px 0}
.legal-panel strong{color:var(--navy)}
.legal-panel a{color:var(--blue);font-weight:950;text-decoration:underline;text-underline-offset:3px}
@media(max-width:900px){.legal-layout{grid-template-columns:1fr}.legal-panel{padding:22px}}
