/* ════════════════════════════════════════════════════════════════════
   SERRUFRANCE — MODULES INTERACTIFS « GAMIFIÉS »
   Tout est préfixé .sf-  → aucun risque de conflit avec votre CSS existant.
   Tokens repris de votre home.css : --blue #1B50D8, Bebas Neue, DM Sans.
   ════════════════════════════════════════════════════════════════════ */
.sf-gam{
  --blue:#1B50D8; --blue-dk:#1039A8; --blue-lt:#EBF0FF;
  --dark:#0C0C0F; --dark2:#131318; --dark3:#1A1A22;
  --bd:rgba(255,255,255,.08); --off:#F4F3F0; --txt:#191920; --mut:#64636A;
  --amber:#F59E0B; --green:#22C55E; --red:#EF4444;
  font-family:'DM Sans',sans-serif; color:var(--txt);
  -webkit-font-smoothing:antialiased;
}
.sf-gam *,.sf-gam *::before,.sf-gam *::after{box-sizing:border-box;margin:0;padding:0}
.sf-gam button{font-family:inherit;cursor:pointer;border:none;background:none}
.sf-gam .sf-bebas{font-family:'Bebas Neue',sans-serif;letter-spacing:.03em}

/* shared section shell */
.sf-sec{padding:80px 24px;position:relative;overflow:hidden}
.sf-inner{max-width:920px;margin:0 auto;position:relative;z-index:2}
.sf-sec.sf-dark{background:var(--dark)}
.sf-sec.sf-dark2{background:var(--dark2)}
.sf-sec.sf-light{background:var(--off)}
.sf-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(27,80,216,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(27,80,216,.06) 1px,transparent 1px);background-size:54px 54px;pointer-events:none}
.sf-glow{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(27,80,216,.20) 0%,transparent 70%)}

