@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800;900&display=swap');
:root{color-scheme:light only}

:root{
  /* Palette claire & épurée */
  --ocean:#0ea5e9;
  --ocean-mid:#38bdf8;
  --ocean-light:#7dd3fc;
  --sand:#fef3c7;
  --sand-light:#fffbeb;
  --pine:#16a34a;
  --pine-light:#4ade80;
  --sunset:#f97316;
  --sunset-dark:#ea580c;
  --white:#ffffff;
  --bg:#f8fafc;
  --card:#ffffff;
  --text:#1e293b;
  --muted:#64748b;
  --line:#e2e8f0;
  --shadow:0 4px 16px rgba(0,0,0,.06);
  --shadow-soft:0 2px 8px rgba(0,0,0,.04);
  --max:430px;
  --radius:20px;
  --radius-sm:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#f8fafc;color:var(--text);font-family:'Poppins',Arial,sans-serif;overflow-x:hidden}
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button,a{font:inherit}img{display:block;max-width:100%}

.ride-disclaimer-inline{font-size:12px;color:#6b7280;line-height:1.4;padding:10px 8px 0;text-align:center;max-width:300px;margin:0 auto;font-weight:400;}

@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ─── Layout ──────────────────────────────────────────────────────────────────── */
.app{width:100%;max-width:var(--max);margin:0 auto;padding:10px}
.block{
  background:var(--card);
  border:1px solid rgba(10,79,122,.09);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;margin-bottom:12px;
  transition:transform .2s ease;
}
.hero{
  background:linear-gradient(160deg,#0a4f7a 0%,#1780ee 55%,#43a2ff 100%);
  color:#fff;border:none;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat;
  opacity:.12;
}
.hero>*{position:relative;z-index:1}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
h1,h2,h3,p{margin:0}
h1{font-size:18px;line-height:1.2;font-weight:700;letter-spacing:-0.01em;margin-bottom:4px}
h2{font-size:18px;line-height:1.2;font-weight:700;letter-spacing:-0.01em;margin-bottom:4px}
h3{font-size:15px;line-height:1.25;font-weight:600;margin-bottom:2px}
.sub{margin-top:2px;font-size:12px;line-height:1.4;color:var(--muted);font-weight:500}
.hero .sub{color:rgba(255,255,255,.85)}
.pill{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;white-space:nowrap;padding:5px 13px;
  font-size:10px;font-weight:800;
  background:linear-gradient(135deg,var(--sunset-dark),var(--sunset));
  color:#fff;box-shadow:0 6px 14px rgba(244,132,95,.28);
  letter-spacing:.02em;gap:10px;
}
.mini-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.mini{
  padding:9px 16px;border-radius:999px;
  background:rgba(255,255,255,.18);color:#fff;
  font-size:14px;font-weight:700;
  border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:inline-flex;align-items:center;gap:12px;
}
.mini-gps{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45);font-size:14px;padding:9px 16px}
.mini-weather{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45);font-size:14px;padding:9px 16px;cursor:pointer}

/* ─── Météo 3 jours ───────────────────────────────────────────────────────────── */
.weather-panel{
  display:none;
  margin-top:10px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  border-radius:16px;
  padding:10px 12px;
  backdrop-filter:blur(8px);
}
.weather-panel.open{display:block;animation:fadeInUp .3s ease}
.weather-days{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.weather-day{text-align:center;padding:8px 4px;border-radius:12px;background:rgba(255,255,255,.12)}
.weather-day-name{font-size:10px;font-weight:700;color:rgba(255,255,255,.75);text-transform:uppercase;letter-spacing:.04em}
.weather-day-emoji{font-size:22px;margin:4px 0}
.weather-day-temp{font-size:13px;font-weight:800;color:#fff}
.weather-day-wind{font-size:9px;font-weight:600;color:rgba(255,255,255,.65)}

/* ─── Bandeau PWA ─────────────────────────────────────────────────────────────── */
.pwa-banner{
  display:none;align-items:center;justify-content:space-between;gap:8px;
  padding:12px 16px;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.32), rgba(255,255,255,0) 34%),
    linear-gradient(135deg,#ff8a00 0%,#ff6a00 48%,#f04418 100%);
  color:#fff;border-radius:var(--radius-sm);margin-bottom:10px;
  box-shadow:0 12px 26px rgba(249,115,22,.30), inset 0 1px 0 rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.20);
}
.pwa-banner-text{font-size:12px;font-weight:800;flex:1;text-shadow:0 2px 10px rgba(111,43,0,.18)}
.pwa-banner-install{
  min-height:32px;padding:0 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.58);background:rgba(255,255,255,.94);
  color:#f05a00;font-size:11px;font-weight:900;cursor:pointer;
  box-shadow:0 6px 14px rgba(111,43,0,.16);
}
.pwa-banner-close{
  width:28px;height:28px;border-radius:999px;border:none;
  background:rgba(255,255,255,.18);color:#fff;font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}

/* ─── Filtres rapides ─────────────────────────────────────────────────────────── */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quick-btn{
  min-height:48px;
  border:1px solid #e2e8f0;
  background:#fff;
  color:var(--text);border-radius:var(--radius-sm);
  font-size:13px;font-weight:700;cursor:pointer;
  transition:all .15s;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
}
.quick-btn:hover{background:#f0f9ff;border-color:var(--ocean);color:var(--ocean);box-shadow:0 3px 10px rgba(14,165,233,.12)}
.quick-btn:active{transform:scale(.97)}

/* ─── Filtres catégorie ───────────────────────────────────────────────────────── */
.filters,.cards-row{display:flex;overflow-x:auto;overflow-y:visible;flex-wrap:nowrap;scrollbar-width:none}
.filters::-webkit-scrollbar,.cards-row::-webkit-scrollbar{height:4px}
.filters::-webkit-scrollbar-thumb,.cards-row::-webkit-scrollbar-thumb{background:#c8d8e8;border-radius:999px}
.filters {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding: 4px 0 12px !important;
  margin-bottom: 4px !important;
  overflow-x: visible !important;
  justify-content: flex-start !important;
}
.filter-btn {
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #475569;
  border-radius: 999px;
  padding: 6px 10px !important;
  font-size: 11px !important;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
  transition: all .15s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px !important;
  flex: 0 1 auto !important;
}
.filter-btn.active{
  background:var(--ocean);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(14,165,233,.25);
}

.filter-btn.locked-theme-badge{
  cursor: default;
  color:#0f172a;
  border-color:rgba(255,122,0,.28);
  background:linear-gradient(135deg,#fff 0%,#fff7ed 100%);
  box-shadow:0 2px 8px rgba(255,122,0,.10);
  opacity:.96;
  pointer-events:none;
}
.filter-btn.locked-theme-badge:focus{outline:none}

/* ─── Refonte Unifiée v126 ─── */
.search-unified-block {
  padding-bottom: 20px !important;
}
.filter-subgroup {
  margin-top: 16px;
}
.filter-subgroup-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.unified-filters-container .bikes-filter-row,
.unified-filters-container .filters {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding: 0 !important;
  margin-bottom: 0 !important;
}

/* ─── Cartes de parcours — scroll horizontal simple ─────────────────────────── */
.cards-row{
  gap:12px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 16px 12px 4px;margin-top:8px;
  scrollbar-width:none;
}
.cards-row::-webkit-scrollbar{display:none}
.card{
  flex:0 0 78%;min-width:78%;scroll-snap-align:start;
  border:1.5px solid rgba(14,165,233,.18);border-radius:var(--radius);
  background:linear-gradient(180deg,#ffffff 0%,#f3fbff 52%,#eaf8ff 100%);
  padding:14px;
  box-shadow:0 10px 26px rgba(15,58,91,.08);overflow:hidden;cursor:pointer;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.card:nth-child(even){
  background:linear-gradient(180deg,#ffffff 0%,#f3fbff 52%,#eaf8ff 100%);
  border-color:rgba(14,165,233,.18);
}
.card:active{transform:scale(.99)}
.card.active{
  background:linear-gradient(180deg,#ffffff 0%,#f3fbff 52%,#eaf8ff 100%);
  border-color:rgba(23,128,238,.55);
  box-shadow:0 14px 32px rgba(23,128,238,.16);
}
.card-media{position:relative}
.selected-tag{
  display:none;position:absolute;top:12px;right:12px;
  padding:6px 11px;font-size:10px;border-radius:999px;
  background:linear-gradient(135deg,#1780ee,#0c5fbf);color:#fff;
  font-weight:900;border:1px solid rgba(255,255,255,.48);
  box-shadow:0 8px 18px rgba(23,128,238,.24);
}
.card.active .selected-tag{display:inline-flex;align-items:center;gap:4px}
.card-image{
  width:100%;height:200px;border-radius:var(--radius-sm);overflow:hidden;
  margin:4px 0 12px;border:1px solid rgba(14,165,233,.14);background:#edf4fb;
  position:relative;box-shadow:0 8px 20px rgba(15,58,91,.08);
}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease;display:block}
.card:hover .card-image img{transform:scale(1.03)}

/* Badge favori sur la carte */
.fav-btn{
  position:absolute;top:10px;left:10px;z-index:2;
  width:32px;height:32px;border-radius:50%;border:none;
  background:rgba(255,255,255,.92);
  font-size:16px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 10px rgba(0,0,0,.15);
  transition:transform .2s;
}
.fav-btn:active{transform:scale(.9)}
.fav-btn.active{background:rgba(255,80,80,.1)}

.card-title{font-size:16px;font-weight:900;line-height:1.22;margin:8px 0 4px;letter-spacing:-.02em}
.card-meta{font-size:11px;color:var(--muted);line-height:1.4;font-weight:600}
.card-desc{
  margin-top:7px;font-size:11px;line-height:1.55;color:var(--muted);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  font-weight:600;
}
.card-desc.expanded{-webkit-line-clamp:unset;overflow:visible}
.more-toggle{
  margin-top:8px;min-height:28px;border:none;border-radius:10px;
  padding:5px 10px;font-size:9px;color:#475569;background:#f1f5f9;cursor:pointer;font-weight:700;
}
.route-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:20px;
}
.route-actions .btn {
  min-height: 40px !important; /* Boutons plus petits selon mockup */
  font-size: 12px !important;
  border-radius: 12px !important;
  padding: 6px 10px !important;
}


/* Bouton lancement direct depuis les encarts parcours — v179 */
.btn-start-navigation-card{
  width:100%;
  margin-top:10px;
  min-height:46px !important;
  border:none !important;
  border-radius:16px !important;
  padding:10px 14px !important;
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 45%,#0f8f3c 100%) !important;
  color:#fff !important;
  font-weight:900 !important;
  font-size:15px !important;
  line-height:1.1;
  box-shadow:0 12px 22px rgba(22,163,74,.28), inset 0 1px 0 rgba(255,255,255,.28);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.btn-start-navigation-card:active{
  transform:scale(.985);
  box-shadow:0 7px 16px rgba(22,163,74,.24), inset 0 1px 0 rgba(255,255,255,.24);
}
.btn-start-navigation-card:disabled{
  opacity:.75;
  cursor:wait;
  filter:saturate(.85);
}

/* Barre de difficulté visuelle */
.difficulty-bar{display:flex;gap:3px;margin:8px 0 4px;align-items:center}
.difficulty-label{font-size:9px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-right:4px}
.diff-dot{width:10px;height:10px;border-radius:50%;background:var(--line);transition:background .2s}
.diff-dot.filled-easy{background:var(--pine-light)}
.diff-dot.filled-medium{background:#f59e0b}
.diff-dot.filled-hard{background:#ef4444}

/* Chips distance/durée */
.chips{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:10px;
}
.chip{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:6px 14px;font-size:12px;font-weight:800;
  background:linear-gradient(135deg,var(--pine),var(--pine-light));
  color:#fff;box-shadow:0 6px 14px rgba(45,106,79,.20);
  gap:10px;
}
.chip-elev{
  background:linear-gradient(135deg,#7c3aed,#a855f7);
  box-shadow:0 6px 14px rgba(124,58,237,.20);
}
.route-type-chip{
  background:linear-gradient(135deg,#eaf8ee,#d9f0df);
  color:#066a2d;
  border:1px solid rgba(22,163,74,.16);
  box-shadow:0 6px 14px rgba(22,163,74,.12);
  gap:8px;
  padding:5px 12px 5px 9px;
}
.route-type-chip .route-type-icon{
  width:34px;height:22px;flex:0 0 auto;
  fill:none;stroke:currentColor;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;
}
.route-type-chip .route-type-icon circle{fill:currentColor;stroke:none;}
.route-type-chip span{line-height:1;}

/* Harmonisation des badges dans les encarts “Nos balades incontournables” */
.card .chips{justify-content:center;gap:9px;margin-top:12px;}
.card .chip{
  background:#fff;
  color:#0c5fbf;
  border:1.5px solid rgba(23,128,238,.18);
  box-shadow:0 6px 14px rgba(23,128,238,.08);
}
.card .route-type-chip{
  background:linear-gradient(135deg,#eaf8ee,#dff5e6);
  color:#067a35;
  border-color:rgba(22,163,74,.22);
  box-shadow:0 7px 16px rgba(22,163,74,.12);
}
.card .chip-elev{
  background:#fff;
  color:#7c3aed;
  border-color:rgba(124,58,237,.18);
  box-shadow:0 6px 14px rgba(124,58,237,.08);
}

/* ─── Boutons ─────────────────────────────────────────────────────────────────── */
.btn{
  min-height:46px;width:100%;border:none;border-radius:var(--radius-sm);
  padding:8px 14px;font-size:13px;font-weight:800;text-align:center;
  line-height:1.2;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .1s,opacity .1s,box-shadow .15s;
  letter-spacing:.01em;
}
.btn:active{transform:scale(.97);opacity:.9}
.btn-primary{
  background:linear-gradient(135deg,#16a34a,#22c55e);
  color:#fff;box-shadow:0 12px 24px rgba(22,163,74,.30);
}
.btn-view{
  background:linear-gradient(135deg,#38bdf8 0%,#0ea5e9 60%,#0a4f7a 100%);
  color:#fff;
  border-radius:14px;
  box-shadow:0 4px 14px rgba(14,165,233,.30);
  border:none;
  padding:12px 18px;
  font-size:13px;
  font-weight:800;
}
.btn-danger{background:#f7faff;color:var(--ocean);border:1.5px solid rgba(10,79,122,.14)}
.btn-exit{
  background:linear-gradient(135deg,#dc2626,#ef4444);
  color:#fff;box-shadow:0 12px 22px rgba(239,68,68,.22);
}
.btn-return{background:linear-gradient(135deg,var(--sunset-dark),var(--sunset));color:#fff}
.btn-share{background:#eef6ff;color:var(--ocean);border:1.5px solid rgba(10,79,122,.12)}
.btn-reserve{
  background: rgba(56, 189, 248, 0.15);
  color: #0ea5e9;
  box-shadow:none;
  border: 1.5px solid rgba(14, 165, 233, 0.2);
  min-height:46px;border-radius:var(--radius-sm);
  padding:8px 14px;font-size:13px;font-weight:800;text-align:center;
  line-height:1.2;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .1s, opacity .1s, background .2s;
}
.btn-reserve:hover {
  background: rgba(56, 189, 248, 0.25);
}
.btn-reserve:active{transform:scale(.97);opacity:.9}

/* ─── Section carte ───────────────────────────────────────────────────────────── */
#mapSection{position:relative;padding:10px}
#mapSection .section-head{margin-bottom:6px}
#mapSection h2{font-size:15px;line-height:1.05;font-weight:900}
#mapSection .pill{padding:3px 8px;font-size:9px}
.badges{
  display: flex;
  flex-wrap: wrap;
  gap: 6px 4px; /* Espacement vertical 6px, horizontal 4px */
  margin-bottom: 8px;
  width: 100%; /* Utilise toute la largeur disponible */
  max-width: 320px; /* Largeur optimale pour forcer 2 lignes sur la plupart des mobiles */
}
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;padding:5px 13px;font-size:12px;font-weight:800;white-space:nowrap;
  gap:10px;
}
.badge-blue{background:#e8f3ff;color:var(--ocean)}
.badge-off{background:#eef2f7;color:#475569}
.badge-on{background:#e8fff2;color:var(--pine)}
.badge-bad{background:#fff7ed;color:#c2410c}

/* ─── Bandeau GPS ─────────────────────────────────────────────────────────────── */
.gps-banner{
  margin:0 0 6px;padding:12px 14px;border-radius:18px;
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));
  color:#fff;box-shadow:0 10px 24px rgba(10,79,122,.20);
  display:none;align-items:center;gap:12px;
}
/* gps-banner visible uniquement en navigation (display:flex ajouté dans le bloc ci-dessous) */
.gps-direction-icon{font-size:38px;font-weight:900;min-width:44px;text-align:center;line-height:1}
.gps-banner-text{flex:1}
.gps-title{font-size:20px;line-height:1.15;font-weight:900;letter-spacing:-.02em}
.gps-sub{margin-top:4px;font-size:14px;line-height:1.2;font-weight:700;color:rgba(255,255,255,.85)}

/* ─── Panneau prochain tournant ───────────────────────────────────────────────── */
.next-turn-panel{
  display:none;align-items:center;gap:10px;margin:0 0 6px;
  padding:10px 14px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));
  color:#fff;box-shadow:0 8px 20px rgba(10,79,122,.25);
  animation:slideDown .3s ease;
}
.next-turn-panel.visible{display:flex}
.turn-icon{font-size:28px;font-weight:900;min-width:34px;text-align:center}
.turn-text{font-size:12px;font-weight:700;line-height:1.4}
.turn-text strong{font-size:14px;font-weight:900}


.mini-action{
  min-height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.2);color:#fff;font-size:10px;font-weight:800;
  text-decoration:none;display:flex;align-items:center;justify-content:center;cursor:pointer;
}

/* ─── Alerte hors-parcours ────────────────────────────────────────────────────── */
.offroute-alert{
  display:none;align-items:center;justify-content:center;
  margin:0 0 6px;min-height:36px;padding:8px 12px;border-radius:12px;
  background:linear-gradient(135deg,#ffedd5,#fff7ed);
  border:1.5px solid rgba(244,132,95,.30);
  color:#c2410c;font-size:13px;font-weight:800;text-align:center;
}
.offroute-alert.visible{display:flex}
.offroute-alert.pulse-alert{animation:pulseAlert 0.4s ease 4}
@keyframes pulseAlert{
  0%,100%{transform:scale(1);background:linear-gradient(135deg,#ffedd5,#fff7ed)}
  50%{transform:scale(1.03);background:linear-gradient(135deg,#fed7aa,#ffedd5)}
}

/* ─── Barre de progression ────────────────────────────────────────────────────── */
.progress-wrap{
  margin:0 0 6px;padding:8px 10px;border-radius:12px;
  background:linear-gradient(135deg,#f0f6ff,#e8f2ff);
  border:1px solid rgba(10,79,122,.10);box-shadow:0 5px 12px rgba(10,79,122,.04);
}
.progress-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}
.progress-title,.progress-value{font-size:8px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.progress-value{color:var(--ocean)}
.progress-track{position:relative;width:100%;height:7px;border-radius:999px;background:#dde8f4;overflow:hidden}
.progress-fill{
  position:absolute;left:0;top:0;bottom:0;width:0%;border-radius:999px;
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid),var(--ocean-light));
  transition:width .4s ease;
}
.progress-ends{display:flex;justify-content:space-between;margin-top:3px;font-size:7px;font-weight:800;color:var(--muted);text-transform:uppercase}

/* ─── Profil d'élévation (masqué v39) ───────────────────────────────────────────── */
.elevation-wrap{display:none!important}
.elevation-title{display:none!important}
#elevationCanvas{display:none!important}

/* ─── Carte Leaflet ───────────────────────────────────────────────────────────── */
.map-frame{position:relative;margin-top:0}
.map-frame-inner{height:100%;position:relative}
#map{
  width:100%;height:360px;border-radius:var(--radius);overflow:hidden;
  border:1px solid rgba(10,79,122,.12);background:#eef4fb;
  box-shadow:0 12px 28px rgba(10,79,122,.08);
}
.map-frame.expanded #map{height:min(44vh,420px)}

/* v184 : hors navigation, l'aperçu carte reste fixe et laisse le scroll vertical de la page. */
body:not(.navigation-active) #mapFrame.map-preview-locked #map{
  cursor:default;
  touch-action:pan-y !important;
}
body:not(.navigation-active) #mapFrame.map-preview-locked .leaflet-pane,
body:not(.navigation-active) #mapFrame.map-preview-locked .leaflet-control-container{
  pointer-events:none;
}

/* V176 caméra GPS : mode cap-en-haut Leaflet.
   Les panes sont tournées par JS uniquement en navigation active avec auto-follow. */
#map.map-heading-up .leaflet-pane{
  backface-visibility:hidden;
  transform-style:preserve-3d;
}
#map.map-heading-up .leaflet-tile,
#map.map-heading-up .leaflet-marker-icon,
#map.map-heading-up .leaflet-zoom-animated{
  will-change:transform;
}
body.navigation-active.riding-mode #map.map-heading-up{
  background:#dbeafe;
}

/* ─── Boutons flottants sur la carte ─────────────────────────────────────────── */
.map-fab,.map-mode-fab,.compass-fab{
  position:absolute;border:1px solid rgba(255,255,255,.88);
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(244,248,255,.96));
  color:var(--ocean);box-shadow:0 10px 26px rgba(10,79,122,.14);z-index:500;
}
.map-fab{right:12px;bottom:12px;width:48px;height:48px;border-radius:999px;cursor:pointer;font-size:20px}
.map-gps-fab{width:44px;height:44px;bottom:14px;right:14px;padding:0;display:flex;align-items:center;justify-content:center;transition:transform .12s,box-shadow .12s}
.map-gps-fab:active{transform:scale(.9);box-shadow:0 2px 8px rgba(10,79,122,.18)}
.map-mode-fab{right:12px;bottom:120px;width:44px;height:44px;border-radius:50%;font-size:18px;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center}
.compass-fab{right:12px;top:12px;width:42px;height:42px;border-radius:999px;pointer-events:none}
.compass-inner{position:relative;width:28px;height:28px;border-radius:999px;border:2px solid rgba(10,79,122,.18);transform-origin:center center;transition:transform .38s linear}
.compass-arrow{position:absolute;top:2px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:15px solid #ef4444}
.compass-n{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:900;color:var(--ocean)}

/* ─── Compteur vitesse ────────────────────────────────────────────────────────── */
.speed-display{
  position:absolute;bottom:60px;left:12px;z-index:500;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:58px;height:58px;border-radius:50%;
  background:rgba(255,255,255,.97);
  border:2.5px solid rgba(10,79,122,.20);
  box-shadow:0 6px 20px rgba(10,79,122,.18);
  backdrop-filter:blur(8px);
}
.speed-value{font-size:20px;font-weight:900;color:var(--ocean);line-height:1}
.speed-unit{font-size:8px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* ─── Bouton nord ─────────────────────────────────────────────────────────────── */
.map-north-fab{
  position:absolute;top:60px;right:12px;z-index:500;
  width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(255,255,255,.88);
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(244,248,255,.96));
  color:var(--ocean);box-shadow:0 6px 18px rgba(10,79,122,.14);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;gap:1px;transition:background .2s,box-shadow .2s;
}
.map-north-fab.north-active{background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));border-color:rgba(255,255,255,.5)}
.map-north-fab.north-active .north-arrow,.map-north-fab.north-active .north-label{color:#fff}
.north-arrow{font-size:16px;font-weight:900;line-height:1;color:#ef4444;transition:transform .35s ease}
.north-label{font-size:8px;font-weight:800;color:var(--ocean);text-transform:uppercase}

/* ─── Boutons d'action sous la carte ─────────────────────────────────────────── */
.map-actions{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:10px;align-items:start}
.map-actions-primary{display:grid;gap:8px;flex:1}
.btn-more{
  width:48px;height:48px;border-radius:999px;
  border:1.5px solid rgba(10,79,122,.14);background:#f4f9ff;
  color:var(--ocean);font-size:20px;font-weight:900;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:start;
}
.more-actions-menu{
  display:none;
  position:absolute;
  /* Centrage mathématique parfait par rapport au parent .map-actions */
  left: 50%;
  transform: translateX(-50%);
  bottom: 80px; /* Espace confortable au-dessus des boutons selon mockup */
  background:var(--card);
  border:1px solid rgba(10,79,122,.14);
  border-radius:var(--radius);
  box-shadow:0 18px 44px rgba(10,79,122,.16);
  padding:12px;
  z-index:1100;
  width: auto;
  min-width: 220px;
  max-width: 90%;
  gap:8px;
  flex-direction:column;
}
/* On retire position:relative du wrap pour que le menu se positionne par rapport à .map-actions */
.more-actions-wrap{position:static}
.map-actions{position:relative}
.more-actions-menu.open{display:flex}

/* ─── Historique ──────────────────────────────────────────────────────────────── */
.history-block{
  background:linear-gradient(135deg,#f4f9ff,#eef4fb);
  border:1px solid rgba(10,79,122,.10);border-radius:var(--radius-sm);
  padding:12px;margin-bottom:10px;
}
.history-title{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.history-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:12px;background:#fff;
  border:1px solid rgba(10,79,122,.08);margin-bottom:6px;cursor:pointer;
  transition:box-shadow .15s;
}
.history-item:hover{box-shadow:0 4px 12px rgba(10,79,122,.10)}
.history-emoji{font-size:20px}
.history-info{flex:1}
.history-name{font-size:12px;font-weight:800;color:var(--text)}
.history-meta{font-size:10px;font-weight:600;color:var(--muted);margin-top:1px}
.history-date{font-size:9px;font-weight:700;color:var(--muted)}

/* ─── Disclaimer ──────────────────────────────────────────────────────────────── */
.ride-disclaimer{
  margin:8px 0;padding:10px 14px;border-radius:var(--radius-sm);
  background:#f4f9ff;border:1px solid rgba(10,79,122,.10);
  color:#516275;font-size:10.5px;line-height:1.5;text-align:center;font-weight:600;
}
.detail-toggle-wrap{margin:2px 0 12px;display:flex;justify-content:center}
.detail-toggle-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  min-height:36px;padding:0 18px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid),var(--ocean-light));
  color:#fff;font-size:11px;font-weight:800;
  box-shadow:0 10px 22px rgba(10,79,122,.22);cursor:pointer;
}
.detail-block{background:linear-gradient(180deg,rgba(10,79,122,.07),rgba(10,79,122,.03));border:1px solid rgba(10,79,122,.16)}
.detail-block.collapsed{display:none}
.detail-title{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:46px;padding:10px 20px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));
  color:#fff;box-shadow:0 10px 24px rgba(10,79,122,.20);font-size:15px;line-height:1.2;font-weight:900;
}
.detail-text{margin-top:6px;font-size:12px;line-height:1.6;color:var(--muted);font-weight:600}
.detail-grid,.info-list,.poi-list{display:grid;gap:8px}
.info-list,.poi-list{margin-top:8px}.poi-heading{margin-top:4px;margin-bottom:4px}
.info-item,.poi-item{
  background:#f4f9ff;border:1px solid rgba(10,79,122,.08);
  border-radius:var(--radius-sm);padding:11px;font-size:11px;line-height:1.5;font-weight:600;
}
.info-item strong,.poi-item strong{display:block;font-size:11px;margin-bottom:3px;font-weight:800}
.poi-item em{display:block;margin-top:5px;font-style:normal;color:var(--sunset-dark);font-weight:800}

/* ─── Marqueur GPS style Google Maps ─────────────────────────────────────────── */
/* ─── Marqueur GPS fin + halo léger ──────────────────────────────────────────────── */
.gmap-marker{width:24px;height:24px;position:relative;transform-origin:center center}
.gmap-arrow{
  position:absolute;left:50%;top:-7px;transform:translateX(-50%);
  width:0;height:0;
  border-left:5px solid transparent;border-right:5px solid transparent;
  border-bottom:12px solid var(--ocean);
  filter:drop-shadow(0 1px 3px rgba(10,79,122,.5));
  transform-origin:50% calc(100% + 12px);transition:transform .18s linear;
}
.gmap-dot{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:10px;height:10px;border-radius:50%;
  background:var(--ocean);border:2px solid #fff;
  box-shadow:0 1px 6px rgba(10,79,122,.5);z-index:2;
}
.gmap-pulse{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:24px;height:24px;border-radius:50%;
  background:rgba(10,79,122,.12);border:1px solid rgba(10,79,122,.20);
  animation:gmapPulse 2s ease-in-out infinite;
}
@keyframes gmapPulse{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:1}
  50%{transform:translate(-50%,-50%) scale(1.3);opacity:.4}
}
.start-dot,.end-dot{width:14px;height:14px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 10px rgba(0,0,0,.2)}
.start-dot{background:var(--pine-light)}.end-dot{background:#ef4444}

/* ─── Mode navigation plein écran ────────────────────────────────────────────── */
body.navigation-active{background:#000;overflow:hidden}
body.navigation-active .app{max-width:100%;padding:0;margin:0}
body.navigation-active .app>section.block:not(#mapSection),
body.navigation-active .ride-disclaimer,
body.navigation-active .detail-toggle-wrap,
body.navigation-active #detailSection,
body.navigation-active .pwa-banner{display:none!important}
body.navigation-active #mapSection{position:fixed;inset:0;z-index:100;margin:0;padding:0;border-radius:0;border:none;box-shadow:none;background:transparent}
body.navigation-active .map-frame,
body.navigation-active .map-frame-inner{height:100dvh!important;border-radius:0}
body.navigation-active .map-frame.expanded #map,
body.navigation-active #map{width:100vw!important;height:100dvh!important;border-radius:0!important;border:none!important;box-shadow:none!important}
/* ─── Navigation v46 : interface propre type Google Maps ─────────────────── */
/* Masquer TOUT sauf la carte en navigation */
body.navigation-active #mapSection>.section-head,
body.navigation-active .badges,
body.navigation-active .progress-wrap,
body.navigation-active .elevation-wrap{display:none!important}
/* Barre haute GPS — v65 : blanc glassmorphism */
body.navigation-active .gps-banner{
  display:flex;
  position:fixed;
  top:env(safe-area-inset-top,0);
  left:0;right:0;
  z-index:600;
  margin:10px 12px 0;
  padding:0;
  background:transparent;
  min-height:auto;
  border:none;
  box-shadow:none;
}
/* Badge GPS signal faible : discret, dans la barre */
body.navigation-active #gpsBadge{
  position:fixed;
  top:calc(env(safe-area-inset-top,0) + 12px);
  right:16px;
  z-index:601;
  font-size:9px;padding:3px 8px;border-radius:999px;
  background:rgba(239,68,68,.85);color:#fff;
  border:none;
  display:none;
}
body.navigation-active #gpsBadge.badge-bad{display:inline-flex}
body.navigation-active .offroute-alert.visible{
  position:fixed;top:calc(env(safe-area-inset-top,0) + 82px);left:0;right:0;
  z-index:601;margin:0 12px;border-radius:var(--radius-sm);
}
body.navigation-active #nextTurnPanel.visible{
  position:fixed;top:calc(env(safe-area-inset-top,0) + 92px);left:12px;right:12px;
  z-index:602;margin:0;border-radius:18px;
}
/* ─── Boutons bas en navigation v46 ────────────────────────────────────── */
body.navigation-active .map-actions{
  display:none!important;
}
body.navigation-active .map-actions-primary{display:flex;gap:8px}
/* Bouton Quitter (rouge) */
body.navigation-active #btnLaunchRoute{
  min-height:40px;padding:8px 20px;font-size:11px;width:auto;
  background:rgba(239,68,68,.88);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 4px 18px rgba(239,68,68,.35);
  border-radius:999px;
  color:#fff;
  border:none;
}
body.navigation-active .btn-call,
body.navigation-active .more-actions-wrap{display:none!important}
/* Droite : GPS fab (cible) */
body.navigation-active .map-fab{bottom:calc(env(safe-area-inset-bottom,0) + 72px);right:16px}
body.navigation-active .map-mode-fab{bottom:calc(env(safe-area-inset-bottom,0) + 16px);right:16px;left:auto}
body.navigation-active .compass-fab{top:calc(env(safe-area-inset-top,0) + 92px);right:16px}
body.navigation-active .speed-display{bottom:calc(env(safe-area-inset-bottom,0) + 132px);left:16px}
body.navigation-active .map-north-fab{display:none}
/* Son — droite, au-dessus du bouton GPS (v46) */
body.navigation-active .map-sound-fab{
  top:auto;
  bottom:calc(env(safe-area-inset-bottom,0) + 124px);
  right:16px;
  left:auto;
  width:44px;height:44px;
  padding:0;
  justify-content:center;
  border-radius:999px;
}
body.navigation-active .map-sound-fab .sound-label{display:none}
/* Voir le parcours — masqué en navigation v65 */
body.navigation-active .map-fit-overlay{
  display:none!important;
}
/* Centrer — centré bas, discret (v46) */
body.navigation-active .map-center-overlay{
  bottom:calc(env(safe-area-inset-bottom,0) + 16px);
  background:rgba(255,255,255,.82);
  color:var(--ocean);
  border:1px solid rgba(10,79,122,.12);
  font-size:10px;
  padding:5px 12px;
}
/* Progression — centrée au-dessus des boutons (v46) */
body.navigation-active .progress-overlay{
  bottom:calc(env(safe-area-inset-bottom,0) + 108px);
  left:50%;
  transform:translateX(-50%);
  background:rgba(10,79,122,.82);
  color:#fff;
  font-size:10px;
  padding:4px 12px;
}

/* ─── Section vélos recommandés — scroll horizontal ────────────────────── */
.bikes-section{margin-top:6px}
.bikes-section-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 8px !important;
  color: var(--text) !important;
}
.bikes-filter-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding: 4px 0 12px !important;
  margin-bottom: 4px !important;
  overflow-x: visible !important;
  justify-content: flex-start !important;
}
.bikes-filter-row .bike-filter-btn {
  flex: 0 1 auto !important;
  margin: 0 !important;
  padding: 6px 10px !important;
  font-size: 11px !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
}
.bike-filter-btn{
  border:1px solid #e2e8f0;background:#fff;color:#475569;
  border-radius:999px;padding:6px 12px;font-size:11px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:all .15s;
}
.bike-filter-btn.active{background:var(--ocean);color:#fff;border-color:transparent}
.bikes-cards-row{
  display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  gap:12px;padding:2px 1px 8px;
  scrollbar-width:none;
}
.bikes-cards-row::-webkit-scrollbar{display:none}
.bike-card{display:flex;flex-direction:column;
  flex:0 0 76%;min-width:76%;scroll-snap-align:start;
  border:1px solid #e2e8f0;border-radius:var(--radius-sm);
  background:#fff;padding:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.bike-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(10,79,122,.16)}
.bike-top-badge{
  position:absolute;top:8px;right:8px;
  background:linear-gradient(135deg,var(--sunset-dark),var(--sunset));
  color:#fff;font-size:8px;font-weight:800;border-radius:999px;padding:3px 7px;
  box-shadow:0 3px 8px rgba(244,132,95,.28);
}
.bike-card-image{width:100%;height:140px;border-radius:14px;overflow:hidden;margin-bottom:8px;border:none;background:#edf4fb;box-shadow:0 4px 12px rgba(10,79,122,.08)}
.bike-card-image img{width:100%;height:100%;object-fit:cover}
.bike-card-title{font-size:14px;font-weight:900;margin-bottom:3px;letter-spacing:-.02em}
.bike-card-meta{font-size:9px;color:var(--muted);font-weight:700;margin-bottom:4px}
.bike-card-desc{font-size:10px;color:var(--muted);line-height:1.5;margin-bottom:8px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.bike-card-actions{display:flex;align-items:center;justify-content:space-between;gap:6px}
.btn-book-bike{
  background:rgba(10,79,122,.08);color:var(--ocean);
  border:1.5px solid rgba(10,79,122,.20);border-radius:999px;padding:7px 14px;font-size:10px;font-weight:800;
  cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;
  box-shadow:none;transition:all .15s;
}
.btn-book-bike:hover{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.btn-book-bike:active{transform:scale(.97)}
.price-badge{
  background:linear-gradient(135deg,#f97316,#ea580c);
  color:#fff;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:900;
  white-space:nowrap;box-shadow:0 4px 12px rgba(249,115,22,.35);
  letter-spacing:.01em;
}



/* ─── Badges catégorie vélos ──────────────────────────────────────────────────── */
.bike-cat-badges{display:flex;flex-wrap:wrap;gap:5px;margin:6px 0 4px}
.bike-cat-badge{
  display:inline-flex;align-items:center;gap:5px;
  border-radius:999px;padding:3px 9px;font-size:10px;font-weight:800;
  white-space:nowrap;letter-spacing:.01em;
}
.bike-badge-electric{background:#e0f0ff;color:#0369a1}
.bike-badge-ville{background:#e8f5e9;color:#2d6a4f}
.bike-badge-vtt{background:#f5ede0;color:#92400e}
.bike-badge-gravel{background:#f0ede8;color:#57534e}
.bike-badge-competition{background:#fef9c3;color:#92400e}
.bike-badge-enfant{background:#f3e8ff;color:#7c3aed}
.bike-badge-cargo{background:#e8eef5;color:#334155}
.bike-badge-famille{background:#fff0f0;color:#be185d}
/* ─── Corps carte vélo ────────────────────────────────────────────────────────── */
.bike-card-body{padding:8px 10px 10px;display:flex;flex-direction:column;flex:1}
.bike-card-size{font-size:11px;color:#64748b;font-weight:700;margin-bottom:5px}
.bike-size-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:3px 9px;font-size:10px;font-weight:800;background:#e0f4ff;color:#0369a1;margin-bottom:5px;}

/* ─── Section accessoires recommandés ────────────────────────────────────────── */
.accessories-section{margin-top:10px}
.accessories-title{font-size:13px;font-weight:800;color:var(--ocean);margin-bottom:8px;letter-spacing:-.01em}
.accessories-row{
  display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;gap:8px;padding:2px 1px 6px;scrollbar-width:none;
}
.accessories-row::-webkit-scrollbar{display:none}
.accessory-card{
  flex:0 0 auto;scroll-snap-align:start;
  background:#fff;
  border:1px solid #e2e8f0;border-radius:12px;
  padding:8px 10px;min-width:90px;text-align:center;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  transition:transform .15s;
}
.accessory-card:hover{transform:translateY(-2px)}
.accessory-icon{font-size:22px;margin-bottom:4px}
.accessory-name{font-size:9px;font-weight:800;color:var(--ocean);line-height:1.3}
.accessory-price{font-size:8px;font-weight:700;color:var(--muted);margin-top:2px}
.accessory-free{color:var(--pine);font-weight:800}
/* ─── Filtre taille cycliste ──────────────────────────────────────────────────── */
.size-filter-section{margin-top:14px;padding-top:10px;border-top:1px solid #eef2f7}
.size-filter-label{font-size:11px;font-weight:800;color:var(--ocean);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.size-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.size-btn{
  padding:6px 14px;border-radius:999px;font-size:11px;font-weight:700;
  background:#f0f4f8;color:#445;
  border:1.5px solid #d0d8e4;
  cursor:pointer;transition:all .15s;
}
.size-btn:hover{background:#e2eaf4;border-color:var(--ocean);color:var(--ocean)}
.size-btn.active{
  background:var(--ocean);color:#fff;
  border-color:var(--ocean);box-shadow:0 3px 10px rgba(10,79,122,.25);
}

/* ─── Animations globales ─────────────────────────────────────────────────────── */
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ─── Utilitaires ─────────────────────────────────────────────────────────────── */
.route-empty{
  padding:16px;border:1.5px dashed rgba(10,79,122,.20);border-radius:var(--radius-sm);
  background:#edf4ff;color:var(--muted);font-size:12px;font-weight:700;text-align:center;
}
.review-hidden{display:none!important}
.gpx-error{background:#fff7ed!important;color:#c2410c!important}
body.navigation-active .arrival-actions{margin-bottom:6px}

@media (max-width:390px){
  .card{flex-basis:88%;min-width:88%}
  .app{padding:8px}.block{padding:12px}
  .card-image{height:160px}
  .bikes-cards-grid{grid-template-columns:1fr}
}
@media (max-height:720px){
  body.navigation-active .gps-banner{margin:6px 10px 0}
  .map-actions{gap:6px}.btn{min-height:40px}
}

/* ─── Animations apparition au scroll ────────────────────────────────────────── */
.card-appear{
  opacity:0;transform:translateY(20px);
  transition:opacity .4s ease,transform .4s ease;
}
.card-appear.visible{opacity:1;transform:translateY(0)}

/* ─── Séparateurs de section ─────────────────────────────────────────────────── */
.section-divider{
  height:1px;margin:0 16px;
  background:linear-gradient(90deg,transparent,rgba(10,79,122,.15),transparent);
}

/* ─── Barre de difficulté parcours ───────────────────────────────────────────── */
.difficulty-bar{
  display:flex;gap:3px;align-items:center;margin-top:6px;
}
.difficulty-dot{
  width:8px;height:8px;border-radius:50%;
  background:#dde8f4;transition:background .2s;
}
.difficulty-dot.filled-easy{background:#22c55e}
.difficulty-dot.filled-medium{background:#f59e0b}
.difficulty-dot.filled-hard{background:#ef4444}



/* ─── CTA intelligent ────────────────────────────────────────────────────────── */
.smart-cta-block{
  margin:0 0 12px;
  border-radius:14px;
  background:linear-gradient(135deg,#0ea5e9 0%,#0a4f7a 100%);
  padding:14px 16px;
  box-shadow:0 4px 18px rgba(14,165,233,.25);
}
.smart-cta-inner{
  display:flex;align-items:center;gap:12px;
}
.smart-cta-icon{
  font-size:26px;flex-shrink:0;
}
.smart-cta-text{
  flex:1;min-width:0;
}
.smart-cta-title{
  font-size:13px;font-weight:700;color:#fff;line-height:1.3;
}
.smart-cta-sub{
  font-size:11px;color:rgba(255,255,255,.8);margin-top:2px;line-height:1.3;
}
.smart-cta-btn{
  display:inline-block;
  background:#fff;color:#0a4f7a;
  font-size:12px;font-weight:700;
  padding:8px 14px;border-radius:20px;
  text-decoration:none;white-space:nowrap;
  flex-shrink:0;
  transition:transform .15s,box-shadow .15s;
}
.smart-cta-btn:active{transform:scale(.96);box-shadow:0 2px 8px rgba(0,0,0,.15);}

/* ─── Balades similaires ─────────────────────────────────────────────────────── */
.similar-block{
  margin:0 0 12px;
}
.similar-row{
  display:flex;
  overflow-x:auto;
  gap:12px;
  padding:4px 4px 12px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.similar-row::-webkit-scrollbar{display:none;}
.similar-card{
  scroll-snap-align:start;
  border-radius:12px;
  background:#fff;
  box-shadow:0 2px 12px rgba(10,79,122,.1);
  padding:10px;
  transition:transform .15s;
}
.similar-card:active{transform:scale(.97);}

/* ─── Bouton son ON/OFF (v40) ─────────────────────────────────────────────── */
.map-sound-fab{
  position:absolute;top:12px;left:12px;z-index:500;
  display:none; /* masqué par défaut — visible uniquement en navigation active */
  align-items:center;gap:4px;
  padding:5px 10px;border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(10,79,122,.15);
  color:var(--ocean);
  font-size:10px;font-weight:800;
  box-shadow:0 3px 10px rgba(10,79,122,.12);
  cursor:pointer;
  backdrop-filter:blur(6px);
  transition:background .15s,box-shadow .15s;
}
.map-sound-fab:active{transform:scale(.94)}
.map-sound-fab.sound-on{background:rgba(10,79,122,.90);color:#fff;border-color:transparent}
.sound-label{font-size:9px;font-weight:900;letter-spacing:.04em}

/* ─── Bouton "Voir le parcours" overlay (v40) ────────────────────────────── */
.map-fit-overlay{
  position:absolute;bottom:14px;left:12px;z-index:500;
  padding:5px 10px;border-radius:8px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(10,79,122,.15);
  color:var(--ocean);
  font-size:10px;font-weight:700;
  box-shadow:0 2px 8px rgba(10,79,122,.1);
  cursor:pointer;
  backdrop-filter:blur(8px);
  transition:background .15s;
  letter-spacing:.01em;
  max-width:120px; /* v162: Réduire la largeur */
  height:36px; /* v162: Réduire la hauteur */
  display:flex;align-items:center;justify-content:center; /* Assurer le centrage du texte */
}
.map-fit-overlay:active{background:rgba(10,79,122,.12);transform:scale(.96)}
/* Voir le parcours et son : règles définitives dans le bloc navigation-active v46 */

/* ─── Bouton "Centrer l'itinéraire" overlay (v43) ───────────────────────────────── */
.map-center-overlay{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:500;
  display:flex;align-items:center;gap:5px;
  padding:6px 14px;border-radius:999px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(10,79,122,.15);
  color:var(--ocean);
  font-size:11px;font-weight:800;
  box-shadow:0 3px 12px rgba(10,79,122,.14);
  cursor:pointer;
  backdrop-filter:blur(8px);
  transition:background .15s,transform .12s;
  letter-spacing:.01em;
  white-space:nowrap;
}
.map-center-overlay:active{background:rgba(10,79,122,.12);transform:translateX(-50%) scale(.96)}
/* map-center-overlay navigation : règle définitive dans bloc v46 */

/* ─── Bouton "En savoir plus" pleine largeur (v43) ─────────────────────────────── */
.detail-toggle-wrap{
  padding:0 10px 12px;
  max-width:var(--max);
  margin:0 auto;
}
.detail-toggle-wrap .detail-toggle-btn{
  width:100%;
  border-radius:var(--radius-sm);
  min-height:48px;
  font-size:13px;
  padding:12px 20px;
  justify-content:center;
}

/* ─── Overlay progression distance restante (v45) ──────────────────────────── */
.progress-overlay{
  position:absolute;
  bottom:52px;left:50%;transform:translateX(-50%);
  z-index:500;
  padding:4px 12px;border-radius:999px;
  background:rgba(10,79,122,.78);
  color:#fff;
  font-size:10px;font-weight:800;
  letter-spacing:.02em;
  white-space:nowrap;
  backdrop-filter:blur(6px);
  box-shadow:0 2px 8px rgba(10,79,122,.22);
  pointer-events:none;
}
/* progress-overlay navigation : règle définitive dans bloc navigation-active v46 */

/* ─── Section Avis ──────────────────────────────────────────────────────────── */
.reviews-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.review-card{background:#f9fafb;border-radius:12px;padding:12px 14px;border:1px solid #f0f0f0}
.review-card-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.review-card-stars{color:#f59e0b;font-size:14px;letter-spacing:1px}
.review-card-date{font-size:11px;color:#9ca3af;margin-left:auto}
.review-card-comment{font-size:13px;color:#374151;line-height:1.5}
.review-card-empty{font-size:13px;color:#9ca3af;text-align:center;padding:16px 0}
.btn-review-open{width:100%;padding:12px;background:#1780ee;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;margin-bottom:10px;transition:background .2s}
.btn-review-open:hover{background:#1268c4}
.review-form{background:#f9fafb;border-radius:14px;padding:16px;border:1.5px solid #e5e7eb;margin-top:4px}
.review-stars{display:flex;gap:6px;justify-content:center;margin-bottom:14px}
.review-stars .star{font-size:32px;color:#d1d5db;cursor:pointer;transition:color .15s;user-select:none}
.review-stars .star.active,.review-stars .star:hover{color:#f59e0b}
.review-textarea{width:100%;min-height:80px;border:1.5px solid #e5e7eb;border-radius:10px;padding:10px;font-size:13px;resize:vertical;font-family:inherit;box-sizing:border-box}
.review-textarea:focus{outline:none;border-color:#1780ee}
.btn-review-cancel{width:100%;padding:10px;background:transparent;color:#9ca3af;border:none;font-size:13px;cursor:pointer;margin-top:6px}
.reviews-avg{font-size:22px;font-weight:800;color:#1780ee}
.reviews-count{font-size:12px;color:#9ca3af;margin-left:4px}



/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v66 — Hiérarchie z-index propre · Zéro chevauchement · Mobile first
   ═══════════════════════════════════════════════════════════════════════════

   HIÉRARCHIE Z-INDEX :
   - Écran fin de parcours   : 1000
   - Header GPS              : 900
   - Alerte hors-parcours    : 890
   - Panneau prochain virage : 880
   - Footer flottant         : 870
   - Boutons flottants (FAB) : 860
   - Panneau arrivée ancien  : 850
   - Carte Leaflet           : 1
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Variables de layout GPS ─────────────────────────────────────────────── */
:root {
  --gps-header-h: 80px;
  --gps-footer-h: 95px;
  --gps-safe-top: env(safe-area-inset-top, 0px);
  --gps-safe-bot: env(safe-area-inset-bottom, 0px);
}

/* ── Masquer le header GPS hors navigation ────────────────────────────────── */
.gps-banner { display: none !important; }

/* ══ HEADER GPS ══════════════════════════════════════════════════════════════
   z-index: 900 · fixed · centré · max-width 420px
   ════════════════════════════════════════════════════════════════════════════ */
body.navigation-active .gps-banner {
  display: flex !important;
  align-items: center;
  gap: 14px;
  position: fixed !important;
  top: calc(var(--gps-safe-top) + 10px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 900 !important;
  /* Style glassmorphism blanc */
  background: rgba(255,255,255,0.88) !important;
  backdrop-filter: blur(24px) saturate(1.8) !important;
  -webkit-backdrop-filter: blur(24px) saturate(1.8) !important;
  border-radius: 22px !important;
  box-shadow: 0 8px 32px rgba(10,79,122,.14), 0 1px 0 rgba(255,255,255,.9) inset !important;
  border: 1px solid rgba(10,79,122,.10) !important;
  padding: 14px 18px !important;
  color: #0a4f7a !important;
  margin: 0 !important;
  animation: gpsSlideDown .35s cubic-bezier(.4,0,.2,1) both;
  transition: padding .3s ease, box-shadow .3s ease, background .3s ease;
}

@keyframes gpsSlideDown {
  from { opacity:0; transform:translateX(-50%) translateY(-18px); }
  to   { opacity:1; transform:translateX(-50%) translateY(0); }
}

/* Distance : texte dominant */
body.navigation-active .gps-title {
  font-size: 24px !important;
  font-weight: 700 !important;
  color: #0a4f7a !important;
  letter-spacing: -.04em;
  line-height: 1;
}
/* Instruction : plus petite, grise */
body.navigation-active .gps-sub {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #64748b !important;
  margin-top: 3px;
}
/* Icône direction */
body.navigation-active .gps-direction-icon {
  font-size: 28px !important;
  min-width: 38px;
  text-align: center;
  color: #1780ee !important;
  filter: none !important;
}

/* Header agrandi avant virage */
body.navigation-active .gps-banner.turn-imminent {
  padding: 18px 20px !important;
  background: rgba(23,128,238,.10) !important;
  border-color: rgba(23,128,238,.28) !important;
  box-shadow: 0 12px 40px rgba(23,128,238,.20) !important;
}
body.navigation-active .gps-banner.turn-imminent .gps-title { font-size: 28px !important; }
body.navigation-active .gps-banner.turn-imminent .gps-direction-icon { font-size: 32px !important; }

/* Header réduit en mouvement */
body.navigation-active .gps-banner.riding-compact {
  padding: 10px 14px !important;
  opacity: .90;
}

/* Vibration */
@keyframes gpsVibrate {
  0%,100%{transform:translateX(-50%) translateY(0)}
  20%{transform:translateX(calc(-50% - 3px))}
  40%{transform:translateX(calc(-50% + 3px))}
  60%{transform:translateX(calc(-50% - 2px))}
  80%{transform:translateX(calc(-50% + 2px))}
}
.gps-banner.vibrate-alert { animation: gpsVibrate .4s ease !important; }

/* ══ ALERTE HORS-PARCOURS ════════════════════════════════════════════════════
   z-index: 890 · sous le header
   ════════════════════════════════════════════════════════════════════════════ */
body.navigation-active .offroute-alert.visible {
  position: fixed !important;
  top: calc(var(--gps-safe-top) + var(--gps-header-h) + 10px) !important;
  left: 10px !important;
  right: auto !important;
  transform: none !important;
  width: auto !important;
  max-width: 40% !important; /* Encore plus petit */
  z-index: 850 !important;
  margin: 0 !important;
  border-radius: 8px !important;
  padding: 4px 8px !important;
  font-size: 10px !important; /* Miniature */
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
  pointer-events: none !important;
  background: #fee2e2 !important; /* Fond rouge très clair */
  color: #991b1b !important; /* Texte rouge foncé */
  border: 1px solid #fecaca !important;
}

/* ══ PANNEAU PROCHAIN VIRAGE ═════════════════════════════════════════════════
   z-index: 880 · sous alerte
   ════════════════════════════════════════════════════════════════════════════ */
body.navigation-active #nextTurnPanel,
body.navigation-active .progress-wrap,
body.navigation-active .elevation-wrap {
  display: none !important;
}
@keyframes gpsSlideDownSub {
  from { opacity:0; transform:translateX(-50%) translateY(-10px); }
  to   { opacity:1; transform:translateX(-50%) translateY(0); }
}

/* ══ FOOTER FLOTTANT ═════════════════════════════════════════════════════════
   z-index: 870 · fixed · centré · max-width 420px
   ════════════════════════════════════════════════════════════════════════════ */
.nav-footer-float {
  display: none;
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot) + 12px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 870 !important;
  background: rgba(255,255,255,0.2) !important;
  backdrop-filter: blur(12px) saturate(1.2);
  -webkit-backdrop-filter: blur(12px) saturate(1.2);
  border-radius: 24px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.1), 0 1px 0 rgba(255,255,255,0.2) inset;
  border: 1px solid rgba(255,255,255,0.15) !important;
  padding: 8px 16px 8px;
}
body.navigation-active .nav-footer-float {
  display: block;
  animation: gpsFooterSlideUp .4s cubic-bezier(.4,0,.2,1) both;
}
@keyframes gpsFooterSlideUp {
  from { opacity:0; transform:translateX(-50%) translateY(16px); }
  to   { opacity:1; transform:translateX(-50%) translateY(0); }
}
body.navigation-active.riding-mode .nav-footer-float {
  opacity: .65;
  transform: translateX(-50%) translateY(4px);
  transition: opacity .4s, transform .4s;
}

/* Stats */
.nav-footer-stats {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.nav-footer-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.nav-footer-stat-value {
  font-size: 14px;
  font-weight: 900;
  color: #0a4f7a;
  letter-spacing: -.02em;
  line-height: 1;
  transition: all .4s cubic-bezier(.4,0,.2,1);
}
.nav-footer-stat-label {
  font-size: 8px;
  font-weight: 700;
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.nav-footer-divider {
  width: 1px;
  height: 22px;
  background: rgba(10,79,122,.09);
  border-radius: 1px;
  flex-shrink: 0;
}

/* Barre de progression */
.nav-footer-progress-track {
  height: 3px;
  background: rgba(10,79,122,.09);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 6px;
}
.nav-footer-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #1780ee, #0a4f7a);
  border-radius: 999px;
  width: 0%;
  transition: width .6s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 0 8px rgba(23,128,238,.35);
}

/* Boutons footer */
.nav-footer-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.nav-footer-btn {
  border: none;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 700;
  transition: transform .15s, background .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  height: 34px;
}
.nav-footer-btn:active { transform: scale(.93); }
.nav-footer-btn-quit {
  flex: 1;
  background: rgba(239,68,68,.10);
  color: #ef4444;
  padding: 0 14px;
  border: 1.5px solid rgba(239,68,68,.18);
}
.nav-footer-btn-quit:active { background: rgba(239,68,68,.20); }
.nav-footer-btn-icon {
  width: 34px;
  background: rgba(10,79,122,.06);
  color: #0a4f7a;
  border: 1.5px solid rgba(10,79,122,.10);
  font-size: 16px;
}
.nav-footer-btn-icon:active { background: rgba(10,79,122,.16); }

/* ══ BOUTONS FLOTTANTS (FABs) ════════════════════════════════════════════════
   z-index: 860 · right: 12px · empilés au-dessus du footer
   ════════════════════════════════════════════════════════════════════════════ */
/* v111 — Harmonisation des boutons de contrôle (Son, Satellite, GPS) */
/* v112 — Alignement parfait et bouton GPS bleu */
/* v122 — Bouton Son Global (visible même sans navigation) */
.map-sound-fab {
  position: fixed !important;
  right: 12px !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  z-index: 1001 !important; /* Au-dessus de tout */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  background: #ffffff !important;
  border: 1.5px solid rgba(0,0,0,0.1) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
  top: 12px !important; /* Position par défaut (haut droite) */
  bottom: auto !important;
  left: auto !important;
  transition: top 0.3s ease;
}

body.navigation-active .map-mode-fab,
body.navigation-active .map-fab {
  position: fixed !important;
  right: 12px !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  z-index: 860 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  background: #ffffff !important;
  border: 1.5px solid rgba(0,0,0,0.1) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
  bottom: auto !important;
  left: auto !important;
}

body.navigation-active .map-sound-fab {
  top: calc(var(--gps-safe-top) + var(--gps-header-h) + 12px) !important;
}
.map-sound-fab .sound-label { display: none !important; }
body.navigation-active .map-mode-fab {
  top: calc(var(--gps-safe-top) + var(--gps-header-h) + 68px) !important; /* Espacement 12px entre chaque */
  font-size: 20px !important;
}
body.navigation-active .map-fab {
  top: calc(var(--gps-safe-top) + var(--gps-header-h) + 124px) !important;
  background: #0ea5e9 !important; /* Rétablissement du bleu */
  color: #ffffff !important;
  border-color: rgba(0,0,0,0.05) !important;
}
body.navigation-active .map-sound-fab .sound-label { display: none !important; }
body.navigation-active .map-sound-fab .sound-label { display: none !important; }
body.navigation-active .compass-fab {
  position: fixed !important;
  top: calc(var(--gps-safe-top) + var(--gps-header-h) + 8px) !important;
  right: 12px !important;
  z-index: 860 !important;
}
body.navigation-active .speed-display {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot) + var(--gps-footer-h) + 12px) !important;
  left: 12px !important;
  z-index: 860 !important;
}

/* ══ ÉLÉMENTS MASQUÉS EN NAVIGATION ═════════════════════════════════════════ */
body.navigation-active .map-fit-overlay   { display: none !important; }
body.navigation-active .map-center-overlay { display: none !important; }
body.navigation-active .map-actions       { display: none !important; }
body.navigation-active .progress-overlay  { display: none !important; }
body.navigation-active .map-north-fab     { display: none !important; }


/* ══ BADGE GPS SIGNAL ════════════════════════════════════════════════════════ */
body.navigation-active #gpsBadge {
  position: fixed !important;
  top: calc(var(--gps-safe-top) + 12px) !important;
  right: 16px !important;
  z-index: 910 !important;
  font-size: 9px; padding: 3px 8px; border-radius: 999px;
  background: rgba(239,68,68,.85); color: #fff;
  border: none; display: none;
}
body.navigation-active #gpsBadge.badge-bad { display: inline-flex !important; }

/* ══ ÉCRAN FIN DE PARCOURS ═══════════════════════════════════════════════════
   z-index: 1000 · au-dessus de tout
   ════════════════════════════════════════════════════════════════════════════ */
.arrival-premium {
  display: none;
  position: fixed !important;
  inset: 0 !important;
  z-index: 1000 !important;
  background: rgba(0,0,0,.52);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.arrival-premium.visible {
  display: flex;
  animation: gpsFadeIn .4s ease;
}
@keyframes gpsFadeIn { from{opacity:0} to{opacity:1} }
.arrival-premium-card {
  background: #fff;
  border-radius: 28px;
  padding: 32px 28px 28px;
  max-width: 360px;
  width: 100%;
  text-align: center;
  box-shadow: 0 24px 80px rgba(0,0,0,.22);
  animation: gpsScaleIn .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes gpsScaleIn { from{opacity:0;transform:scale(.85)} to{opacity:1;transform:scale(1)} }
.arrival-premium-emoji { font-size:52px; line-height:1; margin-bottom:12px; }
.arrival-premium-title { font-size:22px; font-weight:900; color:#0a4f7a; margin-bottom:6px; letter-spacing:-.03em; }
.arrival-premium-sub { font-size:13px; color:#64748b; line-height:1.5; margin-bottom:20px; }
.arrival-premium-stats { display:flex; justify-content:center; gap:24px; margin-bottom:24px; padding:14px 0; border-top:1px solid #f1f5f9; border-bottom:1px solid #f1f5f9; }
.arrival-stat { display:flex; flex-direction:column; align-items:center; gap:2px; }
.arrival-stat-value { font-size:18px; font-weight:900; color:#0a4f7a; }
.arrival-stat-label { font-size:10px; font-weight:700; color:#94a3b8; text-transform:uppercase; letter-spacing:.05em; }
.btn-rate-ride { display:block; width:100%; background:linear-gradient(135deg,#ff7a00,#ff9a2f); color:#fff; border:none; border-radius:16px; padding:14px 20px; font-size:15px; font-weight:900; cursor:pointer; box-shadow:0 8px 24px rgba(255,122,0,.32); transition:transform .15s; margin-bottom:10px; }
.btn-rate-ride:active { transform:scale(.97); }
.btn-new-ride { display:block; width:100%; background:#f1f5f9; color:#475569; border:none; border-radius:14px; padding:12px 20px; font-size:13px; font-weight:700; cursor:pointer; transition:background .15s; }
.btn-new-ride:active { background:#e2e8f0; }
.arrival-premium-help { margin-top:12px; font-size:11px; line-height:1.35; font-weight:800; color:#94a3b8; }

/* ── Feedback tactile global ─────────────────────────────────────────────── */
.btn:active, .map-fab:active, .map-mode-fab:active, .map-sound-fab:active {
  transform: scale(.95) !important;
  transition: transform .1s ease !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v68 — Nettoyage boutons carte · Message hors-parcours visible
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── "Voir le parcours" : centré en bas de la carte ─────────────────────── */
.map-fit-group {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;
}
.map-fit-overlay {
  background: rgba(255, 255, 255, .95) !important;
  color: var(--text) !important;
  padding: 10px 24px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .15) !important;
  border: 1px solid rgba(0, 0, 0, .05) !important;
  cursor: pointer;
  white-space: nowrap;
  backdrop-filter: blur(8px);
}
.map-fit-overlay:active {
  transform: scale(.96) !important;
}

/* Nouveau bouton "Voir tous les parcours" secondaire v132 */
.btn-all-routes-secondary {
  width: 100%;
  height: 46px;
  background: #f0f9ff;
  color: var(--ocean);
  border: 1.5px solid var(--ocean);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-weight: 700;
  margin-top: 10px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-all-routes-secondary:active {
  background: #e0f2fe;
  transform: scale(0.98);
}

/* ─── Vue Tous les parcours v136 Premium ─── */
.hidden { display: none !important; }

.all-routes-page {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #f7f9fc;
  overflow-y: auto;
  font-family: Poppins, Arial, sans-serif;
  padding-bottom: 28px;
  animation: slideInUp 0.3s ease;
}
@keyframes slideInUp {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}

.all-routes-header-premium {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  padding: 22px 18px 18px;
  border-bottom: 1px solid #e8eef6;
  display: flex;
  align-items: center;
  gap: 14px;
}

.all-routes-back {
  width: 46px;
  height: 46px;
  border: none;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 8px 20px rgba(15,23,42,.08);
  font-size: 22px;
  color: #132033;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.all-routes-header-premium h1 {
  margin: 0;
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
  color: #132033;
}

.all-routes-header-premium p {
  margin: 4px 0 0;
  font-size: 13px;
  color: #667085;
  font-weight: 500;
}

.all-routes-list-premium {
  padding: 18px 14px 24px;
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.route-card-premium {
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(15,23,42,.08);
  border: 1px solid #f1f5f9;
}

.route-image-wrap-premium {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #eaf1f8;
  position: relative;
}

.route-image-wrap-premium img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.route-card-content-premium {
  padding: 16px;
}

.route-card-premium h2 {
  margin: 0 0 10px;
  font-size: 19px;
  line-height: 1.2;
  font-weight: 800;
  color: #132033;
}

.route-meta-premium {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.route-meta-premium span {
  font-size: 12px;
  font-weight: 700;
  color: #344054;
  background: #f1f6ff;
  border: 1px solid #d8e7fb;
  padding: 6px 12px;
  border-radius: 999px;
}
.route-meta-premium .route-type-chip{
  display:inline-flex;
  align-items:center;
  color:#066a2d;
  background:linear-gradient(135deg,#eaf8ee,#d9f0df);
  border-color:rgba(22,163,74,.18);
  padding:5px 12px 5px 8px;
  gap:7px;
}
.route-meta-premium .route-type-icon{width:30px;height:20px;}
.route-meta-premium .route-type-chip .route-type-label{
  background:transparent;
  border:0;
  padding:0;
  border-radius:0;
  color:inherit;
  font-size:inherit;
  font-weight:inherit;
}

.route-desc-premium {
  margin: 0 0 16px;
  font-size: 13.5px;
  line-height: 1.5;
  color: #667085;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.route-btn-premium {
  width: 100%;
  height: 48px;
  border-radius: 14px;
  border: 1.5px solid #1780EE;
  background: #fff;
  color: #1780EE;
  font-size: 14px;
  font-weight: 800;
  font-family: Poppins, Arial, sans-serif;
  cursor: pointer;
  transition: all 0.2s;
}

.route-btn-premium:active {
  background: #f0f7ff;
  transform: scale(.98);
}



/* ── Bouton "Lancer la navigation" : pleine largeur ─────────────────────── */
#btnLaunchRoute {
  width: 100% !important;
  display: block !important;
}

/* ── Texte légal : directement sous le bouton ───────────────────────────── */
.ride-disclaimer-inline {
  margin-top: 8px !important;
  text-align: center !important;
}

/* ── Message hors-parcours : toujours visible sous le header ────────────── */
body.navigation-active .offroute-alert.visible {
  position: fixed !important;
  top: calc(var(--gps-safe-top, 0px) + var(--gps-header-h, 80px) + 10px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 890 !important;
  margin: 0 !important;
  border-radius: 14px !important;
  display: flex !important;
}

/* ── Boutons flottants (FABs) : alignés à droite, espacement régulier ───── */
body.navigation-active .map-fab {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 12px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
}
body.navigation-active .map-mode-fab {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 62px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
}
body.navigation-active .map-sound-fab {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 112px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  padding: 0 !important;
  justify-content: center !important;
}
body.navigation-active .map-sound-fab .sound-label { display: none !important; }
body.navigation-active .compass-fab {
  position: fixed !important;
  top: calc(var(--gps-safe-top, 0px) + var(--gps-header-h, 80px) + 8px) !important;
  right: 12px !important;
  z-index: 860 !important;
  bottom: auto !important;
  left: auto !important;
}
body.navigation-active .speed-display {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 12px) !important;
  left: 12px !important;
  z-index: 860 !important;
  top: auto !important;
  right: auto !important;
}

/* ── Masquer le bouton GPS footer (doublon supprimé côté HTML) ───────────── */
#btnFooterGps { display: none !important; }

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v69 — Boutons sous carte alignés sur une ligne
   ═══════════════════════════════════════════════════════════════════════════ */

/* Ligne principale v149 : ⋯ + Voir tous + Lancer */
.map-actions-row {
  display: flex;
  align-items: center;
  gap: 10px; /* v164: Augmenter l'espacement entre les boutons */
  width: 100%;
  flex-wrap: nowrap;
  padding: 0 16px; /* v164: Ajouter un padding latéral pour les boutons */
}

/* Bouton ⋯ : compact et fixe */
.map-actions-row .more-actions-wrap {
  flex-shrink: 0;
}

/* Bouton Voir tous les parcours : centré */
#btnAllRoutes.route-btn-premium {
  flex: 1.2;
  min-width: 0;
  white-space: nowrap;
  font-size: 13px !important; /* v164: Taille de police harmonisée */
  padding: 0 12px !important; /* v164: Ajuster le padding horizontal */
  height: 48px; /* v164: Hauteur harmonisée */
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff; /* v164: Fond blanc */
  border: 1.5px solid var(--ocean-mid); /* v164: Bordure bleue fine */
  color: var(--ocean); /* v164: Texte bleu */
  border-radius: 12px; /* v164: Arrondi */
  box-shadow: var(--shadow-soft); /* v164: Ombre légère */
}

/* Bouton Lancer : à droite */
.btn-launch {
  flex: 1.5;
  min-width: 0;
  width: auto !important;
  font-size: 13px !important;
  padding: 0 12px !important; /* v164: Ajuster le padding pour le bouton Lancer */
  height: 48px;
  border-radius: 12px; /* v164: Arrondi */
}

/* v163: Supprimer les media queries spécifiques pour la taille de police, car elle est maintenant définie plus haut */

/* Texte légal : pleine largeur, sous la ligne de boutons */
.map-actions .ride-disclaimer-inline {
  width: 100% !important;
  max-width: 100% !important;
  margin-top: 8px !important;
  text-align: center !important;
}

/* Supprimer l'ancien grid sur map-actions */
.map-actions {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  margin-top: 10px;
  align-items: stretch;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v70 — Satellite dans footer · Message hors-parcours discret
   ═══════════════════════════════════════════════════════════════════════════ */

/* Bouton Satellite : overlay carte, entre Son et GPS (v103) */
body.navigation-active .map-mode-fab {
  display: flex !important;
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 66px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.95) !important;
  border: 1px solid rgba(10,79,122,0.15) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
  justify-content: center !important;
  align-items: center !important;
  font-size: 18px !important;
}

/* Décaler le bouton Son un cran plus haut pour laisser la place au Satellite */
body.navigation-active .map-sound-fab {
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 120px) !important;
}

/* Masquer le bouton Satellite du footer (redondant) */
body.navigation-active #btnFooterSatellite {
  display: none !important;
}

/* Message hors-parcours : décalé sous le header (header ~80px + safe-area + 16px marge) */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + 96px) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v71 — Message hors-parcours plus bas · Son au-dessus du GPS
   ═══════════════════════════════════════════════════════════════════════════ */

/* Message hors-parcours : 130px du haut (header + marge confortable) */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + 130px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 890 !important;
  position: fixed !important;
  margin: 0 !important;
  border-radius: 14px !important;
  display: flex !important;
}

/* Bouton Son : retiré du footer, placé tout en haut de la pile (v103) */
body.navigation-active .map-sound-fab {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 120px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  padding: 0 !important;
  justify-content: center !important;
  display: flex !important;
}
body.navigation-active .map-sound-fab .sound-label { display: none !important; }

/* Bouton GPS bleu : juste au-dessus du footer */
body.navigation-active .map-fab {
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 12px) !important;
  right: 12px !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
}

/* Masquer les boutons non pertinents en mode navigation */
body.navigation-active #btnFooterSound,
body.navigation-active #btnFooterSatellite,
body.navigation-active #btnFooterFit {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v165 — Footer : Bouton 'Voir le parcours' intégré
   ═══════════════════════════════════════════════════════════════════════════ */

.nav-footer-btn-view {
  background: var(--ocean); /* Fond bleu */
  border: none; /* Pas de bordure */
  color: #fff; /* Texte blanc */
  font-size: 12px; /* Taille de police */
  font-weight: 700;
  padding: 0 12px; /* Padding ajusté */
  height: 40px; /* Hauteur */
  border-radius: 10px; /* Arrondi */
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-shrink: 0;
  flex-grow: 1;
  max-width: 140px; /* v165: Largeur ajustée pour s'intégrer */
  box-shadow: var(--shadow-soft); /* Ombre légère */
}

.nav-footer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-grow: 1;
  justify-content: center; /* v165: Centrer les boutons dans le footer */
  padding: 0 12px; /* v165: Ajouter un padding latéral */
}

.nav-footer-btn-quit {
  flex-grow: 0;
  flex-shrink: 0;
  height: 40px; /* v165: Hauteur harmonisée */
  border-radius: 10px; /* v165: Arrondi harmonisé */
  font-size: 12px; /* v165: Taille de police harmonisée */
  padding: 0 12px; /* v165: Padding ajusté */
}

.nav-footer-speed {
  flex-grow: 0;
  flex-shrink: 0;
  height: 40px; /* v165: Hauteur harmonisée */
  border-radius: 10px; /* v165: Arrondi harmonisé */
  padding: 4px 10px; /* v165: Padding ajusté */
}

/* Masquer l'ancien map-fit-overlay qui était flottant */
.map-fit-group {
  display: none !important;
}



/* Badge km/h dans le footer */
.nav-footer-speed {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(23,128,238,0.12);
  border: 1.5px solid rgba(23,128,238,0.25);
  border-radius: 10px;
  padding: 4px 8px;
  min-width: 44px;
  line-height: 1.1;
}
.nav-footer-speed span:first-child {
  font-size: 15px;
  font-weight: 700;
  color: #1780ee;
  line-height: 1;
}
.nav-footer-speed-unit {
  font-size: 9px;
  color: #64748b;
  font-weight: 500;
  letter-spacing: 0.03em;
}

/* Masquer le bouton Son flottant sur la carte (maintenant dans le footer) */
body.navigation-active .map-sound-fab {
  display: none !important;
}

/* Remettre le bouton GPS bleu juste au-dessus du footer (sans le Son au-dessus) */
body.navigation-active .map-fab {
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 12px) !important;
  right: 12px !important;
  position: fixed !important;
  z-index: 860 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v74 — Badge vitesse carte masqué · Alerte visible · GPS remonté
   ═══════════════════════════════════════════════════════════════════════════ */

/* 1. Masquer le badge vitesse flottant sur la carte (présent dans le footer) */
body.navigation-active #speedDisplay {
  display: none !important;
}

/* 2. Supprimer le header fantôme : le gps-banner original (v65) avait
      background:transparent mais occupait de l'espace — on force 0 hauteur
      sur l'ancienne règle et on laisse la v64 (lignes 1051+) prendre le dessus */
body.navigation-active .gps-banner {
  min-height: 0 !important;
}

/* 3. Message hors-parcours : sous le header glassmorphism (header ~80px + safe-area + 14px) */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + var(--gps-header-h, 80px) + 14px) !important;
  position: fixed !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 890 !important;
  margin: 0 !important;
  border-radius: 14px !important;
  display: flex !important;
}

/* 4. Bouton GPS bleu : remonté de 20px supplémentaires au-dessus du footer */
body.navigation-active .map-fab {
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 20px) !important;
  right: 12px !important;
  position: fixed !important;
  z-index: 860 !important;
  left: auto !important;
  top: auto !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v75 — Alerte plus bas · nextTurnPanel sans fond quand vide
   ═══════════════════════════════════════════════════════════════════════════ */

/* nextTurnPanel : aucun fond, aucune ombre quand il est vide (pas .visible) */
body.navigation-active #nextTurnPanel:not(.visible) {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  pointer-events: none !important;
  height: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Message hors-parcours : encore plus bas (header ~80px + 60px de marge) */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + var(--gps-header-h, 80px) + 60px) !important;
  position: fixed !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 24px) !important;
  max-width: 420px !important;
  z-index: 890 !important;
  margin: 0 !important;
  border-radius: 14px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v78 — Masquer boutons Voir le parcours et GPS hors navigation
   ═══════════════════════════════════════════════════════════════════════════ */

/* Masquer le bouton "Voir le parcours" quand la navigation n'est pas active */
body:not(.navigation-active) .map-fit-overlay,
body:not(.navigation-active) #btnFitOverlay {
  display: none !important;
}

/* Masquer le bouton GPS bleu rond quand la navigation n'est pas active */
body:not(.navigation-active) .map-fab,
body:not(.navigation-active) #mapRecenterFab {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v79 — Suppression définitive encadré fantôme en navigation
   ═══════════════════════════════════════════════════════════════════════════ */

/* Masquer le titre "Votre parcours en direct" + badge Navigation */
body.navigation-active #mapSection > .section-head {
  display: none !important;
}

/* Masquer les badges GPS inactif / Trace en attente / Vélo conseillé */
body.navigation-active #mapSection > .badges {
  display: none !important;
}

/* Masquer le profil d'élévation en navigation */
body.navigation-active #elevationWrap {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v95 — Bouton Son : overlay carte, navigation active uniquement
   ═══════════════════════════════════════════════════════════════════════════ */

/* Masquer le bouton son dans tous les contextes hors navigation */
body:not(.navigation-active) .map-sound-fab {
  display: none !important;
}

/* Afficher le bouton son uniquement en navigation, tout en haut de la pile (v103) */
body.navigation-active .map-sound-fab {
  display: flex !important;
  position: fixed !important;
  bottom: calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 120px) !important;
  right: 12px !important;
  left: auto !important;
  top: auto !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  padding: 0 !important;
  justify-content: center !important;
  align-items: center !important;
  background: rgba(255,255,255,0.95) !important;
  border: 1px solid rgba(10,79,122,0.15) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
  z-index: 860 !important;
}
body.navigation-active .map-sound-fab.sound-on {
  background: rgba(10,79,122,0.90) !important;
  color: #fff !important;
  border-color: transparent !important;
}
/* Masquer le label texte ON/OFF en navigation (icône seule) */
body.navigation-active .map-sound-fab .sound-label {
  display: none !important;
}
/* Masquer le bouton son du footer (redondant avec l'overlay) */
body.navigation-active #btnFooterSound {
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v96 — Corrections UX navigation
   ═══════════════════════════════════════════════════════════════════════════ */

/* 1. Supprimer le bloc blanc vide (section-head + badges) sous le bandeau en navigation */
body.navigation-active #mapSection > .section-head,
body.navigation-active #mapSection > .badges {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* 2. Header navigation : fond blanc propre (supprimer le bleu résiduel) */
body.navigation-active .gps-banner {
  background: rgba(255,255,255,0.97) !important;
  border: 1px solid rgba(10,79,122,0.10) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.10) !important;
}

/* 3. Texte header : moins gros, moins gras */
body.navigation-active .gps-title {
  font-size: 17px !important;
  font-weight: 700 !important;
  letter-spacing: -.02em !important;
}
body.navigation-active .gps-sub {
  font-size: 11px !important;
  font-weight: 500 !important;
}
body.navigation-active .gps-banner.turn-imminent .gps-title {
  font-size: 20px !important;
  font-weight: 800 !important;
}
body.navigation-active .gps-direction-icon {
  font-size: 24px !important;
  min-width: 32px !important;
}

/* 4. Bouton "Voir l'itinéraire" dans le footer : texte au lieu d'icône */
#btnFooterFit {
  width: auto !important;
  padding: 0 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}
#btnFooterFit::before {
  content: "Voir l'itinéraire" !important;
  font-size: 11px !important;
}

/* Masquer l'emoji 🗺️ du bouton Fit (remplacé par le texte ci-dessus) */
#btnFooterFit {
  font-size: 0 !important; /* cache l'emoji */
  color: #0a4f7a !important;
}
#btnFooterFit::before {
  font-size: 11px !important;
  color: #0a4f7a !important;
}

/* 5. Bouton Quitter : plus petit pour laisser de la place */
.nav-footer-btn-quit {
  flex: 0.7 !important;
  padding: 0 10px !important;
  font-size: 12px !important;
}

/* 6. Supprimer le bouton "En savoir plus sur la balade" et son contenu */
.detail-toggle-wrap,
#detailToggleBtn,
#detailSection {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v97 — 8 corrections UX navigation
   ═══════════════════════════════════════════════════════════════════════════ */

/* 1. Rectangle blanc résiduel : masquer progress-wrap et tout bloc non-carte */
body.navigation-active .progress-wrap,
body.navigation-active .elevation-wrap {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}

/* 2. Message hors-parcours : compact, juste sous le header (pas 60px trop bas) */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + 70px) !important;
  padding: 6px 12px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  min-height: 0 !important;
  line-height: 1.3 !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
}

/* 3. Bloc direction : padding réduit, texte allégé */
body.navigation-active .gps-banner {
  padding: 10px 14px !important;
}
body.navigation-active .gps-title {
  font-size: 15px !important;
  font-weight: 700 !important;
}
body.navigation-active .gps-sub {
  font-size: 10px !important;
  font-weight: 500 !important;
  margin-top: 2px !important;
}
body.navigation-active .gps-direction-icon {
  font-size: 22px !important;
  min-width: 28px !important;
}
body.navigation-active .gps-banner.turn-imminent {
  padding: 12px 16px !important;
}
body.navigation-active .gps-banner.turn-imminent .gps-title {
  font-size: 18px !important;
  font-weight: 800 !important;
}

/* 4. Footer bas : padding et stats réduits */
body.navigation-active .nav-footer-float {
  padding: 6px 12px 6px !important;
}
body.navigation-active .nav-footer-stats {
  margin-bottom: 4px !important;
}
body.navigation-active .nav-footer-stat-value {
  font-size: 13px !important;
  font-weight: 800 !important;
}
body.navigation-active .nav-footer-stat-label {
  font-size: 7px !important;
}
body.navigation-active .nav-footer-divider {
  height: 18px !important;
}
body.navigation-active .nav-footer-progress-track {
  margin-bottom: 4px !important;
}
body.navigation-active .nav-footer-btn {
  height: 30px !important;
  font-size: 11px !important;
}
body.navigation-active .nav-footer-btn-icon {
  width: 30px !important;
  font-size: 14px !important;
}
body.navigation-active .nav-footer-actions {
  gap: 5px !important;
}

/* 7. Badge GPS overlay : entre bouton son (footer+72px+44px) et bouton GPS (footer+12px) */
.gps-badge-overlay {
  display: none;
  position: fixed;
  right: 12px;
  z-index: 1000; /* Doit être au-dessus des FABs */
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 9px;
  font-weight: 700;
  white-space: nowrap;
  pointer-events: none;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
  letter-spacing: 0.01em;
}
/* Visible uniquement en navigation, entre GPS (footer+20px) et Son (footer+72px+44px) */
/* Règle obsolète v99 remplacée par v108 en fin de fichier */
.gps-badge-overlay.gps-badge-active {
  background: rgba(16,185,129,0.92);
  color: #fff;
  border: 1px solid rgba(16,185,129,0.25);
}
.gps-badge-overlay.gps-badge-weak {
  background: rgba(245,158,11,0.92);
  color: #fff;
  border: 1px solid rgba(245,158,11,0.25);
}
.gps-badge-overlay.gps-badge-off {
  background: rgba(100,116,139,0.80);
  color: #fff;
  border: 1px solid rgba(100,116,139,0.20);
}

/* 8. Zéro doublon : masquer #gpsBadge en navigation (remplacé par overlay) */
body.navigation-active #gpsBadge {
  display: none !important;
}

/* v108 — Badge GPS overlay repositionné sous le header */
body.navigation-active .gps-badge-overlay {
  display: flex !important;
  bottom: calc(var(--gps-safe-bottom) + 124px + 10px) !important; /* Aligné avec le bouton GPS bleu (124px) + centrage visuel */
  left: 12px !important; /* En bas à gauche */
  right: auto !important;
  top: auto !important;
  background: rgba(255,255,255,0.95);
  color: #1e293b;
  border: 1px solid rgba(0,0,0,0.1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 15px;
}
.gps-badge-overlay.gps-badge-active { background: #d4edda !important; color: #155724 !important; border-color: #c3e6cb !important; }
.gps-badge-overlay.gps-badge-weak { background: #fff3cd !important; color: #856404 !important; border-color: #ffeeba !important; }
.gps-badge-overlay.gps-badge-off { background: #f8d7da !important; color: #721c24 !important; border-color: #f5c6cb !important; }



/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v166-BnBike — corrections ciblées navigation
   - alerte hors parcours plus discrète
   - bouton carte explicite Plan / Sat
   - footer navigation plus compact
   - meilleure lisibilité du tracé BnBike
   ═══════════════════════════════════════════════════════════════════════════ */
body.navigation-active .offroute-alert.visible {
  top: calc(var(--gps-safe-top, 0px) + var(--gps-header-h, 80px) + 8px) !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: auto !important;
  max-width: calc(100% - 42px) !important;
  min-height: 0 !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  background: rgba(255,247,237,.94) !important;
  border: 1px solid rgba(251,146,60,.32) !important;
  color: #9a3412 !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  line-height: 1.15 !important;
  box-shadow: 0 6px 18px rgba(15,23,42,.12) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  pointer-events: none !important;
}

body.navigation-active .offroute-alert.pulse-alert {
  animation: none !important;
}

.map-mode-fab {
  width: 54px !important;
  height: 44px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  padding: 0 8px !important;
  white-space: nowrap !important;
}

body.navigation-active .map-mode-fab {
  width: 54px !important;
  height: 44px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  color: #0a4f7a !important;
}

body.navigation-active .nav-footer-float {
  width: calc(100% - 30px) !important;
  max-width: 390px !important;
  bottom: calc(var(--gps-safe-bot, 0px) + 8px) !important;
  padding: 6px 12px 6px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.76) !important;
  backdrop-filter: blur(16px) saturate(1.15) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.15) !important;
}

body.navigation-active .nav-footer-stats {
  margin-bottom: 4px !important;
}

body.navigation-active .nav-footer-stat-value {
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

body.navigation-active .nav-footer-stat-label {
  font-size: 6.5px !important;
  letter-spacing: .05em !important;
}

body.navigation-active .nav-footer-divider {
  height: 16px !important;
}

body.navigation-active .nav-footer-progress-track {
  height: 3px !important;
  margin-bottom: 5px !important;
}

body.navigation-active .nav-footer-actions {
  gap: 6px !important;
}

body.navigation-active .nav-footer-btn {
  height: 30px !important;
  min-height: 30px !important;
  border-radius: 11px !important;
  font-size: 11px !important;
}

body.navigation-active .nav-footer-btn-view {
  flex: 1.35 !important;
}

body.navigation-active .nav-footer-speed {
  height: 30px !important;
  min-width: 50px !important;
  padding: 0 8px !important;
  border-radius: 11px !important;
}

body.navigation-active .nav-footer-speed span:first-child {
  font-size: 15px !important;
}

body.navigation-active .nav-footer-speed-unit {
  font-size: 7px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BnBike GPS v168 — lisibilité satellite, trace GPX complète, boutons mobile
   ═══════════════════════════════════════════════════════════════════════════ */

/* Header GPS plus lisible uniquement en mode Satellite */
body.navigation-active.map-satellite-active .gps-banner {
  background: rgba(255,255,255,0.96) !important;
  border: 1.5px solid rgba(255,255,255,0.92) !important;
  box-shadow: 0 10px 38px rgba(0,0,0,.26), 0 1px 0 rgba(255,255,255,.95) inset !important;
  backdrop-filter: blur(30px) saturate(1.55) !important;
  -webkit-backdrop-filter: blur(30px) saturate(1.55) !important;
}
body.navigation-active.map-satellite-active .gps-title {
  color: #073f63 !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.65) !important;
}
body.navigation-active.map-satellite-active .gps-sub {
  color: #334155 !important;
  font-weight: 800 !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.70) !important;
}
body.navigation-active.map-satellite-active .gps-direction-icon {
  color: #0f7fe8 !important;
  text-shadow: 0 2px 8px rgba(255,255,255,.85) !important;
}
body.navigation-active.map-satellite-active .gps-banner.turn-imminent {
  background: rgba(255,255,255,0.98) !important;
  box-shadow: 0 12px 44px rgba(0,0,0,.30), 0 0 0 1px rgba(23,128,238,.18) inset !important;
}

/* Boutons sous carte : version mobile-first, lisible, sans débordement */
.map-actions {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 10px !important;
  margin-top: 12px !important;
  position: relative !important;
}
.map-actions-row {
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) !important;
  grid-template-areas:
    "more all"
    "launch launch" !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 0 14px !important;
  box-sizing: border-box !important;
  align-items: stretch !important;
}
.map-actions-row .more-actions-wrap {
  grid-area: more !important;
  width: 48px !important;
  min-width: 48px !important;
  position: relative !important;
}
.map-actions-row .btn-more {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  border-radius: 16px !important;
  background: rgba(255,255,255,.96) !important;
  border: 1.5px solid rgba(23,128,238,.20) !important;
  box-shadow: 0 8px 20px rgba(10,79,122,.10) !important;
  color: var(--ocean) !important;
}
#btnAllRoutes.route-btn-premium {
  grid-area: all !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 48px !important;
  padding: 0 14px !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  font-size: clamp(12px, 3.45vw, 14px) !important;
  line-height: 1.05 !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  border: 1.5px solid rgba(23,128,238,.72) !important;
  color: var(--ocean) !important;
  box-shadow: 0 8px 20px rgba(10,79,122,.10) !important;
}
.map-actions-row #btnLaunchRoute.btn-launch {
  grid-area: launch !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 54px !important;
  padding: 0 18px !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: normal !important;
  text-align: center !important;
  font-size: clamp(15px, 4.2vw, 18px) !important;
  line-height: 1.08 !important;
  border-radius: 18px !important;
  box-shadow: 0 14px 28px rgba(22,163,74,.24) !important;
}
.map-actions .ride-disclaimer-inline {
  width: auto !important;
  margin: 0 18px 0 !important;
  font-size: clamp(13px, 3.7vw, 15px) !important;
  line-height: 1.35 !important;
}
.more-actions-menu {
  left: 14px !important;
  right: 14px !important;
  bottom: 112px !important;
  transform: none !important;
  width: auto !important;
  max-width: none !important;
}

@media (max-width: 340px) {
  .map-actions-row {
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 8px !important;
    padding: 0 10px !important;
  }
  .map-actions-row .more-actions-wrap,
  .map-actions-row .btn-more {
    width: 44px !important;
    min-width: 44px !important;
    height: 44px !important;
  }
  #btnAllRoutes.route-btn-premium { height: 44px !important; font-size: 12px !important; padding: 0 8px !important; }
  .map-actions-row #btnLaunchRoute.btn-launch { height: 50px !important; font-size: 15px !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   BnBike GPS v169 — corrections ciblées demandées
   - remonte uniquement le footer de navigation active
   - repositionne uniquement le bouton Plan/Sat de la carte principale
   - ne touche pas aux boutons à droite en navigation active
   ═══════════════════════════════════════════════════════════════════════════ */

/* Navigation active : remonter légèrement le bloc blanc du bas pour laisser
   l'attribution Leaflet visible. Ne modifie PAS la colonne de boutons à droite. */
body.navigation-active .nav-footer-float {
  bottom: calc(var(--gps-safe-bot, 0px) + 30px) !important;
}

/* Carte principale uniquement, avant navigation : bouton Plan/Sat mieux placé
   en bas à droite de la carte, au-dessus du bouton de géolocalisation. */
body:not(.navigation-active) #mapFrame .map-mode-fab {
  position: absolute !important;
  right: 14px !important;
  bottom: 72px !important;
  left: auto !important;
  top: auto !important;
  z-index: 510 !important;
}

/* Carte principale : préserver la place entre Plan/Sat et géolocalisation. */
body:not(.navigation-active) #mapFrame .map-gps-fab {
  right: 14px !important;
  bottom: 14px !important;
}

/* ─── Aperçu dépliable des parcours — page Tous les parcours v176 ─── */
.route-preview-toggle {
  width: 100%;
  height: 42px;
  margin-top: 10px;
  border-radius: 14px;
  border: 1.5px solid #d8e7fb;
  background: linear-gradient(180deg, #ffffff, #f7fbff);
  color: #0C5FBF;
  font-family: Poppins, Arial, sans-serif;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
}

.route-preview-toggle:active {
  transform: scale(.985);
}

.route-preview-toggle.is-open {
  background: #eef7ff;
  border-color: #1780EE;
  color: #132033;
}

.route-preview-panel {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  margin-top: 0;
  transform: translateY(-4px);
  transition: max-height .32s ease, opacity .22s ease, margin-top .22s ease, transform .22s ease;
}

.route-preview-panel.open {
  max-height: 340px;
  opacity: 1;
  margin-top: 12px;
  transform: translateY(0);
}

.route-preview-map {
  width: 100%;
  height: 190px;
  border-radius: 18px;
  overflow: hidden;
  background: #eaf3ff;
  border: 1px solid #d8e7fb;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}

.route-preview-map .leaflet-control-container {
  display: none;
}

.route-preview-caption {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-top: 8px;
  padding: 0 2px;
  color: #132033;
  font-size: 12px;
}

.route-preview-caption strong {
  font-weight: 800;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.route-preview-caption span {
  flex: 0 0 auto;
  color: #667085;
  font-weight: 700;
}

.route-preview-loading,
.route-preview-error {
  border: 1px dashed #c9dcf3;
  border-radius: 16px;
  background: #f7fbff;
  color: #667085;
  font-size: 13px;
  font-weight: 700;
  padding: 18px;
  text-align: center;
}


/* ═══════════════════════════════════════════════════════════════════════════
   GPS v180 — Auto-follow premium, feedback recentrer, stabilité visuelle
   ═══════════════════════════════════════════════════════════════════════════ */
.gps-follow-toast{
  position:absolute;
  left:50%;
  top:calc(var(--gps-safe-top, 0px) + 78px);
  transform:translate(-50%, -8px);
  z-index:3800;
  max-width:min(86vw, 360px);
  padding:9px 14px;
  border-radius:999px;
  background:rgba(10, 31, 68, .88);
  color:#fff;
  font-size:12px;
  font-weight:800;
  letter-spacing:-.01em;
  box-shadow:0 10px 30px rgba(0,0,0,.22);
  backdrop-filter:blur(12px);
  opacity:0;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease;
}
.gps-follow-toast.visible{
  opacity:1;
  transform:translate(-50%, 0);
}
#mapRecenterFab.is-following{
  background:rgba(14,165,233,.96) !important;
  color:#fff !important;
  box-shadow:0 8px 24px rgba(14,165,233,.42) !important;
}
#mapRecenterFab.is-paused{
  background:#fff !important;
  color:#1780EE !important;
  box-shadow:0 0 0 4px rgba(23,128,238,.22), 0 12px 28px rgba(23,128,238,.22) !important;
  animation:recenterPulseV180 1.5s ease-in-out infinite;
}
#mapRecenterFab.is-recentering{
  background:#FF7A00 !important;
  color:#fff !important;
  box-shadow:0 0 0 4px rgba(255,122,0,.18), 0 12px 28px rgba(255,122,0,.28) !important;
}
@keyframes recenterPulseV180{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.045)}
}
body.gps-follow-paused .gps-banner{
  border-color:rgba(255,122,0,.28) !important;
}

/* ─── Splash BnBike avec texte de chargement seul (v190) ─────────────── */
body.has-splash{
  overflow: hidden;
  overscroll-behavior: none;
}
.app-splash{
  position: fixed;
  inset: 0;
  z-index: 99999;
  min-height: 100svh;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #043f93;
  opacity: 1;
  visibility: visible;
  transition: opacity .65s ease, visibility .65s ease;
  font-family: inherit;
}
.app-splash.is-hidden{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.app-splash-bg{
  position: absolute;
  inset: 0;
  background-image: url('../img/splash-bnbike-bg.jpg');
  background-size: cover;
  background-position: center center;
  transform: scale(1.015);
  filter: saturate(1.06) contrast(1.03);
}
.app-splash-shade{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 31%, rgba(255,255,255,.16), rgba(255,255,255,0) 28%),
    linear-gradient(180deg, rgba(0,46,112,.10) 0%, rgba(0,33,86,.02) 45%, rgba(0,17,51,.42) 100%);
}
.app-splash-content{
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  text-align: center;
  color: #fff;
  padding: 0 20px max(10svh, 72px);
  box-sizing: border-box;
  transform: none;
  animation: splashContentIn .85s cubic-bezier(.2,.8,.2,1) both;
}
.app-splash-title{
  font-size: clamp(46px, 13vw, 74px);
  line-height: .95;
  font-weight: 900;
  letter-spacing: -.045em;
  text-shadow: 0 8px 24px rgba(0,0,0,.34);
}
.app-splash-subtitle{
  margin-top: 10px;
  color: #ff9500;
  font-size: clamp(22px, 6vw, 34px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: .015em;
  text-shadow: 0 4px 18px rgba(0,0,0,.34);
}
.app-splash-loading{
  margin-top: 16px;
  color: rgba(255,255,255,.98);
  font-size: clamp(20px, 5.2vw, 28px);
  font-weight: 900;
  letter-spacing: .015em;
  padding: 10px 18px;
  border-radius: 999px;
  background: rgba(0,28,78,.24);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 14px 34px rgba(0,35,90,.22);
  backdrop-filter: blur(8px);
  text-shadow: 0 4px 18px rgba(0,0,0,.34);
}
.loading-dots span{
  display: inline-block;
  animation: splashDotPulse 1.15s ease-in-out infinite;
}
.loading-dots span:nth-child(2){ animation-delay: .16s; }
.loading-dots span:nth-child(3){ animation-delay: .32s; }
@keyframes splashDotPulse{
  0%, 70%, 100%{ opacity: .25; transform: translateY(0); }
  35%{ opacity: 1; transform: translateY(-2px); }
}
@keyframes splashContentIn{
  from{ opacity:0; transform: translateY(calc(7svh + 18px)) scale(.98); }
  to{ opacity:1; transform: translateY(7svh) scale(1); }
}
@media (max-height: 720px){
  .app-splash-content{ padding-bottom: max(8svh, 56px); }
  @keyframes splashContentIn{
    from{ opacity:0; transform: translateY(calc(4svh + 14px)) scale(.98); }
    to{ opacity:1; transform: translateY(4svh) scale(1); }
  }
}
@media (prefers-reduced-motion: reduce){
  .loading-dots span,
  .app-splash-content{ animation: none !important; }
  .app-splash{ transition-duration: .25s; }
}



/* ═══════════════════════════════════════════════════════════════════════════
   GPS UI v192 — Contrôles Zoom + / Zoom - en navigation active
   Objectif : pile de boutons plus lisible, espacée, sans modifier le GPS.
   ═══════════════════════════════════════════════════════════════════════════ */
.map-zoom-fab{
  display:none;
  position:absolute;
  right:14px;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1.5px solid rgba(10,79,122,.14);
  background:linear-gradient(180deg,#ffffff 0%,#f4fbff 100%);
  color:#0a4f7a;
  box-shadow:0 8px 20px rgba(10,79,122,.18);
  font-size:28px;
  line-height:1;
  font-weight:700;
  align-items:center;
  justify-content:center;
  z-index:860;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.map-zoom-fab:active{
  transform:scale(.94);
  box-shadow:0 4px 12px rgba(10,79,122,.16);
}

body:not(.navigation-active) .map-zoom-fab{display:none!important}

body.navigation-active .map-sound-fab,
body.navigation-active .map-mode-fab,
body.navigation-active .map-zoom-fab,
body.navigation-active #mapRecenterFab{
  position:fixed!important;
  right:16px!important;
  left:auto!important;
  top:auto!important;
  width:50px!important;
  height:50px!important;
  border-radius:999px!important;
  z-index:880!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:0!important;
  border:1.5px solid rgba(10,79,122,.14)!important;
  box-shadow:0 8px 22px rgba(10,79,122,.18)!important;
}

/* Pile depuis le bas : Recentrer reste prioritaire, puis zoom, Plan/Sat, Son. */
body.navigation-active #mapRecenterFab{
  bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 18px)!important;
  background:#0ea5e9!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.45)!important;
}
body.navigation-active .map-zoom-out-fab{
  bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 76px)!important;
  background:rgba(255,255,255,.96)!important;
  color:#0a4f7a!important;
}
body.navigation-active .map-zoom-in-fab{
  bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 134px)!important;
  background:rgba(255,255,255,.96)!important;
  color:#0a4f7a!important;
}
body.navigation-active .map-mode-fab{
  bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 192px)!important;
  width:54px!important;
  height:46px!important;
  font-size:12px!important;
  font-weight:700!important;
  background:rgba(255,255,255,.96)!important;
  color:#0a4f7a!important;
}
body.navigation-active .map-sound-fab{
  bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 248px)!important;
  background:rgba(10,79,122,.90)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.35)!important;
}
body.navigation-active .map-sound-fab:not(.sound-on){
  background:rgba(255,255,255,.96)!important;
  color:#0a4f7a!important;
  border-color:rgba(10,79,122,.14)!important;
}
body.navigation-active .map-sound-fab .sound-label{display:none!important}

@media (max-height:680px){
  body.navigation-active .map-sound-fab,
  body.navigation-active .map-mode-fab,
  body.navigation-active .map-zoom-fab,
  body.navigation-active #mapRecenterFab{
    width:44px!important;
    height:44px!important;
    right:12px!important;
  }
  body.navigation-active #mapRecenterFab{bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 14px)!important}
  body.navigation-active .map-zoom-out-fab{bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 66px)!important}
  body.navigation-active .map-zoom-in-fab{bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 118px)!important}
  body.navigation-active .map-mode-fab{bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 170px)!important}
  body.navigation-active .map-sound-fab{bottom:calc(var(--gps-safe-bot, 0px) + var(--gps-footer-h, 95px) + 222px)!important}
}


/* v194 : stabilisation des encarts "Nos balades incontournables"
   Supprime l'effet de petit mouvement vertical/interne pendant le scroll. */
#routeList.cards-row{
  overflow-x:auto;
  overflow-y:hidden !important;
  align-items:stretch;
  overscroll-behavior-x:contain;
}
#routeList .card{
  align-self:stretch;
  transform:none;
}
#routeList .card:active{
  transform:none !important;
}
#routeList .card-appear,
#routeList .card-appear.visible{
  opacity:1 !important;
  transform:none !important;
}
#routeList .card-image img,
#routeList .card:hover .card-image img{
  transform:none !important;
}


/* v196 : comportement stable des encarts "Nos balades incontournables".
   Le swipe horizontal ne doit plus provoquer de micro-mouvement vertical ni d'effet rebond interne. */
#routeList.cards-row{
  overflow-y:hidden !important;
  align-items:stretch !important;
  scroll-behavior:auto;
}
#routeList .card{
  transition:border-color .18s ease, box-shadow .18s ease !important;
  will-change:auto !important;
  transform:none !important;
  contain:layout paint;
}
#routeList .card:active,
#routeList .card:hover{
  transform:none !important;
}
#routeList .card *{
  -webkit-tap-highlight-color:transparent;
}
#routeList .card-desc{
  overflow:hidden;
}


/* v197 : encarts "Nos balades incontournables" plus nets et clic stable */
#routeList .card{
  border-width:2.5px !important;
  border-style:solid !important;
  border-color:rgba(23,128,238,.30) !important;
  box-shadow:0 10px 24px rgba(15,58,91,.10) !important;
}
#routeList .card:nth-child(even){
  border-color:rgba(23,128,238,.30) !important;
}
#routeList .card.active{
  border-color:rgba(23,128,238,.58) !important;
  box-shadow:0 12px 28px rgba(23,128,238,.16) !important;
}
#routeList .btn-start-navigation-card{
  min-height:40px !important;
  margin-top:9px !important;
  padding:8px 13px !important;
  border-radius:14px !important;
  font-size:14px !important;
  background:linear-gradient(135deg,#5dff9b 0%,#20d66b 34%,#10b957 64%,#078b3a 100%) !important;
  box-shadow:0 10px 20px rgba(16,185,87,.30), inset 0 1px 0 rgba(255,255,255,.34) !important;
  letter-spacing:-.01em;
}
#routeList .btn-start-navigation-card:active{
  transform:none !important;
  box-shadow:0 7px 15px rgba(16,185,87,.24), inset 0 1px 0 rgba(255,255,255,.28) !important;
}


/* v200 — Bouton visible pour rejoindre le point de départ BnBike */
.btn-start-point-maps{
  width: calc(100% - 32px);
  margin: 10px 16px 0;
  min-height: 44px;
  border-radius: 14px;
  border: 1.5px solid rgba(23,128,238,.38);
  background: linear-gradient(180deg,#ffffff 0%,#eef7ff 100%);
  color: var(--ocean);
  font-family: Poppins, Arial, sans-serif;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .01em;
  box-shadow: 0 10px 22px rgba(23,128,238,.12);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: transform .12s ease, box-shadow .18s ease, background .18s ease;
}
.btn-start-point-maps:active{
  transform: scale(.98);
  background: #f4fbff;
}
body.navigation-active .btn-start-point-maps{
  display: none !important;
}


/* v202 — Ajustements visuels ciblés demandés
   - badges Durée (Journée / Demi-journée) alignés sur la hauteur des badges Ambiance
   - bloc "Votre parcours en direct" harmonisé avec l'encart bleu du haut
   - boutons des encarts "Nos balades incontournables" plus compacts et proportionnés
*/

/* Les badges "Journée" et "Demi-journée" doivent avoir la même hauteur que Tous / Océan / etc. */
.unified-quick-filters .quick-btn,
.filters.unified-quick-filters .filter-btn.quick-btn{
  min-height:0 !important;
  height:auto !important;
  padding:6px 10px !important;
  border-radius:999px !important;
  font-size:11px !important;
  line-height:1.15 !important;
  font-weight:600 !important;
  gap:6px !important;
  box-shadow:0 1px 3px rgba(0,0,0,.04) !important;
  transform:none !important;
}
.unified-quick-filters .quick-btn:active{
  transform:none !important;
}

/* Fond du bloc "Votre parcours en direct" aligné avec l'encart principal du haut */
body:not(.navigation-active) #mapSection.block{
  background:linear-gradient(160deg,#0a4f7a 0%,#1780ee 55%,#43a2ff 100%) !important;
  color:#fff !important;
  border:none !important;
  position:relative;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(10,79,122,.18) !important;
}
body:not(.navigation-active) #mapSection.block::before{
  content:'';
  position:absolute;
  inset:0;
  background:url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat;
  opacity:.12;
  pointer-events:none;
}
body:not(.navigation-active) #mapSection.block > *{
  position:relative;
  z-index:1;
}
body:not(.navigation-active) #mapSection .section-head h2{
  color:#fff !important;
  text-shadow:0 2px 10px rgba(0,0,0,.16);
}
body:not(.navigation-active) #mapSection .section-head .pill{
  background:linear-gradient(135deg,var(--sunset-dark),var(--sunset)) !important;
  color:#fff !important;
}

/* Boutons des encarts "Nos balades incontournables" : plus petits, mais toujours lisibles */
#routeList .route-actions{
  gap:7px !important;
  margin-top:14px !important;
}
#routeList .route-actions .btn{
  min-height:34px !important;
  padding:5px 8px !important;
  border-radius:10px !important;
  font-size:11px !important;
  line-height:1.1 !important;
  font-weight:800 !important;
  gap:5px !important;
}
#routeList .btn-start-navigation-card{
  min-height:36px !important;
  margin-top:8px !important;
  padding:7px 12px !important;
  border-radius:13px !important;
  font-size:13px !important;
  line-height:1.05 !important;
  gap:6px !important;
}

/* Le clic ne doit pas donner l'impression que le contour change d'état */
#routeList .card.active{
  border-color:rgba(23,128,238,.30) !important;
  box-shadow:0 10px 24px rgba(15,58,91,.10) !important;
}

/* v203 — Correction visuelle ciblée "Votre parcours en direct"
   Objectif : garder le header bleu premium, mais rendre le corps de l'encart blanc/lisible.
   Aucun impact en navigation active. */
body:not(.navigation-active) #mapSection.block{
  background:#ffffff !important;
  color:var(--ink, #0f172a) !important;
  border:1.5px solid rgba(23,128,238,.18) !important;
  box-shadow:0 14px 34px rgba(15,58,91,.10) !important;
  overflow:hidden !important;
  position:relative !important;
}
body:not(.navigation-active) #mapSection.block::before{
  content:'' !important;
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  top:0 !important;
  height:150px !important;
  background:
    linear-gradient(135deg, rgba(10,79,122,.94) 0%, rgba(23,128,238,.92) 58%, rgba(67,162,255,.86) 100%),
    url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat !important;
  opacity:1 !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block > *{
  position:relative !important;
  z-index:1 !important;
}
body:not(.navigation-active) #mapSection .section-head{
  margin-bottom:8px !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  color:#fff !important;
  text-shadow:0 2px 10px rgba(0,0,0,.16) !important;
}
body:not(.navigation-active) #mapSection .section-head .pill{
  background:linear-gradient(135deg,var(--sunset-dark, #f97316),var(--sunset, #ff7a00)) !important;
  color:#fff !important;
  box-shadow:0 8px 18px rgba(249,115,22,.24) !important;
}
body:not(.navigation-active) #mapSection .badges{
  margin-bottom:10px !important;
}
body:not(.navigation-active) #mapSection #routeReadyBadge{
  box-shadow:0 5px 12px rgba(22,163,74,.16) !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  background:#fff !important;
  border-radius:22px !important;
  border:1px solid rgba(23,128,238,.16) !important;
  box-shadow:0 12px 26px rgba(15,58,91,.12) !important;
  padding:8px !important;
  margin-top:8px !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:17px !important;
  overflow:hidden !important;
  background:#f7fbff !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  background:#fff !important;
  border-radius:20px !important;
  border:1px solid rgba(23,128,238,.12) !important;
  box-shadow:0 10px 22px rgba(15,58,91,.08) !important;
  padding:10px 10px 12px !important;
  margin-top:10px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  gap:8px !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute{
  box-shadow:0 10px 22px rgba(34,197,94,.24) !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  margin-top:10px !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  color:#667085 !important;
  background:rgba(248,250,252,.92) !important;
  border:1px solid rgba(15,58,91,.08) !important;
  border-radius:14px !important;
  padding:10px 12px !important;
  line-height:1.35 !important;
  text-shadow:none !important;
}

/* v204 — Harmonisation des titres principaux
   Objectif : titres de sections uniformes, proches de "Trouver ma balade idéale",
   et titre "Votre parcours en direct" moins collé au cadre. */
:root{
  --bnbike-section-title-size: 22px;
  --bnbike-section-title-line: 1.08;
}
.app > .block > .section-head h1,
.app > .block > .section-head h2,
#routeSection .section-head h2,
.search-unified-block .section-head h2,
#mapSection .section-head h2,
.bikes-section-title,
.reviews-title,
.history-title{
  font-size:var(--bnbike-section-title-size) !important;
  line-height:var(--bnbike-section-title-line) !important;
  font-weight:900 !important;
  letter-spacing:-.035em !important;
}
.app > .block > .section-head{
  align-items:flex-start !important;
}
body:not(.navigation-active) #mapSection.block{
  padding:16px !important;
}
body:not(.navigation-active) #mapSection .section-head{
  margin-bottom:12px !important;
  padding-top:2px !important;
  padding-left:1px !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  max-width:245px !important;
}
body:not(.navigation-active) #mapSection .badges{
  margin-top:2px !important;
}
@media (max-width:360px){
  :root{ --bnbike-section-title-size: 20px; }
  body:not(.navigation-active) #mapSection .section-head h2{ max-width:220px !important; }
}

