@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%}

/* ─── Splash ──────────────────────────────────────────────────────────────────── */
.loading-screen{
  position:fixed;inset:0;
  background:linear-gradient(160deg,#0a4f7a 0%,#1780ee 50%,#43a2ff 100%);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;color:#fff;
  transition:opacity .5s ease,visibility .5s ease;
}
.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loading-card{text-align:center;padding:32px 24px}
.loading-logo{
  font-size:64px;font-weight:900;letter-spacing:-.05em;
  background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.loading-tagline{margin-top:6px;font-size:13px;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:.06em;text-transform:uppercase}
.loading-title{margin-top:20px;font-size:15px;font-weight:700;color:rgba(255,255,255,.9)}
.loading-sub{margin-top:4px;font-size:11px;color:rgba(255,255,255,.65);font-weight:600}
.loading-dots{display:flex;gap:6px;justify-content:center;margin-top:18px}
.loading-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);animation:dotPulse 1.4s ease-in-out infinite}
.loading-dot:nth-child(2){animation-delay:.2s}
.loading-dot:nth-child(3){animation-delay:.4s}
@keyframes dotPulse{0%,80%,100%{transform:scale(.8);opacity:.4}40%{transform:scale(1.2);opacity:1}}
.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;}

/* ─── Onboarding ──────────────────────────────────────────────────────────────── */
.onboarding-overlay{
  position:fixed;inset:0;z-index:8000;
  background:linear-gradient(160deg,#0a4f7a,#1780ee,#43a2ff);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;color:#fff;
  transition:opacity .4s ease,visibility .4s ease;
}
.onboarding-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.onboarding-step{display:none;text-align:center;max-width:320px}
.onboarding-step.active{display:block;animation:fadeInUp .4s ease}
.onboarding-emoji{font-size:64px;margin-bottom:16px}
.onboarding-title{font-size:26px;font-weight:900;letter-spacing:-.03em;margin-bottom:10px}
.onboarding-text{font-size:14px;font-weight:600;color:rgba(255,255,255,.85);line-height:1.6;margin-bottom:28px}
.onboarding-dots{display:flex;gap:8px;justify-content:center;margin-bottom:28px}
.onboarding-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);transition:background .3s,width .3s}
.onboarding-dot.active{background:#fff;width:24px}
.onboarding-btn{
  min-height:52px;padding:0 32px;border-radius:999px;border:none;
  background:#fff;color:var(--ocean);font-size:15px;font-weight:900;cursor:pointer;
  box-shadow:0 12px 28px rgba(0,0,0,.2);transition:transform .15s;
}
.onboarding-btn:active{transform:scale(.97)}
.onboarding-skip{margin-top:16px;font-size:12px;font-weight:600;color:rgba(255,255,255,.55);cursor:pointer;text-decoration:underline}
@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:linear-gradient(135deg,var(--ocean),var(--ocean-mid));
  color:#fff;border-radius:var(--radius-sm);margin-bottom:10px;
  box-shadow:0 8px 20px rgba(10,79,122,.22);
}
.pwa-banner-text{font-size:12px;font-weight:700;flex:1}
.pwa-banner-install{
  min-height:32px;padding:0 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.5);background:rgba(255,255,255,.2);
  color:#fff;font-size:11px;font-weight:800;cursor:pointer;
}
.pwa-banner-close{
  width:28px;height:28px;border-radius:999px;border:none;
  background:rgba(255,255,255,.15);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);
}

/* ─── 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:1px solid rgba(249, 115, 22, 0.3);border-radius:var(--radius);
  background: rgba(249, 115, 22, 0.18); /* Orange encore plus visible */
  padding:14px;
  box-shadow:0 2px 10px rgba(0,0,0,.05);overflow:hidden;cursor:pointer;
  transition:transform .2s,box-shadow .2s;
}
/* Alternance : les cartes paires passent en bleu transparent */
.card:nth-child(even) {
  background: rgba(14, 165, 233, 0.08);
  border-color: rgba(14, 165, 233, 0.2);
}
.card:active{transform:scale(.99)}
.card.active{
  background:linear-gradient(160deg,#f0f9ff 0%,#e0f2fe 100%);
  border-color:rgba(14,165,233,.30);
  box-shadow:0 4px 20px rgba(14,165,233,.12);
}
.card-media{position:relative}
.selected-tag{
  display:none;position:absolute;top:12px;right:12px;
  padding:5px 10px;font-size:10px;border-radius:999px;
  background:rgba(255,255,255,.94);color:var(--sunset-dark);
  font-weight:800;border:1px solid rgba(244,132,95,.25);
}
.card.active .selected-tag{display:inline-flex}
.card-image{
  width:100%;height:200px;border-radius:var(--radius-sm);overflow:hidden;
  margin:4px 0 12px;border:none;background:#edf4fb;
  position:relative;
}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.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;
}

/* 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);
}

/* ─── 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}


/* ─── Arrivée ─────────────────────────────────────────────────────────────────── */
.arrival-panel{
  display:none;margin:0 0 8px;padding:14px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--pine),var(--pine-light));
  color:#fff;box-shadow:0 12px 28px rgba(45,106,79,.22);text-align:center;
}
.arrival-panel.visible{display:block;animation:fadeInUp .4s ease}
.arrival-title{font-size:18px;font-weight:900}
.arrival-sub{margin-top:4px;font-size:11px;line-height:1.4;font-weight:700;color:rgba(255,255,255,.9)}
.arrival-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.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)}

/* ─── 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 .38s 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;
}
body.navigation-active .arrival-panel.visible{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:700;width:calc(100% - 40px);max-width:380px;border-radius:24px;
}
/* ─── 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 ─────────────────────────────────────────────────────────────── */
.loading-screen.hidden{pointer-events:none}
.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: 900 !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; }

/* ══ PANNEAU ARRIVÉE ANCIEN ══════════════════════════════════════════════════
   z-index: 850 · centré
   ════════════════════════════════════════════════════════════════════════════ */
body.navigation-active .arrival-panel.visible {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%,-50%) !important;
  z-index: 850 !important;
  width: calc(100% - 40px) !important;
  max-width: 380px !important;
  border-radius: 24px !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,#1780ee,#0a4f7a); color:#fff; border:none; border-radius:16px; padding:14px 20px; font-size:15px; font-weight:800; cursor:pointer; box-shadow:0 8px 24px rgba(23,128,238,.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; }

/* ── 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-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 bien visible
   ═══════════════════════════════════════════════════════════════════════════ */

/* 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; }

