body.app-mode {
  background-color: #ffffff;
}

body.app-mode .page {
  display: block;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 0;
  background-color: #ffffff;
}

body.app-mode #authPage {
  display: none !important;
}

body.app-mode #appPage {
  display: block !important;
}

.app-page {
  width: 100%;
  min-height: 100vh;
  background: #ffffff;
  padding: 0;
  position: relative;
  overflow: hidden;
}

@media (min-width: 900px) {
  .app-page {
    padding: 0;
  }
}

#map {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 0;
  z-index: 0;
  touch-action: none;
}

#appPage:not([hidden]) {
  visibility: visible;
}

#map.charji-map--fallback {
  background: linear-gradient(165deg, #e2e8f0 0%, #cbd5e1 45%, #94a3b8 100%);
}

#map.charji-map--dev-off {
  background:
    radial-gradient(circle at 50% 38%, rgba(22, 163, 74, 0.12) 0, transparent 52%),
    linear-gradient(165deg, #ecfdf5 0%, #d1fae5 42%, #bbf7d0 100%);
}

#map .charji-map-dev-off-msg {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(92vw, 360px);
  box-sizing: border-box;
  padding: 18px 20px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 40px rgba(22, 163, 74, 0.12), 0 8px 24px rgba(15, 23, 42, 0.08);
  border: 1px solid rgba(22, 163, 74, 0.2);
  text-align: center;
  z-index: 2;
  pointer-events: none;
}

#map .charji-map-dev-off-msg__t {
  margin: 0 0 8px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #14532d;
}

#map .charji-map-dev-off-msg__d {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: #166534;
}

#map .charji-map-fallback-msg {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(92vw, 360px);
  box-sizing: border-box;
  padding: 18px 20px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
  border: 1px solid rgba(15, 23, 42, 0.08);
  text-align: center;
  z-index: 2;
  pointer-events: auto;
}

#map .charji-map-fallback-msg__t {
  margin: 0 0 8px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #0f172a;
}

#map .charji-map-fallback-msg__d {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: #475569;
}

#map .charji-map-fallback-msg__d code {
  font-size: 0.72rem;
  word-break: break-all;
}

/* Marqueurs carte (google.maps.Marker — pastilles via SymbolPath) */
.charji-map-pin-wrap {
  position: relative;
  width: 0;
  height: 0;
  overflow: visible;
}

.charji-map-pin {
  position: absolute;
  left: 0;
  top: 0;
  width: 14px;
  height: 14px;
  margin-left: -7px;
  margin-top: -7px;
  border-radius: 50%;
  border: 2px solid #ffffff;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.28);
  box-sizing: border-box;
}

.charji-map-pin--ev {
  background: #2563eb;
}

.charji-map-pin--fuel {
  background: #f97316;
}

/* Bornes EV — calque OverlayView Google (même ancrage GPS que le point bleu) */
.charji-ev-blips-layer--pass .charji-ev-blip {
  pointer-events: none !important;
}

.charji-ev-blips-layer {
  --charji-blip-fill: #22c98a;
  --charji-blip-a: #3ddc97;
  --charji-blip-m: #22c98a;
  --charji-blip-d: #12b981;
  --charji-blip-ink: #047857;
  --charji-blip-halo: rgba(34, 201, 138, 0.45);
  --charji-blip-body: 28px;
  --charji-blip-radius: 50%;
  --charji-blip-ring: 2px;
  --charji-blip-icon-size: 18px;
  --charji-blip-anchor: 5px;
  --charji-blip-anchor-gap: 2px;
  --charji-blip-stack-h: calc(var(--charji-blip-body) + var(--charji-blip-anchor-gap) + var(--charji-blip-anchor));
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  overflow: visible;
  pointer-events: none;
  z-index: 400;
}

/* Pin : left/top recalculés via OverlayView — pas de transition sur transform */
.charji-ev-blip {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--charji-blip-body);
  height: var(--charji-blip-stack-h);
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  box-sizing: border-box;
  overflow: visible;
  pointer-events: auto;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transform: translate(-50%, -100%);
}

.charji-ev-blip:active .charji-ev-blip__ic {
  filter: brightness(0.94);
}

/* Style Charji : badge circulaire + point d’ancrage GPS */
.charji-ev-blip__pin {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  display: block;
  box-sizing: border-box;
  background: transparent;
  border: none;
}