/* v206 — Votre parcours en direct : fond bleu dégradé complet
   Annule la dernière correction de position v205 en repartant de v204.
   Le fond de tout l'encart redevient bleu premium, sans toucher au GPS. */
body:not(.navigation-active) #mapSection.block{
  background:
    radial-gradient(circle at 18% 12%, rgba(73, 190, 255, .40) 0%, rgba(73, 190, 255, 0) 34%),
    radial-gradient(circle at 92% 8%, rgba(255, 122, 0, .22) 0%, rgba(255, 122, 0, 0) 28%),
    linear-gradient(145deg, #063d76 0%, #0b6fd4 48%, #22a8ff 100%) !important;
  color:#fff !important;
  border:none !important;
  box-shadow:0 18px 42px rgba(6, 61, 118, .24) !important;
  overflow:hidden !important;
}
body:not(.navigation-active) #mapSection.block::before{
  content:'' !important;
  position:absolute !important;
  inset:0 !important;
  width:auto !important;
  height:auto !important;
  background:
    linear-gradient(135deg, rgba(6,61,118,.78) 0%, rgba(23,128,238,.62) 58%, rgba(67,162,255,.50) 100%),
    url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat !important;
  opacity:1 !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 34%, rgba(255,255,255,.05) 100%);
  pointer-events:none;
  z-index:0;
}
body:not(.navigation-active) #mapSection .section-head h2,
body:not(.navigation-active) #mapSection .sub,
body:not(.navigation-active) #mapSection .map-label{
  color:#fff !important;
  text-shadow:0 2px 12px rgba(0, 31, 76, .22) !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  box-shadow:0 8px 18px rgba(0, 31, 76, .12) !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  margin-top:10px !important;
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(255,255,255,.72) !important;
  box-shadow:0 14px 30px rgba(0, 31, 76, .18) !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  background:rgba(255,255,255,.20) !important;
  border:1px solid rgba(255,255,255,.26) !important;
  box-shadow:0 10px 24px rgba(0, 31, 76, .14) !important;
  backdrop-filter:blur(8px);
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  color:rgba(255,255,255,.94) !important;
  background:rgba(255,255,255,.14) !important;
  border:1px solid rgba(255,255,255,.20) !important;
  text-shadow:0 1px 8px rgba(0, 31, 76, .25) !important;
}

