  /* ============ THÈMES ============ */
  :root{
    --accent:#ff5a1f;
    --accent-2:#b85420;          /* orange brûlé (DA : orange / noir / crème) */
    --radius:16px;
    --maxw:1180px;
    --font:'Segoe UI',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
    --t:.45s cubic-bezier(.4,0,.2,1);
  }
  /* Clair (défaut) */
  html[data-theme="light"]{
    --bg:#ffffff;
    --bg-2:#f5f6f4;
    --panel:#ffffff;
    --line:rgba(15,20,18,.10);
    --text:#14181a;
    --muted:#5d6562;
    --accent-soft:rgba(255,90,31,.12);
    --hud:rgba(15,20,18,.16);
    --shadow:0 18px 40px -22px rgba(15,20,18,.30);
    --grid:rgba(15,20,18,.085);
    --hole:rgba(14,17,15,.84);
  }
  /* Sombre */
  html[data-theme="dark"]{
    --bg:#0d0f0e;
    --bg-2:#121514;
    --panel:#171a19;
    --line:rgba(255,255,255,.09);
    --text:#eef0ee;
    --muted:#9aa39d;
    --accent-soft:rgba(255,90,31,.16);
    --hud:rgba(255,255,255,.18);
    --shadow:0 22px 50px -26px rgba(0,0,0,.8);
    --grid:rgba(255,255,255,.028);
    --hole:rgba(244,246,243,.92);
  }

  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--font);background:var(--bg);color:var(--text);
    line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;
    transition:background var(--t),color var(--t);
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{display:inline-block;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:18px}
  h1,h2,h3{line-height:1.12;letter-spacing:-.01em;font-weight:800}
  h2{font-size:clamp(28px,4vw,46px);text-transform:uppercase}
  .lead{color:var(--muted);font-size:clamp(15px,1.4vw,18px);max-width:60ch}

  .btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:999px;
    font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;
    transition:transform .18s,background .2s,border-color .2s,color .2s;border:1px solid transparent;cursor:pointer}
  .btn-primary,a.btn-primary,.nav-links a.btn-primary{background:var(--accent);color:#000}
  .btn-primary:hover,a.btn-primary:hover,.nav-links a.btn-primary:hover{transform:translateY(-2px);background:#ff7038;color:#000}
  .btn-ghost{border-color:var(--line);color:var(--text)}
  .btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

  /* ============ NAV ============ */
  header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 80%,transparent);
    backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:background var(--t),border-color var(--t)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
  .brand{display:flex;align-items:center;gap:14px}
  .brand img{height:46px;width:auto}
  .brand .wordmark{font-weight:800;font-size:20px;letter-spacing:.14em;text-transform:uppercase}
  .brand .wordmark span{color:var(--accent)}
  .nav-links{display:flex;align-items:center;gap:30px}
  .nav-links a{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;transition:color .18s}
  .nav-links a:hover{color:var(--text)}
  .nav-right{display:flex;align-items:center;gap:14px}

  /* Bascule thème - switch tactique */
  .theme-btn{width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:var(--bg-2);
    display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);
    transition:transform .2s,border-color .2s,background var(--t)}
  .theme-btn:hover{transform:rotate(-12deg) scale(1.06);border-color:var(--accent);color:var(--accent)}
  .theme-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
  html[data-theme="light"] .theme-btn .moon{display:none}
  html[data-theme="dark"]  .theme-btn .sun{display:none}

  .menu-toggle{display:none}

  /* ============ TICKER TACTIQUE ============ */
  .ticker{background:var(--accent);color:#fff;overflow:hidden;white-space:nowrap;border-bottom:1px solid var(--line)}
  .ticker .run{display:inline-block;padding:9px 0;animation:scroll 26s linear infinite;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase}
  .ticker .run span{padding:0 26px;opacity:.95}
  @keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ============ HERO ============ */
  .hero{position:relative;min-height:calc(100vh - 120px);display:flex;align-items:stretch;overflow:hidden;
    background:linear-gradient(180deg,var(--bg),var(--bg-2));border-bottom:1px solid var(--line)}
  .hero-halo{position:absolute;inset:-10% -5% auto -5%;height:80%;z-index:0;pointer-events:none;
    background:radial-gradient(closest-side at 50% 30%,var(--accent-soft),transparent 70%);
    animation:heroPulse 6s ease-in-out infinite}
  @keyframes heroPulse{0%,100%{opacity:.7;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(18px) scale(1.08)}}
  .hero::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
    background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
    background-size:62px 62px;mask-image:radial-gradient(closest-side at 50% 45%,#000,transparent);
    animation:heroGrid 12s linear infinite}
  @keyframes heroGrid{from{background-position:0 0,0 0}to{background-position:62px 62px,-62px 62px}}
  .hero::before{content:"";position:absolute;left:0;right:0;height:2px;z-index:1;pointer-events:none;
    background:linear-gradient(90deg,transparent 0%,transparent 18%,var(--accent) 50%,transparent 82%,transparent 100%);
    box-shadow:0 0 14px color-mix(in srgb,var(--accent) 70%,transparent);
    opacity:0;animation:heroScan 6s linear infinite}
  @keyframes heroScan{0%{top:-3%;opacity:0}8%{opacity:.6}92%{opacity:.6}100%{top:103%;opacity:0}}
  /* Particules orange flottantes */
  .hero-particles{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
  .hero-particles i{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--accent);
    opacity:0;box-shadow:0 0 8px var(--accent);animation:floatUp 14s linear infinite}
  /* délais NÉGATIFS : les points sont déjà répartis sur la hauteur dès l'affichage
     (sinon ils mettent du temps à monter depuis le bas) */
  .hero-particles i:nth-child(1){left:8%;animation-delay:-3s;animation-duration:13s}
  .hero-particles i:nth-child(2){left:22%;animation-delay:-9s;animation-duration:16s;width:3px;height:3px}
  .hero-particles i:nth-child(3){left:38%;animation-delay:-6s;animation-duration:12s}
  .hero-particles i:nth-child(4){left:54%;animation-delay:-13s;animation-duration:18s;width:5px;height:5px}
  .hero-particles i:nth-child(5){left:71%;animation-delay:-2s;animation-duration:15s}
  .hero-particles i:nth-child(6){left:86%;animation-delay:-7s;animation-duration:13s;width:3px;height:3px}
  .hero-particles i:nth-child(7){left:62%;animation-delay:-11s;animation-duration:17s}
  @keyframes floatUp{0%{bottom:-5%;opacity:0;transform:translateX(0)}
    10%{opacity:.55}80%{opacity:.55}100%{bottom:105%;opacity:0;transform:translateX(28px)}}
  .hero-frame{position:absolute;inset:26px;pointer-events:none;z-index:1}
  .hero-frame i{position:absolute;width:34px;height:34px;border:0 solid var(--accent);opacity:.5}
  .hero-frame i:nth-child(1){top:0;left:0;border-top-width:2px;border-left-width:2px}
  .hero-frame i:nth-child(2){top:0;right:0;border-top-width:2px;border-right-width:2px}
  .hero-frame i:nth-child(3){bottom:0;left:0;border-bottom-width:2px;border-left-width:2px}
  .hero-frame i:nth-child(4){bottom:0;right:0;border-bottom-width:2px;border-right-width:2px}
  /* Disposition éditoriale : bloc collé en bas-gauche (flush au bord), pas centré */
  .hero .wrap{position:relative;z-index:2;width:100%;max-width:none;margin:0;text-align:left;
    padding:74px 6vw 210px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}
  .hero-top{max-width:960px;width:100%}
  /* titre centré verticalement ; le pied (stats + accroche/CTA) épinglé en bas, hors flux */
  /* stats remontées en haut à droite, en carré 2×2 */
  .hero-head{position:absolute;right:6vw;top:92px;z-index:3}
  .hero-foot{position:absolute;left:6vw;right:6vw;bottom:54px;z-index:3;
    display:flex;flex-direction:row-reverse;align-items:flex-end;justify-content:space-between;gap:28px 40px}
  .hero-stats{display:grid;grid-template-columns:repeat(2,auto);gap:16px 34px}
  .hero-stats .num{font-size:clamp(20px,2.2vw,30px);font-weight:800;color:var(--accent);line-height:1}
  .hero-stats .hstat-lbl{margin-top:5px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
  .hero-bottom{max-width:470px;text-align:right}
  .hero-bottom .lead{margin:0 0 0 auto}
  .hero-bottom .hero-cta{justify-content:flex-end}
  .hero h1{font-size:clamp(38px,7vw,86px);text-transform:uppercase}
  .hero h1 em{color:var(--accent);font-style:normal}
  .hero .lead{margin:24px 0 34px;font-size:clamp(16px,1.6vw,20px);max-width:52ch}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-start}
  .chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:38px;justify-content:flex-start}
  .chip{display:flex;align-items:center;gap:9px;padding:9px 15px;border:1px solid var(--line);border-radius:999px;
    font-size:13px;color:var(--muted);background:color-mix(in srgb,var(--text) 4%,transparent)}
  .chip b{color:var(--text);font-weight:700}
  .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

  /* Fond photo du hero (auto si img/hero.jpg existe) */
  .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
  .hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(180deg,
      color-mix(in srgb,var(--bg) 28%,transparent) 0%,
      color-mix(in srgb,var(--bg) 22%,transparent) 38%,
      color-mix(in srgb,var(--bg) 78%,transparent) 78%,
      var(--bg) 100%)}
  .hero .hero-frame{z-index:2}.hero .wrap{z-index:3}

  /* ============ GALERIE — carrousel incliné défilant ============ */
  .gcar{position:relative;overflow:hidden;padding:40px 0 48px;margin-top:14px;
    -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
            mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
  .gcar-track{display:flex;width:max-content;animation:gscroll 50s linear infinite;will-change:transform}
  .gcar:hover .gcar-track{animation-play-state:paused}
  .gtile{position:relative;flex:0 0 auto;width:360px;height:480px;margin-right:30px;border-radius:22px;overflow:hidden;
    border:1px solid var(--line);background:var(--bg-2);box-shadow:0 32px 60px -24px rgba(0,0,0,.55);
    transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .45s}
  .gtile:nth-child(3n+1){transform:rotate(-4deg)}
  .gtile:nth-child(3n+2){transform:rotate(3deg);width:320px;height:500px}
  .gtile:nth-child(3n+3){transform:rotate(-1.5deg);width:410px;height:458px}
  .gtile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:2}
  .gtile .ph{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:14px;color:var(--muted);
    background:
      repeating-linear-gradient(45deg,color-mix(in srgb,var(--text) 4%,transparent) 0 14px,transparent 14px 28px),
      var(--bg-2)}
  .gtile .ph svg{width:42px;height:42px;stroke:var(--accent);fill:none;stroke-width:1.6;opacity:.85}
  .gtile .ph span{font-size:11px;letter-spacing:.22em;text-transform:uppercase}
  .gcar:hover .gtile:hover{transform:rotate(0deg) scale(1.04);z-index:5;box-shadow:0 36px 64px -20px rgba(0,0,0,.62)}
  @keyframes gscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  @media(prefers-reduced-motion:reduce){
    .gcar{-webkit-mask:none;mask:none}
    .gcar-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:18px}
    .gtile{transform:none!important;margin-right:0}
  }
  @media(max-width:760px){
    .gtile{width:248px;height:330px;margin-right:20px}
    .gtile:nth-child(3n+2){width:218px;height:344px}
    .gtile:nth-child(3n+3){width:282px;height:314px}
  }

  /* Photo de fond des cartes Terrain (auto si dispo) */
  .terrain .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
  .terrain .bg+*{position:relative;z-index:2}
  .terrain::after{content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,color-mix(in srgb,#000 48%,transparent),transparent 32%,color-mix(in srgb,#000 68%,transparent))}
  .terrain.has-bg .size,.terrain.has-bg .size small,.terrain.has-bg p{color:#fff;position:relative;z-index:2}
  .terrain.has-bg .tag{color:#fff;z-index:2;text-shadow:0 1px 6px rgba(0,0,0,.55)}

  /* ============ CURSEUR VISEUR (tout le site) + IMPACT AU CLIC ============ */
  html.scope,html.scope *{cursor:none!important}
  .scope-cur{position:fixed;left:0;top:0;width:54px;height:54px;margin:-27px 0 0 -27px;
    pointer-events:none;z-index:99999;opacity:0;
    transition:opacity .18s,width .14s,height .14s,margin .14s;will-change:transform}
  .scope-cur svg{width:100%;height:100%;display:block;stroke:var(--accent);fill:none;stroke-width:1.6}
  .scope-cur.on{opacity:1}
  .scope-cur.link{width:68px;height:68px;margin:-34px 0 0 -34px}
  .scope-cur.down{width:42px;height:42px;margin:-21px 0 0 -21px}
  .impact{position:absolute;width:34px;height:34px;margin:-17px 0 0 -17px;pointer-events:none;z-index:5;
    animation:imp .5s ease-out forwards}
  .impact b{position:absolute;inset:40%;border-radius:50%;background:var(--accent)}
  .impact i{position:absolute;inset:0;border-radius:50%;border:2px solid var(--accent)}
  @keyframes imp{0%{opacity:0;transform:scale(.2)}22%{opacity:1}100%{opacity:0;transform:scale(2)}}
  .hole{position:absolute;pointer-events:none;z-index:4;color:var(--hole);
    animation:hole 2.6s ease-out forwards}
  .hole svg{width:100%;height:100%;display:block;overflow:visible}
  @keyframes hole{0%{opacity:0;transform:scale(.25)}10%{opacity:1;transform:scale(1.1)}16%{transform:scale(1)}62%{opacity:1}100%{opacity:0}}

  /* ============ SECTIONS ============ */
  .sec{padding:96px 0}
  .sec-alt{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);transition:background var(--t)}
  .sec-head{max-width:720px;margin-bottom:54px}
  .sec-head h2{margin:0 0 16px}

  /* Stats compteurs */
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
  .stat{padding:30px 18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow)}
  .stat .num{font-size:clamp(30px,3.6vw,44px);font-weight:800;color:var(--accent);line-height:1}
  .stat .lbl{margin-top:10px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

  .grid{display:grid;gap:22px}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;
    box-shadow:var(--shadow);transition:transform .2s,border-color .2s;position:relative;overflow:hidden}
  .card::after{content:"";position:absolute;top:14px;right:14px;width:22px;height:22px;border:2px solid var(--accent);
    border-radius:50%;opacity:0;transform:scale(.5);transition:.25s}
  .card::before{content:"";position:absolute;top:24px;right:24px;width:2px;height:2px;background:var(--accent);opacity:0;transition:.25s}
  .card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}
  .card:hover::after,.card:hover::before{opacity:1;transform:scale(1)}
  .card .ic{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);margin-bottom:22px}
  .card .ic svg{width:24px;height:24px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .card h3{font-size:21px;text-transform:uppercase;margin-bottom:10px}
  .card p{color:var(--muted);font-size:15px}
  .card .meta{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:baseline;justify-content:space-between}
  .card .meta .price{font-size:24px;font-weight:800}
  .card .meta .when{font-size:13px;color:var(--muted);text-align:right}

  .terrains{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .terrain{position:relative;border-radius:var(--radius);overflow:hidden;min-height:340px;padding:38px;
    display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--line);box-shadow:var(--shadow)}
  .terrain.indoor{background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 10%,var(--panel)),var(--panel))}
  .terrain.outdoor{background:linear-gradient(150deg,color-mix(in srgb,var(--accent-2) 16%,var(--panel)),var(--panel))}
  .terrain .tag{position:absolute;top:30px;left:38px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:700}
  .terrain .size{font-size:clamp(38px,5vw,58px);font-weight:800;line-height:1}
  .terrain .size small{display:block;font-size:14px;font-weight:600;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-top:8px}
  .terrain p{color:var(--muted);margin-top:14px;font-size:15px;max-width:42ch}

  .split{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .feature{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:42px 38px;box-shadow:var(--shadow)}
  .feature h3{font-size:24px;text-transform:uppercase;margin-bottom:14px}
  .feature p{color:var(--muted);margin-bottom:22px}
  .feature ul{list-style:none;display:flex;flex-direction:column;gap:12px}
  .feature li{display:flex;align-items:flex-start;gap:12px;font-size:15px}
  .feature li::before{content:"";flex:none;width:18px;height:18px;border-radius:5px;margin-top:3px;background:var(--accent-soft);
    background-image:linear-gradient(135deg,transparent 45%,var(--accent) 45% 55%,transparent 55%)}

  /* ============ ARSENAL ============ */
  .arsenal-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:28px}
  .arsenal-chips{display:flex;gap:8px;flex-wrap:wrap}
  .a-chip{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border:1px solid var(--line);border-radius:999px;
    font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);background:var(--panel);
    cursor:pointer;transition:.2s;font-family:inherit}
  .a-chip:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
  .a-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
  .a-chip .n{font-size:10px;padding:2px 6px;border-radius:999px;background:color-mix(in srgb,var(--text) 8%,transparent);color:var(--text)}
  .a-chip.active .n{background:rgba(255,255,255,.25);color:#fff}
  .arsenal-meta{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
  .arsenal-meta .live{width:7px;height:7px;border-radius:50%;background:#3fbf63;box-shadow:0 0 0 0 rgba(63,191,99,.6);animation:pulse 1.8s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(63,191,99,.55)}70%{box-shadow:0 0 0 10px rgba(63,191,99,0)}100%{box-shadow:0 0 0 0 rgba(63,191,99,0)}}

  .arsenal{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .item{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
    box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
  .item:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--accent) 50%,transparent)}
  .item .vis{position:relative;aspect-ratio:16/10;background:
      repeating-linear-gradient(45deg,color-mix(in srgb,var(--text) 4%,transparent) 0 12px,transparent 12px 24px),
      linear-gradient(135deg,color-mix(in srgb,var(--accent) 8%,var(--bg-2)),var(--bg-2));
    display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line);overflow:hidden}
  .item .vis::before,.item .vis::after{content:"";position:absolute;width:18px;height:18px;border:1px solid var(--accent);opacity:.6}
  .item .vis::before{top:10px;left:10px;border-right:0;border-bottom:0}
  .item .vis::after{bottom:10px;right:10px;border-left:0;border-top:0}
  .item .vis .ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);text-align:center;padding:0 16px}
  .item .vis .ph svg{width:42px;height:42px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;opacity:.85}
  .item .vis .ph span{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700}

  .item .badges{position:absolute;top:12px;left:12px;right:12px;display:flex;justify-content:space-between;gap:8px;z-index:2}
  .b-tag{padding:5px 10px;border-radius:6px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;
    font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:rgba(15,20,18,.78);color:#fff;backdrop-filter:blur(4px)}
  html[data-theme="dark"] .b-tag{background:rgba(255,255,255,.16)}
  .b-stock{padding:5px 10px;border-radius:6px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;
    font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;display:inline-flex;align-items:center;gap:6px}
  .b-stock.ok{background:rgba(63,191,99,.18);color:#2e9b50}
  .b-stock.low{background:rgba(255,170,40,.2);color:#c27a00}
  .b-stock.out{background:rgba(220,80,80,.18);color:#c44545}
  .b-stock i{width:6px;height:6px;border-radius:50%;background:currentColor}

  .item .body{padding:22px 22px 20px;display:flex;flex-direction:column;gap:14px;flex:1}
  .item .ref{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:10px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase}
  .item h3{font-size:18px;text-transform:uppercase;line-height:1.2;letter-spacing:-.005em}
  .item .specs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 0;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line)}
  .spec{display:flex;flex-direction:column;gap:2px}
  .spec .k{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:9px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
  .spec .v{font-size:13px;font-weight:800;font-variant-numeric:tabular-nums}
  .item .foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}
  .item .price{font-size:24px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;line-height:1}
  .item .price small{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:600}
  .item .act{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--line);border-radius:999px;
    font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text);transition:.2s;cursor:pointer;background:transparent;font-family:inherit}
  .item .act:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
  .item .act svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4}

  .arsenal-note{margin-top:30px;display:flex;align-items:center;gap:14px;padding:18px 22px;background:var(--panel);border:1px dashed var(--line);border-radius:var(--radius);color:var(--muted);font-size:13px}
  .arsenal-note svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:2;flex:none}
  .arsenal-note b{color:var(--text)}

  .atelier{margin-top:36px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
  .at-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:.25s;position:relative;overflow:hidden}
  .at-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .3s}
  .at-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
  .at-card:hover::before{transform:scaleY(1)}
  .at-card .at-ic{width:42px;height:42px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
  .at-card .at-ic svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .at-card h4{font-size:15px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
  .at-card p{color:var(--muted);font-size:13.5px;line-height:1.55}
  /* Les cartes "tombent" une par une au scroll */
  .atelier .at-card.reveal{opacity:0;transform:translateY(-90px)}
  .atelier .at-card.reveal.is-in{opacity:1;transform:none;animation:cardDrop .8s cubic-bezier(.34,1.45,.5,1) backwards}
  .atelier .at-card.reveal.is-in:nth-child(2){animation-delay:.16s}
  .atelier .at-card.reveal.is-in:nth-child(3){animation-delay:.32s}
  @keyframes cardDrop{
    0%{opacity:0;transform:translateY(-90px) rotate(-3deg)}
    55%{opacity:1;transform:translateY(10px) rotate(.6deg)}
    100%{opacity:1;transform:translateY(0) rotate(0)}
  }
  /* Cartes "Nos activités" : même chute une par une au scroll */
  .grid-3 .card.reveal{opacity:0;transform:translateY(-90px)}
  .grid-3 .card.reveal.is-in{opacity:1;transform:none;animation:cardDrop .8s cubic-bezier(.34,1.45,.5,1) backwards}
  .grid-3 .card.reveal.is-in:nth-child(2){animation-delay:.16s}
  .grid-3 .card.reveal.is-in:nth-child(3){animation-delay:.32s}
  @media(prefers-reduced-motion:reduce){
    .atelier .at-card.reveal,.grid-3 .card.reveal{opacity:1;transform:none}
    .atelier .at-card.reveal.is-in,.grid-3 .card.reveal.is-in{animation:none}
  }

  @media(max-width:980px){.arsenal{grid-template-columns:repeat(2,1fr)}.atelier{grid-template-columns:1fr 1fr}}
  @media(max-width:620px){.arsenal{grid-template-columns:1fr}.atelier{grid-template-columns:1fr}}

  .tarifs{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
  .trow{display:grid;grid-template-columns:1.4fr 1fr .8fr;padding:22px 32px;border-bottom:1px solid var(--line);align-items:center}
  .trow:last-child{border-bottom:0}
  .trow.head{background:color-mix(in srgb,var(--text) 3%,transparent);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700}
  .trow .name{font-weight:700}
  .trow .sub{font-size:13px;color:var(--muted)}
  .trow .pr{font-size:22px;font-weight:800;color:var(--accent);text-align:right}

  .contact{background:radial-gradient(700px 400px at 18% 25%,var(--accent-soft),transparent 60%),var(--bg-2);border-top:1px solid var(--line)}
  .contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
  .info-list{display:flex;flex-direction:column;gap:22px;margin-top:30px}
  .info{display:flex;gap:16px;align-items:flex-start;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);transition:transform .2s,border-color .2s}
  .info:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}
  .info .ic{width:44px;height:44px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--accent-soft)}
  .info .ic svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .info .label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
  .info .val{font-weight:700;font-size:16px}
  .info .val a:hover{color:var(--accent)}
  .info .val small{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-top:4px;letter-spacing:0;text-transform:none}

  /* Carte horaires - menu déroulant */
  .hours-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden}
  .hours-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:1}
  .hours-card summary{list-style:none;cursor:pointer;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;
    transition:background .2s;outline:none}
  .hours-card summary::-webkit-details-marker{display:none}
  .hours-card summary:hover{background:color-mix(in srgb,var(--accent) 5%,transparent)}
  .hours-card summary:focus-visible{box-shadow:inset 0 0 0 2px var(--accent)}
  .hours-head{display:flex;flex-direction:column;gap:4px;min-width:0}
  .hours-head h3{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:800}
  .hours-head .hours-sub{font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
  .hours-right{display:flex;align-items:center;gap:14px;flex:none}
  .hours-status{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:11px;font-weight:800;
    letter-spacing:.18em;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
  .hours-status.open{background:rgba(63,191,99,.16);color:#2e9b50}
  .hours-status.closed{background:rgba(220,80,80,.16);color:#c44545}
  .hours-status i{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 0 0 currentColor;animation:pulse 1.8s infinite}
  .hours-chev{width:28px;height:28px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
    transition:transform .3s,border-color .2s;flex:none;color:var(--muted)}
  .hours-chev svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
  .hours-card[open] .hours-chev{transform:rotate(180deg);border-color:var(--accent);color:var(--accent)}
  .hours-body{padding:4px 28px 26px;border-top:1px dashed var(--line);animation:slideDown .3s ease-out}
  @keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  .hours-list{display:flex;flex-direction:column;gap:0;margin-top:6px}
  .hrow{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px dashed var(--line);font-size:15px;transition:padding .2s}
  .hrow:last-child{border-bottom:0}
  .hrow.closed{opacity:.55}
  .hrow.today{padding-left:12px;padding-right:12px;margin:0 -12px;background:var(--accent-soft);border-radius:8px;border-bottom-color:transparent}
  .hrow.today + .hrow{border-top:1px dashed var(--line)}
  .hrow .day{font-weight:600;letter-spacing:.04em;display:flex;align-items:center;gap:8px}
  .hrow.today .day::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent)}
  .hrow.today .day{color:var(--accent);font-weight:800}
  .hrow .h{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:600;font-size:14px}
  .hrow.today .h{color:var(--text);font-weight:800}
  .hrow.closed .h{color:var(--accent);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.2em}
  .hours-card .phone-hours{margin-top:18px;padding:14px 16px;background:var(--accent-soft);border-radius:10px;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text)}
  .hours-card .phone-hours svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:2;flex:none}
  .hours-card .phone-hours b{color:var(--accent);letter-spacing:.04em}

  .map-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-top:22px;display:flex;flex-direction:column}
  .map-embed{position:relative;aspect-ratio:16/11;width:100%;background:var(--bg-2);overflow:hidden}
  .map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;filter:saturate(.9)}
  html[data-theme="dark"] .map-embed iframe{filter:invert(.9) hue-rotate(180deg) saturate(.7) brightness(.95)}
  .map-embed::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px var(--line)}
  .map-embed .corners i{position:absolute;width:18px;height:18px;border:1.5px solid var(--accent);opacity:.85;pointer-events:none}
  .map-embed .corners i:nth-child(1){top:10px;left:10px;border-right:0;border-bottom:0}
  .map-embed .corners i:nth-child(2){top:10px;right:10px;border-left:0;border-bottom:0}
  .map-embed .corners i:nth-child(3){bottom:10px;left:10px;border-right:0;border-top:0}
  .map-embed .corners i:nth-child(4){bottom:10px;right:10px;border-left:0;border-top:0}
  .map-info{padding:24px 28px;text-align:left;display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between;border-top:1px solid var(--line)}
  .map-info .left{display:flex;align-items:center;gap:14px;min-width:0}
  .map-info .pin{width:46px;height:46px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;background:var(--accent-soft)}
  .map-info .pin svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  .map-info .addr{font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
  .map-info .city{color:var(--muted);font-size:13px;margin-top:2px}

  /* ============ AVIS — carrousel incliné défilant ============ */
  .rcar{position:relative;overflow:hidden;padding:34px 0 38px;margin-top:6px;
    -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
            mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
  .rcar-track{display:flex;width:max-content;animation:gscroll 60s linear infinite;will-change:transform}
  .rcar:hover .rcar-track{animation-play-state:paused}
  .rtile{position:relative;flex:0 0 auto;width:340px;margin-right:26px;padding:26px 26px 28px;
    border-radius:20px;background:var(--panel);border:1px solid var(--line);
    box-shadow:0 28px 56px -28px rgba(0,0,0,.45);
    transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .45s,border-color .3s}
  .rtile:nth-child(3n+1){transform:rotate(-3deg)}
  .rtile:nth-child(3n+2){transform:rotate(2.5deg)}
  .rtile:nth-child(3n+3){transform:rotate(-1deg)}
  .rcar:hover .rtile:hover{transform:rotate(0deg) scale(1.04);z-index:5;
    border-color:rgba(255,90,31,.35);box-shadow:0 36px 64px -22px rgba(255,90,31,.28)}
  .rt-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
  .rt-av{width:44px;height:44px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;font-size:18px}
  .rt-id{display:flex;flex-direction:column;flex:1;min-width:0}
  .rt-name{font-weight:800;font-size:15px;color:var(--text)}
  .rt-date{font-size:12px;color:var(--muted);margin-top:1px}
  .rt-stars{color:#fbbc04;font-size:16px;letter-spacing:2px;margin-bottom:10px}
  .rt-text{color:var(--muted);font-size:14.5px;line-height:1.6;font-style:italic}

  .g-logo{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;
    background:#fff;border-radius:50%;border:1px solid rgba(0,0,0,.08);
    font-family:Arial,sans-serif;font-weight:800;font-size:14px;color:#4285f4;flex:none}
  .rt-top .g-logo{margin-left:auto}
  .reviews-cta{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;margin-top:14px}
  .reviews-cta .rp-google{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14px;color:var(--muted)}
  .btn-sm{padding:11px 22px;font-size:13px}

  @media(prefers-reduced-motion:reduce){
    .rcar{-webkit-mask:none;mask:none}
    .rcar-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:18px}
    .rtile{transform:none!important;margin-right:0}
  }
  @media(max-width:760px){
    .rtile{width:284px;margin-right:18px}
  }

  /* ============ BOUTON REMONTER ============ */
  .to-top{position:fixed;right:24px;bottom:24px;z-index:70;width:50px;height:50px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    background:var(--accent);color:#000;border:none;padding:0;
    box-shadow:0 14px 30px -10px rgba(255,90,31,.55);
    opacity:0;visibility:hidden;transform:translateY(16px) scale(.85);
    transition:opacity .35s,transform .35s,visibility .35s,background .2s}
  .to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
  .to-top:hover{background:#ff7038;transform:translateY(-3px) scale(1.05)}
  .to-top svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
  @media(max-width:760px){
    .to-top{right:16px;bottom:16px;width:46px;height:46px}
  }

  /* ============ FAQ ============ */
  .faq{column-count:2;column-gap:16px}
  .faq-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
    overflow:hidden;position:relative;transition:border-color .25s,transform .25s;
    break-inside:avoid;display:block;margin:0 0 16px 0}
  .faq-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);
    transform:scaleY(0);transform-origin:top;transition:transform .3s}
  .faq-item:hover{border-color:color-mix(in srgb,var(--accent) 45%,transparent);transform:translateY(-2px)}
  .faq-item[open]::before{transform:scaleY(1)}
  .faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;align-items:center;justify-content:space-between;
    gap:18px;outline:none;transition:background .2s}
  .faq-item summary::-webkit-details-marker{display:none}
  .faq-item summary:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}
  .faq-item summary:focus-visible{box-shadow:inset 0 0 0 2px var(--accent)}
  .faq-q{display:flex;align-items:center;gap:14px;min-width:0;flex:1}
  .faq-num{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;letter-spacing:.18em;
    color:var(--accent);font-weight:800;flex:none;padding:5px 9px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
    border-radius:6px;background:var(--accent-soft)}
  .faq-q h3{font-size:15px;text-transform:uppercase;letter-spacing:.02em;line-height:1.35;font-weight:800}
  .faq-toggle{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);flex:none;
    display:flex;align-items:center;justify-content:center;position:relative;transition:.3s;color:var(--muted)}
  .faq-toggle::before,.faq-toggle::after{content:"";position:absolute;background:currentColor;border-radius:2px;transition:.3s}
  .faq-toggle::before{width:12px;height:2px}
  .faq-toggle::after{width:2px;height:12px}
  .faq-item[open] .faq-toggle{border-color:var(--accent);color:var(--accent);transform:rotate(135deg)}
  .faq-item[open] .faq-toggle::after{opacity:0}
  .faq-body{padding:0 26px 24px 64px;animation:slideDown .3s ease-out}
  .faq-body p{color:var(--muted);font-size:15px;line-height:1.65}
  .faq-body p+p{margin-top:10px}
  .faq-body strong{color:var(--text);font-weight:700}
  @media(max-width:760px){
    .faq{column-count:1}
    .faq-body{padding:0 22px 22px 22px}
    .faq-item summary{padding:20px 22px}
  }

  footer{border-top:1px solid var(--line);padding:54px 0 40px;background:var(--bg)}
  .foot{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
  .foot .brand img{height:40px}
  .foot .brand .wordmark{font-size:17px}
  .foot-links{display:flex;gap:24px;font-size:13px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;flex-wrap:wrap}
  .foot-links a:hover{color:var(--accent)}
  .copy{color:var(--muted);font-size:13px;margin-top:30px;border-top:1px solid var(--line);padding-top:24px}

  /* Révélations au scroll */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
  .reveal.is-in{opacity:1;transform:none}

  /* ============ RESPONSIVE ============ */
  @media(max-width:900px){
    .grid-3{grid-template-columns:1fr}
    .terrains,.split,.contact-grid{grid-template-columns:1fr}
    .nav-links{position:fixed;inset:78px 0 auto 0;flex-direction:column;gap:0;background:var(--bg-2);
      border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .3s}
    .nav-links a{padding:18px 24px;width:100%;border-bottom:1px solid var(--line)}
    #nav-check:checked ~ .nav-right .nav-links{max-height:360px}
    .menu-toggle{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
    .menu-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px}
    .trow{grid-template-columns:1fr auto;gap:6px 16px}
    .trow .sub{grid-column:1/-1}
    .sec{padding:70px 0}
  }
  @media(max-width:520px){.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{justify-content:center}}

  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
    .reveal{opacity:1;transform:none}
    .hero{cursor:auto}
  }


