  /* ─── Reset + tokens mobile-first ─── */
  *{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
  :root{
    --safe-top:env(safe-area-inset-top);
    --safe-bottom:env(safe-area-inset-bottom);
    --safe-left:env(safe-area-inset-left);
    --safe-right:env(safe-area-inset-right);
  }
  html,body{overscroll-behavior:none;}
  body{
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
    background:#f5f5f5;
    height:100vh;height:100dvh;
    display:flex;flex-direction:column;
    -webkit-text-size-adjust:100%;
    -webkit-font-smoothing:antialiased;
    touch-action:manipulation;
  }

  /* ─── Topbar mobile : compact, safe-area aware ─── */
  #topbar{
    background:#fff;border-bottom:1px solid #e5e5e5;
    padding:calc(10px + var(--safe-top)) calc(14px + var(--safe-right)) 10px calc(14px + var(--safe-left));
    display:flex;align-items:center;justify-content:space-between;gap:10px;
    flex-shrink:0;z-index:1000;min-height:56px;
  }
  #topbar-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1;}
  /* Logo : SVG porteur de son propre fond + arrondi (rx 17.896/80 ≈ même rondeur que l'ancien rad 9px). */
  #logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
  #logo svg{display:block;width:100%;height:100%;}
  .app-title{font-size:17px;font-weight:700;color:#111;letter-spacing:-0.2px;flex-shrink:0;}
  .pill{font-size:11px;padding:4px 10px;border-radius:20px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;}
  .pill-crisis{background:#FCEBEB;color:#A32D2D;}
  /* Pill signalements : flottante en bas de carte, pulse vivant, tap = refresh */
  #signals-pill{
    position:absolute;bottom:calc(70px + var(--safe-bottom));left:50%;transform:translateX(-50%);
    z-index:400;
    background:rgba(255,255,255,0.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    color:#0F6E56;border:1.5px solid rgba(29,158,117,0.25);
    border-radius:20px;padding:7px 14px;
    display:inline-flex;align-items:center;gap:7px;
    font-size:13px;font-weight:600;cursor:pointer;
    box-shadow:0 2px 12px rgba(0,0,0,0.10);
    transition:transform 0.12s,background 0.15s,opacity 0.2s;
    white-space:nowrap;
  }
  #signals-pill:active{transform:translateX(-50%) scale(0.96);}
  #signals-pill.refreshing{opacity:0.6;}
  #signals-pill[hidden]{display:none;}
  .pill-pulse-dot{
    width:8px;height:8px;border-radius:50%;background:#1D9E75;flex-shrink:0;
    box-shadow:0 0 0 0 rgba(29,158,117,0.45);
    animation:pillPulse 1.8s ease-out infinite;
  }
  @keyframes pillPulse{
    0%{box-shadow:0 0 0 0 rgba(29,158,117,0.45);}
    70%{box-shadow:0 0 0 7px rgba(29,158,117,0);}
    100%{box-shadow:0 0 0 0 rgba(29,158,117,0);}
  }
  /* Petit i dans la topbar — rond vert plein, i blanc */
  .info-btn{
    display:inline-flex;align-items:center;justify-content:center;
    width:18px;height:18px;border-radius:50%;
    background:#1D9E75;color:#fff;
    font-size:11px;font-weight:700;font-style:italic;
    text-decoration:none;flex-shrink:0;line-height:1;
    transition:background 0.15s,transform 0.12s;
  }
  .info-btn:active{background:#169060;transform:scale(0.92);}

  /* About link (item 8) — discret, à côté du logo */
  .about-link{
    display:block;text-align:center;
    margin:16px auto 4px;
    color:#1D9E75;font-size:13px;font-weight:600;text-decoration:none;
    padding:8px 16px;border-radius:20px;
    border:1.5px solid #1D9E75;
    width:fit-content;
    transition:background 0.15s,color 0.15s;
  }
  .about-link:hover,.about-link:active{background:#E1F5EE;}

  /* ─── Barre de contrôles : segmented control (portée) + toggle de tri ─── */
  #filters-float{
    position:absolute;top:10px;left:10px;right:10px;
    display:flex;gap:8px;z-index:335;
    align-items:center;justify-content:space-between;
    padding:2px 0;
  }
  /* Segmented control "Tout / Dispo / Sans file" — 1 seul contrôle, 3 états, sévérité croissante */
  .scope-seg{
    display:inline-flex;gap:2px;flex-shrink:1;min-width:0;
    background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border:1.5px solid rgba(0,0,0,0.08);border-radius:20px;
    padding:3px;box-shadow:0 2px 8px rgba(0,0,0,0.08);
  }
  .scope-btn{
    border:none;background:transparent;cursor:pointer;
    padding:6px 12px;border-radius:16px;
    font-size:12.5px;font-weight:600;color:#555;
    white-space:nowrap;min-height:30px;
    transition:background 0.18s,color 0.18s,box-shadow 0.18s,transform 0.12s;
  }
  .scope-btn:active{transform:scale(0.96);}
  .scope-btn.active{background:#111;color:#fff;box-shadow:0 1px 3px rgba(0,0,0,0.15);}
  /* Sort seg — segmented "Plus proche / Moins cher" (2 états), même look que scope-seg.
     Plus découvrable que l'ancien bouton ↕ à état unique : les deux options sont
     affichées d'entrée, on voit qu'on peut filtrer par prix sans tâtonner. */
  .sort-seg{
    display:inline-flex;gap:2px;flex-shrink:0;
    background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border:1.5px solid rgba(0,0,0,0.08);border-radius:20px;
    padding:3px;box-shadow:0 2px 8px rgba(0,0,0,0.08);
  }
  .sort-btn{
    border:none;background:transparent;cursor:pointer;
    padding:6px 11px;border-radius:16px;
    font-size:12.5px;font-weight:600;color:#555;
    white-space:nowrap;min-height:30px;
    transition:background 0.18s,color 0.18s,box-shadow 0.18s,transform 0.12s;
  }
  .sort-btn:active{transform:scale(0.96);}
  .sort-btn.active{background:#111;color:#fff;box-shadow:0 1px 3px rgba(0,0,0,0.15);}
  /* Anciennes classes sort-toggle : conservées pour ne rien casser si un listener
     traîne, mais plus rendues par l'HTML. */
  .sort-toggle{display:none;}
  /* Anciens chips : conservés dans le CSS pour compat mais plus rendus par l'HTML */
  #filters-float::-webkit-scrollbar{display:none;}
  .f-chip{
    display:inline-flex;align-items:center;gap:4px;flex-shrink:0;
    padding:7px 10px;border-radius:18px;
    background:rgba(255,255,255,0.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    border:1.5px solid rgba(0,0,0,0.08);
    font-size:12.5px;cursor:pointer;color:#444;white-space:nowrap;
    min-height:34px;user-select:none;
    box-shadow:0 2px 8px rgba(0,0,0,0.08);
    transition:transform 0.12s,background 0.15s,border-color 0.15s,padding 0.15s;
  }
  .f-chip:active{transform:scale(0.94);}
  .f-ico{font-size:13px;line-height:1;}
  .f-lbl{font-weight:600;}
  .f-count{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:16px;height:16px;padding:0 4px;border-radius:8px;
    background:rgba(0,0,0,0.08);font-size:10px;font-weight:700;color:#555;
  }
  /* Indicateur de désélection : × visible uniquement sur chip active */
  .f-clear{
    display:none;align-items:center;justify-content:center;
    width:16px;height:16px;border-radius:50%;
    background:rgba(255,255,255,0.3);font-size:11px;line-height:1;font-weight:700;
    margin-left:1px;
  }
  .f-chip.on .f-clear{display:inline-flex;}
  /* États actifs colorés par statut */
  .f-chip.on{color:#fff;border-color:transparent;font-weight:600;}
  .f-chip.on .f-count{background:rgba(255,255,255,0.25);color:#fff;}
  .f-chip.ok.on{background:#1D9E75;}
  .f-chip.queue.on{background:#F59300;}
  .f-chip.empty.on{background:#E24B4A;}
  .f-chip.cheap.on{background:#6C5CE7;}
  /* Shield "fiable uniquement" : compact, icône seule, style distinct (modifier non exclusif) */
  .f-chip.shield{padding:7px 10px;min-width:34px;justify-content:center;}
  .f-chip.shield .f-ico{font-size:14px;}
  .f-chip.shield.on{background:#185FA5;color:#fff;border-color:transparent;}
  .f-chip.shield.on .f-ico{filter:drop-shadow(0 1px 1px rgba(0,0,0,0.25));}

  /* ─── Map zone : remplit l'espace vertical sous le topbar ─── */
  #map-wrap{flex:1;position:relative;min-height:0;}
  #map{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;}

  /* ─── Tab bar Carte/Liste : supprimée — liste en bottom sheet ─── */
  #view-segment{ display:none; }
  .seg-btn{ display:none; } /* conservé pour compat JS */

  /* ─── Bottom sheet liste — style Airbnb/Waze ─── */
  #list-view{
    position:fixed;bottom:0;left:0;right:0;
    height:72vh;
    z-index:350;
    background:#f0f0f0;
    border-radius:20px 20px 0 0;
    box-shadow:0 -4px 24px rgba(0,0,0,0.14);
    transform:translateY(calc(100% + 20px));
    transition:transform 0.32s cubic-bezier(0.32,0.72,0,1);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    padding-left:var(--safe-left);
    padding-right:var(--safe-right);
    padding-bottom:calc(20px + var(--safe-bottom));
    display:block !important; /* toujours dans le DOM, caché via transform */
  }
  #list-view.open{ transform:translateY(0); }
  /* Handle drag */
  .list-sheet-handle{
    width:36px;height:4px;border-radius:2px;
    background:#ccc;margin:10px auto 4px;
    flex-shrink:0;
  }
  /* Bouton fermer le sheet */
  #list-close-btn{
    background:#e5e5e5;border:none;border-radius:50%;
    width:28px;height:28px;font-size:15px;color:#555;
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  #list-close-btn:active{background:#d5d5d5;}
  /* FAB Liste flottant sur la carte */
  #list-fab{
    position:absolute;bottom:16px;right:52px;
    z-index:340;
    background:#fff;border:none;border-radius:20px;
    padding:9px 14px 9px 11px;
    font-size:13px;font-weight:600;color:#333;
    box-shadow:0 2px 10px rgba(0,0,0,0.16);
    display:none;align-items:center;gap:5px;
    cursor:pointer;white-space:nowrap;
    transition:transform 0.12s;
  }
  #list-fab.show{ display:flex; }
  #list-fab:active{ transform:scale(0.96); }
  .list-header{
    display:flex;justify-content:space-between;align-items:center;
    padding:14px 16px 8px;font-size:12px;color:#999;font-weight:500;
  }
  .list-header strong{color:#555;font-weight:600;}
  .list-section{
    margin:0 12px 24px;background:#fff;
    border-radius:18px;overflow:hidden;
    box-shadow:0 1px 4px rgba(0,0,0,0.07);
  }
  .list-item{
    display:flex;align-items:center;gap:12px;
    padding:14px 16px;background:#fff;cursor:pointer;
    border-bottom:1px solid #f2f2f2;transition:background 0.12s;
  }
  .list-item:last-child{border-bottom:none;}
  .list-item:active{background:#f7f7f7;}
  .list-item.best{
    background:linear-gradient(90deg,#FFFBEF 0%,#fff 65%);
    border-left:3px solid #F1B820;padding-left:13px;
  }
  .list-item.best:active{background:linear-gradient(90deg,#FFF4D5 0%,#f7f7f7 65%);}
  /* Colonne centrale */
  .li-main{flex:1;min-width:0;}
  .li-name{
    font-size:15px;font-weight:600;color:#111;line-height:1.25;
    display:flex;align-items:center;gap:6px;margin-bottom:5px;
  }
  .li-name span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .li-top-badge{
    display:inline-flex;align-items:center;gap:2px;flex-shrink:0;
    background:linear-gradient(135deg,#F1B820 0%,#E8A100 100%);color:#fff;
    font-size:9px;font-weight:700;letter-spacing:0.3px;
    padding:2px 5px;border-radius:5px;
  }
  .li-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
  .li-pill{
    display:inline-flex;align-items:center;gap:3px;
    padding:2px 8px 2px 6px;border-radius:20px;
    font-size:11px;font-weight:700;flex-shrink:0;line-height:1.5;
  }
  .li-pill-dot{width:6px;height:6px;border-radius:50%;opacity:0.8;}
  .li-dist{font-size:12px;color:#aaa;}
  /* Colonne prix à droite */
  .li-right{flex-shrink:0;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:1px;}
  .li-price-main{font-size:19px;font-weight:800;color:#111;letter-spacing:-0.5px;line-height:1.1;}
  .li-price-label{font-size:11px;color:#aaa;font-weight:500;}
  .li-price-sec{font-size:11px;color:#bbb;}
  .li-chevron{color:#d0d0d0;font-size:20px;flex-shrink:0;margin-left:2px;font-weight:300;line-height:1;}
  .list-src{text-align:center;font-size:11px;color:#bbb;padding:4px 16px 8px;}
  .list-sort-toggle{
    display:inline-flex;align-items:center;gap:4px;
    background:#ebebeb;border:none;border-radius:20px;
    padding:5px 10px;font-size:12px;font-weight:600;color:#444;
    cursor:pointer;transition:background 0.15s;-webkit-tap-highlight-color:transparent;
  }
  .list-sort-toggle:active{background:#ddd;}
  .list-sort-arrow{font-size:11px;color:#888;}

  /* ─── Drawer : safe-area aware, plus grand, handle tappable ─── */
  #drawer{
    position:fixed;bottom:0;left:0;right:0;background:#fff;
    border-radius:18px 18px 0 0;box-shadow:0 -4px 24px rgba(0,0,0,0.15);
    z-index:1500;padding:8px 16px calc(20px + var(--safe-bottom));
    padding-left:calc(16px + var(--safe-left));padding-right:calc(16px + var(--safe-right));
    display:none;max-height:88vh;max-height:88dvh;overflow-y:auto;
    -webkit-overflow-scrolling:touch;overscroll-behavior:contain;
    animation:drawerUp 0.25s ease-out;
    will-change:transform;transform:translateZ(0);
  }
  @keyframes drawerUp{from{transform:translateY(20px);opacity:0;}to{transform:translateY(0);opacity:1;}}
  #drawer.open{display:block;}
  /* zone de grip tappable de 24px minimum */
  .drawer-grip{
    display:flex;align-items:center;justify-content:center;
    height:24px;margin:0 -16px 6px;cursor:grab;
  }
  .drawer-handle{width:44px;height:5px;background:#d0d0d0;border-radius:3px;}
  .d-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:10px;}
  .d-name{font-size:17px;font-weight:600;color:#111;line-height:1.25;}
  .d-addr{font-size:13px;color:#888;margin-top:3px;line-height:1.3;}
  .d-dist{font-size:12px;color:#aaa;margin-top:2px;}
  .status-pill-lg{font-size:12px;padding:6px 12px;border-radius:20px;font-weight:500;white-space:nowrap;}
  .close-btn{
    background:#f5f5f5;border:none;font-size:22px;cursor:pointer;color:#666;
    line-height:1;margin-left:4px;width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
  }
  .close-btn:active{background:#e8e8e8;}
  /* Bouton partage — partage URL stable via Web Share API (fallback WhatsApp) */
  .share-btn{
    background:#F0EEE5;border:none;font-size:16px;cursor:pointer;color:#3C3A2E;
    line-height:1;width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:background 0.15s;
  }
  .share-btn:active{background:#E0DDD0;transform:scale(0.94);}
  /* Modale signal différé — affichée au retour d'une session Maps/Waze */
  .deferred-modal{
    position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;
  }
  .deferred-modal[hidden]{display:none;}
  .dm-backdrop{
    position:absolute;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(2px);
    -webkit-backdrop-filter:blur(2px);
  }
  .dm-card{
    position:relative;background:#fff;border-radius:18px;padding:20px 18px 14px;
    max-width:340px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,0.25);
    animation:dmIn 0.22s ease-out;
  }
  @keyframes dmIn{from{transform:translateY(16px);opacity:0;}to{transform:translateY(0);opacity:1;}}
  .dm-title{font-size:17px;font-weight:600;color:#111;margin-bottom:4px;line-height:1.3;}
  .dm-sub{font-size:13px;color:#666;margin-bottom:16px;}
  .dm-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px;}
  .dm-btn{
    border:none;border-radius:12px;padding:12px 6px;font-size:14px;font-weight:600;
    cursor:pointer;transition:transform 0.1s;
  }
  .dm-btn:active{transform:scale(0.97);}
  .dm-btn.ok{background:#E1F5EE;color:#0F6E56;}
  .dm-btn.queue{background:#FCECCB;color:#8A4D00;}
  .dm-btn.empty{background:#FCEBEB;color:#A32D2D;}
  .dm-dismiss{
    width:100%;background:none;border:none;color:#888;font-size:13px;
    padding:10px 0 2px;cursor:pointer;
  }
  .dm-dismiss:active{color:#555;}
  /* ── Modale carburant concerné (signal "À sec") ── */
  #fuel-signal-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:flex-end;justify-content:center;padding:0;}
  #fuel-signal-modal[hidden]{display:none;}
  .fsm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);}
  .fsm-card{
    position:relative;background:#fff;border-radius:20px 20px 0 0;padding:22px 18px 32px;
    width:100%;max-width:480px;box-shadow:0 -4px 30px rgba(0,0,0,0.15);
    animation:dmIn 0.22s ease-out;
  }
  .fsm-title{font-size:16px;font-weight:700;color:#111;margin-bottom:4px;}
  .fsm-sub{font-size:13px;color:#888;margin-bottom:16px;}
  .fsm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px;}
  .fsm-btn{
    border:1px solid #eee;border-radius:12px;padding:12px 6px;font-size:13px;font-weight:600;
    cursor:pointer;background:#fafafa;color:#333;transition:background 0.1s,border-color 0.1s;
    display:flex;flex-direction:column;align-items:center;gap:4px;
  }
  .fsm-btn:active{background:#f0f0f0;}
  .fsm-btn.all{background:#FCEBEB;color:#A32D2D;border-color:#f5c6c6;}
  .fsm-cancel{width:100%;background:none;border:none;color:#888;font-size:13px;padding:10px 0 0;cursor:pointer;}
  /* Fallback géoloc refusée — champ de recherche ville/CP */
  #geoloc-fallback{padding:12px 16px 0;position:relative;}
  #geoloc-fallback[hidden]{display:none;}
  #city-search{
    width:100%;padding:10px 14px;border-radius:10px;border:1px solid #e0e0e0;
    font-size:15px;font-family:inherit;background:#fff;outline:none;
    -webkit-appearance:none;appearance:none;
  }
  #city-search:focus{border-color:#F59300;box-shadow:0 0 0 3px rgba(245,147,0,0.15);}
  #city-suggestions{
    position:absolute;left:16px;right:16px;top:50px;background:#fff;
    border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 6px 20px rgba(0,0,0,0.08);
    max-height:240px;overflow-y:auto;z-index:50;
  }
  #city-suggestions[hidden]{display:none;}
  .cs-item{
    padding:10px 14px;cursor:pointer;font-size:14px;color:#222;
    border-bottom:1px solid #f0f0f0;
  }
  .cs-item:last-child{border-bottom:none;}
  .cs-item:hover, .cs-item:active, .cs-item.active{background:#FFF7E5;}
  .prices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;}
  .price-box{background:#f7f7f7;border-radius:12px;padding:12px 8px;text-align:center;}
  .price-box .label{font-size:11px;color:#888;margin-bottom:4px;font-weight:500;}
  .price-box .val{font-size:17px;font-weight:600;color:#111;}
  .price-box .diff{font-size:10px;margin-top:3px;}
  /* Highlight "meilleur choix" — combo halo + anneau doré + couronne + badge latéral */
  .best-wrap{position:relative;width:100%;height:100%;}
  /* Halo qui pulse — large et bien doré */
  .best-halo{position:absolute;inset:-10px;border-radius:50%;background:radial-gradient(circle, rgba(241,184,32,0.75) 0%, rgba(241,184,32,0.25) 45%, rgba(241,184,32,0) 75%);animation:bestPulse 1.8s ease-in-out infinite;pointer-events:none;}
  @keyframes bestPulse{0%{transform:scale(0.9);opacity:1;}50%{transform:scale(1.35);opacity:0.45;}100%{transform:scale(0.9);opacity:1;}}
  /* Anneau doré solide autour du pin — visible même sans animation */
  .best-ring{position:absolute;inset:4px;border-radius:50%;border:3px solid #F1B820;box-shadow:0 0 0 1.5px #fff, 0 2px 8px rgba(241,184,32,0.55);pointer-events:none;}
  /* Couronne au-dessus du pin */
  .best-crown{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:18px;filter:drop-shadow(0 2px 3px rgba(0,0,0,0.35));pointer-events:none;z-index:2;}
  /* Badge "★ Top" latéral — plus lisible que la couronne seule */
  .best-badge{position:absolute;top:50%;left:100%;transform:translate(-2px,-50%);background:linear-gradient(135deg,#F1B820 0%,#E8A100 100%);color:#fff;font-size:10px;font-weight:700;padding:3px 7px 3px 6px;border-radius:10px;white-space:nowrap;box-shadow:0 2px 6px rgba(0,0,0,0.2);border:1.5px solid #fff;pointer-events:none;letter-spacing:0.2px;z-index:3;}

  /* Bannière "meilleur choix pour toi" dans le drawer — pas d'animation (stabilité en stress) */
  .best-tag{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#FFF4D5 0%,#FFE9A8 100%);border:1px solid #F1B820;border-radius:12px;padding:9px 12px;margin-bottom:12px;}
  .best-tag .bt-emoji{font-size:18px;}
  .best-tag .bt-text{flex:1;min-width:0;}
  .best-tag .bt-title{font-size:13px;font-weight:600;color:#6B4A00;line-height:1.2;}
  .best-tag .bt-reason{font-size:11px;color:#8A6A1E;margin-top:2px;}
  @keyframes slideDown{from{transform:translateY(-8px);opacity:0;}to{transform:translateY(0);opacity:1;}}

  /* Boutons "Y aller" : Google Maps et Waze côte à côte (1 tap chacun) */
  /* Bloc B : Maps dominant (2/3 de largeur), Waze en secondaire (1/3) — le tap Maps est le CTA principal J0 */
  .go-row{display:grid;grid-template-columns:2fr 1fr;gap:8px;margin-top:12px;margin-bottom:4px;}
  .go-btn{
    display:flex;align-items:center;justify-content:center;gap:6px;width:100%;
    border:none;font-size:13px;font-weight:600;
    padding:10px 10px;border-radius:12px;cursor:pointer;
    min-height:40px;transition:background 0.15s,transform 0.15s;
  }
  .go-btn:active{transform:scale(0.97);}
  .go-btn .go-icon{font-size:16px;line-height:1;}
  .go-btn.maps{background:#1D9E75;color:#fff;}
  .go-btn.maps:active{background:#178663;}
  .go-btn.waze{background:#33CCFF;color:#fff;}
  .go-btn.waze:active{background:#25B3E6;}

  /* Bouton loupe — ouvre/ferme la zone de recherche depuis la topbar */
  .search-toggle{
    background:transparent;border:none;font-size:17px;cursor:pointer;
    width:34px;height:34px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:background 0.15s;color:#555;
  }
  .search-toggle:active{background:#f0f0f0;}
  .search-toggle.active{background:#E1F5EE;color:#0F6E56;}
  @keyframes searchPulse{
    0%,100%{box-shadow:0 0 0 0 rgba(29,158,117,0.4);}
    50%{box-shadow:0 0 0 6px rgba(29,158,117,0);}
  }
  /* Zone de recherche : toujours dans le DOM, visible/cachée par toggle ou géoloc refusée.
     Cachée en vue Liste. */
  #search-zone{
    padding:10px 16px 2px;position:relative;
  }
  #search-zone[hidden]{display:none;}
  #search-zone-input{
    width:100%;padding:10px 36px 10px 14px;border-radius:10px;border:1px solid #e0e0e0;
    font-size:15px;font-family:inherit;background:#fff;outline:none;
    -webkit-appearance:none;appearance:none;
  }
  #search-zone-input:focus{border-color:#1D9E75;box-shadow:0 0 0 3px rgba(29,158,117,0.15);}
  #search-zone-input.pulsing{
    border-color:#1D9E75;
    animation:searchPulse 1.6s ease-in-out infinite;
  }
  #search-zone-clear{
    position:absolute;right:26px;top:50%;transform:translateY(-50%);
    background:none;border:none;font-size:16px;color:#aaa;cursor:pointer;padding:4px;
    display:none;
  }
  #search-zone-clear.visible{display:block;}
  #search-zone-suggestions{
    position:absolute;left:16px;right:16px;top:52px;background:#fff;
    border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 6px 20px rgba(0,0,0,0.08);
    max-height:240px;overflow-y:auto;z-index:50;
  }
  #search-zone-suggestions[hidden]{display:none;}

  /* Tant que la search-zone est ouverte, on cache les filtres flottants : leur z-index 335
     les faisait passer par-dessus la dropdown des suggestions (z-index 50), et cognitivement
     l'utilisateur cherche une nouvelle zone — pas à filtrer. Sélecteur de frère général :
     #search-zone et #map-wrap sont siblings directs (lignes 843 et 865). */
  #search-zone:not([hidden]) ~ #map-wrap #filters-float{display:none;}

  /* Chip "mon carburant" dans le header */
  .fuel-chip{
    display:inline-flex;align-items:center;gap:5px;
    background:#F0EEE5;color:#3C3A2E;font-size:12px;font-weight:500;
    padding:7px 12px;border-radius:20px;border:1px solid transparent;cursor:pointer;
    transition:background 0.15s,border-color 0.15s;min-height:36px;user-select:none;
  }
  .fuel-chip:active{background:#E8E6DC;border-color:#D5D3C6;}
  .fuel-chip .fc-emoji{font-size:13px;}
  .fuel-chip .fc-caret{opacity:0.5;font-size:9px;margin-left:1px;}
  /* Pulse discret quand l'user n'a jamais choisi de carburant — nudge sans forcer */
  .fuel-chip.needs-setup{position:relative;}
  .fuel-chip.needs-setup::after{
    content:'';position:absolute;top:-2px;right:-2px;
    width:10px;height:10px;border-radius:50%;background:#1D9E75;
    border:2px solid #fff;box-shadow:0 0 0 3px rgba(29,158,117,0.22);
    animation:fuelChipPulse 1.8s ease-in-out infinite;pointer-events:none;
  }
  @keyframes fuelChipPulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.55;transform:scale(1.2);}}

  /* Sélecteur de carburant (popover depuis le chip) */
  #fuel-picker{position:fixed;inset:0;background:rgba(0,0,0,0.4);display:none;align-items:flex-end;justify-content:center;z-index:9998;animation:fadeIn 0.2s ease;}
  #fuel-picker.open{display:flex;}
  .fp-card{
    background:#fff;width:100%;max-width:460px;border-radius:22px 22px 0 0;
    padding:20px 18px calc(28px + var(--safe-bottom));
    padding-left:calc(18px + var(--safe-left));padding-right:calc(18px + var(--safe-right));
    animation:slideUp 0.3s ease-out;
  }
  .fp-title{font-size:18px;font-weight:600;color:#111;text-align:center;margin-bottom:4px;}
  .fp-sub{font-size:13px;color:#888;text-align:center;margin-bottom:20px;line-height:1.4;}
  .fp-choices{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
  .fp-btn{
    padding:18px 10px;border-radius:14px;border:2px solid #e5e5e5;background:#fff;cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:6px;
    min-height:96px;transition:transform 0.15s,box-shadow 0.15s,border-color 0.15s;
  }
  .fp-btn:active{transform:scale(0.97);}
  .fp-btn.selected{border-color:#1D9E75;background:#E1F5EE;}
  .fp-emoji{font-size:28px;}
  .fp-label{font-size:14px;font-weight:600;color:#111;}
  .fp-desc{font-size:11px;color:#888;}
  @keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
  @keyframes slideUp{from{transform:translateY(20px);opacity:0.5;}to{transform:translateY(0);opacity:1;}}

  /* Onboarding — même popover mais ne peut pas être fermé sans choisir */
  #fuel-picker.onboarding .fp-card{padding-top:28px;}

  /* Highlight du carburant préféré dans le drawer */
  .price-box.primary{border:2px solid #1D9E75;background:linear-gradient(135deg,#E8F5EF 0%,#F7F7F5 100%);padding:12px 8px;position:relative;}
  .price-box.primary::before{content:'★';position:absolute;top:4px;right:6px;font-size:10px;color:#1D9E75;}
  .price-box.primary .val{color:#0F6E56;font-size:22px;}
  .price-box.muted{opacity:0.45;}
  .price-box.muted .val{font-size:13px;}

  /* Indicateur de fraîcheur des prix officiels */
  .price-fresh{display:flex;align-items:center;gap:6px;font-size:11px;margin-top:-4px;margin-bottom:14px;padding:4px 8px;border-radius:8px;background:#F7F7F5;width:fit-content;}
  .fresh-dot{width:6px;height:6px;border-radius:50%;background:#B5B3A8;display:inline-block;flex-shrink:0;}
  .price-fresh.fresh-fresh{background:#E8F5EF;color:#0F6E56;}
  .price-fresh.fresh-fresh .fresh-dot{background:#1D9E75;}
  .price-fresh.fresh-moderate{background:#FCECCB;color:#8A4D00;}
  .price-fresh.fresh-moderate .fresh-dot{background:#F59300;}
  .price-fresh.fresh-stale{background:#FCEBEB;color:#A32D2D;}
  .price-fresh.fresh-stale .fresh-dot{background:#E24B4A;}

  /* Community pulse — façon Waze (dot qui pulse = live) */
  .community-pulse{display:flex;align-items:center;gap:10px;background:#F7F7F5;border-radius:12px;padding:10px 12px;margin-bottom:14px;}
  .pulse-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;position:relative;background:#1D9E75;}
  .pulse-dot::before{content:'';position:absolute;inset:-5px;background:inherit;border-radius:50%;opacity:0.35;animation:pulseRing 1.8s ease-out infinite;}
  @keyframes pulseRing{0%{transform:scale(0.8);opacity:0.5;}100%{transform:scale(2.2);opacity:0;}}
  .pulse-text{flex:1;min-width:0;}
  .pulse-title{font-size:13px;font-weight:500;color:#111;line-height:1.3;}
  .pulse-sub{font-size:11px;color:#888;margin-top:2px;}

  /* Trust line — fusion community-pulse + price-fresh en une seule ligne de confiance.
     Moins de bruit visuel dans le drawer, signal CTA remonte. */
  /* Bloc "état vide explicite" — ton discret : petit, gris, italique.
     On dit ce qu'on sait (prix à jour) et ce qu'on ne sait pas (dispo). */
  .empty-state{
    padding:2px 2px 10px;font-size:12px;line-height:1.4;color:#888;font-style:italic;
  }
  .empty-state[hidden]{display:none;}
  .trust-line{display:flex;align-items:center;gap:10px;background:#F7F7F5;border-radius:12px;padding:10px 12px;margin-bottom:14px;}
  .trust-line.empty{background:#FCEBEB;}
  /* Variante "sois le premier à signaler" (item 9) — quand reports===0.
     Teinte ambre chaleureuse (pas rouge alarmant), emoji en prefix, légère pulse
     pour accrocher l'œil sans stresser. Redirige visuellement vers les boutons de signal. */
  .trust-line.first-reporter{
    background:linear-gradient(135deg,#FFF7E5 0%,#FFECC7 100%);
    border:1px solid #F5CE72;
    position:relative;
  }
  .trust-line.first-reporter::after{
    content:'';position:absolute;left:50%;bottom:-8px;transform:translateX(-50%);
    width:0;height:0;
    border-left:8px solid transparent;border-right:8px solid transparent;
    border-top:8px solid #F5CE72;
    pointer-events:none;
  }
  .trust-line.first-reporter .trust-dot{background:#F59300;}
  .trust-line.first-reporter .trust-dot.live::before{background:#F59300;}
  .trust-line.first-reporter .trust-text{color:#6B4400;}
  .trust-line.first-reporter .trust-text b{color:#3F2900;}
  .trust-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;position:relative;background:#1D9E75;}
  .trust-dot.live::before{content:'';position:absolute;inset:-5px;background:inherit;border-radius:50%;opacity:0.35;animation:pulseRing 1.8s ease-out infinite;}
  .trust-text{flex:1;min-width:0;font-size:12px;color:#555;line-height:1.35;}
  .trust-text b{color:#111;font-weight:600;}
  .trust-sep{color:#bbb;margin:0 5px;}

  /* Call-to-action du signalement — cadre clair */
  .signal-cta{text-align:center;margin-bottom:10px;padding-top:4px;}
  .cta-title{font-size:14px;font-weight:600;color:#111;}
  .cta-sub{font-size:12px;color:#888;margin-top:2px;}
  /* Variante "hot" quand reports===0 (item 9) — renforce l'incitation au 1er signal.
     Couleur chaude, titre plus gros, petite anim subtile. */
  .signal-cta.hot{padding:14px 8px 10px;background:#FFF7E5;border-radius:12px;margin-bottom:12px;}
  .signal-cta.hot .cta-title{font-size:15px;color:#3F2900;}
  .signal-cta.hot .cta-sub{color:#6B4400;}
  .signal-cta.hot .cta-badge{
    display:inline-block;font-size:11px;font-weight:700;letter-spacing:0.4px;
    background:#F5CE72;color:#3F2900;padding:2px 9px;border-radius:10px;
    text-transform:uppercase;margin-bottom:6px;
  }
  /* Petit halo pulsé sur les boutons de signal quand reports===0 pour attirer l'œil. */
  .sig-row.hot .sig-btn{
    animation:sigAttract 2.4s ease-in-out infinite;
  }
  .sig-row.hot .sig-btn:nth-child(2){animation-delay:0.3s;}
  .sig-row.hot .sig-btn:nth-child(3){animation-delay:0.6s;}
  @keyframes sigAttract{
    0%,100%{box-shadow:0 0 0 0 rgba(245,206,114,0);}
    50%{box-shadow:0 0 0 4px rgba(245,206,114,0.38);}
  }

  /* Boutons de signalement — plus gros, façon Uber */
  .sig-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
  .sig-btn{
    padding:14px 6px;border-radius:14px;border:1.5px solid #e5e5e5;background:#fff;cursor:pointer;
    text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;
    min-height:76px;transition:transform 0.15s ease,box-shadow 0.15s ease,background 0.15s ease;
  }
  .sig-btn:active{transform:scale(0.97);}
  .sig-emoji{font-size:22px;line-height:1;font-weight:600;}
  .sig-title{font-size:12px;font-weight:600;color:#111;line-height:1.2;}
  .sig-desc{font-size:10px;color:#888;}
  .sig-btn.ok .sig-emoji{color:#1D9E75;}
  .sig-btn.queue .sig-emoji{color:#F59300;}
  .sig-btn.empty .sig-emoji{color:#E24B4A;}
  .sig-btn.ok.active{background:#E1F5EE;border-color:#1D9E75;}
  .sig-btn.queue.active{background:#FCECCB;border-color:#F59300;}
  .sig-btn.empty.active{background:#FCEBEB;border-color:#E24B4A;}
  .sig-btn.just-clicked{animation:bump 0.5s ease;}
  @keyframes bump{0%{transform:scale(1);}30%{transform:scale(1.06);}60%{transform:scale(0.98);}100%{transform:scale(1);}}
  #loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:999;background:#fff;padding:20px 28px;border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,0.12);}
  #loading p{font-size:14px;color:#555;margin-top:8px;}
  .spinner{width:32px;height:32px;border:3px solid #eee;border-top-color:#1D9E75;border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto;}
  @keyframes spin{to{transform:rotate(360deg);}}
  .legend-ctrl{background:#fff;padding:8px 10px;border-radius:10px;box-shadow:0 1px 6px rgba(0,0,0,0.15);font-size:11px;line-height:1.8;}
  .leg{display:flex;align-items:center;gap:6px;}
  .ldot{width:10px;height:10px;border-radius:50%;display:inline-block;}
  .src-note{font-size:11px;color:#aaa;text-align:center;padding:8px 16px 16px;}

  /* ─── Barre de chargement carte : 2px verte en haut, discrète, non-bloquante ─── */
  #map-loading-bar{
    position:absolute;top:0;left:0;height:2px;
    background:#1D9E75;width:0%;z-index:800;
    opacity:0;pointer-events:none;
    transition:width 0.4s ease,opacity 0.4s ease;
  }
  #map-loading-bar.loading{opacity:0.7;width:75%;}
  #map-loading-bar.done{opacity:0;width:100%;transition:width 0.2s ease,opacity 0.5s ease 0.15s;}

  /* ─── Chip "Actualiser / Actualisation" au pan ─────────────────────────────
     Positionné à ~70% de la hauteur de la carte (style Google Maps / Airbnb).
     États : hidden → prompt (tappable) → loading (spinner) → hidden.
  ─────────────────────────────────────────────────────────────────────────── */
  #map-refresh-chip{
    position:absolute;
    bottom:28%;          /* ~70% du haut = ~30% depuis le bas de la carte */
    left:50%;
    transform:translateX(-50%) translateY(20px);
    z-index:900;pointer-events:none;
    display:flex;align-items:center;gap:8px;
    background:#fff;color:#111;
    padding:10px 20px;border-radius:99px;
    font-size:14px;font-weight:600;white-space:nowrap;
    box-shadow:0 4px 16px rgba(0,0,0,0.18);
    opacity:0;
    transition:transform 0.25s ease, opacity 0.2s ease;
    user-select:none;
  }
  #map-refresh-chip.chip-visible{
    transform:translateX(-50%) translateY(0);
    opacity:1;
  }
  /* État prompt : bouton tappable, icône de refresh */
  #map-refresh-chip.chip-prompt{
    pointer-events:auto;cursor:pointer;
  }
  #map-refresh-chip.chip-prompt:active{
    background:#f5f5f5;
    transform:translateX(-50%) translateY(0) scale(0.96);
  }
  /* Spinner pour l'état loading */
  #map-refresh-chip .chip-spinner{
    width:14px;height:14px;flex-shrink:0;
    border:2px solid #ddd;border-top-color:#1D9E75;
    border-radius:50%;
    animation:chip-spin 0.75s linear infinite;
  }
  @keyframes chip-spin{to{transform:rotate(360deg);}}

  /* ─── Toast : positionné près du bas, safe-area aware ─── */
  #toast{
    position:fixed;
    bottom:calc(20px + var(--safe-bottom));
    left:50%;transform:translateX(-50%);
    background:#111;color:#fff;padding:13px 20px;border-radius:22px;
    font-size:14px;display:none;z-index:9999;max-width:calc(100vw - 32px);
    text-align:center;line-height:1.4;box-shadow:0 6px 24px rgba(0,0,0,0.3);
    animation:toastIn 0.25s ease-out;
  }
  @keyframes toastIn{from{opacity:0;transform:translate(-50%,10px);}to{opacity:1;transform:translate(-50%,0);}}

  /* Bloc D : drag-hint supprimé — le drag du marker reste fonctionnel, sans coach mark intrusif */

  /* ─── Bandeau Best Choice (Bloc B #7) : hero feature J0, entre view-segment et map-wrap.
       S'affiche uniquement si carburant défini et meilleure station identifiée. ─── */
  .best-banner{
    display:flex;align-items:center;gap:10px;flex-shrink:0;
    margin:8px calc(12px + var(--safe-right)) 8px calc(12px + var(--safe-left));
    padding:9px 10px 9px 12px;
    background:linear-gradient(90deg,#FFF6D9 0%,#FFFBF0 100%);
    border:1px solid #F1B820;border-radius:12px;
    box-shadow:0 1px 3px rgba(193,143,0,0.15);
  }
  .best-banner[hidden]{display:none;}
  .bb-body{
    flex:1;display:flex;align-items:center;gap:10px;min-width:0;
    border:none;background:transparent;padding:0;
    cursor:pointer;color:inherit;text-align:left;font:inherit;
    transition:transform 0.12s;
  }
  .bb-body:active{transform:scale(0.98);}
  .bb-crown{font-size:20px;flex-shrink:0;line-height:1;}
  .bb-text{min-width:0;flex:1;}
  .bb-title{font-size:10.5px;color:#6B4400;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;}
  .bb-detail{font-size:13px;color:#3F2900;font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-top:1px;}
  .bb-detail b{color:#111;font-weight:700;}
  .bb-go{
    flex-shrink:0;background:#1D9E75;color:#fff;border:none;
    width:38px;height:38px;border-radius:10px;cursor:pointer;
    font-size:17px;display:flex;align-items:center;justify-content:center;
    transition:transform 0.12s,background 0.15s;
  }
  .bb-go:active{transform:scale(0.94);background:#178663;}

  /* ─── Drawer : empêche la sélection de texte pendant un swipe ─── */
  #drawer.swiping{transition:none!important;user-select:none;}

  /* ─── Welcome hook : bandeau de valeur 1re visite, persistant jusqu'au dismiss ou 1er tap station.
       Layout 2 lignes : titre (bénéfice) + sous-titre (cas concrets) + lien "à propos" discret en bout. ─── */
  #welcome-hook{
    display:none;
    background:linear-gradient(135deg,#1D9E75 0%,#148A5F 100%);
    color:#fff;flex-shrink:0;
    padding:10px calc(14px + var(--safe-right)) 10px calc(14px + var(--safe-left));
    align-items:flex-start;gap:10px;
    font-size:12.5px;line-height:1.35;
    box-shadow:0 2px 8px rgba(20,138,95,0.18);
    animation:welcomeIn 0.35s ease-out;
  }
  #welcome-hook.show{display:flex;}
  @keyframes welcomeIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
  .wh-emoji{font-size:16px;flex-shrink:0;line-height:1.2;margin-top:1px;}
  .wh-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;}
  .wh-title{font-weight:700;font-size:13.5px;line-height:1.3;}
  .wh-sub{font-size:12px;opacity:0.92;line-height:1.35;}
  /* .wh-about supprimé : le lien "à propos" est désormais uniquement en pied de fuel-picker */
  .wh-close{
    background:rgba(255,255,255,0.22);border:none;color:#fff;
    width:26px;height:26px;border-radius:50%;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    font-size:15px;line-height:1;flex-shrink:0;padding:0;
    margin-top:1px;
  }
  .wh-close:active{background:rgba(255,255,255,0.35);}

  /* ─── Empty-zone banner : 0 signalement communautaire dans le viewport.
       Ton ambre/crème, plus discret que le welcome-hook (qui est plus saillant car 1re visite).
       Affiché uniquement quand welcome-hook est masqué. ─── */
  #empty-zone-banner{
    display:none;flex-shrink:0;
    background:linear-gradient(135deg,#FFF7E5 0%,#FFECC7 100%);
    color:#7A4D00;
    padding:8px calc(14px + var(--safe-right)) 8px calc(14px + var(--safe-left));
    align-items:center;gap:8px;
    font-size:12px;line-height:1.35;
    border-bottom:1px solid #F5CE72;
    animation:welcomeIn 0.3s ease-out;
  }
  #empty-zone-banner.show{display:flex;}
  .ezb-emoji{font-size:14px;flex-shrink:0;line-height:1;}
  .ezb-text{flex:1;min-width:0;}

  /* Ticker supprimé (item 10) : dupliquait l'info des pins colorés + trust-line drawer */

  /* ─── Nearby station card : signal en 1 tap si on est à <80m ─── */
  #nearby-card{
    position:absolute;left:10px;right:10px;bottom:calc(10px + var(--safe-bottom));
    background:#fff;border-radius:16px;
    padding:13px 14px;display:none;z-index:345;
    box-shadow:0 6px 22px rgba(0,0,0,0.2);
    border:2px solid #1D9E75;
    animation:cardIn 0.35s ease-out;
  }
  #nearby-card.show{display:block;}
  @keyframes cardIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
  .nc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:10px;}
  .nc-label{font-size:10.5px;color:#1D9E75;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;display:flex;align-items:center;gap:5px;}
  .nc-label::before{content:'';width:7px;height:7px;border-radius:50%;background:#1D9E75;box-shadow:0 0 0 3px rgba(29,158,117,0.2);animation:pulseRing 1.8s ease-out infinite;}
  .nc-title{font-size:15px;font-weight:600;color:#111;line-height:1.25;margin-top:3px;}
  .nc-close{background:#f2f2f2;border:none;width:30px;height:30px;border-radius:50%;font-size:17px;color:#555;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;}
  .nc-close:active{background:#e5e5e5;}
  .nc-cta{font-size:11.5px;color:#777;margin-bottom:10px;}
  .nc-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
  .nc-btn{
    padding:11px 6px;border-radius:11px;border:1.5px solid #e5e5e5;background:#fff;cursor:pointer;
    display:flex;flex-direction:column;align-items:center;gap:3px;min-height:60px;
    transition:transform 0.12s,background 0.12s;
  }
  .nc-btn:active{transform:scale(0.97);}
  .nc-btn .nc-emoji{font-size:17px;line-height:1;font-weight:600;}
  .nc-btn .nc-lbl{font-size:11px;font-weight:600;color:#111;}
  .nc-btn.ok .nc-emoji{color:#1D9E75;} .nc-btn.ok:active{background:#E1F5EE;}
  .nc-btn.queue .nc-emoji{color:#F59300;} .nc-btn.queue:active{background:#FCECCB;}
  .nc-btn.empty .nc-emoji{color:#E24B4A;} .nc-btn.empty:active{background:#FCEBEB;}

  /* ─── Badge compteur sur les pins (nombre de signalements récents) ─── */
  .pin-count-badge{
    position:absolute;top:-2px;right:-4px;
    background:#E24B4A;color:#fff;
    min-width:16px;height:16px;border-radius:8px;
    font-size:10px;font-weight:700;line-height:16px;text-align:center;padding:0 4px;
    border:1.5px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,0.3);
    pointer-events:none;z-index:4;
  }

  /* ─── Leaflet controls : plus tappables, repositionnés pour pas chevaucher la bottom nav ─── */
  .leaflet-control-zoom a{
    width:40px!important;height:40px!important;line-height:40px!important;
    font-size:20px!important;border-radius:10px!important;
  }
  .leaflet-bottom{margin-bottom:calc(58px + var(--safe-bottom))!important;}
  .leaflet-control-attribution{font-size:9px;}

  /* ─── Très petits écrans (≤ 360px, type iPhone SE 1re gén) ─── */
  @media (max-width: 360px){
    .app-title{font-size:16px;}
    .pill{max-width:90px;font-size:10px;}
    .fuel-chip{padding:6px 10px;font-size:11px;}
    #logo{width:28px;height:28px;}
    .prices-grid{gap:6px;}
    .price-box{padding:10px 4px;}
    .price-box .val{font-size:15px;}
    /* Topbar déjà chargé — on cache l'about-link pour laisser respirer la pill-loc */
    .about-link{display:none;}
  }

  /* ─── Masquer les éléments de survol sur tactile (pas de hover) ─── */
  @media (hover: none){
    .f-chip:hover,.fuel-chip:hover,.go-btn:hover,.close-btn:hover,.sig-btn:hover,.fp-btn:hover{
      transform:none;box-shadow:none;
    }
  }

  /* ─── T2.1 Trust-line : états communautaires colorés ─── */
  .trust-line.community-ok{background:#E1F5EE;}
  .trust-line.community-ok .trust-dot{background:#1D9E75;}
  .trust-line.community-queue{background:#FFF3E0;}
  .trust-line.community-queue .trust-dot{background:#F59300;}
  .trust-line.community-empty{background:#FCEBEB;}
  .trust-line.community-empty .trust-dot{background:#E24B4A;}

  /* ─── T2.4 Modale vie privée ─── */
  #privacy-modal{
    position:fixed;inset:0;z-index:8500;
    display:flex;align-items:flex-end;justify-content:center;
    background:rgba(0,0,0,0.45);
    animation:fadeOverlay 0.2s ease-out;
  }
  #privacy-modal[hidden]{display:none;}
  @keyframes fadeOverlay{from{opacity:0;}to{opacity:1;}}
  .pm-card{
    background:#fff;border-radius:20px 20px 0 0;
    width:100%;max-width:500px;
    padding:24px 20px calc(28px + var(--safe-bottom));
    animation:slideUp 0.25s ease-out;
  }
  @keyframes slideUp{from{transform:translateY(40px);opacity:0;}to{transform:translateY(0);opacity:1;}}
  .pm-title{font-size:17px;font-weight:700;color:#111;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
  .pm-table{width:100%;border-collapse:collapse;margin-bottom:16px;}
  .pm-table tr{border-bottom:1px solid #f0f0f0;}
  .pm-table tr:last-child{border-bottom:none;}
  .pm-table td{padding:10px 4px;font-size:13.5px;}
  .pm-table td:first-child{color:#555;width:55%;}
  .pm-table td:last-child{font-weight:700;color:#111;text-align:right;}
  .pm-table td:last-child.good{color:#1D9E75;}
  .pm-footer{display:flex;gap:10px;margin-top:4px;}
  .pm-btn-secondary{flex:1;padding:12px;border-radius:12px;border:1.5px solid #e5e5e5;background:#fff;font-size:14px;font-weight:600;color:#555;cursor:pointer;}
  .pm-btn-primary{flex:1;padding:12px;border-radius:12px;border:none;background:#1D9E75;font-size:14px;font-weight:700;color:#fff;cursor:pointer;text-decoration:none;display:flex;align-items:center;justify-content:center;}

  /* ─── T2.5 Testimonials dans le splash ─── */
  .splash-testimonials{display:flex;flex-direction:column;gap:8px;width:100%;}
  .splash-testi{
    background:#f7f7f7;border-radius:12px;
    padding:11px 14px;font-size:13px;color:#444;
    line-height:1.45;font-style:italic;text-align:left;
  }
  .splash-testi::before{content:'"';font-size:16px;font-style:normal;color:#1D9E75;margin-right:2px;}
  .testi-author{display:block;margin-top:6px;font-size:11px;font-style:normal;color:#aaa;}

  /* ─── Splash first-visit : bottom sheet sur overlay sombre (carte visible derrière) ─── */
  #splash{
    position:fixed;inset:0;z-index:9000;
    background:rgba(0,0,0,0.52);
    display:flex;align-items:flex-end;justify-content:center;
    animation:splashOverlay 0.25s ease-out;
  }
  #splash[hidden]{display:none;}
  @keyframes splashOverlay{from{opacity:0;}to{opacity:1;}}
  #splash-inner{
    width:100%;max-width:480px;
    background:#fff;
    border-radius:24px 24px 0 0;
    padding:8px 24px calc(28px + var(--safe-bottom)) 24px;
    display:flex;flex-direction:column;align-items:center;
    animation:splashSheetUp 0.32s cubic-bezier(0.34,1.1,0.64,1);
    max-height:88vh;overflow-y:auto;
  }
  @keyframes splashSheetUp{from{transform:translateY(100%);}to{transform:translateY(0);}}
  /* Poignée visuelle en haut du sheet */
  #splash-inner::before{
    content:'';display:block;width:40px;height:4px;border-radius:2px;
    background:#e0e0e0;margin:8px auto 20px;flex-shrink:0;
  }
  .splash-slide{display:none;flex-direction:column;align-items:center;gap:16px;text-align:center;width:100%;}
  .splash-slide.active{display:flex;}
  .splash-logo{margin-bottom:0;}
  .splash-title{font-size:24px;font-weight:800;color:#111;letter-spacing:-0.4px;line-height:1.2;}
  .splash-sub{font-size:14px;color:#555;line-height:1.55;max-width:300px;}
  .splash-pills{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;}
  .splash-pill{background:#f0faf6;color:#1D9E75;border:1px solid #b6e8d4;font-size:12px;font-weight:600;padding:5px 13px;border-radius:20px;}
  .splash-btn-primary{
    width:100%;padding:15px;border-radius:14px;
    background:#1D9E75;color:#fff;border:none;
    font-size:16px;font-weight:700;cursor:pointer;
    box-shadow:0 4px 14px rgba(29,158,117,0.3);
    transition:background 0.15s,transform 0.12s;
    margin-top:2px;
  }
  .splash-btn-primary:active{background:#178663;transform:scale(0.98);}
  .splash-btn-skip{
    width:100%;padding:13px;border-radius:14px;
    background:none;border:1.5px solid #1D9E75;
    color:#1D9E75;font-size:15px;font-weight:600;
    cursor:pointer;margin-top:0;
    transition:background 0.15s;
  }
  .splash-btn-skip:active{background:#f0faf6;}
  .splash-steps{display:flex;flex-direction:column;gap:10px;text-align:left;width:100%;}
  .splash-step{
    display:flex;align-items:flex-start;gap:12px;
    font-size:13.5px;color:#333;line-height:1.5;
    background:#f5fdf9;border:1px solid #c8eed9;
    border-radius:12px;padding:12px 14px;
  }
  .splash-step-num{
    width:26px;height:26px;border-radius:50%;
    background:#1D9E75;color:#fff;
    font-size:13px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;line-height:1;
  }
  .splash-step strong{color:#111;}
  .splash-privacy{
    font-size:11px;color:#aaa;
    width:100%;text-align:center;line-height:1.45;
    padding:4px 0;
  }

/* ─── Bannière iOS "Ajoute à l'écran d'accueil" ─── */
@keyframes ios-arrow-bounce {
  0%, 100% { transform: translateY(0); opacity: 1; }
  50%       { transform: translateY(7px); opacity: 0.6; }
}
.ios-install-arrow { animation: ios-arrow-bounce 1.1s ease-in-out infinite; display: inline-block; }