/* v207 — Amélioration ciblée du bloc “Votre parcours en direct”
   Design plus propre, boutons mieux hiérarchisés, sans modification GPS. */
body:not(.navigation-active) #mapSection.block{
  padding:18px 14px 16px !important;
  border-radius:24px !important;
  background:
    radial-gradient(circle at 18% 8%, rgba(95,205,255,.42) 0%, rgba(95,205,255,0) 34%),
    radial-gradient(circle at 92% 6%, rgba(255,122,0,.22) 0%, rgba(255,122,0,0) 28%),
    linear-gradient(145deg,#073d7a 0%,#0d73d6 50%,#20a9ff 100%) !important;
  box-shadow:0 18px 44px rgba(6,61,118,.24) !important;
}
body:not(.navigation-active) #mapSection.block::before{
  background:
    linear-gradient(145deg, rgba(6,61,118,.64), rgba(23,128,238,.46), rgba(67,162,255,.30)),
    url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat !important;
  opacity:1 !important;
}
body:not(.navigation-active) #mapSection .section-head{
  padding:0 2px !important;
  margin-bottom:10px !important;
  align-items:flex-start !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  max-width:250px !important;
  color:#fff !important;
  font-size:24px !important;
  line-height:1.02 !important;
  letter-spacing:-.045em !important;
  text-shadow:0 3px 14px rgba(0,31,76,.25) !important;
}
body:not(.navigation-active) #mapSection .section-head .pill{
  margin-top:2px !important;
  padding:7px 12px !important;
  border-radius:999px !important;
  font-size:11px !important;
  box-shadow:0 10px 20px rgba(255,122,0,.24) !important;
}
body:not(.navigation-active) #mapSection .badges{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  margin:0 0 13px !important;
  padding:0 2px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  min-height:32px !important;
  padding:7px 13px !important;
  border-radius:999px !important;
  font-size:13px !important;
  font-weight:900 !important;
  box-shadow:0 9px 18px rgba(0,31,76,.14) !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  margin-top:4px !important;
  padding:8px !important;
  border-radius:24px !important;
  background:rgba(255,255,255,.98) !important;
  border:1.5px solid rgba(255,255,255,.72) !important;
  box-shadow:0 16px 34px rgba(0,31,76,.22) !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:18px !important;
  overflow:hidden !important;
}
body:not(.navigation-active) #mapSection .map-mode-fab{
  border-radius:18px !important;
  min-width:58px !important;
  height:48px !important;
  background:#fff !important;
  color:#0876cf !important;
  box-shadow:0 10px 24px rgba(0,31,76,.18) !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:10px !important;
  padding:12px !important;
  border-radius:22px !important;
  background:rgba(255,255,255,.18) !important;
  border:1px solid rgba(255,255,255,.26) !important;
  backdrop-filter:blur(10px) !important;
  box-shadow:0 12px 28px rgba(0,31,76,.16) !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  display:grid !important;
  grid-template-columns:58px minmax(0,1fr) !important;
  gap:10px !important;
  width:100% !important;
  padding:0 !important;
  align-items:stretch !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:58px !important;
  min-width:58px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:58px !important;
  height:50px !important;
  border-radius:16px !important;
  background:#fff !important;
  border:1.5px solid rgba(23,128,238,.20) !important;
  box-shadow:0 10px 20px rgba(0,31,76,.12) !important;
  color:#1685df !important;
  font-size:22px !important;
}
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{
  height:50px !important;
  border-radius:16px !important;
  font-size:14px !important;
  font-weight:900 !important;
  background:#fff !important;
  color:#0780d7 !important;
  border:1.5px solid rgba(23,128,238,.24) !important;
  box-shadow:0 10px 20px rgba(0,31,76,.12) !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  grid-column:1 / -1 !important;
  width:100% !important;
  height:48px !important;
  margin-top:2px !important;
  border-radius:16px !important;
  font-size:15px !important;
  font-weight:900 !important;
  background:linear-gradient(135deg,#1bd66b 0%,#17b957 42%,#0e9f45 100%) !important;
  box-shadow:0 13px 26px rgba(22,185,87,.34) !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:46px !important;
  border-radius:16px !important;
  margin-top:10px !important;
  background:#fff !important;
  color:#0780d7 !important;
  border:1.5px solid rgba(23,128,238,.22) !important;
  box-shadow:0 9px 18px rgba(0,31,76,.10) !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin-top:12px !important;
  padding:12px 14px !important;
  border-radius:16px !important;
  color:rgba(255,255,255,.96) !important;
  background:rgba(0,31,76,.16) !important;
  border:1px solid rgba(255,255,255,.20) !important;
  text-align:left !important;
  max-width:100% !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection .section-head h2{font-size:22px !important;max-width:220px !important;}
  body:not(.navigation-active) #mapSection .map-actions{padding:10px !important;}
  body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{font-size:12.5px !important;}
}

/* v208 — Votre parcours en direct : rendu proche du mockup validé
   Fond bleu premium sur tout l'encart, carte blanche en profondeur,
   hiérarchie claire des boutons. Aucune modification GPS. */
body:not(.navigation-active) #mapSection.block{
  padding:22px 16px 20px !important;
  border-radius:26px !important;
  border:1px solid rgba(255,255,255,.34) !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(79,205,255,.42) 0%, rgba(79,205,255,0) 34%),
    radial-gradient(circle at 96% 4%, rgba(255,122,0,.20) 0%, rgba(255,122,0,0) 28%),
    linear-gradient(145deg,#063d7a 0%,#0b6fd2 48%,#1597ef 100%) !important;
  box-shadow:0 20px 46px rgba(6,61,118,.24) !important;
  overflow:hidden !important;
}
body:not(.navigation-active) #mapSection.block::before{
  content:'' !important;
  position:absolute !important;
  inset:0 !important;
  background:
    linear-gradient(145deg, rgba(4,38,89,.22), rgba(23,128,238,.18), rgba(67,162,255,.10)),
    url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat !important;
  opacity:.34 !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block::after{
  content:'' !important;
  position:absolute !important;
  inset:0 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,0) 38%, rgba(0,60,140,.18) 100%),
    radial-gradient(circle at 50% 62%, rgba(255,255,255,.16), rgba(255,255,255,0) 38%) !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block > *{
  position:relative !important;
  z-index:1 !important;
}
body:not(.navigation-active) #mapSection .section-head{
  padding:2px 2px 0 !important;
  margin-bottom:12px !important;
  align-items:flex-start !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  color:#fff !important;
  font-size:25px !important;
  line-height:1.02 !important;
  max-width:255px !important;
  letter-spacing:-.045em !important;
  text-shadow:0 4px 16px rgba(0,32,80,.30) !important;
}
body:not(.navigation-active) #mapSection .section-head .pill{
  margin-top:3px !important;
  padding:7px 13px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#ff7a00 0%,#ff5f00 100%) !important;
  box-shadow:0 10px 20px rgba(255,95,0,.26) !important;
  color:#fff !important;
  font-size:11px !important;
}
body:not(.navigation-active) #mapSection .badges{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  margin:0 0 16px !important;
  padding:0 2px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  min-height:33px !important;
  padding:7px 14px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.94) !important;
  color:#0d3c68 !important;
  border:1px solid rgba(255,255,255,.55) !important;
  box-shadow:0 9px 18px rgba(0,32,80,.14) !important;
  backdrop-filter:blur(8px) !important;
  font-size:13px !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection #routeReadyBadge{
  background:#e7fff0 !important;
  color:#0c8f42 !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  margin:0 !important;
  padding:10px !important;
  border-radius:25px !important;
  background:rgba(255,255,255,.98) !important;
  border:1.5px solid rgba(255,255,255,.76) !important;
  box-shadow:0 18px 38px rgba(0,32,80,.26), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:19px !important;
  overflow:hidden !important;
  background:#eef8ff !important;
}
body:not(.navigation-active) #mapSection .map-mode-fab{
  border-radius:18px !important;
  min-width:58px !important;
  height:48px !important;
  right:12px !important;
  bottom:18px !important;
  background:#fff !important;
  color:#0876cf !important;
  border:0 !important;
  box-shadow:0 12px 24px rgba(0,32,80,.20) !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:14px !important;
  padding:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  display:grid !important;
  grid-template-columns:58px minmax(0,1fr) !important;
  gap:10px !important;
  width:100% !important;
  align-items:stretch !important;
  margin-bottom:12px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:58px !important;
  min-width:58px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:52px !important;
  border-radius:17px !important;
  background:#fff !important;
  color:#0876cf !important;
  border:1.5px solid rgba(255,255,255,.72) !important;
  box-shadow:0 12px 24px rgba(0,32,80,.16) !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:58px !important;
  font-size:23px !important;
  padding:0 !important;
}
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{
  font-size:14px !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  grid-column:1 / -1 !important;
  width:100% !important;
  height:54px !important;
  margin:0 0 12px !important;
  border-radius:18px !important;
  font-size:16px !important;
  font-weight:950 !important;
  background:linear-gradient(135deg,#20df74 0%,#14bd58 46%,#07983e 100%) !important;
  box-shadow:0 16px 32px rgba(20,189,88,.36), inset 0 1px 0 rgba(255,255,255,.28) !important;
  color:#fff !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  width:100% !important;
  margin:0 !important;
  font-size:14px !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin-top:18px !important;
  padding:12px 14px !important;
  border-radius:17px !important;
  color:rgba(255,255,255,.96) !important;
  background:rgba(0,32,80,.20) !important;
  border:1px solid rgba(255,255,255,.22) !important;
  text-align:left !important;
  line-height:1.4 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10) !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection.block{padding:18px 12px 16px !important;border-radius:22px !important;}
  body:not(.navigation-active) #mapSection .section-head h2{font-size:22px !important;max-width:218px !important;}
  body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{font-size:12.5px !important;}
}

