/*
Theme Name: Office Deratisation (Astra Child)
Theme URI: https://office-deratisation.fr
Description: Theme enfant d'Astra pour Office Deratisation France. Source unique de tout le code sur-mesure (CSS, micro-interactions, JSON-LD). Direction artistique A : bleu clinique.
Author: Office Deratisation France
Template: astra
Version: 1.0.20260621-1
Text Domain: astra-child
*/

/* ============================================================
   Variables de la Direction A (bleu clinique) - a etoffer en Phase 3
   ============================================================ */
:root {
      --odf-bleu: #1f6feb;
      --odf-bleu-fonce: #144a99;
      --odf-bleu-clair: #eaf2ff;
      --odf-texte: #1a2433;
      --odf-blanc: #ffffff;
      --odf-radius: 12px;
}

/* Le CSS sur-mesure (mise en page, micro-interactions, boutons)
   sera ajoute ici au fur et a mesure de la Phase 3. */

/* ===== PAGE D'ACCUEIL (#odf-home) — déplacé depuis la page le 20/06/2026 ===== */
/* Office Deratisation - Page d'accueil (portee depuis proposition1-v6, scopee #odf-home) */
#odf-home{max-width:480px;margin:0 auto;background:#fff;color:var(--ink);line-height:1.6;font-family:'Segoe UI',system-ui,-apple-system,Roboto,'Helvetica Neue',Arial,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
:root{
    --ac:#1763c9;--ac2:#0a2e6b;--marine:#0a2240;--soft:#eef3fc;--soft2:#f6f9fe;
    --ink:#0f2444;--mut:#5e6f88;--warm:#f3922f;--warm2:#e07d0e;--line:#e7eef7;
    --green:#15a05a;
  }