/* ============================================================ */
/*  NAV - menu deroulant (sous-categories Accueil) + lien actif  */
/* ============================================================ */
.nav-item{position:relative;display:flex;align-items:center}
.nav-item.has-sub > a{display:inline-flex;align-items:center;gap:6px}
.sub-caret{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s;opacity:.65}
.has-sub:hover .sub-caret,.has-sub:focus-within .sub-caret{transform:rotate(180deg);opacity:1}
.nav-links a.active{color:var(--accent)}
.sub-menu{position:absolute;top:100%;left:-12px;min-width:212px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow);padding:9px;display:flex;flex-direction:column;gap:2px;z-index:70;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .22s,transform .22s,visibility .22s}
.sub-menu::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:16px}
.has-sub:hover .sub-menu,.has-sub:focus-within .sub-menu{opacity:1;visibility:visible;transform:none}
.sub-menu a{padding:11px 14px;border-radius:9px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);font-weight:600;display:flex;align-items:center;gap:9px;transition:background .18s,color .18s}
.sub-menu a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .18s}
.sub-menu a:hover{background:var(--accent-soft);color:var(--accent)}
.sub-menu a:hover::before{opacity:1}

/* ============================================================ */
/*  PAGE RESERVATION                                             */
/* ============================================================ */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg),var(--bg-2));padding:66px 0 58px}
.page-hero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:62px 62px;mask-image:radial-gradient(closest-side at 50% 40%,#000,transparent)}
.page-hero .wrap{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}
.page-hero h1{font-size:clamp(34px,6vw,64px);text-transform:uppercase;margin:8px 0 16px}
.page-hero h1 em{color:var(--accent);font-style:normal}
.breadcrumb{display:flex;gap:9px;align-items:center;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{color:var(--accent)}

.formulas{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
.formula{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.formula:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}
.formula.featured{border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
.formula-top{position:relative;padding:30px 32px 26px;border-bottom:1px solid var(--line);overflow:hidden}
.formula.laser .formula-top{background:linear-gradient(150deg,color-mix(in srgb,var(--accent-2) 18%,var(--panel)),var(--panel))}
.formula.airsoft .formula-top{background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 13%,var(--panel)),var(--panel))}
.formula .tagline{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:9px}
.formula .tagline .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex:none}
.formula h2{font-size:clamp(24px,3vw,33px);text-transform:uppercase;line-height:1.05;text-align:left}
.formula .sub{color:var(--muted);font-size:14px;margin-top:10px;max-width:46ch}
.formula .price-row{display:flex;align-items:baseline;gap:9px;margin-top:20px}
.formula .price{font-size:clamp(38px,5vw,46px);font-weight:800;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}
.formula .price small{font-size:13px;color:var(--muted);font-weight:600;letter-spacing:.03em}
.badge-best{position:absolute;top:20px;right:-36px;transform:rotate(45deg);background:var(--accent);color:#000;
  font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;padding:6px 44px;box-shadow:var(--shadow);z-index:3}
.formula-body{padding:26px 32px 30px;display:flex;flex-direction:column;gap:20px;flex:1}
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.spec-box{border:1px dashed var(--line);border-radius:12px;padding:12px 14px}
.spec-box .k{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.spec-box .v{font-size:15px;font-weight:800;margin-top:4px}
.formula ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.formula li{display:flex;align-items:flex-start;gap:11px;font-size:14.5px;color:var(--text)}
.formula li svg{width:18px;height:18px;flex:none;stroke:var(--accent);fill:none;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;margin-top:2px}
.formula .cta{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap}
.formula .cta .btn{flex:1 1 auto;justify-content:center}
@media(max-width:820px){.formulas{grid-template-columns:1fr}}

.addon{margin-top:24px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:space-between;
  background:var(--panel);border:1px dashed var(--line);border-radius:var(--radius);padding:24px 30px;box-shadow:var(--shadow)}
.addon .addon-l{display:flex;align-items:center;gap:18px;min-width:0;flex:1 1 360px}
.addon .addon-ic{width:54px;height:54px;border-radius:14px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--accent-soft)}
.addon .addon-ic svg{width:25px;height:25px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.addon h3{font-size:18px;text-transform:uppercase;margin-bottom:5px}
.addon p{color:var(--muted);font-size:14px;max-width:62ch}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;box-shadow:var(--shadow);overflow:hidden}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:20px;right:24px;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:38px;font-weight:800;color:var(--accent);opacity:.16;line-height:1}
.step .step-ic{width:48px;height:48px;border-radius:12px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.step .step-ic svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.step h3{font-size:18px;text-transform:uppercase;margin-bottom:9px}
.step p{color:var(--muted);font-size:14.5px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}

.know{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.know-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;box-shadow:var(--shadow)}
.know-item .ic{width:42px;height:42px;border-radius:11px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.know-item .ic svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.know-item h4{font-size:14px;text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px}
.know-item p{color:var(--muted);font-size:13.5px;line-height:1.55}
@media(max-width:900px){.know{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.know{grid-template-columns:1fr}}

/* --- Cartes : reflet lumineux qui balaie au survol (premium, valable sur tout le site) --- */
.know-item,.step{position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.22,.61,.36,1),border-color .3s ease,box-shadow .3s ease}
.know-item:hover,.step:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--accent) 42%,transparent);box-shadow:0 20px 44px -24px rgba(0,0,0,.75)}
.know-item::after,.step::after,.at-card::after{
  content:"";position:absolute;top:0;bottom:0;left:0;width:42%;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.16) 42%,rgba(255,255,255,.32) 50%,rgba(255,255,255,.16) 58%,transparent);
  transform:translateX(-240%) skewX(-14deg);opacity:0;
}
.know-item:hover::after,.step:hover::after,.at-card:hover::after{animation:cardSheen .9s ease}
@keyframes cardSheen{
  0%{opacity:0;transform:translateX(-240%) skewX(-14deg)}
  12%{opacity:1}
  88%{opacity:1}
  100%{opacity:0;transform:translateX(360%) skewX(-14deg)}
}
@media(prefers-reduced-motion:reduce){
  .know-item::after,.step::after,.at-card::after{display:none}
  .know-item:hover,.step:hover{transform:none}
}