/* v209 — Votre parcours en direct : style mockup exact demandé
   Rendu plus proche du mockup : grand panneau bleu, carte blanche détachée,
   boutons hiérarchisés et texte légal intégré. Aucun impact navigation GPS. */
body:not(.navigation-active) #mapSection.block{
  padding:24px 18px 22px !important;
  border-radius:28px !important;
  border:1px solid rgba(255,255,255,.38) !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(103,214,255,.42) 0%, rgba(103,214,255,0) 33%),
    radial-gradient(circle at 94% 10%, rgba(255,122,0,.18) 0%, rgba(255,122,0,0) 28%),
    linear-gradient(150deg,#06458f 0%,#0b78df 52%,#16a7ff 100%) !important;
  box-shadow:0 24px 52px rgba(6,69,143,.28), inset 0 1px 0 rgba(255,255,255,.22) !important;
  overflow:hidden !important;
  color:#fff !important;
}
body:not(.navigation-active) #mapSection.block::before{
  content:'' !important;
  position:absolute !important;
  inset:0 !important;
  background:
    linear-gradient(160deg, rgba(0,36,98,.12), rgba(23,128,238,.08), rgba(255,255,255,.04)),
    url('https://static.wixstatic.com/media/6cb3f4_a811d3cd2de248d7bd5a13fc2230e6a3~mv2.jpg') center/cover no-repeat !important;
  opacity:.22 !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block::after{
  content:'' !important;
  position:absolute !important;
  inset:0 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,0) 34%, rgba(0,63,150,.20) 100%),
    radial-gradient(circle at 52% 54%, rgba(255,255,255,.18), rgba(255,255,255,0) 42%) !important;
  pointer-events:none !important;
  z-index:0 !important;
}
body:not(.navigation-active) #mapSection.block > *{
  position:relative !important;
  z-index:1 !important;
}
body:not(.navigation-active) #mapSection .section-head{
  padding:0 4px !important;
  margin:0 0 14px !important;
  align-items:flex-start !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  color:#fff !important;
  font-size:28px !important;
  line-height:1.02 !important;
  max-width:270px !important;
  letter-spacing:-.05em !important;
  text-shadow:0 5px 18px rgba(0,28,78,.32) !important;
}
body:not(.navigation-active) #mapSection .section-head .pill{
  margin-top:2px !important;
  padding:7px 13px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#ff8a12 0%,#ff5f00 100%) !important;
  color:#fff !important;
  box-shadow:0 12px 22px rgba(255,95,0,.30) !important;
  border:0 !important;
  font-size:11px !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .badges{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:9px !important;
  margin:0 0 18px !important;
  padding:0 4px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  min-height:36px !important;
  padding:8px 16px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.95) !important;
  color:#0d4777 !important;
  border:1px solid rgba(255,255,255,.62) !important;
  box-shadow:0 10px 20px rgba(0,32,80,.14) !important;
  backdrop-filter:blur(10px) !important;
  font-size:13px !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection #routeReadyBadge{
  background:#eafff2 !important;
  color:#0a9443 !important;
  border-color:rgba(255,255,255,.76) !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  margin:0 !important;
  padding:11px !important;
  border-radius:28px !important;
  background:#fff !important;
  border:1.5px solid rgba(255,255,255,.88) !important;
  box-shadow:0 22px 42px rgba(0,32,80,.28), inset 0 1px 0 rgba(255,255,255,.92) !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:21px !important;
  overflow:hidden !important;
  background:#edf8ff !important;
}
body:not(.navigation-active) #mapSection .map-mode-fab{
  min-width:62px !important;
  height:54px !important;
  right:13px !important;
  bottom:18px !important;
  border-radius:20px !important;
  background:#fff !important;
  color:#0876cf !important;
  border:0 !important;
  box-shadow:0 14px 28px rgba(0,32,80,.22) !important;
  font-weight:950 !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:18px !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  border-radius:0 !important;
  backdrop-filter:none !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  display:grid !important;
  grid-template-columns:62px minmax(0,1fr) !important;
  gap:12px !important;
  width:100% !important;
  margin-bottom:14px !important;
  align-items:stretch !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:62px !important;
  min-width:62px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:58px !important;
  border-radius:18px !important;
  background:#fff !important;
  color:#0876cf !important;
  border:1.5px solid rgba(255,255,255,.82) !important;
  box-shadow:0 14px 28px rgba(0,32,80,.18) !important;
  font-weight:950 !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:62px !important;
  padding:0 !important;
  font-size:24px !important;
}
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{
  font-size:14.5px !important;
  justify-content:center !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  grid-column:1 / -1 !important;
  width:100% !important;
  height:60px !important;
  margin:0 0 14px !important;
  border-radius:18px !important;
  font-size:17px !important;
  font-weight:950 !important;
  color:#fff !important;
  background:linear-gradient(135deg,#24e277 0%,#16c960 48%,#079842 100%) !important;
  box-shadow:0 18px 34px rgba(20,189,88,.38), inset 0 1px 0 rgba(255,255,255,.30) !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  width:100% !important;
  margin:0 !important;
  font-size:14.5px !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin:20px 8px 0 !important;
  padding:0 !important;
  color:rgba(255,255,255,.96) !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  text-align:left !important;
  line-height:1.38 !important;
  font-size:14px !important;
  text-shadow:0 3px 12px rgba(0,32,80,.30) !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection.block{padding:20px 13px 18px !important;border-radius:24px !important;}
  body:not(.navigation-active) #mapSection .section-head h2{font-size:23px !important;max-width:225px !important;}
  body:not(.navigation-active) #mapSection .badges .badge,
  body:not(.navigation-active) #mapSection .badge{font-size:12.5px !important;padding:7px 12px !important;}
  body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{font-size:12.5px !important;}
}

/* v210 — Ajustement mockup : badges/boutons plus compacts, carte plus grande
   Aucun impact navigation GPS : uniquement hors navigation active. */
body:not(.navigation-active) #mapSection .badges{
  gap:7px !important;
  margin:0 0 12px !important;
  padding:0 4px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  min-height:28px !important;
  padding:5px 11px !important;
  font-size:11.5px !important;
  line-height:1.05 !important;
  border-radius:999px !important;
}
body:not(.navigation-active) #mapSection .section-head{
  margin-bottom:10px !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  padding:9px !important;
  border-radius:26px !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:20px !important;
}
body:not(.navigation-active) #mapSection #map{
  height:min(52vh, 470px) !important;
  min-height:390px !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:13px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  grid-template-columns:54px minmax(0,1fr) !important;
  gap:10px !important;
  margin-bottom:10px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:54px !important;
  min-width:54px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:48px !important;
  min-height:48px !important;
  border-radius:15px !important;
  font-size:13px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:54px !important;
  font-size:22px !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  height:50px !important;
  min-height:50px !important;
  margin:0 0 10px !important;
  border-radius:16px !important;
  font-size:15px !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  font-size:13px !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin-top:15px !important;
  font-size:13px !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection #map{
    height:48vh !important;
    min-height:340px !important;
  }
  body:not(.navigation-active) #mapSection .badges .badge,
  body:not(.navigation-active) #mapSection .badge{
    min-height:26px !important;
    padding:5px 9px !important;
    font-size:11px !important;
  }
  body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
  body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
  body:not(.navigation-active) #mapSection .btn-start-point-maps{
    height:46px !important;
    min-height:46px !important;
    font-size:12px !important;
  }
}