.sf-eye{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:10px;text-align:center}
.sf-dark .sf-eye,.sf-dark2 .sf-eye,.sf-diag .sf-eye{color:#7AABFF}
.sf-h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5.5vw,60px);line-height:1;letter-spacing:.02em;text-align:center;color:var(--dark)}
.sf-dark .sf-h2,.sf-dark2 .sf-h2,.sf-diag .sf-h2{color:#fff}
.sf-h2 span{color:var(--blue)}
.sf-dark .sf-h2 span,.sf-dark2 .sf-h2 span,.sf-diag .sf-h2 span{color:#7AABFF}
.sf-sub{text-align:center;font-size:15px;line-height:1.7;color:var(--mut);max-width:520px;margin:14px auto 0}
.sf-dark .sf-sub,.sf-dark2 .sf-sub,.sf-diag .sf-sub{color:rgba(255,255,255,.78)}

/* reusable phone button (matches your .hcbtn) */
.sf-call{display:inline-flex;align-items:center;gap:0;background:var(--blue);color:#fff;border-radius:8px;overflow:hidden;transition:background .2s,transform .15s,box-shadow .2s;text-decoration:none;box-shadow:0 8px 28px rgba(27,80,216,.4)}
.sf-call:hover{background:var(--blue-dk);transform:translateY(-2px);box-shadow:0 12px 36px rgba(27,80,216,.5)}
.sf-call .sf-call-t{padding:16px 24px;font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.05em;color:#fff;white-space:nowrap}
.sf-call .sf-call-a{width:56px;align-self:stretch;background:rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;color:#fff}
.sf-call .sf-call-a svg{width:22px;height:22px;fill:#fff}
@keyframes sf-shake{0%,70%,100%{transform:rotate(0)}10%{transform:rotate(-15deg)}20%{transform:rotate(15deg)}30%{transform:rotate(-10deg)}40%{transform:rotate(10deg)}50%{transform:rotate(-5deg)}60%{transform:rotate(5deg)}}
.sf-shake{display:inline-block;transform-origin:center;animation:sf-shake 1.8s ease-in-out infinite}
@keyframes sf-fup{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.sf-fade{animation:sf-fup .55s cubic-bezier(.22,1,.36,1) both}

/* ─────────────────────────────────────────────────────────────────
   MODULE 1+2+3 · DIAGNOSTIC : situation → questions → jauge → tarif
   ───────────────────────────────────────────────────────────────── */
.sf-diag{background:linear-gradient(150deg,#0C0C0F 0%,#131318 55%,#0C0C0F 100%)}
.sf-card{max-width:640px;margin:34px auto 0;background:#fff;border-radius:8px 28px 8px 28px;box-shadow:0 28px 70px rgba(0,0,0,.45);overflow:hidden}
.sf-card-top{display:flex;align-items:center;gap:10px;padding:14px 22px;background:var(--dark2);border-bottom:.5px solid var(--bd)}
.sf-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:sf-pulse 2s infinite}
@keyframes sf-pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 9px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.sf-card-top .sf-live{font-size:12px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.02em}
.sf-prog{margin-left:auto;display:flex;gap:5px}
.sf-prog i{width:26px;height:4px;border-radius:3px;background:rgba(255,255,255,.14);transition:background .3s}
.sf-prog i.on{background:var(--blue)}
.sf-card-body{padding:30px 28px 34px}
.sf-step{display:none}
.sf-step.on{display:block;animation:sf-fup .4s ease both}
.sf-q{font-family:'Bebas Neue',sans-serif;font-size:27px;color:var(--dark);letter-spacing:.02em;text-align:center;margin-bottom:4px}
.sf-q-s{text-align:center;font-size:13px;color:var(--mut);margin-bottom:22px}
.sf-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sf-opt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:22px 14px;border:1.5px solid #e6e6ec;border-radius:14px;background:#fafafb;text-align:center;transition:border-color .18s,transform .12s,box-shadow .18s,background .18s}
.sf-opt:hover{border-color:var(--blue);background:var(--blue-lt);transform:translateY(-2px);box-shadow:0 8px 22px rgba(27,80,216,.14)}
.sf-opt .sf-ico{font-size:30px;line-height:1}
.sf-opt .sf-lbl{font-weight:600;font-size:14px;color:var(--dark)}
.sf-opt .sf-meta{font-size:11px;color:var(--mut)}
.sf-back{display:inline-flex;align-items:center;gap:6px;margin-top:20px;font-size:13px;font-weight:600;color:var(--mut);background:none}
.sf-back:hover{color:var(--blue)}

/* jauge d'urgence */
.sf-gauge-wrap{text-align:center}
.sf-gauge{position:relative;width:240px;height:124px;margin:8px auto 4px}
.sf-gauge svg{width:100%;height:100%;overflow:visible}
.sf-gauge-track{fill:none;stroke:#ececf1;stroke-width:16;stroke-linecap:round}
.sf-gauge-fill{fill:none;stroke:url(#sf-grad);stroke-width:16;stroke-linecap:round;transition:stroke-dashoffset 1.1s cubic-bezier(.22,1,.36,1)}
.sf-gauge-needle{transition:transform 1.1s cubic-bezier(.34,1.56,.64,1);transform-origin:120px 110px}
.sf-gauge-val{font-family:'Bebas Neue',sans-serif;font-size:50px;color:var(--dark);line-height:.9;margin-top:-6px}
.sf-gauge-lbl{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-top:2px}
.sf-result{margin-top:18px;padding:20px;border-radius:16px;background:var(--blue-lt);border:1px solid rgba(27,80,216,.2);text-align:center}
.sf-result .sf-price{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--blue);line-height:1}
.sf-result .sf-price-l{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--mut);margin-bottom:4px}
.sf-result .sf-note{font-size:12px;color:var(--mut);margin-top:10px;line-height:1.5}
.sf-result .sf-call{margin-top:18px}
.sf-reassure{margin-top:16px;padding:16px 18px;background:#fafafb;border:1px solid #ececf1;border-radius:14px;font-size:14px;line-height:1.6;color:#444}
.sf-reassure b{color:var(--dark)}
@media(max-width:520px){.sf-opts{grid-template-columns:1fr}.sf-card{border-radius:8px 18px 8px 18px}}

/* ─────────────────────────────────────────────────────────────────
   MODULE 5 · COMPTEUR D'INTERVENTIONS (anime au scroll)
   MODULE 6 · BADGE TEMPS DE RÉPONSE (pulse)
   ───────────────────────────────────────────────────────────────── */
.sf-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:820px;margin:34px auto 0}
.sf-stat{background:rgba(255,255,255,.05);border:.5px solid rgba(255,255,255,.1);border-radius:18px;padding:26px 18px;text-align:center;position:relative;overflow:hidden}
.sf-stat::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(27,80,216,.18),transparent 70%)}
.sf-stat-n{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,7vw,58px);color:#fff;line-height:1;position:relative}
.sf-stat-n span{color:#7AABFF}
.sf-stat-l{font-size:12px;color:rgba(255,255,255,.5);font-weight:500;margin-top:6px;letter-spacing:.04em;position:relative}
/* badge temps réponse */
.sf-resp{display:inline-flex;align-items:center;gap:12px;margin:0 auto;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.35);border-radius:999px;padding:9px 9px 9px 18px}
.sf-resp .sf-resp-t{color:#fff;font-size:14px;font-weight:600}
.sf-resp .sf-resp-t b{color:#4ADE80}
.sf-resp .sf-resp-badge{display:flex;align-items:center;gap:6px;background:var(--green);color:#062b14;font-weight:700;font-size:13px;padding:6px 13px;border-radius:999px}
.sf-resp .sf-rdot{width:7px;height:7px;border-radius:50%;background:#062b14;animation:sf-blink 1.2s infinite}
@keyframes sf-blink{0%,100%{opacity:1}50%{opacity:.25}}
.sf-stats-cta{text-align:center;margin-top:14px}
@media(max-width:600px){.sf-stats{grid-template-columns:1fr;gap:12px}.sf-stat{padding:20px}}

/* ─────────────────────────────────────────────────────────────────
   MODULE 7 · CARROUSEL D'AVIS + remplissage des étoiles
   ───────────────────────────────────────────────────────────────── */
.sf-rev{max-width:680px;margin:34px auto 0;position:relative}
.sf-rev-card{background:rgba(255,255,255,.05);border:.5px solid rgba(255,255,255,.1);border-radius:20px;padding:34px 32px 28px;display:none;position:relative;overflow:hidden}
.sf-rev-card.on{display:block;animation:sf-fup .5s ease both}
.sf-rev-card::before{content:'\201C';position:absolute;top:-22px;right:20px;font-size:130px;font-family:'Bebas Neue',sans-serif;color:rgba(27,80,216,.13)}
.sf-stars{display:flex;gap:4px;margin-bottom:14px}
.sf-star{width:22px;height:22px;position:relative}
.sf-star svg{width:100%;height:100%;display:block}
.sf-star .sf-star-bg{fill:rgba(255,255,255,.14)}
.sf-star .sf-star-fg{fill:var(--amber);clip-path:inset(0 100% 0 0);transition:clip-path .45s ease}
.sf-rev-card.on .sf-star .sf-star-fg{clip-path:inset(0 0 0 0)}
.sf-rev-card.on .sf-star:nth-child(2) .sf-star-fg{transition-delay:.08s}
.sf-rev-card.on .sf-star:nth-child(3) .sf-star-fg{transition-delay:.16s}
.sf-rev-card.on .sf-star:nth-child(4) .sf-star-fg{transition-delay:.24s}
.sf-rev-card.on .sf-star:nth-child(5) .sf-star-fg{transition-delay:.32s}
.sf-rev-txt{font-size:16px;line-height:1.8;color:rgba(255,255,255,.9);position:relative}
.sf-rev-foot{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:.5px solid rgba(255,255,255,.08)}
.sf-rev-av{width:42px;height:42px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:17px;color:#fff;flex-shrink:0;box-shadow:0 3px 12px rgba(27,80,216,.4)}
.sf-rev-name{font-weight:700;font-size:14px;color:#fff}
.sf-rev-loc{font-size:12px;color:rgba(255,255,255,.4)}
.sf-rev-nav{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px}
.sf-rev-dots{display:flex;gap:7px}
.sf-rev-dots b{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);cursor:pointer;transition:background .2s,transform .2s}
.sf-rev-dots b.on{background:var(--blue);transform:scale(1.25)}
.sf-rev-arrow{width:38px;height:38px;border-radius:50%;border:.5px solid rgba(255,255,255,.16);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .2s,border-color .2s}
.sf-rev-arrow:hover{background:rgba(27,80,216,.2);border-color:var(--blue)}

/* ─────────────────────────────────────────────────────────────────
   MODULE 8 · « SERRURIER LE PLUS PROCHE » — épingle animée (page commune)
   ───────────────────────────────────────────────────────────────── */
.sf-map{max-width:560px;margin:34px auto 0;background:rgba(255,255,255,.04);border:.5px solid rgba(255,255,255,.1);border-radius:20px;padding:10px;overflow:hidden}
.sf-map-canvas{position:relative;height:240px;border-radius:14px;overflow:hidden;background:radial-gradient(circle at 50% 60%,#15233f 0%,#0d1426 70%)}
.sf-map-roads{position:absolute;inset:0;opacity:.5}
.sf-ripple{position:absolute;top:50%;left:50%;width:18px;height:18px;border-radius:50%;border:2px solid rgba(122,171,255,.7);transform:translate(-50%,-50%);animation:sf-ripple 2.4s ease-out infinite}
.sf-ripple:nth-child(2){animation-delay:.8s}
.sf-ripple:nth-child(3){animation-delay:1.6s}
@keyframes sf-ripple{0%{width:18px;height:18px;opacity:.8}100%{width:200px;height:200px;opacity:0}}
.sf-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-160%) scale(.4);opacity:0;animation:sf-drop .7s cubic-bezier(.34,1.56,.64,1) .3s forwards}
@keyframes sf-drop{60%{transform:translate(-50%,-86%) scale(1.1);opacity:1}100%{transform:translate(-50%,-92%) scale(1);opacity:1}}
.sf-pin svg{width:42px;height:42px;filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}
.sf-map-tag{position:absolute;bottom:14px;left:14px;right:14px;display:flex;align-items:center;gap:10px;background:rgba(12,12,15,.82);backdrop-filter:blur(8px);border:.5px solid rgba(255,255,255,.12);border-radius:12px;padding:11px 14px}
.sf-map-tag .sf-dot{flex-shrink:0}
.sf-map-tag-t{font-size:14px;color:#fff;font-weight:600;line-height:1.35}
.sf-map-tag-t span{color:#7AABFF}
.sf-map-tag-s{font-size:11px;color:rgba(255,255,255,.5)}
.sf-map-cta{text-align:center;margin-top:18px}

/* ─────────────────────────────────────────────────────────────────
   MODULE 9 · DIAGNOSTIC SÉCURITÉ (score /100)
   ───────────────────────────────────────────────────────────────── */
.sf-secq{max-width:560px;margin:34px auto 0}
.sf-secq .sf-step{display:none}
.sf-secq .sf-step.on{display:block;animation:sf-fup .4s ease both}
.sf-secq .sf-opts{grid-template-columns:1fr}
.sf-secq .sf-opt{flex-direction:row;justify-content:flex-start;text-align:left;padding:16px 18px;background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
.sf-secq .sf-opt:hover{background:rgba(27,80,216,.16);border-color:var(--blue)}
.sf-secq .sf-opt .sf-ico{font-size:24px}
.sf-secq .sf-opt .sf-lbl{color:#fff;font-size:15px}
.sf-secq .sf-q{color:#fff}
.sf-secq .sf-q-s{color:rgba(255,255,255,.72)}
.sf-secq .sf-back{color:rgba(255,255,255,.5)}
.sf-secq .sf-back:hover{color:#7AABFF}
.sf-prog.sf-prog-c{justify-content:center;margin:0 auto 20px}
.sf-score-ring{position:relative;width:180px;height:180px;margin:6px auto 0}
.sf-score-ring svg{transform:rotate(-90deg)}
.sf-score-bg{fill:none;stroke:rgba(255,255,255,.1);stroke-width:14}
.sf-score-fg{fill:none;stroke-width:14;stroke-linecap:round;transition:stroke-dashoffset 1.2s cubic-bezier(.22,1,.36,1)}
.sf-score-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sf-score-n{font-family:'Bebas Neue',sans-serif;font-size:54px;line-height:.9;color:#fff}
.sf-score-n small{font-size:22px;color:rgba(255,255,255,.4)}
.sf-score-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.sf-score-msg{text-align:center;font-size:15px;line-height:1.7;color:rgba(255,255,255,.78);margin-top:18px;max-width:440px;margin-left:auto;margin-right:auto}
.sf-score-msg b{color:#fff}
.sf-score-cta{text-align:center;margin-top:20px}

/* ─────────────────────────────────────────────────────────────────
   MODULE 11 · « MYTHE OU RÉALITÉ » — swipe
   ───────────────────────────────────────────────────────────────── */
.sf-swipe{max-width:440px;margin:34px auto 0}
.sf-deck{position:relative;height:300px;user-select:none}
.sf-mcard{position:absolute;inset:0;background:#fff;border-radius:22px;box-shadow:0 18px 50px rgba(0,0,0,.4);padding:30px 28px;display:flex;flex-direction:column;justify-content:center;text-align:center;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .4s;will-change:transform}
.sf-mcard .sf-mc-tag{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.sf-mcard .sf-mc-q{font-family:'Bebas Neue',sans-serif;font-size:26px;line-height:1.08;color:var(--dark);letter-spacing:.01em}
.sf-mcard .sf-mc-hint{font-size:12px;color:var(--mut);margin-top:16px}
.sf-stamp{position:absolute;top:24px;font-family:'Bebas Neue',sans-serif;font-size:34px;padding:4px 16px;border:4px solid;border-radius:10px;opacity:0;transition:opacity .15s;letter-spacing:.04em}
.sf-stamp.vrai{left:24px;color:var(--green);border-color:var(--green);transform:rotate(-14deg)}
.sf-stamp.faux{right:24px;color:var(--red);border-color:var(--red);transform:rotate(14deg)}
.sf-reveal{position:absolute;inset:0;background:var(--dark2);border-radius:22px;box-shadow:0 18px 50px rgba(0,0,0,.4);padding:28px;display:none;flex-direction:column;justify-content:center;text-align:center}
.sf-reveal.on{display:flex;animation:sf-fup .4s ease both}
.sf-reveal .sf-rv-verdict{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:.05em;margin-bottom:10px}
.sf-reveal .sf-rv-verdict.is-faux{color:#FCA5A5}
.sf-reveal .sf-rv-verdict.is-vrai{color:#86EFAC}
.sf-reveal .sf-rv-txt{font-size:14px;line-height:1.7;color:rgba(255,255,255,.8)}
.sf-swipe-btns{display:flex;gap:12px;margin-top:18px}
.sf-sbtn{flex:1;padding:15px;border-radius:14px;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .12s,box-shadow .2s,filter .2s}
.sf-sbtn:hover{transform:translateY(-2px)}
.sf-sbtn.faux{background:rgba(239,68,68,.14);color:#FCA5A5;border:1px solid rgba(239,68,68,.4)}
.sf-sbtn.vrai{background:rgba(34,197,94,.14);color:#86EFAC;border:1px solid rgba(34,197,94,.4)}
.sf-swipe-prog{text-align:center;font-size:12px;color:rgba(255,255,255,.45);margin-top:14px;font-weight:600;letter-spacing:.05em}
.sf-swipe-end{display:none;text-align:center}
.sf-swipe-end.on{display:block;animation:sf-fup .5s ease both}
.sf-swipe-end .sf-score-big{font-family:'Bebas Neue',sans-serif;font-size:60px;color:#7AABFF;line-height:1}
.sf-swipe-end .sf-call{margin-top:18px}

/* utility: scroll reveal (mirror du .rv de votre site) */
.sf-rvl{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.sf-rvl.sf-vis{opacity:1;transform:translateY(0)}




/* Fix: ensure Services photos fill the card on city pages (overrides a malformed base rule) */
.svc-sec .sc-illo{position:relative;overflow:hidden}
.svc-sec .sc-illo picture{position:absolute!important;inset:0!important;display:block!important;width:100%!important;height:100%!important}
.svc-sec .sc-illo img.photo-placeholder{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important;object-position:center!important}

/* ── Campagne week-end : barre promo discrète et fermable ───────────── */
.sf-promo{background:linear-gradient(90deg,#1039A8,#1B50D8);color:#fff;font-family:'DM Sans',sans-serif;position:relative;z-index:60;border-bottom:1px solid rgba(255,255,255,.12)}
.sf-promo.sf-promo-hidden{display:none}
.sf-promo-in{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:13.5px;line-height:1.35}
.sf-promo-tag{flex-shrink:0;font-family:'Bebas Neue',sans-serif;letter-spacing:.06em;font-size:15px;background:#fff;color:#1B50D8;padding:2px 9px;border-radius:5px}
.sf-promo-txt{flex:1;min-width:0}
.sf-promo-fine{opacity:.72;font-size:12px}
.sf-promo-short{display:none}
.sf-promo-long{display:inline}
.sf-promo-code{font-weight:800;letter-spacing:.04em;background:rgba(255,255,255,.16);border:1px dashed rgba(255,255,255,.55);color:#fff;padding:1px 8px;border-radius:5px;cursor:pointer;font-family:inherit;font-size:13px;transition:background .15s}
.sf-promo-code:hover{background:rgba(255,255,255,.28)}
.sf-promo-code.sf-copied{background:#22C55E;border-color:#22C55E;color:#06280f}
.sf-promo-call{flex-shrink:0;font-weight:700;color:#fff;text-decoration:none;background:rgba(0,0,0,.18);padding:6px 12px;border-radius:6px;white-space:nowrap;transition:background .15s}
.sf-promo-call:hover{background:rgba(0,0,0,.32)}
.sf-promo-x{flex-shrink:0;background:none;border:none;color:#fff;font-size:22px;line-height:1;opacity:.75;cursor:pointer;padding:0 4px}
.sf-promo-x:hover{opacity:1}
@media(max-width:900px){
  .sf-promo-fine{display:none}
  .sf-promo-call{display:none}
}
@media(max-width:560px){
  .sf-promo-in{padding:8px 10px;gap:8px;font-size:12px;flex-wrap:nowrap;align-items:center}
  .sf-promo-tag{display:none}
  .sf-promo-txt{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sf-promo-long{display:none}
  .sf-promo-short{display:inline}
}



/* Fix nav squeeze: switch to burger earlier so long city names don't collide with the menu */
@media(max-width:1024px){
  #nav .nlinks{display:none !important}
  #nav .burger{display:flex !important}
  #nav{padding:14px 20px}
}


/* Subtitles fully legible (white) on the security-diagnostic and myth-game sections */
#sf-secq-sec .sf-sub,
#sf-swipe-sec .sf-sub{color:#fff !important}

/* Battement de cœur sur le code promo */
@keyframes sf-heartbeat{
  0%{transform:scale(1)}
  14%{transform:scale(1.12)}
  28%{transform:scale(1)}
  42%{transform:scale(1.12)}
  70%{transform:scale(1)}
  100%{transform:scale(1)}
}
.sf-promo-code{animation:sf-heartbeat 1.6s ease-in-out infinite;transform-origin:center}
.sf-promo-code:hover,.sf-promo-code.sf-copied{animation:none}
@media(prefers-reduced-motion:reduce){.sf-promo-code{animation:none}}

/* Fix: dynamic ETA number must stay white (the unit span stays blue) */
.scn span[data-sf-eta]{color:#fff !important}
.wbn span[data-sf-eta]{color:inherit !important}

/* Promo bar fixed at top; nav + hero offset purely via CSS presence (no JS flash) */
.sf-promo{position:fixed;top:0;left:0;right:0;z-index:210}
body:has(#sfPromo:not(.sf-promo-hidden)) #nav{top:var(--sf-promo-h,42px)}
body:has(#sfPromo:not(.sf-promo-hidden)) .hero{padding-top:var(--sf-promo-h,42px)}
/* Fallback for browsers without :has() — JS adds .sf-has-promo */
body.sf-has-promo #nav{top:var(--sf-promo-h,42px)}
body.sf-has-promo .hero{padding-top:var(--sf-promo-h,42px)}
