  :root{
    --green:#0fae7e;--green2:#23c89a;--greend:#0a8f68;
    --bg:#ffffff;--bg2:#f4f8f5;--ink:#0e1726;--ink2:#33414f;--mut:#5d6b80;--line:#e6ece9;--card:#ffffff;--cream:#edf7f1;
    --shadow:0 30px 60px -32px rgba(13,40,33,.35);--shadow-sm:0 14px 30px -16px rgba(13,40,33,.22);
    --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--disp:"Fraunces","Iowan Old Style",Georgia,serif;
    --hero1:#0a8f68;--hero2:#0e1726;--auroraA:rgba(15,174,126,.16);--auroraB:rgba(35,200,154,.12);
  }
  [data-theme="dark"]{
    --bg:#080d14;--bg2:#0c1320;--ink:#eef3f7;--ink2:#c3cdd7;--mut:#8a97a8;--line:#1d2736;--card:#101a28;--cream:#0f261d;
    --shadow:0 30px 70px -30px rgba(0,0,0,.7);--shadow-sm:0 16px 36px -18px rgba(0,0,0,.6);
    --auroraA:rgba(15,174,126,.22);--auroraB:rgba(35,200,154,.14);
  }
  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html{scroll-behavior:smooth}
  body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .4s,color .4s}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:1180px;margin:0 auto;padding:0 24px}
  .disp{font-family:var(--disp);font-weight:600;letter-spacing:-.015em;line-height:1.06}
  h1{font-size:clamp(34px,5.4vw,62px)}h2{font-size:clamp(27px,3.6vw,42px)}h3{font-size:20px}
  .ey{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
  .ey::before{content:"";width:24px;height:2px;background:var(--green);border-radius:2px}
  .lead{font-size:clamp(16px,1.7vw,19px);color:var(--ink2)}
  .muted{color:var(--mut)}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:15px;padding:13px 22px;border-radius:40px;border:1.5px solid transparent;cursor:pointer;transition:.2s;white-space:nowrap}
  .btn svg{width:18px;height:18px}
  .btn-grn{background:linear-gradient(135deg,var(--green),var(--green2));color:#04130d;box-shadow:0 16px 34px -14px rgba(15,174,126,.6)}
  .btn-grn:hover{transform:translateY(-1px)}
  .btn-ghost{border-color:var(--line);color:var(--ink);background:var(--card)}
  .btn-ghost:hover{border-color:var(--green)}
  .btn-sm{padding:9px 16px;font-size:14px}
  /* header */
  header{position:sticky;top:0;z-index:600;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:background .4s}
  .nav{display:flex;align-items:center;gap:18px;height:70px}
  .logo{font-family:var(--disp);font-weight:700;font-size:23px;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
  .logo b{color:var(--green)}
  .pmark{width:34px;height:34px;border-radius:10px;background:linear-gradient(140deg,var(--green),var(--green2));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px -4px color-mix(in srgb,var(--green) 70%,transparent)}
  .pmark svg{width:20px;height:20px}
  nav.main{display:flex;align-items:center;gap:4px;margin-left:14px}
  nav.main>div,nav.main>a{position:relative}
  .navlink{padding:10px 14px;border-radius:10px;font-weight:600;font-size:15px;color:var(--ink2);cursor:pointer;display:flex;align-items:center;gap:6px}
  .navlink:hover{color:var(--ink);background:var(--bg2)}
  .navlink svg{width:14px;height:14px;opacity:.6}
  .mega{position:absolute;top:calc(100% + 8px);left:0;width:560px;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:18px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  nav.main>div:hover .mega{opacity:1;visibility:visible;transform:none}
  .megacol-h{grid-column:1/-1;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--mut);padding:4px 10px 2px}
  .megaitem{display:flex;gap:11px;padding:10px;border-radius:12px}
  .megaitem:hover{background:var(--bg2)}
  .megaitem .mi{width:34px;height:34px;border-radius:9px;background:var(--cream);color:var(--green);display:flex;align-items:center;justify-content:center;flex:none}
  .megaitem .mi svg{width:18px;height:18px}
  .megaitem b{font-size:14.5px;display:block}.megaitem span{font-size:12.5px;color:var(--mut)}
  .nav-r{margin-left:auto;display:flex;align-items:center;gap:10px}
  .tt{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer}
  .tt svg{width:19px;height:19px}
  .burger{display:none;width:42px;height:42px;border-radius:11px;border:1px solid var(--line);background:var(--card);color:var(--ink);align-items:center;justify-content:center;cursor:pointer}
  .burger svg{width:22px;height:22px}
  /* hero */
  .hero{position:relative;overflow:hidden}
  .hero::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 70% at 12% 0%,var(--auroraA),transparent 60%),radial-gradient(70% 60% at 100% 20%,var(--auroraB),transparent 55%);pointer-events:none}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:64px 0 72px;position:relative}
  .pill{display:inline-flex;align-items:center;gap:8px;background:var(--cream);border:1px solid color-mix(in srgb,var(--green) 30%,transparent);color:var(--greend);border-radius:40px;padding:7px 15px;font-size:13px;font-weight:700}
  [data-theme="dark"] .pill{color:var(--green2)}
  .hero h1{margin:18px 0 0}
  .rot{color:var(--green);position:relative;display:inline-block}
  .hero .sub{margin-top:20px;max-width:30ch}
  .hcta{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
  .rate{display:flex;align-items:center;gap:10px;margin-top:22px;font-size:14px;color:var(--mut)}
  .stars{color:#f5a623;display:flex;gap:1px}.stars svg{width:16px;height:16px}
  .trust{display:flex;gap:18px;flex-wrap:wrap;margin-top:26px}
  .trust div{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink2)}
  .trust svg{width:17px;height:17px;color:var(--green)}
  .hero-visual{position:relative}
  .hero-img{border-radius:26px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/4.4;background:#ccc center/cover}
  .hero-card{position:absolute;left:-26px;bottom:26px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:14px 16px;display:flex;align-items:center;gap:12px;max-width:255px}
  .hero-card .av{width:42px;height:42px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
  .hero-card .av svg{width:22px;height:22px}
  .hero-card b{font-size:14px;display:block;line-height:1.25}.hero-card span{display:block;font-size:12px;color:var(--mut);margin-top:2px}
  /* sections */
  section{position:relative}
  .sec{padding:78px 0}
  .center{text-align:center;max-width:720px;margin:0 auto}
  .reveal{opacity:0;transform:translateY(22px);transition:.75s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
  /* segmentation */
  .seg{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
  .segcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;transition:.2s;cursor:pointer}
  .segcard:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
  .segcard .ic{width:46px;height:46px;border-radius:13px;background:var(--cream);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
  .segcard .ic svg{width:24px;height:24px}
  .segcard h3{font-size:17px;margin:0 0 4px}.segcard p{font-size:13.5px;color:var(--mut);margin:0}
  /* manifesto */
  .manifesto{background:linear-gradient(135deg,var(--greend),var(--green) 60%,var(--green2));color:#04130d;border-radius:30px;padding:60px;text-align:center}
  .manifesto .q{font-family:var(--disp);font-weight:600;font-size:clamp(24px,3.4vw,40px);line-height:1.15;max-width:24ch;margin:0 auto}
  .manifesto p{color:#06402e;font-size:17px;margin-top:18px}
  /* services */
  .svc{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
  .svccard{background:var(--card);border:1px solid var(--line);border-radius:22px;overflow:hidden;display:flex;flex-direction:column;transition:.22s}
  .svccard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
  .svccard .ph{height:160px;background:#ccc center/cover}
  .svccard .bd{padding:22px;flex:1;display:flex;flex-direction:column}
  .svccard .tag{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green)}
  .svccard h3{font-family:var(--disp);font-size:22px;margin:6px 0 8px}
  .svccard p{font-size:14px;color:var(--ink2);margin:0 0 14px;flex:1}
  .svccard .more{font-weight:700;font-size:14px;color:var(--green);display:flex;align-items:center;gap:6px}
  .svccard .more svg{width:16px;height:16px;transition:.2s}.svccard:hover .more svg{transform:translateX(3px)}
  /* pillars */
  .pil{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:38px}
  .pilcard{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:26px}
  .pilcard .ic{width:50px;height:50px;border-radius:14px;background:var(--cream);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
  .pilcard .ic svg{width:26px;height:26px}
  .pilcard h3{font-family:var(--disp);font-size:20px;margin:0 0 6px}.pilcard p{font-size:13.5px;color:var(--mut);margin:0}
  /* eco band */
  .eco{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;background:var(--bg2);border:1px solid var(--line);border-radius:30px;padding:48px;overflow:hidden}
  .eco-img{border-radius:20px;aspect-ratio:16/11;background:#ccc center/cover;box-shadow:var(--shadow-sm)}
  .ecostats{display:flex;gap:30px;margin-top:24px}
  .ecostats .stat{font-family:var(--disp);font-weight:700;font-size:30px;color:var(--green);line-height:1}
  .ecostats span{font-size:12.5px;color:var(--mut)}
  /* app */
  .appband{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
  .applist{list-style:none;padding:0;margin:22px 0;display:grid;gap:13px}
  .applist li{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:var(--ink2)}
  .applist li svg{width:20px;height:20px;color:var(--green);flex:none;margin-top:2px}
  /* reviews */
  .rev-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
  .revwrap{margin-top:34px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
  .revtrack{display:flex;gap:20px;width:max-content;animation:scrollx 46s linear infinite}
  .revwrap:hover .revtrack{animation-play-state:paused}
  @keyframes scrollx{to{transform:translateX(-50%)}}
  .revcard{width:360px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;flex:none}
  .revcard .top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
  .revcard .pic{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;flex:none}
  .revcard .nm{font-weight:700;font-size:15px}.revcard .meta{font-size:12px;color:var(--mut);display:flex;align-items:center;gap:6px}
  .gico{width:15px;height:15px}
  .revcard .stars{margin-bottom:8px}
  .revcard p{font-size:14px;color:var(--ink2);margin:0;line-height:1.55}
  /* faq */
  .faq{max-width:820px;margin:36px auto 0}
  .qa{border-bottom:1px solid var(--line)}
  .qa summary{list-style:none;cursor:pointer;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:700;font-size:16.5px}
  .qa summary::-webkit-details-marker{display:none}
  .qa summary .pl{width:26px;height:26px;border-radius:50%;background:var(--cream);color:var(--green);display:flex;align-items:center;justify-content:center;flex:none;transition:.2s}
  .qa[open] summary .pl{transform:rotate(45deg)}
  .qa .a{padding:0 0 20px;color:var(--ink2);font-size:15px;max-width:62ch}
  /* cta */
  .ctaband{background:linear-gradient(135deg,var(--hero2),#10243a);border-radius:30px;padding:60px;text-align:center;color:#fff;position:relative;overflow:hidden}
  .ctaband::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 80% 20%,rgba(15,174,126,.4),transparent 60%)}
  .ctaband h2{position:relative;color:#fff}.ctaband p{position:relative;color:#aeb8c6;margin-top:12px}
  /* footer */
  footer{background:var(--bg2);border-top:1px solid var(--line);margin-top:80px;padding:56px 0 28px}
  .fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
  .fcol h4{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin:0 0 14px}
  .fcol a{display:block;font-size:14px;color:var(--ink2);padding:5px 0}.fcol a:hover{color:var(--green)}
  .fbot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:40px;padding-top:22px;border-top:1px solid var(--line);font-size:13px;color:var(--mut)}
  .soc{display:flex;gap:10px}.soc a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink2)}
  .soc a:hover{border-color:var(--green);color:var(--green)}.soc svg{width:18px;height:18px}
  /* mobile menu */
  .mmenu{position:fixed;inset:0;z-index:700;background:var(--bg);transform:translateX(100%);transition:.3s;padding:80px 24px 24px;overflow:auto}
  .mmenu.on{transform:none}
  .mmenu a{display:block;padding:14px 8px;font-size:18px;font-weight:700;border-bottom:1px solid var(--line)}
  .mclose{position:absolute;top:18px;right:20px;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;background:var(--card);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer}
  @media(max-width:920px){
    .hero-grid{grid-template-columns:1fr;gap:36px;padding:44px 0 50px}.hero-visual{order:-1}
    .seg,.svc,.pil{grid-template-columns:1fr 1fr}.eco,.appband{grid-template-columns:1fr;gap:30px;padding:32px}
    .fgrid{grid-template-columns:1fr 1fr}.manifesto,.ctaband{padding:40px 26px}
    nav.main,.nav-r .btn{display:none}.burger{display:flex}.nav-r{gap:8px}
  }
  @media(max-width:560px){.seg,.svc,.pil,.fgrid{grid-template-columns:1fr}.hero-card{display:none}}

  /* ============== FX 2026, vie, profondeur, mouvement ============== */
  html{background:var(--bg);transition:background .5s}
  body{background:transparent}
  .fx-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
  .blob{position:absolute;border-radius:50%;filter:blur(72px);opacity:.32;will-change:transform}
  [data-theme="dark"] .blob{opacity:.5}
  .blob.b1{width:48vw;height:48vw;left:-10vw;top:-8vw;background:radial-gradient(circle,rgba(15,174,126,.85),transparent 68%);animation:drift1 28s ease-in-out infinite}
  .blob.b2{width:42vw;height:42vw;right:-12vw;top:14vh;background:radial-gradient(circle,rgba(35,200,154,.75),transparent 68%);animation:drift2 34s ease-in-out infinite}
  .blob.b3{width:40vw;height:40vw;left:34vw;bottom:-16vw;background:radial-gradient(circle,rgba(13,143,104,.7),transparent 68%);animation:drift3 31s ease-in-out infinite}
  @keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(9vw,7vh) scale(1.16)}}
  @keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-8vw,-6vh) scale(1.12)}}
  @keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(5vw,-9vh) scale(1.2)}}
  .scrollbar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--green),var(--green2));z-index:900;box-shadow:0 0 14px rgba(15,174,126,.7);transition:width .1s linear}
  /* révélations cinématiques */
  .reveal{opacity:0;transform:translateY(36px) scale(.965);filter:blur(7px);transition:opacity .85s cubic-bezier(.2,.75,.25,1),transform .85s cubic-bezier(.2,.75,.25,1),filter .85s}
  .reveal.in{opacity:1;transform:none;filter:none}
  /* tilt 3D + reflet (macOS) */
  .tiltable{transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s;position:relative;transform-style:preserve-3d}
  .tiltable:hover{box-shadow:var(--shadow)}
  .glare{position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--gx,50%) var(--gy,0%),rgba(255,255,255,.35),transparent 42%);opacity:0;transition:opacity .3s;pointer-events:none;mix-blend-mode:soft-light}
  [data-theme="dark"] .glare{background:radial-gradient(circle at var(--gx,50%) var(--gy,0%),rgba(120,240,200,.22),transparent 45%);mix-blend-mode:screen}
  .tiltable:hover .glare{opacity:1}
  /* verre dépoli */
  .hero-card{background:color-mix(in srgb,var(--card) 72%,transparent);backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5);animation:floaty 5.5s ease-in-out infinite}
  @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-11px)}}
  .hero-visual{transition:transform .25s ease-out}
  .hero-img{will-change:transform}
  /* dégradé animé sur l'accent du hero */
  .rot{background:linear-gradient(100deg,var(--green) 18%,var(--green2) 40%,#8ff5cf 50%,var(--green2) 60%,var(--green) 82%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 7s linear infinite}
  @keyframes shimmer{to{background-position:220% center}}
  /* boutons : reflet qui balaie + magnétique */
  .btn-grn{position:relative;overflow:hidden;will-change:transform;transition:transform .2s ease,box-shadow .2s}
  .btn-grn::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-18deg);pointer-events:none}
  .btn-grn:hover::after{animation:shine .85s ease}
  @keyframes shine{to{left:140%}}
  .btn-grn:hover{box-shadow:0 22px 44px -14px rgba(15,174,126,.75)}
  /* lift doux + ombre dynamique sur cartes non tiltées */
  .revcard{transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s}
  .revcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
  .segcard,.svccard,.pilcard{transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s,border-color .3s}
  @media(prefers-reduced-motion:reduce){.blob,.hero-card,.rot{animation:none}.reveal{transition:opacity .3s}}

  /* ===== Partenaires + Contact ===== */
  .ptgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
  .ptcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow-sm)}
  .ptcard .ic{width:46px;height:46px;border-radius:13px;background:var(--cream);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:15px}
  .ptcard .ic svg{width:23px;height:23px}
  .ptcard h3{font-size:17.5px;margin:0 0 7px}
  .ptcard p{font-size:14px;color:var(--mut);margin:0;line-height:1.5}
  .contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:40px;align-items:start;margin-top:10px}
  .cform{background:var(--card);border:1px solid var(--line);border-radius:26px;padding:32px;box-shadow:var(--shadow)}
  .cform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .field{margin-bottom:15px;display:flex;flex-direction:column;gap:7px}
  .field label{font-size:13px;font-weight:600;color:var(--ink2)}
  .field input,.field select,.field textarea{font:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}
  .field input:focus,.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 20%,transparent)}
  .field textarea{resize:vertical;min-height:120px}
  .hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0}
  .intent{display:flex;gap:10px;flex-wrap:wrap}
  .intent label{flex:1;min-width:118px;position:relative;border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center;font-size:14px;font-weight:600;cursor:pointer;color:var(--ink2);transition:.2s}
  .intent input{position:absolute;opacity:0;inset:0;cursor:pointer}
  .intent label:has(input:checked){border-color:var(--green);background:var(--cream);color:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 16%,transparent)}
  .cnote{font-size:12.5px;color:var(--mut);margin-top:12px;line-height:1.5}
  @media(max-width:860px){.ptgrid{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr;gap:28px}}
  @media(max-width:560px){.ptgrid{grid-template-columns:1fr}.cform .row{grid-template-columns:1fr}}


/* ===== Fond carte de Lyon (subtil, thémé, parallaxe) ===== */
.fx-map{position:fixed;inset:-9% -5%;z-index:-1;pointer-events:none;color:#0e3b2c;opacity:.085;will-change:transform;transition:opacity .6s}
[data-theme="dark"] .fx-map{color:#8ff0cf;opacity:.13}
.fx-map svg{width:100%;height:100%;display:block}
.fx-map .riv{stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.fx-map .st{stroke:currentColor;fill:none;stroke-width:1;opacity:.55}
.fx-map .lm{fill:var(--green);opacity:.9}
.fx-map .lmr{stroke:var(--green);fill:none;opacity:.5}
.fx-map .lmt{fill:currentColor;font:700 14px var(--sans);opacity:.95;letter-spacing:.04em}
/* on atténue les blobs pour laisser respirer la carte */
.blob{opacity:.14}
[data-theme="dark"] .blob{opacity:.24}
@media(prefers-reduced-motion:reduce){.fx-map{transform:none!important}}