/* v211 — Votre parcours en direct : badges et boutons harmonisés
   Badges = hauteur des badges Journée / Demi-journée.
   Boutons = hauteur proche des boutons des encarts Nos balades incontournables.
   Aucun impact navigation GPS. */
body:not(.navigation-active) #mapSection .badges{
  gap:6px !important;
  margin:0 0 10px !important;
  padding:0 2px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge{
  min-height:30px !important;
  height:30px !important;
  padding:6px 10px !important;
  border-radius:999px !important;
  font-size:11px !important;
  line-height:1 !important;
  font-weight:800 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:6px !important;
}
body:not(.navigation-active) #mapSection #routeReadyBadge{
  min-height:30px !important;
  height:30px !important;
  padding:6px 10px !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:10px !important;
  padding:9px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  grid-template-columns:46px minmax(0,1fr) !important;
  gap:8px !important;
  margin-bottom:8px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:46px !important;
  min-width:46px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:36px !important;
  min-height:36px !important;
  padding:6px 10px !important;
  border-radius:12px !important;
  font-size:11.5px !important;
  line-height:1.1 !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:46px !important;
  font-size:18px !important;
  padding:0 !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  height:38px !important;
  min-height:38px !important;
  margin:0 0 8px !important;
  padding:7px 12px !important;
  border-radius:13px !important;
  font-size:13px !important;
  line-height:1.05 !important;
  font-weight:900 !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  margin-top:0 !important;
}
body:not(.navigation-active) #mapSection #map{
  height:min(54vh, 490px) !important;
  min-height:405px !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection .badges .badge,
  body:not(.navigation-active) #mapSection .badge{
    min-height:28px !important;
    height:28px !important;
    padding:5px 9px !important;
    font-size:10.5px !important;
  }
  body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
  body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
  body:not(.navigation-active) #mapSection .btn-start-point-maps{
    height:34px !important;
    min-height:34px !important;
    font-size:11px !important;
  }
  body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
    height:36px !important;
    min-height:36px !important;
    font-size:12.5px !important;
  }
  body:not(.navigation-active) #mapSection #map{
    height:50vh !important;
    min-height:355px !important;
  }
}