.book-cta{text-align:center;background:radial-gradient(720px 360px at 50% 0%,var(--accent-soft),transparent 65%),var(--bg-2);border-top:1px solid var(--line)}
.book-cta .sec-head{margin:0 auto 26px}
.book-cta .lead{margin:0 auto}
.book-cta .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}

/* ============================================================ */
/*  NAV mobile - sous-menu deplie dans le panneau                */
/* ============================================================ */
@media(max-width:900px){
  .nav-item{flex-direction:column;align-items:stretch;width:100%}
  .nav-item.has-sub > a{justify-content:space-between}
  .sub-caret{display:none}
  .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;
    padding:0;min-width:0;background:color-mix(in srgb,var(--text) 3%,transparent)}
  .sub-menu::before{display:none}
  .sub-menu a{padding:14px 24px 14px 46px;border-bottom:1px solid var(--line);border-radius:0;text-transform:none;letter-spacing:.03em;font-size:13px}
  .sub-menu a::before{display:none}
  #nav-check:checked ~ .nav-right .nav-links{max-height:840px}
}


/* ============================================================ */
/*  NAV - survol "roll" lettre par lettre + pastille             */
/*  (inspire de champions4good.club) : au survol, chaque lettre  */
/*  monte en cascade, une copie accent remonte du bas, et une    */
/*  pastille de fond jaillit (scale-in), easing ressort.         */
/* ============================================================ */
:root{--spring:cubic-bezier(.34,1.56,.64,1)}
.has-roll{position:relative;z-index:0}
.has-roll::before{content:"";position:absolute;inset:-7px -12px;border-radius:12px;background:var(--accent-soft);
  transform:scale(.7);opacity:0;transition:transform .45s var(--spring),opacity .28s ease;z-index:-1;pointer-events:none}