.charji-ev-blip__ic {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--charji-blip-body);
  height: var(--charji-blip-body);
  aspect-ratio: 1 / 1;
  border-radius: var(--charji-blip-radius);
  background: var(--charji-blip-fill, var(--charji-blip-m));
  border: var(--charji-blip-ring) solid #fff;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
  box-shadow:
    0 3px 10px rgba(15, 23, 42, 0.28),
    0 0 0 2px var(--charji-blip-halo);
}

.charji-ev-blip__pin::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  width: var(--charji-blip-anchor);
  height: var(--charji-blip-anchor);
  margin-left: calc(var(--charji-blip-anchor) / -2);
  border-radius: 50%;
  background: var(--charji-blip-fill, var(--charji-blip-m));
  border: 2px solid #fff;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.22);
  box-sizing: border-box;
}

.charji-ev-blip__svg {
  display: block;
  width: var(--charji-blip-icon-size);
  height: var(--charji-blip-icon-size);
  flex-shrink: 0;
}

.charji-ev-blip__svg path[stroke],
.charji-ev-blip__svg rect[stroke] {
  stroke-width: 2.5;
}

.charji-ev-blip--slow {
  --charji-blip-fill: #64748b;
  --charji-blip-a: #94a3b8;
  --charji-blip-m: #64748b;
  --charji-blip-d: #475569;
  --charji-blip-ink: #475569;
  --charji-blip-halo: rgba(100, 116, 139, 0.42);
  --charji-blip-count-shadow: rgba(71, 85, 105, 0.35);
}

.charji-ev-blip--fast {
  --charji-blip-fill: #22c98a;
  --charji-blip-a: #3ddc97;
  --charji-blip-m: #22c98a;
  --charji-blip-d: #12b981;
  --charji-blip-ink: #12b981;
  --charji-blip-halo: rgba(34, 201, 138, 0.45);
}

.charji-ev-blip--very_fast {
  --charji-blip-fill: #12b981;
  --charji-blip-a: #22c98a;
  --charji-blip-m: #12b981;
  --charji-blip-d: #059669;
  --charji-blip-ink: #059669;
  --charji-blip-halo: rgba(18, 185, 129, 0.48);
}

.charji-ev-blip--ultra {
  --charji-blip-fill: #047857;
  --charji-blip-a: #12b981;
  --charji-blip-m: #047857;
  --charji-blip-d: #065f46;
  --charji-blip-ink: #065f46;
  --charji-blip-halo: rgba(4, 120, 87, 0.5);
}

.charji-ev-blip--cluster {
  --charji-blip-body: 28px;
  --charji-blip-icon-size: 18px;
}

.charji-ev-blip--grid {
  --charji-blip-body: 24px;
  --charji-blip-ring: 2px;
  --charji-blip-icon-size: 15px;
  --charji-blip-anchor: 4px;
}

.charji-ev-blip--grid.charji-ev-blip {
  opacity: 0.96;
}

/* Favori : badge jaune, contour blanc identique. */
.charji-ev-blip--favorite {
  --charji-blip-fill: #eab308;
  --charji-blip-a: #fde047;
  --charji-blip-m: #eab308;
  --charji-blip-d: #ca8a04;
  --charji-blip-ink: #854d0e;
  --charji-blip-halo: rgba(234, 179, 8, 0.48);
  --charji-blip-count-shadow: rgba(133, 77, 14, 0.38);
}

.charji-ev-blip--favorite.charji-ev-blip--slow {
  --charji-blip-fill: #eab308;
  --charji-blip-a: #fde047;
  --charji-blip-m: #eab308;
  --charji-blip-d: #ca8a04;
  --charji-blip-ink: #854d0e;
}

.charji-ev-blip--favorite.charji-ev-blip--ultra {
  --charji-blip-fill: #ca8a04;
  --charji-blip-a: #eab308;
  --charji-blip-m: #ca8a04;
  --charji-blip-d: #a16207;
  --charji-blip-ink: #854d0e;
}

.charji-ev-blip__count {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 50%;
  margin-left: 7px;
  width: 14px;
  height: 14px;
  min-width: 14px;
  padding: 0;
  border-radius: 50%;
  background: var(--charji-blip-ink, var(--charji-blip-d));
  color: #fff;
  font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  font-size: 9px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 14px;
  letter-spacing: -0.04em;
  text-align: center;
  box-sizing: border-box;
  border: none;
  box-shadow: 0 1px 4px var(--charji-blip-count-shadow, rgba(15, 23, 42, 0.35));
}

/* Positionné par OverlayView (left/top + translate -50%) à chaque frame carte */
.charji-user-loc {
  position: absolute;
  width: 56px;
  height: 56px;
  overflow: visible;
  pointer-events: none;
  margin: 0;
  padding: 0;
}