/* v212 — Votre parcours en direct : bloc condensé pour tenir dans l'écran
   Objectif : garder le style mockup, mais réduire les hauteurs et marges
   afin que la carte + boutons + texte légal soient visibles plus facilement. */
body:not(.navigation-active) #mapSection.block{
  padding:14px 12px 13px !important;
  border-radius:22px !important;
}
body:not(.navigation-active) #mapSection .section-head{
  margin:0 0 7px !important;
  padding:0 2px !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  font-size:22px !important;
  line-height:1 !important;
  max-width:220px !important;
  letter-spacing:-.045em !important;
}
body:not(.navigation-active) #mapSection .section-head .pill{
  padding:5px 10px !important;
  font-size:10px !important;
  min-height:27px !important;
}
body:not(.navigation-active) #mapSection .badges{
  gap:5px !important;
  margin:0 0 7px !important;
  padding:0 2px !important;
}
body:not(.navigation-active) #mapSection .badges .badge,
body:not(.navigation-active) #mapSection .badge,
body:not(.navigation-active) #mapSection #routeReadyBadge{
  min-height:27px !important;
  height:27px !important;
  padding:5px 9px !important;
  font-size:10.5px !important;
  gap:5px !important;
}
body:not(.navigation-active) #mapSection .map-frame{
  padding:7px !important;
  border-radius:21px !important;
}
body:not(.navigation-active) #mapSection .map-frame-inner{
  border-radius:16px !important;
}
body:not(.navigation-active) #mapSection #map{
  height:clamp(275px, 38vh, 360px) !important;
  min-height:275px !important;
}
body:not(.navigation-active) #mapSection .map-mode-fab{
  min-width:48px !important;
  height:40px !important;
  right:10px !important;
  bottom:14px !important;
  border-radius:15px !important;
  font-size:12px !important;
}
body:not(.navigation-active) #mapSection .map-actions{
  margin-top:8px !important;
  padding:0 !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  grid-template-columns:42px minmax(0,1fr) !important;
  gap:7px !important;
  margin-bottom:7px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  width:42px !important;
  min-width:42px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium,
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  height:34px !important;
  min-height:34px !important;
  padding:5px 9px !important;
  border-radius:11px !important;
  font-size:11px !important;
  line-height:1.05 !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:42px !important;
  font-size:17px !important;
  padding:0 !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  height:36px !important;
  min-height:36px !important;
  margin:0 0 7px !important;
  padding:6px 11px !important;
  border-radius:12px !important;
  font-size:12.5px !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps{
  margin-top:0 !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin:9px 5px 0 !important;
  font-size:11.5px !important;
  line-height:1.25 !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection.block{padding:12px 10px 11px !important;border-radius:20px !important;}
  body:not(.navigation-active) #mapSection .section-head h2{font-size:20px !important;max-width:205px !important;}
  body:not(.navigation-active) #mapSection #map{height:clamp(245px, 36vh, 320px) !important;min-height:245px !important;}
  body:not(.navigation-active) #mapSection .ride-disclaimer-inline{font-size:10.8px !important;}
}