.has-roll:hover::before,.has-roll:focus-visible::before{transform:scale(1);opacity:1}
.nl-roll{position:relative;display:inline-grid;overflow:hidden;vertical-align:bottom;line-height:1.2;padding:1px 0}
.nl-layer{grid-area:1/1;display:inline-flex;white-space:nowrap}
.nl-top{color:var(--muted)}
.nl-bot{color:var(--accent)}
.nl-char{display:inline-block;transform:translateY(0);transition:transform .5s var(--spring);transition-delay:calc(var(--char)*0.025s);will-change:transform}
.nl-bot .nl-char{transform:translateY(110%)}
.has-roll:hover .nl-top .nl-char,.has-roll:focus-visible .nl-top .nl-char{transform:translateY(-110%)}
.has-roll:hover .nl-bot .nl-char,.has-roll:focus-visible .nl-bot .nl-char{transform:translateY(0)}
.has-roll.active .nl-top{color:var(--accent)}
.has-roll:hover{color:inherit}
@media(prefers-reduced-motion:reduce){
  .nl-bot{display:none}
  .nl-char,.has-roll::before{transition:none}
  .has-roll::before{display:none}
  .has-roll:hover .nl-top{color:var(--accent)}
  .has-roll:hover .nl-top .nl-char{transform:none}
}