#odf-home *{margin:0;padding:0;box-sizing:border-box}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(120,235,160,.7)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}
#odf-home .head{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line)}
#odf-home .burger{font-size:22px;color:var(--marine);background:none;border:none}
#odf-home .logo-row{display:flex;align-items:center;gap:9px}
#odf-home .logo-row svg{width:42px;height:42px;flex-shrink:0}
#odf-home .logo-row .lt{line-height:1}
#odf-home .logo-row .lt b{font-size:13.5px;font-weight:900;color:var(--ac2);letter-spacing:-.2px;display:block}
#odf-home .logo-row .lt s{font-size:8px;font-weight:700;color:var(--warm2);letter-spacing:1.5px;text-decoration:none;text-transform:uppercase}
#odf-home .tdot{width:30px;height:30px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ac);text-decoration:none}
#odf-home .hero{background:linear-gradient(165deg,#1763c9,#0a2e6b 72%,#0a2240);position:relative;overflow:hidden;padding:24px 22px 30px;text-align:center}
#odf-home .hero .g1{position:absolute;top:-50px;right:-40px;width:210px;height:210px;background:radial-gradient(rgba(150,190,255,.28),transparent 70%)}
#odf-home .hero .g2{position:absolute;bottom:0;left:-60px;width:180px;height:180px;background:radial-gradient(rgba(243,146,47,.18),transparent 70%)}
#odf-home .hero .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:22px 22px}
#odf-home .hin{position:relative;z-index:3}
#odf-home .glogo{width:68px;height:68px;margin:0 auto 12px;display:block}
#odf-home .bdg{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.25);color:#dbe8ff;font-size:12px;font-weight:600;padding:6px 14px;border-radius:30px;margin-bottom:14px}
#odf-home .pls{width:8px;height:8px;border-radius:50%;background:#7aeba0;animation:pulse 2s infinite}
#odf-home h1{font-size:27px;line-height:1.2;font-weight:800;color:#fff;letter-spacing:-.6px;margin-bottom:12px}
#odf-home h1 .hl{color:#ffce5e}
#odf-home .sub{font-size:13.5px;color:rgba(255,255,255,.86);margin-bottom:20px;padding:0 4px}
#odf-home .sub b{color:#fff}
#odf-home .cta{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--warm);color:#fff;font-weight:800;font-size:20px;padding:16px;border-radius:14px;text-decoration:none;box-shadow:0 8px 22px rgba(243,146,47,.45);margin-bottom:10px}
#odf-home .cta2{display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.1);color:#fff;font-weight:600;font-size:14.5px;padding:13px;border-radius:14px;text-decoration:none;border:1.5px solid rgba(255,255,255,.32)}
#odf-home .floats{display:flex;gap:8px;margin-top:20px;justify-content:center}
#odf-home .fl{flex:1;background:rgba(255,255,255,.97);border-radius:12px;padding:10px 8px;box-shadow:0 7px 18px rgba(0,0,0,.2);text-align:center}
#odf-home .fl b{font-size:15px;font-weight:900;color:var(--ac2);display:block;line-height:1.1}
#odf-home .fl small{font-size:9px;color:var(--mut);letter-spacing:.3px}
#odf-home .fl .st{color:#f5b400;font-size:11px;letter-spacing:1px}
#odf-home .sky{width:100%;display:block;position:relative;z-index:1;margin-top:20px;margin-bottom:-6px}
#odf-home /* Bandeau certifications défilant */
  /* Bandeau logos Certibiocide réels (2 versions) */
  .certlogo{background:#fff;padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
#odf-home .certlogo .cb-ecusson{height:58px;width:auto;display:block}
#odf-home .certlogo .cb-feuille{height:42px;width:auto;display:block}
#odf-home .certbar{background:var(--marine);padding:14px 0;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08)}
#odf-home .certbar .track{display:flex;gap:14px;padding:0 16px;justify-content:space-between}
#odf-home .cert{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;text-align:center}
#odf-home .cert .cic{width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#ffce5e}
#odf-home .cert .cic svg{width:20px;height:20px}
#odf-home .cert span{font-size:9px;font-weight:700;color:rgba(255,255,255,.85);letter-spacing:.3px;line-height:1.2}
#odf-home /* Bandeau références défilant */
  .refs{background:#fff;padding:18px 0 16px;border-bottom:1px solid var(--line);overflow:hidden}
#odf-home .refs .rtitle{text-align:center;font-size:10.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--mut);margin-bottom:13px}
#odf-home .marquee{display:flex;width:max-content;animation:scroll-x 22s linear infinite}
#odf-home .marquee:hover{animation-play-state:paused}
@keyframes scroll-x{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
#odf-home .rlogo{display:flex;align-items:center;justify-content:center;height:54px;margin:0 6px;padding:0 18px;background:#fff;border:1px solid var(--line);border-radius:12px;flex-shrink:0}
#odf-home .rlogo img{height:30px;width:auto;display:block;object-fit:contain}
#odf-home .strip{display:flex;background:var(--ac2)}
#odf-home .strip div{flex:1;text-align:center;padding:13px 4px;border-right:1px solid rgba(255,255,255,.1)}
#odf-home .strip div:last-child{border:none}
#odf-home .strip .n{font-size:18px;font-weight:900;color:#ffce5e}
#odf-home .strip .l{font-size:9px;color:rgba(255,255,255,.78);letter-spacing:.4px;margin-top:1px}
#odf-home section{padding:30px 22px}
#odf-home .eye{display:block;font-size:11px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--ac);text-align:center;margin-bottom:7px}
#odf-home h2{font-size:21px;font-weight:800;color:var(--marine);text-align:center;letter-spacing:-.3px;margin-bottom:7px;line-height:1.25}
#odf-home .lead{font-size:13.5px;color:var(--mut);text-align:center;margin-bottom:22px;padding:0 6px}
#odf-home .ib{width:46px;height:46px;border-radius:13px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ac)}
#odf-home .ib svg{width:23px;height:23px}
#odf-home .grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
#odf-home .card{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-home .card .ib{width:40px;height:40px;flex-shrink:0}
#odf-home .card .ib svg{width:20px;height:20px}
#odf-home .card b{font-size:13.5px;font-weight:700;color:var(--marine);display:block;line-height:1.15}
#odf-home .card small{font-size:11px;color:var(--mut)}
#odf-home .pale{background:var(--soft2)}
#odf-home .dark{background:var(--marine)}
#odf-home .dark .eye{color:#ffce5e}
#odf-home .dark h2{color:#fff}
#odf-home .dark .lead{color:rgba(255,255,255,.75)}
#odf-home .steps{max-width:330px;margin:0 auto}
#odf-home .step{display:flex;gap:15px;padding-bottom:22px;position:relative}
#odf-home .step:not(:last-child)::before{content:"";position:absolute;left:21px;top:44px;bottom:0;width:2px;background:#d9e6f7}
#odf-home .step .nm{width:44px;height:44px;flex-shrink:0;border-radius:50%;background:#fff;border:2px solid var(--ac);color:var(--ac);font-weight:900;font-size:17px;display:flex;align-items:center;justify-content:center;z-index:2}
#odf-home .step h3{font-size:15px;font-weight:800;color:var(--marine);margin:9px 0 2px}
#odf-home .step p{font-size:12.5px;color:var(--mut)}
#odf-home /* Risques */
  .risk{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--warm);border-radius:0 14px 14px 0;padding:14px;margin-bottom:10px;box-shadow:0 4px 14px rgba(13,43,84,.05)}
#odf-home .risk .ric{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:#fff3e6;display:flex;align-items:center;justify-content:center;color:var(--warm2)}
#odf-home .risk .ric svg{width:20px;height:20px}
#odf-home .risk b{font-size:13.5px;color:var(--marine);display:block;margin-bottom:1px}
#odf-home .risk p{font-size:12px;color:var(--mut);line-height:1.4}
#odf-home /* Garanties */
  .guar{display:flex;align-items:flex-start;gap:11px;padding:13px 0;border-bottom:1px solid var(--line)}
#odf-home .guar:last-child{border:none}
#odf-home .guar .gic{width:26px;height:26px;flex-shrink:0;border-radius:50%;background:#e6f6ee;display:flex;align-items:center;justify-content:center;color:var(--green);margin-top:1px}
#odf-home .guar .gic svg{width:15px;height:15px}
#odf-home .guar b{font-size:14px;color:var(--marine);display:block;margin-bottom:1px}
#odf-home .guar p{font-size:12.5px;color:var(--mut);line-height:1.4}
#odf-home /* Zones */
  .zones .zmap{background:var(--soft);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:14px}
#odf-home .zones .zmap svg{width:100%;display:block}
#odf-home .ztag{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
#odf-home .ztag span{font-size:11px;font-weight:600;color:var(--ac2);background:var(--soft);border:1px solid #d9e6f7;border-radius:20px;padding:5px 11px}
#odf-home .zsub{text-align:center;font-size:12.5px;color:var(--mut);margin-top:14px}
#odf-home .zsub b{color:var(--marine)}
#odf-home /* Pro/Particulier */
  .pp{display:grid;grid-template-columns:1fr 1fr;gap:11px}
#odf-home .pp .b{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 14px;text-align:center;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-home .pp .b .ib{margin:0 auto 10px}
#odf-home .pp .b h3{font-size:14.5px;font-weight:800;color:var(--marine);margin-bottom:4px}
#odf-home .pp .b p{font-size:11.5px;color:var(--mut);line-height:1.4}
#odf-home .why{display:grid;grid-template-columns:1fr 1fr;gap:12px}
#odf-home .why .c{text-align:center;padding:18px 12px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-home .why .ib{margin:0 auto 10px}
#odf-home .why b{font-size:13px;color:var(--marine);display:block}
#odf-home .why small{font-size:11px;color:var(--mut)}
#odf-home .rev{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:0 4px 16px rgba(13,43,84,.06);margin-bottom:10px}
#odf-home .rev .tp{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
#odf-home .rev .st{color:#f5b400;font-size:14px;letter-spacing:2px}
#odf-home .rev .gg{font-size:10px;color:var(--mut);display:flex;align-items:center;gap:3px}
#odf-home .rev p{font-size:12.5px;font-style:italic;margin-bottom:10px;line-height:1.5}
#odf-home .rev .wh{display:flex;align-items:center;gap:9px}
#odf-home .rev .av{width:32px;height:32px;border-radius:50%;background:var(--soft);color:var(--ac);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:12px}
#odf-home .rev .wh b{font-size:12.5px;color:var(--marine);display:block;line-height:1.1}
#odf-home .rev .wh small{font-size:10.5px;color:var(--mut)}
#odf-home /* Avis défilants */
  .revmarq-wrap{overflow:hidden;padding:2px 0 4px}
#odf-home .revmarq{display:flex;width:max-content;animation:scroll-rev 32s linear infinite}
#odf-home .revmarq-wrap:hover .revmarq{animation-play-state:paused}
@keyframes scroll-rev{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
#odf-home .revc{width:270px;flex-shrink:0;margin:0 6px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-home .revc .tp{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
#odf-home .revc .st{color:#f5b400;font-size:13px;letter-spacing:2px}
#odf-home .revc .gg{font-size:10px;color:var(--mut);display:flex;align-items:center;gap:3px}
#odf-home .revc p{font-size:12.5px;font-style:italic;margin-bottom:11px;line-height:1.5;min-height:54px}
#odf-home .revc .wh{display:flex;align-items:center;gap:9px}
#odf-home .revc .av{width:32px;height:32px;border-radius:50%;background:var(--soft);color:var(--ac);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
#odf-home .revc .wh b{font-size:12.5px;color:var(--marine);display:block;line-height:1.1}
#odf-home .revc .wh small{font-size:10.5px;color:var(--mut)}
#odf-home .gnote{text-align:center;font-size:12px;color:var(--mut);margin-top:6px}
#odf-home .gnote b{color:var(--ac2)}
#odf-home .faq{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:9px;overflow:hidden;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-home .faq .q{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:15px;cursor:pointer;font-weight:700;font-size:13.5px;color:var(--marine)}
#odf-home .faq .q .cv{color:var(--ac);font-size:16px;transition:transform .25s}
#odf-home .faq.open .q .cv{transform:rotate(180deg)}
#odf-home .faq .a{max-height:0;overflow:hidden;transition:max-height .3s;font-size:12.5px;color:var(--mut);padding:0 15px}
#odf-home .faq.open .a{max-height:240px;padding:0 15px 15px}
#odf-home .final{background:linear-gradient(165deg,#1763c9,#0a2240);padding:38px 22px;text-align:center;position:relative;overflow:hidden}
#odf-home .final .g1{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:280px;height:200px;background:radial-gradient(rgba(150,190,255,.22),transparent 70%)}
#odf-home .final h2{color:#fff;font-size:22px;margin-bottom:7px;position:relative;z-index:2}
#odf-home .final p{color:rgba(255,255,255,.84);font-size:13.5px;margin-bottom:20px;position:relative;z-index:2}
#odf-home .final .cta{display:inline-flex;margin-bottom:0;position:relative;z-index:2}
#odf-home footer{background:var(--marine);color:rgba(255,255,255,.62);padding:24px 22px 28px;font-size:11.5px;text-align:center}
#odf-home footer b{color:#fff;font-weight:900;font-size:15px;display:block;margin-bottom:7px}
#odf-home footer a{color:#ffce5e;text-decoration:none}
#odf-home .bar{position:sticky;bottom:0;left:0;right:0;z-index:80;display:flex;gap:9px;padding:11px 13px;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -4px 18px rgba(13,43,84,.1)}
#odf-home .bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:12px;font-weight:800;font-size:14.5px;text-decoration:none}
#odf-home .bar .ap{background:var(--warm);color:#fff;box-shadow:0 4px 12px rgba(243,146,47,.4)}
#odf-home .bar .dv{background:var(--soft);color:var(--ac);border:1.5px solid #cfe0f5}


/* ===== MICRO-EFFETS (Phase 2) — halo, onde au clic, apparition au scroll ===== */
#odf-home .cta,#odf-home .cta2,#odf-home .ap,#odf-home .dv{position:relative;overflow:hidden}
#odf-home .cta{transition:box-shadow .25s ease,transform .12s ease}
#odf-home .cta:hover{box-shadow:0 8px 26px rgba(243,146,47,.55)}
#odf-home .cta:active,#odf-home .cta2:active,#odf-home .ap:active,#odf-home .dv:active{transform:translateY(1px)}
#odf-home .cta svg,#odf-home .cta2 svg,#odf-home .ap svg,#odf-home .dv svg{transition:transform .25s ease}
#odf-home .cta:hover svg,#odf-home .cta2:hover svg,#odf-home .ap:hover svg,#odf-home .dv:hover svg{transform:translateX(-2px)}
#odf-home .odf-ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.45);animation:odf-ripple .6s ease-out;pointer-events:none}
@keyframes odf-ripple{to{transform:scale(2.6);opacity:0}}
/* Apparition au scroll — degradation gracieuse : tout reste visible si JS absent */
#odf-home.odf-reveal-on section{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease;will-change:opacity,transform}
#odf-home.odf-reveal-on section.odf-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){#odf-home.odf-reveal-on section{opacity:1;transform:none;transition:none}#odf-home .odf-ripple{display:none}}


/* ===== Retouches 20/06 v2 (menu plein ecran) ===== */
/* P2 — masquer la fleche retour-en-haut d'Astra */
#ast-scroll-top{display:none!important}

/* P4 v2 — burger + label + menu plein ecran */
#odf-home .head{position:sticky}
#odf-home .burger{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:0;padding:4px 6px;cursor:pointer;color:#0a2240}
#odf-home .burger .bicon{width:26px;height:18px;position:relative;display:block}
#odf-home .burger .bicon i{position:absolute;left:0;right:0;height:2.6px;border-radius:2px;background:#1763c9;transition:transform .25s ease,opacity .2s ease,top .25s ease}
#odf-home .burger .bicon i:nth-child(1){top:0}
#odf-home .burger .bicon i:nth-child(2){top:7.7px}
#odf-home .burger .bicon i:nth-child(3){top:15.4px}
#odf-home .burger .blabel{font-size:12px;font-weight:700;letter-spacing:.5px;color:#0a2240;line-height:1}
#odf-home.nav-open .burger .bicon i:nth-child(1){top:7.7px;transform:rotate(45deg)}
#odf-home.nav-open .burger .bicon i:nth-child(2){opacity:0}
#odf-home.nav-open .burger .bicon i:nth-child(3){top:7.7px;transform:rotate(-45deg)}
#odf-home .odf-nav{position:fixed;inset:0;z-index:80;background:#fff;display:flex;flex-direction:column;padding:84px 18px 24px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .22s ease,transform .22s ease,visibility 0s linear .22s}
#odf-home.nav-open .odf-nav{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .22s ease,transform .22s ease}
#odf-home .odf-nav-inner{display:flex;flex-direction:column}
#odf-home .odf-nav-item{display:flex;align-items:center;gap:16px;padding:18px 6px;border-bottom:1px solid #eef1f6;color:#0f2547;text-decoration:none;font-size:21px;font-weight:600}
#odf-home .odf-nav-item svg{width:30px;height:30px;color:#1763c9;flex:0 0 auto}
#odf-home .odf-nav-item:active{background:#f3f7fd}
@media(hover:hover){#odf-home .odf-nav-item:hover{color:#1763c9}}
#odf-home .odf-nav-foot{margin-top:24px;padding-top:18px}
#odf-home .odf-nav-foot p{margin:0 0 14px;color:#5b6b85;font-size:15px;line-height:1.4}
#odf-home .odf-nav-call{display:flex;align-items:center;justify-content:center;gap:10px;background:#1763c9;color:#fff;font-weight:800;font-size:20px;letter-spacing:.5px;padding:15px;border-radius:14px;text-decoration:none;margin-bottom:12px}
#odf-home .odf-nav-rdv{display:flex;align-items:center;justify-content:center;background:#f3922f;color:#fff;font-weight:800;font-size:17px;padding:15px;border-radius:14px;text-decoration:none}
#odf-home .odf-nav-call:active{background:#0f4ea3}
#odf-home .odf-nav-rdv:active{background:#e07d0e}
body.odf-noscroll{overflow:hidden}

/* ===== Bouton fermeture menu (croix + Menu) + offset admin-bar ===== */
#odf-home .odf-nav-close{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:0;padding:4px 6px;cursor:pointer;color:#0a2240;z-index:2}
#odf-home .odf-nav-close svg{width:26px;height:26px;color:#1763c9;display:block}
#odf-home .odf-nav-close .blabel{font-size:12px;font-weight:700;letter-spacing:.5px;color:#0a2240;line-height:1}
#odf-home .odf-nav-close:active{opacity:.6}
/* l'overlay laisse la place au bouton fermeture en haut */
#odf-home .odf-nav{padding-top:88px}
/* quand connecte a WP, l'overlay et le bouton descendent sous la barre admin */
body.admin-bar #odf-home .odf-nav{top:32px}
@media screen and (max-width:782px){body.admin-bar #odf-home .odf-nav{top:46px}}

/* ===== Menu v4 : 3 zones plein ecran, footer epingle, logo en-tete ===== */
#odf-home .odf-nav{padding:0 18px 14px;overflow:hidden}
#odf-home .odf-nav-head{position:relative;flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:12px 0 12px;border-bottom:1px solid #eef1f6}
#odf-home .odf-nav-close{position:absolute;top:50%;left:0;transform:translateY(-50%)}
#odf-home .odf-nav-brand{display:flex;align-items:center;gap:9px}
#odf-home .odf-nav-brand .blogo{width:40px;height:40px;flex:0 0 auto}
#odf-home .odf-nav-brand .bname{display:flex;flex-direction:column;line-height:1.05}
#odf-home .odf-nav-brand .bname b{font-size:15px;font-weight:800;color:#0f2547;letter-spacing:.3px}
#odf-home .odf-nav-brand .bname s{font-size:10.5px;text-decoration:none;color:#f3922f;font-weight:700;letter-spacing:1.5px}
#odf-home .odf-nav-inner{flex:1 1 auto;min-height:0;justify-content:space-evenly;overflow-y:auto}
#odf-home .odf-nav-item{padding:11px 6px}
#odf-home .odf-nav-foot{flex:0 0 auto;margin-top:0;padding-top:12px}
#odf-home .odf-nav-foot p{margin:0 0 10px;font-size:14px}
#odf-home .odf-nav-call{padding:13px;margin-bottom:10px}
#odf-home .odf-nav-rdv{padding:13px}
@media screen and (max-height:620px){#odf-home .odf-nav-item{padding:8px 6px;font-size:19px}#odf-home .odf-nav-item svg{width:26px;height:26px}#odf-home .odf-nav-foot p{margin-bottom:8px;font-size:13px}#odf-home .odf-nav-call,#odf-home .odf-nav-rdv{padding:11px}}


/* ===================================================================
   GABARIT PAGE SERVICE  (#odf-service)  — Phase 3
   Reprend le système de design de l'accueil (#odf-home).
   Palette et composants partagés, scopés pour ne pas toucher l'accueil.
   =================================================================== */
#odf-service{
  --ac:#1763c9;--ac2:#0a2e6b;--marine:#0a2240;--soft:#eef3fc;--soft2:#f6f9fe;
  --ink:#0f2444;--mut:#5e6f88;--warm:#f3922f;--warm2:#e07d0e;--line:#e7eef7;--green:#15a05a;
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;line-height:1.6;
  color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased;
  max-width:560px;margin:0 auto;position:relative;overflow-x:hidden;
}
#odf-service *{margin:0;padding:0;box-sizing:border-box}
#odf-service img{max-width:100%}
@keyframes odfs-pulse{0%{box-shadow:0 0 0 0 rgba(120,235,160,.7)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* Header */
#odf-service .head{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line)}
#odf-service .burger{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--marine)}
#odf-service .burger .bicon{width:24px;height:16px;position:relative;display:block}
#odf-service .burger .bicon i{position:absolute;left:0;width:24px;height:2.4px;background:var(--marine);border-radius:2px;transition:.3s}
#odf-service .burger .bicon i:nth-child(1){top:0}
#odf-service .burger .bicon i:nth-child(2){top:6.8px}
#odf-service .burger .bicon i:nth-child(3){top:13.6px}
#odf-service .burger .blabel{font-size:9px;font-weight:700;letter-spacing:.5px;color:var(--marine)}
#odf-service .logo-row{display:flex;align-items:center;gap:9px;text-decoration:none}
#odf-service .logo-row svg{width:42px;height:42px;flex-shrink:0}
#odf-service .logo-row .lt{line-height:1}
#odf-service .logo-row .lt b{font-size:13.5px;font-weight:900;color:var(--ac2);letter-spacing:-.2px;display:block}
#odf-service .logo-row .lt s{font-size:8px;font-weight:700;color:var(--warm2);letter-spacing:1.5px;text-decoration:none;text-transform:uppercase}
#odf-service .tdot{width:30px;height:30px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ac);text-decoration:none;flex-shrink:0}

/* Hero */
#odf-service .hero{background:linear-gradient(165deg,#1763c9,#0a2e6b 72%,#0a2240);position:relative;overflow:hidden;padding:22px 22px 30px;text-align:center}
#odf-service .hero .g1{position:absolute;top:-50px;right:-40px;width:210px;height:210px;background:radial-gradient(rgba(150,190,255,.28),transparent 70%)}
#odf-service .hero .g2{position:absolute;bottom:0;left:-60px;width:180px;height:180px;background:radial-gradient(rgba(243,146,47,.18),transparent 70%)}
#odf-service .hero .dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:22px 22px}
#odf-service .hin{position:relative;z-index:3}
#odf-service .bcrumb{font-size:11px;color:rgba(255,255,255,.7);margin-bottom:14px;letter-spacing:.2px}
#odf-service .bcrumb a{color:rgba(255,255,255,.85);text-decoration:none}
#odf-service .bcrumb span{margin:0 5px;opacity:.6}
#odf-service .bdg{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.25);color:#dbe8ff;font-size:12px;font-weight:600;padding:6px 14px;border-radius:30px;margin-bottom:14px}
#odf-service .pls{width:8px;height:8px;border-radius:50%;background:#7aeba0;animation:odfs-pulse 2s infinite}
#odf-service h1{font-size:26px;line-height:1.2;font-weight:800;color:#fff;letter-spacing:-.6px;margin-bottom:12px}
#odf-service h1 .hl{color:#ffce5e}
#odf-service .sub{font-size:13.5px;color:rgba(255,255,255,.86);margin-bottom:20px;padding:0 4px}
#odf-service .sub b{color:#fff}
#odf-service .cta{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--warm);color:#fff;font-weight:800;font-size:20px;padding:16px;border-radius:14px;text-decoration:none;box-shadow:0 8px 22px rgba(243,146,47,.45);margin-bottom:10px;position:relative;overflow:hidden}
#odf-service .cta2{display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.1);color:#fff;font-weight:600;font-size:14.5px;padding:13px;border-radius:14px;text-decoration:none;border:1.5px solid rgba(255,255,255,.32);position:relative;overflow:hidden}
#odf-service .floats{display:flex;gap:8px;margin-top:20px;justify-content:center}
#odf-service .fl{flex:1;background:rgba(255,255,255,.97);border-radius:12px;padding:10px 8px;box-shadow:0 7px 18px rgba(0,0,0,.2);text-align:center}
#odf-service .fl b{font-size:15px;font-weight:900;color:var(--ac2);display:block;line-height:1.1}
#odf-service .fl small{font-size:9px;color:var(--mut);letter-spacing:.3px}
#odf-service .fl .st{color:#f5b400;font-size:11px;letter-spacing:1px}

/* Sections */
#odf-service section{padding:30px 22px}
#odf-service .pale{background:var(--soft2)}
#odf-service .eye{display:block;font-size:11px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--ac);text-align:center;margin-bottom:7px}
#odf-service h2{font-size:21px;font-weight:800;color:var(--marine);text-align:center;letter-spacing:-.3px;margin-bottom:7px;line-height:1.25}
#odf-service .lead{font-size:13.5px;color:var(--mut);text-align:center;margin-bottom:22px;padding:0 6px}
#odf-service .prose p{font-size:13.5px;color:#39495f;line-height:1.7;margin-bottom:13px}
#odf-service .prose p:last-child{margin-bottom:0}
#odf-service .prose i{font-style:italic}
#odf-service .note-soft{font-size:12.5px;color:var(--mut);line-height:1.55;margin-top:16px;padding:13px 15px;background:var(--soft);border-radius:12px}

/* Callout (urgence) */
#odf-service .callout{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:3px solid var(--warm);border-radius:0 14px 14px 0;padding:15px;margin-top:18px;box-shadow:0 4px 14px rgba(13,43,84,.05);font-size:13px;color:#39495f;line-height:1.5}
#odf-service .callout b{color:var(--marine)}
#odf-service .callout a{color:var(--ac);font-weight:700;text-decoration:none}
#odf-service .callout-ic{width:34px;height:34px;flex-shrink:0;border-radius:9px;background:#fff3e6;display:flex;align-items:center;justify-content:center;color:var(--warm2)}
#odf-service .callout-ic svg{width:18px;height:18px}

/* Signs grid */
#odf-service .signs{display:grid;gap:10px}
#odf-service .sign{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-service .sign .sic{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ac)}
#odf-service .sign .sic svg{width:20px;height:20px}
#odf-service .sign b{font-size:13.5px;color:var(--marine);display:block;margin-bottom:2px}
#odf-service .sign p{font-size:12px;color:var(--mut);line-height:1.45}

/* Risk blocks (repris de l'accueil) */
#odf-service .risk{display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--warm);border-radius:0 14px 14px 0;padding:14px;margin-bottom:10px;box-shadow:0 4px 14px rgba(13,43,84,.05)}
#odf-service .risk:last-child{margin-bottom:0}
#odf-service .risk .ric{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:#fff3e6;display:flex;align-items:center;justify-content:center;color:var(--warm2)}
#odf-service .risk .ric svg{width:20px;height:20px}
#odf-service .risk b{font-size:13.5px;color:var(--marine);display:block;margin-bottom:1px}
#odf-service .risk p{font-size:12px;color:var(--mut);line-height:1.45}

/* Why cards (repris de l'accueil) */
#odf-service .why{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
#odf-service .why .c{text-align:center;padding:18px 10px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-service .why .ib{width:44px;height:44px;border-radius:13px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ac);margin:0 auto 10px}
#odf-service .why .ib svg{width:22px;height:22px}
#odf-service .why b{font-size:12.5px;color:var(--marine);display:block;margin-bottom:3px}
#odf-service .why small{font-size:11px;color:var(--mut);line-height:1.4;display:block}
@media (max-width:380px){#odf-service .why{grid-template-columns:1fr}}

/* FAQ (repris de l'accueil) */
#odf-service .faq{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:9px;overflow:hidden;box-shadow:0 4px 16px rgba(13,43,84,.06)}
#odf-service .faq .q{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:15px;cursor:pointer;font-weight:700;font-size:13.5px;color:var(--marine)}
#odf-service .faq .q .cv{color:var(--ac);font-size:16px;transition:transform .25s;flex-shrink:0}
#odf-service .faq.open .q .cv{transform:rotate(180deg)}
#odf-service .faq .a{max-height:0;overflow:hidden;transition:max-height .3s;font-size:12.5px;color:var(--mut);padding:0 15px;line-height:1.55}
#odf-service .faq.open .a{max-height:320px;padding:0 15px 15px}

/* Final CTA + footer + sticky bar (repris de l'accueil) */
#odf-service .final{background:linear-gradient(165deg,#1763c9,#0a2240);padding:38px 22px;text-align:center;position:relative;overflow:hidden}
#odf-service .final .g1{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:280px;height:200px;background:radial-gradient(rgba(150,190,255,.22),transparent 70%)}
#odf-service .final h2{color:#fff;font-size:22px;margin-bottom:7px;position:relative;z-index:2}
#odf-service .final p{color:rgba(255,255,255,.84);font-size:13.5px;margin-bottom:20px;position:relative;z-index:2;padding:0 6px}
#odf-service .final .cta{display:inline-flex;margin-bottom:0;position:relative;z-index:2}
#odf-service footer{background:var(--marine);color:rgba(255,255,255,.62);padding:24px 22px 90px;font-size:11.5px;text-align:center;line-height:1.7}
#odf-service footer b{color:#fff;font-weight:900;font-size:15px;display:block;margin-bottom:7px}
#odf-service footer a{color:#ffce5e;text-decoration:none}
#odf-service .bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:560px;z-index:70;display:flex;gap:9px;padding:11px 13px;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -4px 18px rgba(13,43,84,.1)}
#odf-service .bar a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:12px;font-weight:800;font-size:14.5px;text-decoration:none}
#odf-service .bar .ap{background:var(--warm);color:#fff;box-shadow:0 4px 12px rgba(243,146,47,.4)}
#odf-service .bar .dv{background:var(--soft);color:var(--ac);border:1.5px solid #cfe0f5}

/* Ripple (repris de l'accueil) */
#odf-service .odf-ripple{position:absolute;border-radius:50%;transform:scale(0);background:rgba(255,255,255,.5);pointer-events:none;animation:odfs-ripple .6s linear}
@keyframes odfs-ripple{to{transform:scale(2.4);opacity:0}}

/* Scroll-reveal (repris de l'accueil) */
#odf-service .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
#odf-service .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){#odf-service .reveal{opacity:1;transform:none;transition:none}}

/* Menu plein écran (repris de l'accueil) */
#odf-service .odf-nav{position:fixed;inset:0;z-index:80;background:#fff;display:flex;flex-direction:column;padding:18px 20px;opacity:0;visibility:hidden;transition:opacity .25s;max-width:560px;margin:0 auto}
#odf-service .odf-nav.open{opacity:1;visibility:visible}
body.odf-noscroll{overflow:hidden}
body.admin-bar #odf-service .odf-nav{top:46px}
@media screen and (min-width:783px){body.admin-bar #odf-service .odf-nav{top:32px}}
#odf-service .odf-nav-head{display:flex;align-items:center;justify-content:space-between;flex:0 0 auto;padding-bottom:10px;border-bottom:1px solid var(--line)}
#odf-service .odf-nav-close{background:none;border:none;font-size:15px;font-weight:700;color:var(--marine);cursor:pointer;display:flex;align-items:center;gap:5px}
#odf-service .odf-nav-close span{font-weight:700}
#odf-service .odf-nav-brand{display:flex;align-items:center;gap:8px}
#odf-service .odf-nav-brand svg{width:38px;height:38px}
#odf-service .odf-nav-brand b{font-size:12px;font-weight:900;color:var(--ac2);display:block;line-height:1}
#odf-service .odf-nav-brand s{font-size:7.5px;font-weight:700;color:var(--warm2);letter-spacing:1.5px;text-decoration:none;text-transform:uppercase}
#odf-service .odf-nav-inner{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;justify-content:space-evenly;overflow-y:auto}
#odf-service .odf-nav-item{display:flex;align-items:center;gap:14px;padding:11px 6px;font-size:20px;font-weight:700;color:var(--marine);text-decoration:none;border-bottom:1px solid var(--line)}
#odf-service .odf-nav-item:last-child{border-bottom:none}
#odf-service .odf-nav-item .ni{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--ac)}
#odf-service .odf-nav-item .ni svg{width:26px;height:26px}
#odf-service .odf-nav-foot{flex:0 0 auto;padding-top:12px;border-top:1px solid var(--line)}
#odf-service .odf-nav-foot p{margin:0 0 10px;font-size:14px;color:var(--mut);text-align:center}
#odf-service .odf-nav-call{display:block;text-align:center;background:var(--soft);color:var(--ac2);font-weight:900;font-size:19px;padding:13px;border-radius:12px;text-decoration:none;margin-bottom:10px}
#odf-service .odf-nav-rdv{display:block;text-align:center;background:var(--warm);color:#fff;font-weight:800;font-size:15px;padding:13px;border-radius:12px;text-decoration:none}
@media screen and (max-height:620px){#odf-service .odf-nav-item{padding:8px 6px;font-size:19px}#odf-service .odf-nav-item .ni svg{width:24px;height:24px}#odf-service .odf-nav-foot p{margin-bottom:8px;font-size:13px}#odf-service .odf-nav-call,#odf-service .odf-nav-rdv{padding:11px}}
/* ===================== FIN GABARIT PAGE SERVICE ===================== */


/* --- Liste à puces "checklist" (pages arrondissement / géo) — ajout au scope #odf-service --- */
#odf-service .checklist{list-style:none;margin:4px 0 0;padding:0;display:grid;gap:9px}
#odf-service .checklist li{position:relative;padding-left:30px;font-size:13.5px;color:#39495f;line-height:1.5}
#odf-service .checklist li::before{content:"";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:6px;background:var(--soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231763c9' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}


/* --- Sous-titre H3 dans une section (pages ville Sud multi-nuisibles) — ajout scope #odf-service --- */
#odf-service .sub-h{font-size:14.5px;font-weight:800;color:var(--ac2);margin:18px 0 9px;letter-spacing:-.2px}
#odf-service .sub-h:first-of-type{margin-top:6px}


/* --- Article de blog (corps long-forme + méta) — ajout scope #odf-service --- */
#odf-service .ameta{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center;margin-top:14px;font-size:12.5px;color:#5b6b80}
#odf-service .ameta span{display:inline-flex;align-items:center;gap:6px}
#odf-service .ameta svg{width:14px;height:14px;stroke:var(--ac);flex:none}
#odf-service .ameta .dot{width:3px;height:3px;border-radius:50%;background:#c2cede;padding:0}
#odf-service .article-body{max-width:680px;margin:0 auto}
#odf-service .article-body p{font-size:15px;line-height:1.72;color:#33414f;margin:0 0 17px}
#odf-service .article-body h2{font-size:20px;font-weight:800;color:var(--marine);letter-spacing:-.4px;line-height:1.25;margin:34px 0 12px}
#odf-service .article-body h3{font-size:16px;font-weight:800;color:var(--ac2);margin:24px 0 9px}
#odf-service .article-body ul,#odf-service .article-body ol{margin:0 0 18px;padding-left:0;list-style:none;display:grid;gap:9px}
#odf-service .article-body ul li{position:relative;padding-left:26px;font-size:14.5px;line-height:1.6;color:#39495f}
#odf-service .article-body ul li::before{content:"";position:absolute;left:2px;top:8px;width:7px;height:7px;border-radius:50%;background:var(--warm)}
#odf-service .article-body ol{counter-reset:ol}
#odf-service .article-body ol li{counter-increment:ol;position:relative;padding-left:30px;font-size:14.5px;line-height:1.6;color:#39495f}
#odf-service .article-body ol li::before{content:counter(ol);position:absolute;left:0;top:0;width:20px;height:20px;border-radius:6px;background:var(--soft);color:var(--ac);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}
#odf-service .article-body a{color:var(--ac);font-weight:600;text-decoration:underline;text-underline-offset:2px}
#odf-service .article-body strong,#odf-service .article-body b{color:var(--marine);font-weight:700}
#odf-service .article-body blockquote{margin:0 0 18px;padding:13px 16px;border-left:3px solid var(--ac);background:var(--soft);border-radius:0 10px 10px 0;font-size:14.5px;color:#33414f}

/* --- Masquer le bandeau auteur/date par défaut d'Astra sur les articles seuls (le gabarit #odf-service a sa propre méta) --- */
body.single-post .entry-header,body.single-post .ast-single-post .entry-meta{display:none!important}


/* ===== PDL (services) — logos dans les cartes hero ===== */
#odf-service .floats .fl{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;}
#odf-service .floats .fl-logo{height:26px;width:auto;max-width:84px;object-fit:contain;margin-bottom:4px;display:block;}
#odf-service .floats .fl-google{display:inline-flex;align-items:center;justify-content:center;margin-bottom:3px;line-height:0;}
#odf-service .floats .fl-google svg{display:block;}