/* v213 — Réorganisation boutons "Votre parcours en direct"
   - Voir tous les parcours passe en dernier avec emoji carte.
   - Le bouton principal reste Lancer la navigation.
   - Aucun changement fonctionnel. */
body:not(.navigation-active) #mapSection .map-actions{
  gap:7px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  display:grid !important;
  grid-template-columns:42px minmax(0,1fr) !important;
  grid-template-areas:"more launch" !important;
  gap:7px !important;
  margin-bottom:0 !important;
  padding:0 !important;
  align-items:stretch !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .more-actions-wrap{
  grid-area:more !important;
  width:42px !important;
  min-width:42px !important;
}
body:not(.navigation-active) #mapSection .map-actions-row .btn-more{
  width:42px !important;
  height:34px !important;
  min-height:34px !important;
  border-radius:11px !important;
  font-size:17px !important;
  padding:0 !important;
}
body:not(.navigation-active) #mapSection #btnLaunchRoute.btn-launch{
  grid-area:launch !important;
  height:34px !important;
  min-height:34px !important;
  margin:0 !important;
  padding:5px 12px !important;
  border-radius:11px !important;
  font-size:12px !important;
  line-height:1.05 !important;
  width:100% !important;
}
body:not(.navigation-active) #mapSection .btn-start-point-maps,
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{
  width:100% !important;
  height:34px !important;
  min-height:34px !important;
  margin:0 !important;
  padding:5px 12px !important;
  border-radius:11px !important;
  font-size:11.5px !important;
  line-height:1.05 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
}
body:not(.navigation-active) #mapSection #btnAllRoutes.route-btn-premium{
  order:3 !important;
  background:#ffffff !important;
  color:var(--ocean, #1780ee) !important;
  border:1.5px solid rgba(23,128,238,.55) !important;
}
body:not(.navigation-active) #mapSection .ride-disclaimer-inline{
  margin-top:6px !important;
}