/* ============================================================ */
/*  ZONES "PAPIER" (accueil) — section crème texturée + bords     */
/*  déchirés haut/bas (masque PNG). La palette est re-scopée en   */
/*  crème : tout le contenu interne (texte, cartes...) s'adapte.  */
/* ============================================================ */
.sec.paper{
  position:relative; z-index:1; border:0 !important;
  /* palette papier crème — indépendante du thème */
  --bg:#f3e9d3; --bg-2:#ece0c6; --panel:#f7efdd; --text:#211e17; --muted:#6f6452;
  --line:rgba(33,26,12,.18); --accent-soft:rgba(255,90,31,.12);
  --shadow:0 18px 38px -26px rgba(55,40,18,.4); --grid:rgba(33,26,12,.05);
  --hud:rgba(33,26,12,.2); --hole:rgba(33,26,12,.84);
  color:var(--text);
  background:#f3e9d3 url(test2.jpg) center/cover;   /* texture papier : traces, éraflures, points */
}
.sec.paper::before,.sec.paper::after{
  content:"";position:absolute;left:0;right:0;height:46px;z-index:2;pointer-events:none;
  background:#f3e9d3 url(test2.jpg) center/cover;
  -webkit-mask:url(tear-edge.png) center/100% 100% no-repeat;
          mask:url(tear-edge.png) center/100% 100% no-repeat;
}
.sec.paper::before{top:-45px}
.sec.paper::after{bottom:-45px;transform:scaleY(-1)}
.sec.paper + section,.sec.paper + footer{border-top:0 !important}
section:has(+ .sec.paper){border-bottom:0 !important}