.charji-user-loc--nav {
  width: 56px;
  height: 56px;
}

.charji-user-loc__navSvg {
  display: block;
  overflow: visible;
  filter:
    drop-shadow(0 0 6px rgba(66, 165, 255, 0.45))
    drop-shadow(0 2px 10px rgba(26, 115, 232, 0.28));
}

/* Respiration uniquement sur le faisceau (pas le cercle central) */
.charji-user-loc__auraWrap {
  transform-box: view-box;
  transform-origin: 50% 58.9%;
  animation: charji-nav-aura-breathe 2s cubic-bezier(0.42, 0, 0.58, 1) infinite;
}

.charji-user-loc__auraBeam,
.charji-user-loc__auraWide {
  stroke: none;
}

.charji-user-loc__navCore {
  animation: none;
}

@keyframes charji-nav-aura-breathe {
  0%,
  100% {
    opacity: 0.62;
    transform: scale(0.92);
  }
  50% {
    opacity: 0.96;
    transform: scale(1.1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .charji-user-loc__auraWrap {
    animation: none;
    opacity: 0.65;
    transform: none;
  }
}

.charji-user-loc__core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-left: -8px;
  margin-top: -8px;
  border-radius: 50%;
  background: #2196f3;
  border: 3px solid #ffffff;
  box-shadow: 0 0 0 1px rgba(33, 150, 243, 0.35), 0 2px 10px rgba(33, 150, 243, 0.55);
  z-index: 3;
  box-sizing: border-box;
}

.charji-user-loc__ring {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 52px;
  height: 52px;
  margin-left: -26px;
  margin-top: -26px;
  border-radius: 50%;
  border: 2px solid rgba(33, 150, 243, 0.65);
  background: rgba(33, 150, 243, 0.14);
  transform: scale(0.4);
  transform-origin: center center;
  opacity: 0.85;
  animation: charji-user-loc-pulse 2.1s cubic-bezier(0.22, 0.61, 0.36, 1) infinite;
  z-index: 1;
  box-sizing: border-box;
}

.charji-user-loc__ring--b {
  animation-delay: 1.05s;
}

@keyframes charji-user-loc-pulse {
  0% {
    transform: scale(0.38);
    opacity: 0.88;
  }
  65% {
    opacity: 0.22;
  }
  100% {
    transform: scale(1.12);
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .charji-user-loc__ring {
    animation: none;
    opacity: 0.45;
    transform: scale(0.85);
  }
}

/* GPS : notification centrale + fond flouté */
#appPage.is-geo-unavailable #map {
  filter: blur(6px);
  transition: filter 0.25s ease;
}

#appPage.is-geo-unavailable #overlayMobileRoot {
  filter: blur(5px);
  pointer-events: none;
}

#appPage .charji-geo-toast-host {
  position: fixed;
  inset: 0;
  z-index: 950;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease;
  background: rgba(15, 23, 42, 0.48);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}

#appPage .charji-geo-toast-host.is-visible {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}

#appPage .charji-geo-toast {
  width: min(92vw, 360px);
  padding: 22px 20px 18px;
  border-radius: 20px;
  background: #fff;
  box-shadow:
    0 12px 40px rgba(15, 23, 42, 0.22),
    0 0 0 1px rgba(15, 23, 42, 0.06);
  text-align: center;
}

#appPage .charji-geo-toast__icon {
  width: 52px;
  height: 52px;
  margin: 0 auto 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, #dbeafe 0%, #bfdbfe 100%);
  color: #1d4ed8;
  display: flex;
  align-items: center;
  justify-content: center;
}

#appPage .charji-geo-toast__title {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #0f172a;
}

#appPage .charji-geo-toast__msg {
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.45;
  color: #64748b;
}

#appPage .charji-geo-toast__actions {
  display: flex;
  gap: 10px;
}

#appPage .charji-geo-toast__btn {
  flex: 1;
  min-height: 44px;
  border: none;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

#appPage .charji-geo-toast__btn--ghost {
  background: #f1f5f9;
  color: #475569;
}

#appPage .charji-geo-toast__btn--primary {
  background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
  color: #fff;
}

.ls-map-pin {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.22);
}

.ls-map-pin--ev {
  background: #2563eb;
}

.ls-map-pin--fuel {
  background: #f97316;
}

.ls-user-loc-icon-wrap {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  display: grid;
  place-items: center;
}

.ls-user-loc-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #16a34a;
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.2);
}