/* v214 — Bouton Tous les parcours déplacé + titres allégés
   - Le bouton "Voir tous les parcours" vit maintenant en bas de l'encart Autres balades.
   - Les titres principaux sont un peu moins gras pour un rendu plus premium. */
#similarRoutesBlock .similar-all-routes-btn{
  width:100% !important;
  margin:14px 0 0 !important;
  min-height:38px !important;
  height:38px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:14px !important;
  background:#ffffff !important;
  color:var(--ocean, #1780ee) !important;
  border:1.5px solid rgba(23,128,238,.42) !important;
  box-shadow:0 8px 18px rgba(15,58,91,.08) !important;
  font-size:13px !important;
  font-weight:750 !important;
  line-height:1.05 !important;
}
#similarRoutesBlock .similar-all-routes-btn:active{
  transform:translateY(1px) !important;
}
.app h1,
.app h2,
.app h3,
.app .section-head h1,
.app .section-head h2,
.app .route-title,
.app .card h3,
.app .bikes-section-title,
.app .detail-title,
.app .reviews-title,
.app .history-title{
  font-weight:800 !important;
  letter-spacing:-.025em !important;
}
body:not(.navigation-active) #mapSection .section-head h2{
  font-weight:800 !important;
}
#routeList .card h3,
#routeList .route-title{
  font-weight:800 !important;
}


/* v216 — Encart "Trouver ma balade idéale" bleu premium + espacement boutons parcours direct
   Modifications uniquement visuelles. */
.search-unified-block{
  position:relative !important;
  overflow:hidden !important;
  background:
    radial-gradient(circle at 14% 0%, rgba(255,255,255,.24) 0%, rgba(255,255,255,0) 34%),
    radial-gradient(circle at 92% 18%, rgba(67,162,255,.34) 0%, rgba(67,162,255,0) 34%),
    linear-gradient(135deg, #073f82 0%, #1780ee 54%, #45a7ff 100%) !important;
  border:1.5px solid rgba(255,255,255,.24) !important;
  box-shadow:0 18px 38px rgba(10,79,122,.20) !important;
  color:#fff !important;
}
.search-unified-block::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0) 42%),
    radial-gradient(circle at 50% 110%, rgba(255,122,0,.18), rgba(255,122,0,0) 42%);
  pointer-events:none;
}
.search-unified-block > *{
  position:relative !important;
  z-index:1 !important;
}
.search-unified-block .section-head h2{
  color:#fff !important;
  text-shadow:0 3px 14px rgba(0,36,92,.26) !important;
}
.search-unified-block .section-head .sub,
.search-unified-block .filter-subgroup-label{
  color:rgba(255,255,255,.88) !important;
  text-shadow:0 2px 10px rgba(0,36,92,.20) !important;
}
.search-unified-block .section-head .pill{
  background:rgba(255,255,255,.18) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.28) !important;
  box-shadow:0 8px 18px rgba(0,36,92,.14) !important;
}
.search-unified-block .filter-btn,
.search-unified-block .quick-btn,
.search-unified-block .theme-btn{
  background:rgba(255,255,255,.96) !important;
  color:#0a4f7a !important;
  border-color:rgba(255,255,255,.78) !important;
  box-shadow:0 8px 18px rgba(0,36,92,.13) !important;
}
.search-unified-block .filter-btn.active,
.search-unified-block .quick-btn.active,
.search-unified-block .theme-btn.active{
  background:linear-gradient(135deg,#ff7a00,#ff9f1a) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.45) !important;
}
.search-unified-block .locked-theme-badge{
  background:rgba(255,255,255,.80) !important;
  color:#0a4f7a !important;
  border-color:rgba(255,255,255,.72) !important;
}
body:not(.navigation-active) #mapSection .map-actions-row{
  gap:12px !important;
}
@media (max-width:360px){
  body:not(.navigation-active) #mapSection .map-actions-row{ gap:10px !important; }
}

/* v217 — Encart "Vélos recommandés" fond bleu whoua
   Modification visuelle ciblée uniquement sur #bikesSection. */
body:not(.navigation-active) #bikesSection.block{
  background:
    radial-gradient(circle at 18% 0%, rgba(255,255,255,.24), rgba(255,255,255,0) 28%),
    radial-gradient(circle at 86% 18%, rgba(67,162,255,.32), rgba(67,162,255,0) 34%),
    linear-gradient(145deg, #073d73 0%, #0b6fd3 52%, #42a6ff 100%) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:0 16px 34px rgba(10,79,122,.18) !important;
  overflow:hidden !important;
  position:relative !important;
}
body:not(.navigation-active) #bikesSection.block::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 44%, rgba(0,40,100,.08));
  pointer-events:none;
}
body:not(.navigation-active) #bikesSection.block > *{
  position:relative;
  z-index:1;
}
body:not(.navigation-active) #bikesSection .bikes-section-title{
  color:#fff !important;
  text-shadow:0 2px 12px rgba(0,0,0,.18) !important;
}
body:not(.navigation-active) #bikesSection #bikesSub,
body:not(.navigation-active) #bikesSection .sub{
  color:rgba(255,255,255,.88) !important;
  text-shadow:0 1px 8px rgba(0,0,0,.12) !important;
}
body:not(.navigation-active) #bikesSection .pill{
  background:linear-gradient(135deg, #ff8a00, #ffb14a) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.28) !important;
  box-shadow:0 8px 18px rgba(249,115,22,.26) !important;
}
body:not(.navigation-active) #bikesSection .bike-card{
  background:rgba(255,255,255,.96) !important;
  border:1.5px solid rgba(255,255,255,.66) !important;
  box-shadow:0 12px 26px rgba(2,28,74,.18) !important;
}
body:not(.navigation-active) #bikesSection .bike-card-title{
  color:#0f2f55 !important;
}
body:not(.navigation-active) #bikesSection .bike-card-desc,
body:not(.navigation-active) #bikesSection .bike-card-meta,
body:not(.navigation-active) #bikesSection .bike-card-size{
  color:#64748b !important;
}
body:not(.navigation-active) #bikesSection .accessories-title{
  color:#fff !important;
  text-shadow:0 1px 8px rgba(0,0,0,.14) !important;
}

/* v219 — Encart CTA "Balade en famille" en orange whoua
   Correction ciblée : seul le bloc #smartCtaBlock est modifié.
   Les badges d'ambiance restent inchangés. */
body:not(.navigation-active) #smartCtaBlock.smart-cta-block{
  background:
    radial-gradient(circle at 12% 15%, rgba(255,255,255,.28), rgba(255,255,255,0) 34%),
    linear-gradient(135deg, #ffb000 0%, #ff7a00 45%, #f04b00 100%) !important;
  box-shadow: 0 14px 30px rgba(255,122,0,.28), inset 0 1px 0 rgba(255,255,255,.24) !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  color: #fff !important;
}
body:not(.navigation-active) #smartCtaBlock .smart-cta-title,
body:not(.navigation-active) #smartCtaBlock .smart-cta-sub{
  color:#fff !important;
  text-shadow:0 1px 8px rgba(102,35,0,.18) !important;
}
body:not(.navigation-active) #smartCtaBlock .smart-cta-sub{
  color:rgba(255,255,255,.88) !important;
}
body:not(.navigation-active) #smartCtaBlock .smart-cta-btn{
  background:#fff !important;
  color:#0a4f7a !important;
  box-shadow:0 8px 18px rgba(126,42,0,.18) !important;
}

/* v220 — Vélos recommandés : suppression du scroll interne horizontal
   Les cartes vélos/accessoires restent dans l'encart, sans carrousel latéral. */
body:not(.navigation-active) #bikesSection .bikes-cards-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:12px !important;
  overflow-x:hidden !important;
  overflow-y:visible !important;
  scroll-snap-type:none !important;
  -webkit-overflow-scrolling:auto !important;
  padding:2px 0 8px !important;
  width:100% !important;
}
body:not(.navigation-active) #bikesSection .bike-card{
  width:100% !important;
  min-width:0 !important;
  max-width:none !important;
  flex:none !important;
  scroll-snap-align:none !important;
  transform:none !important;
}
body:not(.navigation-active) #bikesSection .bike-card:hover,
body:not(.navigation-active) #bikesSection .bike-card:active{
  transform:none !important;
}
body:not(.navigation-active) #bikesSection .accessories-row{
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  gap:8px !important;
  overflow-x:hidden !important;
  overflow-y:visible !important;
  scroll-snap-type:none !important;
  -webkit-overflow-scrolling:auto !important;
  padding:2px 0 6px !important;
}
body:not(.navigation-active) #bikesSection .accessory-card{
  min-width:0 !important;
  width:100% !important;
  flex:none !important;
  scroll-snap-align:none !important;
  transform:none !important;
}
body:not(.navigation-active) #bikesSection .accessory-card:hover,
body:not(.navigation-active) #bikesSection .accessory-card:active{
  transform:none !important;
}


/* v222 — Vélos recommandés : retour du scroll horizontal, sans scroll vertical interne
   Objectif : garder le carrousel vers la droite, mais empêcher tout mouvement haut/bas dans les cartes. */
body:not(.navigation-active) #bikesSection .bikes-cards-row{
  display:flex !important;
  flex-wrap:nowrap !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  scroll-snap-type:x mandatory !important;
  -webkit-overflow-scrolling:touch !important;
  gap:12px !important;
  padding:2px 1px 8px !important;
  width:100% !important;
  scrollbar-width:none !important;
  overscroll-behavior-y:auto !important;
  touch-action:auto !important;
}
body:not(.navigation-active) #bikesSection .bikes-cards-row::-webkit-scrollbar{display:none !important;}
body:not(.navigation-active) #bikesSection .bike-card{
  flex:0 0 76% !important;
  min-width:76% !important;
  max-width:76% !important;
  width:auto !important;
  scroll-snap-align:start !important;
  transform:none !important;
  overflow:hidden !important;
  touch-action:auto !important;
}
body:not(.navigation-active) #bikesSection .bike-card:hover,
body:not(.navigation-active) #bikesSection .bike-card:active{
  transform:none !important;
}
body:not(.navigation-active) #bikesSection .accessories-row{
  display:flex !important;
  flex-wrap:nowrap !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  scroll-snap-type:x mandatory !important;
  -webkit-overflow-scrolling:touch !important;
  gap:8px !important;
  padding:2px 1px 6px !important;
  width:100% !important;
  scrollbar-width:none !important;
  overscroll-behavior-y:auto !important;
  touch-action:auto !important;
}
body:not(.navigation-active) #bikesSection .accessories-row::-webkit-scrollbar{display:none !important;}
body:not(.navigation-active) #bikesSection .accessory-card{
  flex:0 0 auto !important;
  min-width:90px !important;
  width:auto !important;
  scroll-snap-align:start !important;
  transform:none !important;
  overflow:hidden !important;
  touch-action:auto !important;
}
body:not(.navigation-active) #bikesSection .accessory-card:hover,
body:not(.navigation-active) #bikesSection .accessory-card:active{
  transform:none !important;
}


/* v223 — Bouton "Voir tous les vélos" + page tous les vélos */
.btn-all-bikes{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  min-height:38px!important;
  margin:12px 0 4px!important;
  border-radius:14px!important;
  border:1.5px solid rgba(255,255,255,.72)!important;
  background:rgba(255,255,255,.94)!important;
  color:#0b63ce!important;
  font-size:13px!important;
  font-weight:800!important;
  box-shadow:0 8px 18px rgba(10,79,122,.12)!important;
  cursor:pointer!important;
  touch-action:manipulation!important;
}
.btn-all-bikes:active{transform:scale(.985)!important;}
.all-bikes-page{background:#f5f9ff!important;}
.all-bikes-list-premium{
  max-width:480px;
  margin:0 auto;
  padding:16px 14px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.all-bike-card{
  background:#fff;
  border:1px solid rgba(23,128,238,.14);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 10px 26px rgba(15,58,91,.10);
}
.all-bike-image-wrap{
  position:relative;
  width:100%;
  height:190px;
  background:#eef7ff;
  overflow:hidden;
}
.all-bike-image-wrap img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.all-bike-top-badge{top:10px!important;right:10px!important;}
.all-bike-content{padding:14px 14px 16px;}
.all-bike-content h2{
  margin:0 0 6px;
  color:#102033;
  font-size:18px;
  line-height:1.15;
  font-weight:800;
  letter-spacing:-.02em;
}
.all-bike-content p{
  margin:8px 0 12px;
  color:#607086;
  font-size:13px;
  line-height:1.4;
  font-weight:600;
}
.all-bike-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.all-bikes-empty{
  background:#fff;
  border-radius:18px;
  padding:18px;
  color:#607086;
  font-weight:700;
  text-align:center;
  box-shadow:0 8px 20px rgba(15,58,91,.08);
}


/* v224 — Vélos recommandés : carrousel horizontal + scroll vertical page normal
   On garde le défilement gauche/droite, mais on ne bloque plus le scroll haut/bas de la page. */
body:not(.navigation-active) #bikesSection .bikes-cards-row,
body:not(.navigation-active) #bikesSection .accessories-row{
  overflow-x:auto !important;
  overflow-y:hidden !important;
  -webkit-overflow-scrolling:touch !important;
  touch-action:auto !important;
  overscroll-behavior-y:auto !important;
}
body:not(.navigation-active) #bikesSection .bike-card,
body:not(.navigation-active) #bikesSection .accessory-card{
  overflow:hidden !important;
  touch-action:auto !important;
}