/* ============================================================ */
/*  DÉLIMITATION ORANGE déchirée (réservation + pages hors accueil) */
/* ============================================================ */
.tear{position:relative;height:30px;margin:-15px 0;z-index:3;pointer-events:none;
  background:var(--accent);
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.3))}
/* plusieurs formes de déchirure (alternées par le JS) + retournement */
.tear.t1{-webkit-mask:url(tear-strip-1.png) center/100% 100% no-repeat;mask:url(tear-strip-1.png) center/100% 100% no-repeat}
.tear.t2{-webkit-mask:url(tear-strip-2.png) center/100% 100% no-repeat;mask:url(tear-strip-2.png) center/100% 100% no-repeat}
.tear.t3{-webkit-mask:url(tear-strip-3.png) center/100% 100% no-repeat;mask:url(tear-strip-3.png) center/100% 100% no-repeat}
.tear.t4{-webkit-mask:url(tear-strip-4.png) center/100% 100% no-repeat;mask:url(tear-strip-4.png) center/100% 100% no-repeat}
.tear.flip{transform:scaleX(-1)}
.tear + section,.tear + footer{border-top:0 !important}
section:has(+ .tear){border-bottom:0 !important}

/* ============================================================ */
/*  FOOTER papier crème — bord déchiré en haut, contenu centré   */
/*  (compo réf. flesh&bones ; assets MAISON : paper.jpg +        */
/*   tear-edge.png — PAS l'asset CDN de F&B). Palette re-scopée   */
/*   crème comme .sec.paper. Le footer porte aussi .paper pour    */
/*   que app.js NE pose PAS de déchirure orange avant lui.        */
/* ============================================================ */
footer.paper-foot{
  position:relative; z-index:1; border:0 !important;
  --bg:#f3e9d3; --bg-2:#ece0c6; --panel:#f7efdd; --text:#211e17; --muted:#6f6452;
  --line:rgba(33,26,12,.18); --accent-soft:rgba(255,90,31,.12);
  --shadow:0 18px 38px -26px rgba(55,40,18,.4); --grid:rgba(33,26,12,.05);
  color:var(--text);
  background:#f3e9d3 url(test2.jpg) center/cover;
  padding:104px 0 58px;
}
footer.paper-foot::before{
  content:"";position:absolute;left:0;right:0;top:-45px;height:46px;z-index:2;pointer-events:none;
  background:#f3e9d3 url(test2.jpg) center/cover;
  -webkit-mask:url(tear-edge.png) center/100% 100% no-repeat;
          mask:url(tear-edge.png) center/100% 100% no-repeat;
}
footer.paper-foot .foot-in{display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
footer.paper-foot .foot-loc{color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.2em;font-size:clamp(13px,1.7vw,17px)}
footer.paper-foot .foot-loc span{margin:0 .35em;font-weight:700;opacity:.9}
footer.paper-foot .foot-nav{display:flex;gap:14px 34px;flex-wrap:wrap;justify-content:center}
footer.paper-foot .foot-nav a{color:var(--text);font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:clamp(17px,2.6vw,23px);transition:color .2s}
footer.paper-foot .foot-nav a:hover{color:var(--accent)}
footer.paper-foot .foot-socials{display:flex;gap:12px}
footer.paper-foot .foot-socials a{width:38px;height:38px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;transition:transform .25s,filter .25s}
footer.paper-foot .foot-socials a:hover{transform:translateY(-3px);filter:brightness(1.08)}
footer.paper-foot .foot-socials svg{width:18px;height:18px;display:block}
footer.paper-foot .foot-copy{color:var(--accent);font-size:13px;letter-spacing:.05em;margin-top:2px}


/* ============================================================ */
/*  PRELOADER - panneau papier creme qui se dechire en deux      */
/* ============================================================ */
.preload{position:fixed;inset:0;z-index:9990;pointer-events:none;background:#f3e9d3;  /* couvre dès la 1re frame (pas de flash header) */
  animation:preGone 0s linear 2.45s forwards, preBgClear 0s linear 1.25s forwards}
html.seen .preload{display:none}   /* affiché seulement à la 1ère arrivée (1×/session) */
.preload-half{position:fixed;left:0;top:0;width:100%;height:100%;
  background:#f3e9d3;backface-visibility:hidden;will-change:transform}   /* fond uni (sans texture) */
.preload-half.top{-webkit-mask:url(preload-top.png) center/100% 100% no-repeat;mask:url(preload-top.png) center/100% 100% no-repeat;
  animation:preUp 1.15s cubic-bezier(.82,0,.2,1) 1.25s both}
.preload-half.bottom{-webkit-mask:url(preload-bot.png) center/100% 100% no-repeat;mask:url(preload-bot.png) center/100% 100% no-repeat;
  animation:preDown 1.15s cubic-bezier(.82,0,.2,1) 1.25s both}
/* nom de la marque, centré au-dessus de la coupe */
.preload-brand{position:fixed;top:38%;left:50%;transform:translate(-50%,-50%);font-family:var(--font);
  font-weight:800;font-size:clamp(22px,4.4vw,42px);letter-spacing:.16em;text-transform:uppercase;
  color:#16140f;white-space:nowrap;animation:preBrandIn .5s ease .15s both, preBrandOut .3s ease 1.2s forwards}
.preload-brand span{color:var(--accent)}
/* le TRAIT NOIR dessine le chemin de coupe (gauche→droite) puis s'efface quand ça déchire */
.preload-line{position:fixed;left:0;top:0;width:100%;height:100%;background:#16140f;
  -webkit-mask:url(preload-line.png) center/100% 100% no-repeat;mask:url(preload-line.png) center/100% 100% no-repeat;
  clip-path:inset(0 100% 0 0);animation:preDraw .8s cubic-bezier(.6,0,.2,1) .45s both, preLineOut .25s ease 1.25s forwards}
@keyframes preUp{to{transform:translateY(-101%)}}
@keyframes preDown{to{transform:translateY(101%)}}
@keyframes preDraw{to{clip-path:inset(0 0 0 0)}}
@keyframes preLineOut{to{opacity:0}}
@keyframes preBrandIn{from{opacity:0;letter-spacing:.3em}to{opacity:1;letter-spacing:.16em}}
@keyframes preBrandOut{to{opacity:0}}
@keyframes preGone{to{visibility:hidden}}
@keyframes preBgClear{to{background-color:transparent}}
@media(prefers-reduced-motion:reduce){
  .preload-half.top,.preload-half.bottom{animation-duration:.01s;animation-delay:.5s}
  .preload-line{display:none}
}


/* ============================================================ */
/*  HERO — entrée animée (lignes du titre + reveals) + Scroll    */
/*  compo éditoriale ; fond animé discret (halo + grille)      */
/* ============================================================ */
/* Fond hero : MÊME style sombre (halo + grille tactique), VISIBLEMENT animé —
   la lueur respire, la grille dérive, la LIGNE ORANGE balaie le hero (scan tactique),
   et les POINTS orange flottent (particules réactivées, demande client). */
.hero-halo{animation:heroGlow 9s ease-in-out infinite}          /* la lueur respire */
.hero::after{opacity:.5;animation:heroGrid 22s linear infinite} /* la grille dérive lentement */
/* .hero::before = la ligne orange : on garde son anim heroScan 6s d'origine (réactivée) */
@keyframes heroGlow{
  0%,100%{opacity:.5;transform:translateY(0) scale(1)}
  50%{opacity:.85;transform:translateY(12px) scale(1.06)}
}

.hero-title{display:flex;flex-direction:column;align-items:flex-start;line-height:.96;margin:0}
.hero-title .ln{display:block;overflow:hidden;padding-bottom:.05em}
.hero-title .ln i{display:block;font-style:normal;transform:translateY(115%);will-change:transform;
  transition:transform 1s cubic-bezier(.16,.84,.3,1)}
.hero-title .ln.em i{color:var(--accent)}
.hero-title .ln:nth-child(2){margin-left:.55em}
.hero-title .ln:nth-child(3){margin-left:1.1em}

/* états cachés avant révélation */
.hero .eyebrow,.hero .lead,.hero-cta,.hero-stats{opacity:0;transform:translateY(22px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.16,.84,.3,1)}

/* révélation déclenchée par body.hero-in */
.hero-in .hero-title .ln i{transform:translateY(0)}
.hero-in .hero-title .ln:nth-child(1) i{transition-delay:.06s}
.hero-in .hero-title .ln:nth-child(2) i{transition-delay:.18s}
.hero-in .hero-title .ln:nth-child(3) i{transition-delay:.30s}
.hero-in .hero .eyebrow{opacity:1;transform:none;transition-delay:0s}
.hero-in .hero .lead{opacity:1;transform:none;transition-delay:.52s}
.hero-in .hero-cta{opacity:1;transform:none;transition-delay:.64s}
.hero-in .hero-stats{opacity:1;transform:none;transition-delay:.42s}

/* mobile : le pied repasse en flux, à gauche, sous le titre (paragraphe plus lisible) */
@media(max-width:860px){
  .hero .wrap{justify-content:flex-start;padding:100px 22px 8vh}
  .hero-head{position:static;margin-bottom:26px}
  .hero-foot{position:static;margin-top:40px;flex-direction:column;align-items:flex-start;gap:28px}
  .hero-stats{display:grid;grid-template-columns:repeat(2,auto);gap:20px 34px;max-width:none}
  .hero-bottom{text-align:left;max-width:none}
  .hero-bottom .lead{margin-left:0}
  .hero-bottom .hero-cta{justify-content:flex-start}
}

@media(prefers-reduced-motion:reduce){
  .hero-title .ln i{transform:none}
  .hero .eyebrow,.hero .lead,.hero-cta,.hero-stats{opacity:1;transform:none}
}

/* ============================================================ */
/*  STICKERS (fléchette, M4A1…) — on les ATTRAPE & on les LANCE   */
/*  avec inertie (réf. champions4good). Le CONTENEUR porte la     */
/*  position (transform posé par app.js) ; l'<img> interne flotte */
/*  en boucle (CSS). Les deux transforms se composent sans gêne.  */
/* ============================================================ */
.hero-sticker{
  position:absolute; z-index:4; margin:0; padding:0;
  cursor:grab; touch-action:none;
  user-select:none; -webkit-user-select:none; -webkit-tap-highlight-color:transparent;
  will-change:transform;
  opacity:0; transition:opacity .6s ease .75s;     /* entre avec le hero */
}
.hs-dart {top:40%; right:6%;  width:clamp(150px,16vw,230px)}
.hs-rifle{top:14%; left:3%;   width:clamp(190px,24vw,320px)}
.hs-laser{top:68%; left:45%;  width:clamp(160px,19vw,270px)}
.hero-in .hero-sticker{opacity:1}
.hero-sticker.is-dragging,.hero-sticker:active{cursor:grabbing}
.hero-sticker img{
  display:block; width:100%; height:auto; pointer-events:none;
  -webkit-user-drag:none; user-drag:none;
  transform-origin:50% 50%;
  filter:drop-shadow(0 14px 24px rgba(0,0,0,.30));
  animation:stickerFloat 6s ease-in-out infinite;
}
.hs-rifle img{animation-duration:7.5s; animation-delay:-2.5s}   /* désynchronise les flottements */
.hs-laser img{animation-duration:6.8s; animation-delay:-4s}
/* on fige le flottement pendant qu'on la manipule ou qu'elle vole */
.hero-sticker.is-dragging img,.hero-sticker.is-throwing img{animation-play-state:paused}
@keyframes stickerFloat{
  0%,100%{transform:translateY(0) rotate(-4deg)}
  50%    {transform:translateY(-14px) rotate(4deg)}
}
@media(max-width:860px){ .hero-sticker{display:none} }     /* trop à l'étroit sur mobile */
@media(prefers-reduced-motion:reduce){ .hero-sticker img{animation:none} }
