/**
 * VOCALL CSS - Styles complets
 */

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#07070a;--surface:#101014;--surface2:#18181e;--surface3:#222230;--surface4:#2a2a3a;
  --border:#ffffff08;--border2:#ffffff12;--text:#f0f0f5;--text2:#a0a0b0;--text3:#606070;
  --accent:#b8ff00;--accentGlow:rgba(184,255,0,0.15);
  --online:#00e87b;--onlineGlow:rgba(0,232,123,0.2);
  --cafe:#ff8a00;--cafeGlow:rgba(255,138,0,0.15);
  --phone:#5b8cff;--phoneGlow:rgba(91,140,255,0.15);
  --budee:#a855f7;--budeeGlow:rgba(168,85,247,0.2);
  --shop:#ff6b9d;--shopGlow:rgba(255,107,157,0.2);
  --danger:#ff4757;
  --r-xl:24px;--r-lg:16px;--r-md:12px;--r-sm:8px;
  --safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);
  --font:'Outfit',system-ui,sans-serif;--font-d:'Playfair Display',Georgia,serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font)}
img,video{-webkit-user-drag:none;user-select:none}
.marker img{pointer-events:auto}

#map{position:absolute;inset:0;z-index:1}
.leaflet-container{background:var(--bg)!important}
.leaflet-marker-wrapper{background:transparent!important;border:none!important;overflow:visible!important}
.leaflet-div-icon{background:transparent!important;border:none!important;overflow:visible!important}
.leaflet-marker-icon{backface-visibility:hidden;overflow:visible!important}
.leaflet-tile{}
.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right,.mapboxgl-ctrl-top-right{opacity:0.3}

/* ─── Tooltip régions ─── */
.region-tip{
  background:rgba(15,15,20,0.88)!important;
  border:1px solid rgba(99,102,241,0.3)!important;
  color:#c7d2fe!important;
  font-size:12px!important;font-weight:600!important;
  letter-spacing:0.3px;
  padding:6px 14px!important;border-radius:8px!important;
  backdrop-filter:blur(10px);
  box-shadow:0 4px 16px rgba(0,0,0,0.4)!important
}
.region-tip::before{display:none!important}

/* ══════════════════════════════════════════════════════════════════════════ */
/* TOP BAR                                                                     */
/* ══════════════════════════════════════════════════════════════════════════ */
.top{position:fixed;top:0;left:0;right:0;z-index:70;padding:calc(var(--safe-top) + 12px) 16px 14px;display:flex;align-items:center;gap:10px;background:linear-gradient(to bottom,rgba(7,7,10,0.97) 60%,transparent);pointer-events:none}
.top>*{pointer-events:auto}
.logo{font-family:var(--font-d);font-size:24px;font-weight:800;color:var(--accent);letter-spacing:-0.5px}
.sbar{flex:1;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border2);border-radius:50px;padding:10px 16px;backdrop-filter:blur(20px)}
.sbar:focus-within{border-color:rgba(184,255,0,0.3)}
.sbar svg{width:16px;height:16px;color:var(--text3);flex-shrink:0}
.sbar input{flex:1;background:none;border:none;color:var(--text);font-size:14px;outline:none;min-width:0}
.sbar input::placeholder{color:var(--text3)}
.sbar{position:relative}
.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border2);border-radius:16px;max-height:280px;overflow-y:auto;z-index:100;backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,.5)}
.search-dropdown::-webkit-scrollbar{display:none}
.search-dd-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s}
.search-dd-item:hover,.search-dd-item.active{background:rgba(184,255,0,.08)}
.search-dd-item:first-child{border-radius:16px 16px 0 0}
.search-dd-item:last-child{border-radius:0 0 16px 16px}
.search-dd-img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border2);flex-shrink:0}
.search-dd-info{flex:1;min-width:0}
.search-dd-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-dd-name mark{background:rgba(184,255,0,.25);color:var(--accent);border-radius:2px}
.search-dd-ville{font-size:11px;color:var(--text3)}
.search-dd-type{font-size:10px;padding:2px 8px;border-radius:50px;font-weight:600;flex-shrink:0}
.search-dd-type.hiamee{background:rgba(184,255,0,.15);color:var(--accent)}
.search-dd-type.budee{background:rgba(99,102,241,.15);color:#818cf8}
.search-dd-empty{padding:16px;text-align:center;color:var(--text3);font-size:13px}
.ubtn{width:40px;height:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:var(--bg);cursor:pointer;border:none}

/* ══════════════════════════════════════════════════════════════════════════ */
/* CHIPS                                                                       */
/* ══════════════════════════════════════════════════════════════════════════ */
.chips{position:fixed;top:calc(var(--safe-top) + 70px);left:0;right:0;z-index:40;display:flex;gap:8px;padding:0 16px;overflow-x:auto;pointer-events:none;-webkit-mask-image:linear-gradient(90deg,transparent,#000 16px,#000 calc(100% - 16px),transparent)}
.chips::-webkit-scrollbar{display:none}
.chips>*{pointer-events:auto}
.chip{flex-shrink:0;padding:8px 14px;border-radius:50px;font-size:12px;font-weight:600;background:var(--surface);border:1px solid var(--border2);color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:6px;backdrop-filter:blur(10px)}
.chip.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.chip .dot{width:6px;height:6px;border-radius:50%}

/* ══════════════════════════════════════════════════════════════════════════ */
/* STORIES                                                                     */
/* ══════════════════════════════════════════════════════════════════════════ */
.stories{position:fixed;bottom:calc(var(--safe-bottom) + 16px);left:var(--lsb-w,72px);right:0;z-index:40;display:flex;gap:12px;padding:12px 16px;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12px,#000 calc(100% - 12px),transparent)}
.stories::-webkit-scrollbar{display:none}
.story{flex-shrink:0;text-align:center;cursor:pointer}
.story:active{transform:scale(0.95)}
.story-ring{width:64px;height:64px;border-radius:50%;padding:3px;background:var(--surface3)}
.story.on .story-ring{background:conic-gradient(var(--online),var(--accent),var(--online))}
.story-img{width:100%;height:100%;border-radius:50%;overflow:hidden;border:3px solid var(--bg)}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-name{font-size:10px;color:var(--text3);margin-top:4px;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.story.on .story-name{color:var(--online);font-weight:600}

/* ══════════════════════════════════════════════════════════════════════════ */
/* NAV BAR                                                                     */
/* ══════════════════════════════════════════════════════════════════════════ */
.nav{position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--surface);border-top:1px solid var(--border2);padding:8px 0 calc(8px + var(--safe-bottom));display:flex;justify-content:space-around}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 20px;color:var(--text3);font-size:10px;cursor:pointer;border:none;background:none;position:relative}
.nav-item.active{color:var(--accent)}
.nav-item svg{width:24px;height:24px}
.nav-avatar-photo{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);box-shadow:0 0 6px rgba(184,255,0,0.3)}
.nav-item.active .nav-avatar-photo{border-color:var(--accent);box-shadow:0 0 10px rgba(184,255,0,0.5)}
.nav-item.has-notif::after{content:'';position:absolute;top:4px;right:16px;width:8px;height:8px;background:var(--accent);border-radius:50%;animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

/* ══════════════════════════════════════════════════════════════════════════ */
/* SIDEBAR BASE                                                                */
/* ══════════════════════════════════════════════════════════════════════════ */
.sidebar{position:fixed;top:calc(var(--safe-top) + 64px);right:16px;bottom:calc(var(--safe-bottom,0px) + 16px);width:calc(100% - 32px);max-width:400px;background:var(--surface);z-index:70;transform:translateX(calc(100% + 32px));transition:transform 0.4s var(--ease);display:flex;flex-direction:column;border:1px solid var(--border2);border-radius:var(--r-xl);box-shadow:0 8px 40px rgba(0,0,0,0.5);overflow:hidden}
.sidebar.show{transform:translateX(0)}
.sb-close{display:none}

/* SIDEBAR WELCOME */
.sb-welcome{flex:1;display:flex;flex-direction:column;padding:calc(var(--safe-top) + 70px) 24px 24px;overflow-y:auto}
.sb-welcome-icon{font-size:64px;text-align:center;margin-bottom:16px}
.sb-welcome h2{font-family:var(--font-d);font-size:28px;font-weight:800;text-align:center;margin-bottom:12px}
.sb-welcome p{font-size:14px;color:var(--text2);text-align:center;line-height:1.7;margin-bottom:28px}
.sb-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}
.sb-stat{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-md);padding:16px;text-align:center}
.sb-stat-num{font-size:32px;font-weight:800;color:var(--accent)}
.sb-stat-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.sb-features{display:flex;flex-direction:column;gap:12px}
.sb-feat{display:flex;align-items:center;gap:14px;padding:14px;background:var(--surface2);border-radius:var(--r-sm)}
.sb-feat span:first-child{font-size:24px}
.sb-feat span:last-child{font-size:13px;color:var(--text2)}
.sb-feat-btn{cursor:pointer;transition:all 0.2s;border:1px solid transparent}
.sb-feat-btn:hover{background:rgba(34,197,94,0.15);border-color:rgba(34,197,94,0.3)}
.sb-feat-btn:active{transform:scale(0.98)}

/* SIDEBAR PROFILE */
.sb-profile{display:none;flex-direction:column;height:100%}
.sb-profile.show{display:flex}
.sb-media{position:relative;height:300px;background:#000}
.sb-media-photo{position:absolute;inset:0}
.sb-media-photo img{width:100%;height:100%;object-fit:cover}
.sb-media-video{position:absolute;inset:0;opacity:0;transition:opacity 0.4s}
.sb-media-video.active{opacity:1}
.sb-media-video video{width:100%;height:100%;object-fit:cover}
.sb-media-grad{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,var(--surface),transparent);pointer-events:none}
.sb-media-toggle{position:absolute;bottom:16px;left:16px;display:flex;gap:8px}
.sb-media-btn{padding:8px 14px;border-radius:20px;font-size:12px;font-weight:600;border:none;cursor:pointer;background:rgba(0,0,0,0.6);color:#fff;backdrop-filter:blur(10px)}
.sb-media-btn.active{background:var(--accent);color:var(--bg)}
.sb-mute-btn{position:absolute;bottom:16px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,0.6);border:none;color:#fff;font-size:18px;cursor:pointer;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.sb-media-video.active ~ .sb-mute-btn{display:flex}
.sb-info{padding:20px 24px;border-bottom:1px solid var(--border2)}
.sb-info-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.sb-name{font-family:var(--font-d);font-size:28px;font-weight:800}
.sb-rating{display:inline-flex;align-items:center;gap:4px;background:rgba(255,214,0,0.15);color:#ffd600;padding:6px 12px;border-radius:20px;font-size:18px;font-weight:800}
.sb-ville{font-size:14px;color:var(--text2)}
.sb-compat{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:700;letter-spacing:.3px}
.sb-compat .compat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sb-compat .compat-score{font-size:15px;font-weight:800}
.sb-compat.compat-low{background:rgba(239,68,68,.12);color:#ef4444}
.sb-compat.compat-ok{background:rgba(251,191,36,.12);color:#f59e0b}
.sb-compat.compat-good{background:rgba(34,197,94,.12);color:#22c55e}
.sb-compat.compat-best{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(236,72,153,.15));color:#a855f7}
.sb-body{flex:1;overflow-y:auto;padding:20px 24px}
.sb-section{margin-bottom:24px}
.sb-section h4{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}
.sb-desc{font-size:14px;line-height:1.75;color:var(--text2)}
.sb-slots{display:flex;flex-direction:column;gap:10px}
.slot{display:flex;align-items:center;gap:14px;padding:14px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-sm);cursor:pointer;transition:all 0.2s}
.slot:hover{border-color:var(--accent)}
.slot.cafe{border-left:4px solid var(--cafe)}
.slot.phone{border-left:4px solid var(--phone)}
.slot-date{min-width:44px;text-align:center}
.slot-day{font-size:10px;color:var(--text3);text-transform:uppercase;font-weight:600}
.slot-num{font-size:20px;font-weight:800}
.slot-info{flex:1}
.slot-time{font-size:15px;font-weight:600;margin-bottom:2px}
.slot-loc{font-size:12px}
.slot-loc.is-cafe{color:var(--cafe)}
.slot-loc.is-phone{color:var(--phone)}
.slots-more{text-align:center;padding:14px;font-size:13px;color:var(--text3);background:var(--surface2);border-radius:var(--r-sm)}
.slots-more a{color:var(--accent);text-decoration:none;font-weight:600}
.slots-next-date{text-align:center;padding:8px 12px;margin-bottom:6px;font-size:12px;color:#a78bfa;background:rgba(167,139,250,0.08);border-radius:var(--r-sm);border:1px solid rgba(167,139,250,0.15)}
.slots-next-date strong{color:#c4b5fd;font-weight:700}
.blur-text{filter:blur(4px);user-select:none;cursor:pointer;transition:filter 0.3s}
.blur-text:hover::after{content:' 🔒';filter:none}
.slot-loc .blur-text{color:var(--cafe)}
.slot.past{opacity:0.45;pointer-events:none;border-left-color:var(--text3)!important}
.slot.past .slot-num,.slot.past .slot-time{color:var(--text3)}
.slot-past-label{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;margin-top:2px}
.sb-footer{padding:16px 24px calc(16px + var(--safe-bottom));border-top:1px solid var(--border2);display:flex;gap:10px}
.sb-btn{flex:1;padding:16px;border-radius:var(--r-md);font-size:15px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.sb-btn:active{transform:scale(0.97)}
.sb-btn.primary{background:var(--accent);color:var(--bg)}
.sb-btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border2)}

/* SIDEBAR CAFE */
.sb-cafe{display:none;flex-direction:column;height:100%}
.sb-cafe.show{display:flex}
.sb-cafe-media{position:relative;height:280px;background:linear-gradient(135deg,var(--cafe),#c46200);background-size:cover;background-position:center}
.sb-cafe-media-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--surface) 0%,rgba(16,16,20,0.6) 50%,transparent 100%)}
.sb-cafe-media-content{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:2}
.sb-cafe-name{font-family:var(--font-d);font-size:28px;font-weight:800;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
.sb-cafe-addr{font-size:14px;color:var(--text2);text-shadow:0 1px 4px rgba(0,0,0,0.5)}
.sb-cafe-body{flex:1;overflow-y:auto;padding:24px}
.sb-cafe-desc{font-size:14px;line-height:1.7;color:var(--text2);margin-bottom:24px}
.sb-cafe-info{display:flex;flex-direction:column;gap:14px}
.sb-cafe-row{display:flex;align-items:flex-start;gap:14px;font-size:14px;color:var(--text2)}
.sb-cafe-row span:first-child{font-size:20px;width:28px;text-align:center;flex-shrink:0}
.sb-cafe-row a{color:var(--accent);text-decoration:none}

/* CAFE ROUTE PANEL */
.cafe-route-panel {
  padding: 16px 24px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
}
.cafe-route-field {
  margin-bottom: 12px;
}
.cafe-route-field label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,0.45);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.cafe-route-field input {
  width: 100%;
  padding: 10px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  color: #fff;
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
.cafe-route-field input:focus {
  border-color: #ff8a00;
}
.cafe-route-field input::placeholder {
  color: rgba(255,255,255,0.3);
}
.cafe-route-dest {
  font-size: 14px;
  font-weight: 600;
  color: #ff8a00;
  padding: 4px 0;
}
.cafe-route-info {
  display: flex;
  gap: 20px;
  padding: 14px 16px;
  background: rgba(255,138,0,0.08);
  border: 1px solid rgba(255,138,0,0.15);
  border-radius: 12px;
  margin-top: 4px;
}
.cafe-route-stat {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cafe-route-icon {
  font-size: 18px;
}
.cafe-route-stat span:last-child {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
}
/* Marqueur départ itinéraire café */
.cafe-route-start-marker { background: none !important; border: none !important; }
.cr-marker-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.cr-marker-dot.cr-start {
  background: linear-gradient(135deg, #ff8a00, #e65100);
}

/* AVIS HIAMEE — SIDEBAR GLISSANTE */
.reviews-sb-loading {
  padding: 60px 24px;
  text-align: center;
  color: rgba(255,255,255,0.4);
}
.reviews-sb-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(255,255,255,0.1);
  border-top-color: #fbbf24;
  border-radius: 50%;
  margin: 0 auto 16px;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.reviews-sb-empty {
  padding: 60px 24px;
  text-align: center;
  color: rgba(255,255,255,0.35);
  font-size: 14px;
}
.reviews-sb-summary {
  padding: 24px 20px;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
}
.reviews-sb-avg {
  font-size: 42px;
  font-weight: 800;
  color: #fbbf24;
  line-height: 1;
}
.reviews-sb-stars {
  margin: 8px 0 4px;
}
.rv-star {
  font-size: 20px;
  margin: 0 1px;
}
.rv-star-on { color: #fbbf24; }
.rv-star-off { color: rgba(255,255,255,0.15); }
.reviews-sb-count {
  font-size: 13px;
  color: rgba(255,255,255,0.45);
  margin-top: 4px;
}
.reviews-sb-list {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rv-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px;
}
.rv-card-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.rv-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.rv-avatar-letter {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
}
.rv-card-meta {
  flex: 1;
  min-width: 0;
}
.rv-card-name {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
}
.rv-card-date {
  font-size: 11px;
  color: rgba(255,255,255,0.35);
  margin-top: 2px;
}
.rv-card-stars {
  color: #fbbf24;
  font-size: 14px;
  letter-spacing: 1px;
  flex-shrink: 0;
}
.rv-card-comment {
  font-size: 13px;
  color: rgba(255,255,255,0.75);
  line-height: 1.6;
}

/* SIDEBAR EVENT */
.sb-event{display:none;flex-direction:column;height:100%}
.sb-event.show{display:flex}
.sb-event-header{position:relative;height:200px;background:linear-gradient(135deg,#ffd700,#ff8c00);overflow:hidden}
.sb-event-image{width:100%;height:100%;object-fit:cover}
.sb-event-header-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--surface) 0%,rgba(16,16,20,0.5) 50%,transparent 100%)}
.sb-event-badge{position:absolute;top:16px;left:16px;background:rgba(0,0,0,0.6);backdrop-filter:blur(10px);padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;color:#ffd700}
.sb-event-title{position:absolute;bottom:20px;left:20px;right:20px;font-family:var(--font-d);font-size:24px;font-weight:800;text-shadow:0 2px 10px rgba(0,0,0,0.5)}
.sb-event-body{flex:1;overflow-y:auto;padding:20px}
.sb-event-meta{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding:16px;background:var(--surface2);border-radius:var(--r-md)}
.sb-event-row{font-size:14px;color:var(--text2)}
.sb-event-desc{font-size:14px;line-height:1.7;color:var(--text2)}

/* ══════════════════════════════════════════════════════════════════════════ */
/* SIDEBAR SHOP (BOUTIQUE)                                                     */
/* ══════════════════════════════════════════════════════════════════════════ */
.sb-shop{display:none;flex-direction:column;height:100%;width:100%}
.sb-shop.show{display:flex}

/* Header boutique */
.sb-shop-header{position:relative;height:180px;background:linear-gradient(135deg,var(--shop),#c44d7a);background-size:cover;background-position:center;flex-shrink:0}
.sb-shop-header-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--surface) 0%,rgba(16,16,20,0.5) 50%,transparent 100%)}
.sb-shop-header-content{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2}
.sb-shop-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:10px}
.sb-shop-status.open{background:rgba(0,232,123,0.2);color:var(--online)}
.sb-shop-status.closed{background:rgba(255,71,87,0.2);color:var(--danger)}
.sb-shop-name{font-family:var(--font-d);font-size:26px;font-weight:800;margin-bottom:4px;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
.sb-shop-owner{font-size:13px;color:var(--text2);text-shadow:0 1px 4px rgba(0,0,0,0.5)}
.sb-shop-closes{font-size:12px;color:var(--danger);margin-top:6px}

/* Body boutique - grille d'articles */
.sb-shop-body{flex:1;overflow-y:auto;padding:16px}
.sb-shop-desc{font-size:14px;line-height:1.6;color:var(--text2);margin-bottom:16px;padding:0 4px}
.sb-shop-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}

/* Article */
.shop-item{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all 0.2s}
.shop-item:hover{border-color:var(--shop);transform:translateY(-2px)}
.shop-item.out-of-stock{opacity:0.5;pointer-events:none}
.shop-item-img{width:100%;height:100px;object-fit:cover;background:var(--surface3)}
.shop-item-info{padding:12px}
.shop-item-name{font-size:14px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shop-item-price{font-size:16px;font-weight:800;color:var(--shop)}
.shop-item-stock{font-size:11px;color:var(--text3);margin-top:4px}
.shop-item-add{width:100%;padding:10px;background:var(--shop);color:#fff;border:none;border-radius:0 0 var(--r-sm) var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background 0.2s}
.shop-item-add:hover{background:#e05a8a}

/* Panier flottant */
.sb-shop-cart{position:sticky;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border2);padding:16px 20px calc(16px + var(--safe-bottom))}
.sb-shop-cart-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.sb-shop-cart-count{font-size:14px;color:var(--text2)}
.sb-shop-cart-count span{font-weight:700;color:var(--text)}
.sb-shop-cart-total{font-size:20px;font-weight:800;color:var(--shop)}
.sb-shop-cart-timer{font-size:12px;color:var(--danger);text-align:center;margin-bottom:12px;animation:blink 1s infinite}
.sb-shop-cart-btn{width:100%;padding:16px;background:var(--shop);color:#fff;border:none;border-radius:var(--r-md);font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.sb-shop-cart-btn:hover{background:#e05a8a}
.sb-shop-cart-btn:disabled{background:var(--surface3);color:var(--text3);cursor:not-allowed}

/* ══════════════════════════════════════════════════════════════════════════ */
/* MAP MARKERS                                                                 */
/* ══════════════════════════════════════════════════════════════════════════ */
.marker{width:54px;height:54px;cursor:pointer;transition:transform 0.2s;position:relative;overflow:visible}
.marker:hover{transform:scale(1.12);z-index:10}
.marker img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--surface3);box-shadow:0 4px 16px rgba(0,0,0,0.4)}
.marker.online img{border-color:var(--online);box-shadow:0 0 20px var(--onlineGlow)}
.marker.selected img{border-color:var(--accent);box-shadow:0 0 30px var(--accentGlow)}
.marker.selected::before,.marker.selected::after{content:'';position:absolute;top:50%;left:50%;width:54px;height:54px;margin:-27px;border-radius:50%;border:3px solid var(--accent);animation:pulse 1.5s ease-out infinite;pointer-events:none}
.marker.selected::after{border-width:2px;animation-delay:0.5s}
@keyframes pulse{0%{transform:scale(1);opacity:0.8}100%{transform:scale(2.2);opacity:0}}
.marker-dot{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg)}
.marker.online .marker-dot{background:var(--online)}
.marker:not(.online) .marker-dot{background:var(--text3)}
/* ── Couleur marqueur : bleu pastel = position précise (GPS), violet = aléatoire ── */
.marker.precise img{border-color:#89CFF0;box-shadow:0 0 16px rgba(137,207,240,0.35)}
.marker.precise.online img{border-color:#89CFF0;box-shadow:0 0 20px rgba(137,207,240,0.4)}
.marker.precise .marker-dot{background:#89CFF0}
.marker.random img{border-color:#8B5CF6;box-shadow:0 0 14px rgba(139,92,246,0.3)}
.marker.random.online img{border-color:#8B5CF6;box-shadow:0 0 18px rgba(139,92,246,0.35)}
.marker.random .marker-dot{background:#8B5CF6}
.marker.in-session .marker-dot{background:conic-gradient(from 0deg,#3b82f6,#10b981,#06b6d4,#8b5cf6,#3b82f6)!important}

.marker-mood{position:absolute;top:-8px;left:-8px;width:22px;height:22px;font-size:16px;line-height:22px;text-align:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.5));cursor:pointer;z-index:5}
.marker-compat{position:absolute;top:-6px;right:-10px;min-width:28px;height:16px;font-size:9px;font-weight:800;color:#000;background:#facc15;line-height:16px;text-align:center;padding:0 4px;border-radius:8px;box-shadow:0 1px 4px rgba(0,0,0,.3);z-index:6}
.marker-countdown{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);background:#ff4757;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:8px;white-space:nowrap;box-shadow:0 2px 6px rgba(255,71,87,0.5);animation:countdown-pulse 2s ease-in-out infinite}
@keyframes countdown-pulse{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.05)}}

/* ── In-session : pastille animée style story sur marqueur carte ── */
.marker.in-session .marker-dot{background:conic-gradient(from 0deg,#3b82f6,#10b981,#06b6d4,#8b5cf6,#3b82f6);animation:halo-spin 3s linear infinite;width:16px;height:16px;border:2px solid var(--bg)}
@keyframes halo-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.marker-rdv-tag{position:absolute;top:-10px;right:-12px;background:linear-gradient(135deg,#3b82f6,#10b981);color:#fff;font-size:9px;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:0.5px;box-shadow:0 2px 8px rgba(59,130,246,0.5);z-index:10;white-space:nowrap}

/* ── Friends filter : courbes de compatibilité ── */
.friends-curves-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:400}
.friends-curves-layer svg{width:100%;height:100%}
.friends-legend{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);background:rgba(15,15,25,.92);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:10px 16px;display:flex;gap:16px;align-items:center;z-index:450;box-shadow:0 6px 24px rgba(0,0,0,.4)}
.friends-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#ddd;font-weight:500}
.friends-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.friends-legend-title{font-size:12px;font-weight:700;color:#fff;letter-spacing:.5px}
@keyframes friends-curve-draw{from{stroke-dashoffset:1000}to{stroke-dashoffset:0}}

/* ── Label TAXI texte (voitures SVG pendant les rides actifs) ── */
.taxi-label{
  position:absolute;
  bottom:-12px;
  left:50%;
  transform:translateX(-50%);
  background:#fbbf24;
  color:#000;
  font-size:8px;
  font-weight:900;
  font-family:'Outfit',Arial,sans-serif;
  letter-spacing:1.2px;
  text-transform:uppercase;
  padding:1px 6px;
  border-radius:3px;
  white-space:nowrap;
  line-height:1.3;
  box-shadow:0 1px 4px rgba(0,0,0,0.4);
  z-index:12;
  pointer-events:none;
}
.ck-car-icon .taxi-label{bottom:-14px;font-size:7px;padding:1px 5px}
.r3d-car-icon .taxi-label{bottom:-10px;font-size:8px}
.ride-car .taxi-label{position:relative;bottom:auto;left:auto;transform:none;margin-top:-6px;font-size:7px;padding:1px 5px}

/* ── In-session : story ring animé dans la liste du bas ── */
.story{position:relative}
.story.in-session .story-ring{background:conic-gradient(from 0deg,#3b82f6,#10b981,#06b6d4,#8b5cf6,#3b82f6);animation:halo-spin 3s linear infinite}
.story-rdv-tag{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#3b82f6,#10b981);color:#fff;font-size:8px;font-weight:800;padding:1px 5px;border-radius:5px;letter-spacing:0.4px;box-shadow:0 2px 6px rgba(59,130,246,0.4);z-index:5;white-space:nowrap}

/* ── Marqueur "Vous êtes ici" — position BDD de l'utilisateur connecté ── */
.my-position-marker{position:relative;display:flex;flex-direction:column;align-items:center}
.my-position-marker img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 20px var(--accentGlow);z-index:2}
.my-position-label{background:var(--accent);color:var(--bg);font-size:9px;font-weight:800;padding:2px 8px;border-radius:6px;white-space:nowrap;margin-top:2px;letter-spacing:0.3px;box-shadow:0 2px 8px rgba(184,255,0,0.4);z-index:2}
.my-position-pulse{position:absolute;top:50%;left:50%;width:44px;height:44px;margin:-22px 0 0 -22px;border-radius:50%;border:2px solid var(--accent);animation:pulse 2s ease-out infinite;pointer-events:none}

.user-marker{width:20px;height:20px;background:var(--accent);border-radius:50%;border:4px solid #fff;box-shadow:0 0 20px var(--accentGlow)}
.user-marker::before{content:'';position:absolute;inset:-10px;border-radius:50%;border:2px solid var(--accent);animation:pulse 2s ease-out infinite}

.cafe-marker{width:40px;height:40px;background:var(--cafe);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px var(--cafeGlow);cursor:pointer;transition:transform 0.2s;border:3px solid rgba(255,255,255,0.2);position:relative}
.cafe-marker:hover{transform:scale(1.15)}
.cafe-marker.selected{border-color:#fff;box-shadow:0 0 30px var(--cafe)}
.cafe-marker .cafe-star{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#00bfff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;box-shadow:0 2px 8px rgba(0,191,255,0.5);border:2px solid #fff}

.budee-marker{width:40px!important;height:40px!important;min-width:40px;min-height:40px;background:var(--budee)!important;border-radius:50%!important;display:flex!important;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;box-shadow:0 2px 12px var(--budeeGlow);opacity:1;transition:all 0.2s;position:relative!important;cursor:pointer;overflow:visible}
.budee-marker:hover{opacity:1;transform:scale(1.1)}

/* Event marker avec PULSE */
.event-marker{width:44px;height:44px;background:linear-gradient(135deg,#ffd700,#ffb800);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px rgba(255,215,0,0.5);cursor:pointer;transition:transform 0.2s;border:3px solid #fff;position:relative}
.event-marker::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid #ffd700;animation:event-pulse 1.5s ease-out infinite;pointer-events:none}
.event-marker::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid #ffd700;animation:event-pulse 1.5s ease-out infinite 0.5s;pointer-events:none}
@keyframes event-pulse{0%{transform:scale(1);opacity:0.8}100%{transform:scale(1.8);opacity:0}}
.event-marker:hover{transform:scale(1.15)}
.event-marker.selected{box-shadow:0 0 30px rgba(255,215,0,0.6)}
.event-marker .event-star{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#00bfff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 2px 8px rgba(0,191,255,0.5);border:2px solid #fff;z-index:2}

/* SHOP MARKER - Boutique éphémère */
.shop-marker{width:44px;height:44px;background:linear-gradient(135deg,var(--shop),#c44d7a);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 20px var(--shopGlow);cursor:pointer;transition:transform 0.2s;border:3px solid #fff;position:relative}
.shop-marker::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--shop);animation:shop-sparkle 2s ease-in-out infinite;pointer-events:none}
@keyframes shop-sparkle{0%,100%{transform:scale(1);opacity:0.6}50%{transform:scale(1.3);opacity:0}}
.shop-marker:hover{transform:scale(1.15)}
.shop-marker.selected{box-shadow:0 0 30px var(--shop)}
.shop-marker.closed{opacity:0.5;filter:grayscale(0.5)}
.shop-marker.closed::before{display:none}
.shop-marker .shop-count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--bg);box-shadow:0 2px 8px rgba(184,255,0,0.5);border:2px solid #fff;padding:0 4px}

/* ══════════════════════════════════════════════════════════════════════════ */
/* RTIP — Raavyn Talking In Progress (sessions live sur la carte)              */
/* ══════════════════════════════════════════════════════════════════════════ */
.rtip-marker{position:relative;display:flex;align-items:center;cursor:pointer}
.rtip-photos{display:flex;align-items:center}
.rtip-photo{width:30px;height:30px;border-radius:50%;border:2px solid #a78bfa;object-fit:cover;box-shadow:0 2px 10px rgba(167,139,250,0.5)}
.rtip-photo:last-child{margin-left:-10px;border-color:#c084fc}
.rtip-pulse{position:absolute;inset:-5px;border-radius:20px;border:2px solid #a78bfa;animation:rtip-glow 1.8s ease-in-out infinite;pointer-events:none}
@keyframes rtip-glow{0%,100%{opacity:0.5;transform:scale(1)}50%{opacity:0;transform:scale(1.4)}}
.rtip-label{position:absolute;top:-18px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;font-size:8px;font-weight:900;letter-spacing:1.5px;padding:2px 6px;border-radius:6px;white-space:nowrap;box-shadow:0 2px 8px rgba(124,58,237,0.5)}
.rtip-label::after{content:'';position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #a855f7}
.rtip-tip-container{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}
.rtip-tip-container::before{display:none!important}
.rtip-tooltip{background:rgba(15,23,42,0.92);border:1px solid rgba(167,139,250,0.4);border-radius:10px;padding:5px 10px;color:#e9d5ff;font-size:11px;font-weight:600;white-space:nowrap}

/* ══════════════════════════════════════════════════════════════════════════ */
/* PASSDIAL MAP MARKER                                                         */
/* ══════════════════════════════════════════════════════════════════════════ */
.passdial-marker{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer}
.pd-marker-inner{width:48px;height:48px;background:linear-gradient(135deg,#a855f7,#7c3aed);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 20px rgba(168,85,247,0.5);border:3px solid #fff;transition:transform 0.2s;animation:pd-pulse 2.5s ease-in-out infinite}
.passdial-marker:hover .pd-marker-inner{transform:scale(1.15)}
.pd-marker-label{margin-top:4px;font-size:10px;font-weight:700;color:#a855f7;text-shadow:0 1px 4px rgba(0,0,0,0.8);letter-spacing:0.5px}
@keyframes pd-pulse{0%,100%{box-shadow:0 4px 20px rgba(168,85,247,0.5),0 0 0 4px rgba(168,85,247,0.15)}50%{box-shadow:0 4px 28px rgba(168,85,247,0.7),0 0 0 10px rgba(168,85,247,0.1)}}

/* FAQ MAP MARKER — Créteil */
.faq-map-marker{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer}
.faq-marker-inner{width:52px;height:52px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 20px rgba(59,130,246,0.5);border:3px solid #fff;transition:transform 0.2s;animation:faq-pulse 2.5s ease-in-out infinite}
.faq-map-marker:hover .faq-marker-inner{transform:scale(1.15)}
.faq-marker-label{margin-top:4px;font-size:11px;font-weight:700;color:#3b82f6;text-shadow:0 1px 4px rgba(0,0,0,0.8);letter-spacing:0.5px}
@keyframes faq-pulse{0%,100%{box-shadow:0 4px 20px rgba(59,130,246,0.5),0 0 0 4px rgba(59,130,246,0.15)}50%{box-shadow:0 4px 28px rgba(59,130,246,0.7),0 0 0 10px rgba(59,130,246,0.1)}}

/* PASSDIAL SIDEBAR PANEL */
.sb-passdial{display:none;flex-direction:column;height:100%;width:100%}
.sb-passdial.show{display:flex}
.sb-passdial-header{position:relative;height:160px;background:linear-gradient(135deg,#a855f7,#7c3aed,#6d28d9);flex-shrink:0}
.sb-passdial-header-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--surface) 0%,rgba(16,16,20,0.4) 50%,transparent 100%)}
.sb-passdial-header-content{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2}
.sb-passdial-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:8px;background:rgba(0,232,123,0.2);color:var(--online)}
.sb-passdial-name{font-family:var(--font-d);font-size:26px;font-weight:800;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
.sb-passdial-addr{font-size:13px;color:var(--text2);margin-top:4px;text-shadow:0 1px 4px rgba(0,0,0,0.5)}
.sb-passdial-body{flex:1;overflow-y:auto;padding:16px}
.sb-passdial-intro{padding:0 4px 16px;font-size:14px;line-height:1.6;color:var(--text2)}
.sb-passdial-intro strong{color:#a855f7}

/* Current subscription badge */
.pd-current{background:rgba(168,85,247,0.1);border:1px solid rgba(168,85,247,0.3);border-radius:12px;padding:16px;margin-bottom:16px}
.pd-current-badge{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.pd-badge-icon{font-size:32px}
.pd-badge-info{flex:1}
.pd-badge-title{font-size:15px;font-weight:700;color:#a855f7}
.pd-badge-detail{font-size:12px;color:var(--text2);margin-top:2px;line-height:1.4}
.pd-manage-btn{width:100%;padding:12px;background:rgba(168,85,247,0.2);border:1px solid rgba(168,85,247,0.4);border-radius:8px;color:#a855f7;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.2s}
.pd-manage-btn:hover{background:rgba(168,85,247,0.3)}

/* Offer cards */
.pd-offers{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.pd-offer-card{position:relative;background:rgba(255,255,255,0.04);border:2px solid rgba(255,255,255,0.08);border-radius:14px;padding:20px;cursor:pointer;transition:all 0.2s;text-align:center}
.pd-offer-card:hover{background:rgba(168,85,247,0.08);border-color:rgba(168,85,247,0.3)}
.pd-offer-badge{position:absolute;top:-8px;right:14px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:0.5px}
.pd-offer-icon{font-size:36px;margin-bottom:8px}
.pd-offer-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:6px}
.pd-offer-price{font-size:28px;font-weight:800;color:#a855f7;margin-bottom:6px}
.pd-offer-price small{font-size:13px;font-weight:500;color:var(--text2);margin-left:2px}
.pd-offer-desc{font-size:12px;color:var(--text3);line-height:1.4;margin-bottom:14px}
.pd-offer-btn{padding:12px 24px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s;width:100%}
.pd-offer-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(168,85,247,0.4)}
.pd-offer-btn-alt{background:rgba(168,85,247,0.2);color:#a855f7;border:1px solid rgba(168,85,247,0.4)}
.pd-offer-btn-alt:hover{background:rgba(168,85,247,0.3);box-shadow:none}

/* Features list */
.pd-features{display:flex;flex-direction:column;gap:8px;padding:12px 0}
.pd-feat{font-size:13px;color:var(--text2);padding:6px 4px}

/* ══════════════════════════════════════════════════════════════════════════ */
/* BUS MARKER - Vue de dessus style Waze                                       */
/* ══════════════════════════════════════════════════════════════════════════ */
.bus-icon-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.bus-icon-car{transition:transform 0.3s ease-out;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.4))}
.bus-icon-car svg{display:block}
.bus-marker-wrapper{background:transparent!important}

/* TRAFFIC — Voitures/taxis virtuels animés */
.traffic-marker-wrap{background:transparent!important;border:none!important}
.traffic-car-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;transition:transform 0.8s linear;filter:drop-shadow(0 1px 3px rgba(0,0,0,0.4))}
.traffic-car-icon svg{display:block}
.traffic-car-icon .taxi-label{position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);background:#fbbf24;color:#000;font-size:7px;font-weight:900;padding:1px 4px;border-radius:2px;white-space:nowrap;letter-spacing:0.5px}

/* GARE MARKER - Paris Bercy */
.gare-marker{width:48px;height:48px;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 15px rgba(99,102,241,0.5);cursor:pointer;border:3px solid #fff;position:relative}
.gare-marker:hover{transform:scale(1.1)}
.gare-marker.paris::after{content:'Paris';position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:700;color:#fff;background:rgba(0,0,0,0.7);padding:2px 6px;border-radius:4px;white-space:nowrap}

/* BUREAU MARKER - Le Mans */
.bureau-marker{width:56px;height:56px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 4px 25px rgba(245,158,11,0.5);cursor:pointer;transition:transform 0.2s;border:4px solid #fff;position:relative}
.bureau-marker:hover{transform:scale(1.1)}
.bureau-marker::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:3px solid #f59e0b;animation:bureau-pulse 3s ease-in-out infinite;pointer-events:none}
@keyframes bureau-pulse{0%,100%{transform:scale(1);opacity:0.8}50%{transform:scale(1.2);opacity:0}}

/* PRISON MARKER */
.prison-marker{width:44px;height:44px;background:linear-gradient(135deg,#4b5563,#1f2937);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 15px rgba(0,0,0,0.5);cursor:pointer;border:3px solid #6b7280;position:relative}
.prison-marker::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 4px,rgba(0,0,0,0.3) 4px,rgba(0,0,0,0.3) 6px);border-radius:5px;pointer-events:none}

/* BUS ROUTE */
.bus-route{stroke-linecap:round}

/* ══════════════════════════════════════════════════════════════════════════ */
/* SIDEBAR GARE (Paris Bercy / Le Mans)                                        */
/* ══════════════════════════════════════════════════════════════════════════ */
.sb-gare{display:none;flex-direction:column;height:100%}
.sb-gare.show{display:flex}

.sb-gare-header{position:relative;height:160px;background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px}
.sb-gare-icon{font-size:48px;margin-bottom:8px}
.sb-gare-title{font-family:var(--font-d);font-size:22px;font-weight:800}
.sb-gare-subtitle{font-size:14px;color:rgba(255,255,255,0.8);margin-top:4px}

.gare-tabs{display:flex;border-bottom:1px solid var(--border2);background:var(--surface)}
.gare-tab{flex:1;padding:12px;background:none;border:none;color:var(--text2);font-size:14px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s}
.gare-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.gare-tab:hover{color:var(--text)}

.sb-gare-body{flex:1;overflow-y:auto;padding:20px}

.gare-section-title{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin:0 0 12px;display:flex;align-items:center;gap:8px}

.gare-schedules{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}
.schedule-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface2);border-radius:var(--r-sm);font-size:14px}
.schedule-row.completed{opacity:0.4}
.schedule-row.en-route,.schedule-row.returning{background:rgba(59,130,246,0.15);border-left:3px solid #3b82f6}
.schedule-row.embarquement{background:rgba(34,197,94,0.15);border-left:3px solid #22c55e}
.schedule-row .schedule-time{font-weight:700;min-width:45px}
.schedule-row .schedule-arrow{color:var(--text3);font-size:12px}
.schedule-row .schedule-arrival{min-width:45px}
.schedule-row .schedule-status{font-size:14px;margin-left:auto}
.schedule-row .schedule-passengers{font-size:11px;color:var(--text3);min-width:40px;text-align:right}
.schedule-row .schedule-dir{font-size:12px}

.passenger-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface2);border-radius:var(--r-sm);margin-bottom:6px}
.passenger-seat{font-size:13px;min-width:40px}
.passenger-name{flex:1;font-weight:600}
.passenger-ville{font-size:12px;color:var(--text3)}
.empty{text-align:center;padding:20px;color:var(--text3);font-size:14px}

.gare-info{display:flex;flex-direction:column;gap:8px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border2)}
.gare-info-row{display:flex;justify-content:space-between;font-size:14px}
.gare-info-row span:first-child{color:var(--text3)}
.gare-info-row span:last-child{font-weight:600}

/* Tableau de départs style aéroport */
.departure-board{background:#0a0a0a;border-radius:var(--r-md);overflow:hidden;font-family:'Courier New',monospace}
.departure-header{display:flex;padding:10px 12px;background:#1a1a1a;font-size:11px;font-weight:700;color:#666;text-transform:uppercase;letter-spacing:1px}
.dep-h-time{width:60px}
.dep-h-dest{flex:1}
.dep-h-status{width:100px;text-align:right}

.departure-row{display:flex;align-items:center;padding:12px;border-bottom:1px solid #1a1a1a;cursor:pointer;transition:background 0.2s}
.departure-row:hover{background:#1a1a1a}
.departure-row.boarding{background:rgba(34,197,94,0.1)}
.departure-row.boarding:hover{background:rgba(34,197,94,0.2)}
.departure-row.departed{opacity:0.6}

.dep-time{width:60px;font-size:18px;font-weight:700;color:#fff}
.dep-dest{flex:1;font-size:14px;font-weight:600;color:#fff}
.departure-row.to-lemans .dep-dest::before{content:'🔵 ';font-size:10px}
.departure-row.to-paris .dep-dest::before{content:'🟢 ';font-size:10px}

.dep-status{width:100px;text-align:right;font-size:11px;font-weight:700;padding:4px 8px;border-radius:4px}
.dep-status.boarding{background:#22c55e;color:#000;animation:blink 1s infinite}
.dep-status.closing{background:#f59e0b;color:#000;animation:blink 0.5s infinite}
.dep-status.enroute{background:#3b82f6;color:#fff}
.dep-status.scheduled{background:#333;color:#888}

.departure-row.clickable{cursor:pointer}
.departure-row.clickable:hover{background:rgba(34,197,94,0.2)}

@keyframes blink{0%,100%{opacity:1}50%{opacity:0.7}}

/* Modal achat ticket */
.ticket-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:200;align-items:center;justify-content:center;padding:20px}
.ticket-modal.show{display:flex}
.ticket-content{background:var(--surface);border-radius:var(--r-lg);padding:24px;max-width:360px;width:100%;text-align:center}
.ticket-icon{font-size:48px;margin-bottom:16px}
.ticket-dest{font-family:var(--font-d);font-size:24px;font-weight:800;margin-bottom:8px}
.ticket-heure{font-size:32px;font-weight:700;color:var(--accent);margin-bottom:8px}
.ticket-places{font-size:14px;color:var(--text3);margin-bottom:24px}
.ticket-price{font-size:20px;font-weight:700;margin-bottom:24px}
.ticket-btn{width:100%;padding:16px;background:var(--accent);color:#000;border:none;border-radius:var(--r-md);font-size:16px;font-weight:700;cursor:pointer}
.ticket-btn:hover{background:#a3e600}
.ticket-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:24px;cursor:pointer}

/* Bouton météo */
.meteo-btn{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,0.1);font-size:18px;cursor:pointer;transition:all 0.2s;opacity:0.5}
.meteo-btn.active{opacity:1;background:rgba(59,130,246,0.3)}
.meteo-btn:hover{background:rgba(255,255,255,0.2)}

/* ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════ */
/* INTERFACE IMMERSIVE BUS                                                     */
/* ══════════════════════════════════════════════════════════════════════════ */

/* Header compact */
.bus-imm-header{display:flex;align-items:flex-start;gap:12px;padding:16px;background:linear-gradient(135deg,#1e3a5f,#0f172a);position:relative}
.bus-imm-info{flex:1}
.bus-imm-label{display:block;font-size:10px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:1px}
.bus-imm-dest{display:block;font-size:20px;font-weight:800;font-family:var(--font-d);margin-top:2px}
.bus-imm-stats{display:flex;gap:16px;align-items:center}
.bus-imm-speed{text-align:center}
.speed-value{font-size:28px;font-weight:800;font-family:'Courier New',monospace;color:#22c55e;line-height:1}
.speed-unit{display:block;font-size:10px;color:var(--text3)}
.bus-imm-time,.bus-imm-km{display:flex;flex-direction:column;align-items:center;font-size:12px;gap:2px}
.bus-imm-time span:last-child,.bus-imm-km span:last-child{font-weight:700;font-family:'Courier New',monospace}
.bus-imm-close{position:absolute;top:12px;right:12px;background:rgba(255,255,255,0.1);border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer}
.bus-imm-close:hover{background:rgba(255,255,255,0.2)}

/* Barre de progression */
.bus-imm-progress{padding:16px}
.bus-imm-progress-bar{position:relative;height:6px;background:rgba(255,255,255,0.1);border-radius:3px;overflow:visible}
.bus-imm-progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#3b82f6);border-radius:3px;transition:width 1s}
.bus-imm-progress-bus{position:absolute;top:-10px;transform:translateX(-50%);font-size:20px;transition:left 1s}
.bus-imm-progress-labels{display:flex;justify-content:space-between;margin-top:6px;font-size:11px;color:var(--text3)}

/* Section sièges */
.bus-imm-seats-section{padding:0 16px 16px}
.bus-imm-seats-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600}
.seats-count{font-weight:400;color:var(--text3);font-size:12px}

/* Container bus avec sièges */
.bus-seats-container{background:rgba(0,0,0,0.3);border-radius:12px;padding:12px;max-width:260px;margin:0 auto}
.bus-front{text-align:center;font-size:11px;color:var(--text3);margin-bottom:10px;padding-bottom:8px;border-bottom:1px dashed rgba(255,255,255,0.2)}

/* Rangée de sièges : 2 | allée | 2 */
.bus-seat-row{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:6px;margin-bottom:6px}
.bus-aisle{width:24px;height:48px}

/* Siège individuel */
.bus-seat{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all 0.2s}
.bus-seat.empty{background:rgba(255,255,255,0.05);color:var(--text3);border:2px dashed rgba(255,255,255,0.15)}
.bus-seat.occupied{background:var(--accent);padding:3px}
.bus-seat.occupied img{width:100%;height:100%;border-radius:6px;object-fit:cover}

/* Légende */
.bus-seats-legend{display:flex;justify-content:center;gap:20px;margin-top:12px;font-size:11px;color:var(--text3)}
.legend-empty,.legend-occupied{display:inline-block;width:14px;height:14px;border-radius:4px;vertical-align:middle;margin-right:6px}
.legend-empty{background:rgba(255,255,255,0.05);border:2px dashed rgba(255,255,255,0.15)}
.legend-occupied{background:var(--accent)}
.bus-immersive-header{padding:calc(var(--safe-top) + 16px) 20px 16px;display:flex;justify-content:space-between;align-items:center;background:rgba(0,0,0,0.5);position:absolute;top:0;left:0;right:0;z-index:10}
.bus-immersive-seat{font-size:18px;font-weight:700}
.bus-immersive-close{background:rgba(255,255,255,0.2);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer}
.bus-immersive-video{flex:1;object-fit:cover}
.bus-immersive-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(transparent,rgba(0,0,0,0.8))}
.bus-immersive-progress{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.bus-immersive-bar{flex:1;height:4px;background:rgba(255,255,255,0.2);border-radius:2px;overflow:hidden}
.bus-immersive-fill{height:100%;background:var(--accent);transition:width 1s}
.bus-immersive-time{font-size:14px;color:#fff}

.gare-desc{font-size:14px;line-height:1.7;color:var(--text2);margin-bottom:20px}

.gare-steps{display:flex;flex-direction:column;gap:12px}
.gare-step{display:flex;align-items:center;gap:12px;font-size:14px}
.gare-step span{width:28px;height:28px;background:var(--accent);color:var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}

.bureau-section{display:none}
.bureau-section.show{display:block}

/* ══════════════════════════════════════════════════════════════════════════ */
/* MOBILE                                                                      */
/* ══════════════════════════════════════════════════════════════════════════ */
.mobile-sheet{position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;transform:translateY(100%);transition:transform 0.4s var(--ease);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 -10px 50px rgba(0,0,0,0.5)}
.mobile-sheet.show{transform:translateY(0)}
.ms-grab{display:flex;justify-content:center;padding:12px 0 8px;cursor:grab}
.ms-bar{width:40px;height:4px;background:var(--surface4);border-radius:2px}
.ms-media{height:180px;position:relative;overflow:hidden}
.ms-media img{width:100%;height:100%;object-fit:cover}
.ms-media-grad{position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to top,var(--surface),transparent)}
.ms-header{padding:0 20px 12px;margin-top:-24px;position:relative;display:flex;align-items:flex-end;gap:12px}
.ms-name{font-family:var(--font-d);font-size:24px;font-weight:800}
.ms-rating{background:rgba(255,214,0,0.15);color:#ffd600;padding:4px 10px;border-radius:16px;font-size:14px;font-weight:800}
.ms-body{padding:0 20px 16px;flex:1;overflow-y:auto}
.ms-ville{font-size:13px;color:var(--text2);margin-bottom:12px}
.ms-desc{font-size:14px;line-height:1.6;color:var(--text2);margin-bottom:16px}
.ms-slots{display:flex;flex-direction:column;gap:8px}
.ms-footer{padding:16px 20px calc(16px + var(--safe-bottom));border-top:1px solid var(--border2);display:flex;gap:10px}
.ms-btn{flex:1;padding:14px;border-radius:var(--r-md);font-size:14px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.ms-btn.primary{background:var(--accent);color:var(--bg)}
.ms-btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border2)}

/* CALL SCREEN */
.call-screen{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;background:linear-gradient(180deg,#0a1630,#07070a)}
.call-screen.show{display:flex}
.call-content{text-align:center;padding:40px}
.call-avatar{width:140px;height:140px;border-radius:50%;overflow:hidden;margin:0 auto 28px;border:4px solid var(--accent);box-shadow:0 0 60px var(--accentGlow);animation:call-pulse 2s infinite}
.call-avatar img{width:100%;height:100%;object-fit:cover}
@keyframes call-pulse{0%,100%{box-shadow:0 0 0 0 rgba(184,255,0,0.4)}50%{box-shadow:0 0 0 30px rgba(184,255,0,0)}}
.call-name{font-family:var(--font-d);font-size:32px;font-weight:800;margin-bottom:8px}
.call-status{font-size:14px;color:var(--accent);margin-bottom:24px}
.call-timer{font-size:56px;font-weight:200;color:var(--text2);letter-spacing:4px;font-variant-numeric:tabular-nums;margin-bottom:48px}
.call-actions{display:flex;justify-content:center;gap:28px}
.call-btn{width:64px;height:64px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer}
.call-btn:active{transform:scale(0.9)}
.call-btn.mute,.call-btn.speaker{background:var(--surface3);color:var(--text)}
.call-btn.hangup{background:var(--danger);color:#fff}

/* MOOD BUBBLE */
.mood-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);z-index:100;opacity:0;visibility:hidden;transition:all 0.3s}
.mood-overlay.show{opacity:1;visibility:visible}
.mood-bubble{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.8);z-index:101;opacity:0;visibility:hidden;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1)}
.mood-bubble.show{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.mood-cloud{position:relative;background:linear-gradient(145deg,#ffffff,#f0f0f5);border-radius:30px;padding:30px 35px;min-width:260px;max-width:320px;box-shadow:0 25px 80px rgba(0,0,0,0.4),inset 0 2px 0 rgba(255,255,255,0.9);text-align:center}
.mood-cloud::before,.mood-cloud::after{content:'';position:absolute;background:linear-gradient(145deg,#ffffff,#f0f0f5);border-radius:50%;box-shadow:0 10px 30px rgba(0,0,0,0.15),inset 0 2px 0 rgba(255,255,255,0.8)}
.mood-cloud::before{width:45px;height:45px;bottom:-12px;left:35px}
.mood-cloud::after{width:25px;height:25px;bottom:-30px;left:18px}
.mood-photo{width:65px;height:65px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 4px 15px rgba(184,255,0,0.3);margin-bottom:12px}
.mood-name{font-family:var(--font-d);font-size:20px;font-weight:700;color:#1a1a2e;margin-bottom:4px}
.mood-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px}
.mood-emoji{font-size:45px;margin-bottom:12px;animation:mood-bounce 2s ease-in-out infinite}
@keyframes mood-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.mood-text{font-size:15px;line-height:1.6;color:#333;font-style:italic;padding:14px 18px;background:rgba(184,255,0,0.15);border-radius:12px;border-left:3px solid var(--accent);margin-bottom:18px;text-align:left}
.mood-date{font-size:10px;color:#aaa;margin-bottom:15px}
.mood-close{position:absolute;top:-12px;right:-12px;width:34px;height:34px;background:#1a1a2e;border:none;border-radius:50%;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(0,0,0,0.3);transition:all 0.2s}
.mood-close:hover{transform:scale(1.1);background:var(--accent);color:#1a1a2e}
.mood-action{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;background:#1a1a2e;color:#fff;border:none;border-radius:25px;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s}
.mood-action:hover{background:var(--accent);color:#1a1a2e;transform:translateY(-2px);box-shadow:0 5px 20px rgba(184,255,0,0.4)}

/* ══════════════════════════════════════════════════════════════════════════ */
/* BUDEE MARKERS - Photo par-dessus lettre + pastille rouge + prénom            */
/* ══════════════════════════════════════════════════════════════════════════ */
.budee-marker .budee-photo{position:absolute;top:0;left:0;width:40px!important;height:40px!important;border-radius:50%!important;object-fit:cover;z-index:1}
.budee-name{position:absolute;top:100%;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,0.9);margin-top:3px;pointer-events:none;z-index:2}
.budee-mood{position:absolute;top:-12px;left:-12px;font-size:16px;line-height:1;filter:drop-shadow(0 1px 4px rgba(0,0,0,0.6));pointer-events:none;z-index:3}
.budee-mood-badge{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#e53e3e;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 8px rgba(229,62,62,0.6);animation:badge-pulse 2s ease-in-out infinite;z-index:3}
.budee-audio-badge{position:absolute;bottom:-6px;right:-6px;font-size:10px;width:20px;height:20px;background:var(--cafe);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff;box-shadow:0 2px 8px rgba(255,138,0,0.5);z-index:3}
.budee-pass-star{position:absolute;top:-8px;left:-4px;font-size:12px;z-index:4;filter:drop-shadow(0 1px 3px rgba(168,85,247,0.8));animation:pass-star-glow 2s ease-in-out infinite}
@keyframes pass-star-glow{0%,100%{filter:drop-shadow(0 1px 3px rgba(168,85,247,0.8))}50%{filter:drop-shadow(0 2px 8px rgba(168,85,247,1))}}
@keyframes badge-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}

/* ══════════════════════════════════════════════════════════════════════════ */
/* BUDEE POPUP - Écoute vocal + message soutien                                */
/* ══════════════════════════════════════════════════════════════════════════ */
.budee-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);z-index:150;opacity:0;visibility:hidden;transition:all 0.3s;pointer-events:none}
.budee-overlay.show{opacity:1;visibility:visible;pointer-events:auto}

.budee-popup{position:fixed;bottom:0;left:0;right:0;z-index:151;transform:translateY(100%);transition:transform 0.4s var(--ease);max-height:85vh;overflow-y:auto;pointer-events:none}
.budee-popup.show{transform:translateY(0);pointer-events:auto}

.bp-content{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:24px 20px calc(20px + var(--safe-bottom));position:relative}
.bp-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:var(--surface2);border:1px solid var(--border2);border-radius:50%;color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:all 0.2s}
.bp-close:hover{background:var(--surface3)}

.bp-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.bp-photo{width:56px;height:56px;border-radius:50%;object-fit:cover;border:3px solid var(--cafe);box-shadow:0 4px 12px rgba(255,138,0,0.3);flex-shrink:0}
.bp-letter{width:56px;height:56px;border-radius:50%;background:var(--budee);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;box-shadow:0 4px 12px var(--budeeGlow);flex-shrink:0}
.bp-info{flex:1;min-width:0}
.bp-name{font-family:var(--font-d);font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px}
.bp-mood-emoji{font-size:18px}
.bp-ville{font-size:13px;color:var(--text2);margin-top:2px}

.bp-mood-text{font-size:14px;line-height:1.6;color:var(--text2);font-style:italic;padding:12px 16px;background:var(--surface2);border-radius:var(--r-md);border-left:3px solid var(--cafe);margin-bottom:8px}
.bp-mood-date{font-size:11px;color:var(--text3);margin-bottom:16px;padding-left:4px}

.bp-audio{margin-bottom:16px}
.bp-play{width:100%;padding:14px;background:linear-gradient(135deg,var(--cafe),#e67700);color:#fff;border:none;border-radius:var(--r-md);font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all 0.2s;box-shadow:0 4px 15px rgba(255,138,0,0.3)}
.bp-play:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,138,0,0.4)}
.bp-play:active{transform:translateY(0)}

.bp-respond{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border2);padding-top:16px}
.bp-textarea{width:100%;min-height:70px;max-height:120px;resize:vertical;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-md);padding:12px;color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color 0.2s}
.bp-textarea:focus{border-color:var(--cafe)}
.bp-textarea::placeholder{color:var(--text3)}
.bp-send{padding:12px 20px;background:var(--accent);color:var(--bg);border:none;border-radius:var(--r-md);font-size:14px;font-weight:700;cursor:pointer;align-self:flex-end;transition:all 0.2s}
.bp-send:hover{background:#a3e600;transform:translateY(-1px)}
.bp-send:active{transform:translateY(0)}

/* Message quand Budee n'a pas d'humeur */
.bp-no-mood{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--surface2);border-radius:var(--r-md);border-top:1px solid var(--border2);margin-top:12px}
.bp-no-mood-icon{font-size:24px;flex-shrink:0}
.bp-no-mood span:last-child{font-size:13px;color:var(--text3);line-height:1.4}

/* PassDial Paywall */
.bp-passdial-wall{text-align:center;padding:20px 10px}
.bp-wall-icon{font-size:48px;margin-bottom:12px}
.bp-wall-title{font-family:var(--font-d);font-size:22px;font-weight:800;margin-bottom:8px}
.bp-wall-text{font-size:14px;color:var(--text2);line-height:1.5;margin-bottom:16px}
.bp-wall-price{font-size:28px;font-weight:800;color:var(--cafe);margin-bottom:8px}
.bp-wall-features{font-size:12px;color:var(--text3);margin-bottom:20px}
.bp-wall-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--cafe),#e67700);color:#fff;border:none;border-radius:var(--r-md);font-size:16px;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 15px rgba(255,138,0,0.3)}
.bp-wall-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,138,0,0.4)}

/* ══════════════════════════════════════════════════════════════════════════ */
/* VOYANCE MARKER WRAPPER (Leaflet DivIcon)                                    */
/* ══════════════════════════════════════════════════════════════════════════ */
.voyance-marker-wrap{background:transparent!important;border:none!important}

/* ══════════════════════════════════════════════════════════════════════════ */
/* EMPLOI MARKER WRAPPER (Leaflet DivIcon)                                  */
/* ══════════════════════════════════════════════════════════════════════════ */
.emp-marker-wrap{background:transparent!important;border:none!important;overflow:visible!important}

/* ══════════════════════════════════════════════════════════════════════════ */
/* DESKTOP — Carte plein écran, sidebars en overlay sur demande             */
/* ══════════════════════════════════════════════════════════════════════════ */
@media(min-width:900px){
  /* Sidebar droit : caché par défaut (translateX(100%) hérité), overlay .show */
  .sidebar.show{box-shadow:-4px 0 24px rgba(0,0,0,0.5)}
  .feed-sidebar.show{box-shadow:4px 0 24px rgba(0,0,0,0.5)}
  .mobile-sheet{display:none!important}
  .mobile-profile{display:none!important}
  .nav-item.has-notif::after{display:none}
  .sidebar.shop-mode{max-width:500px}
}

/* ══════════════════════════════════════════════════════════════════════════ */
/* MOBILE FULLSCREEN PROFILE                                                   */
/* ══════════════════════════════════════════════════════════════════════════ */
@media(max-width:899px){
  /* Sidebar flottant mobile */
  .sidebar{right:8px;left:calc(var(--lsb-w,56px) + 8px);bottom:calc(var(--safe-bottom) + 16px);width:auto;max-width:none;border-radius:var(--r-lg)}
  .mobile-sheet{display:none!important}

  .mobile-profile{
    position:fixed;inset:0;z-index:60;background:var(--surface);
    transform:translateX(100%);transition:transform 0.4s var(--ease);
    display:flex;flex-direction:column;overflow:hidden;
  }
  .mobile-profile.show{transform:translateX(0)}
  
  .mp-header{position:relative;height:300px;flex-shrink:0;background:#000}
  .mp-media-photo{position:absolute;inset:0}
  .mp-media-photo img{width:100%;height:100%;object-fit:cover}
  .mp-media-video{position:absolute;inset:0;opacity:0;transition:opacity 0.4s}
  .mp-media-video.active{opacity:1}
  .mp-media-video video{width:100%;height:100%;object-fit:cover}
  .mp-header-grad{position:absolute;inset:0;background:linear-gradient(to top,var(--surface) 0%,transparent 50%);pointer-events:none}
  .mp-back{position:absolute;top:calc(var(--safe-top) + 12px);left:12px;width:40px;height:40px;background:rgba(0,0,0,0.5);border-radius:50%;border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);z-index:5}
  .mp-media-toggle{position:absolute;bottom:80px;left:16px;display:flex;gap:8px;z-index:5}
  .mp-media-btn{padding:8px 14px;border-radius:20px;font-size:12px;font-weight:600;border:none;cursor:pointer;background:rgba(0,0,0,0.6);color:#fff;backdrop-filter:blur(10px)}
  .mp-media-btn.active{background:var(--accent);color:var(--bg)}
  .mp-mute-btn{position:absolute;bottom:80px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,0.6);border:none;color:#fff;font-size:18px;cursor:pointer;display:none;align-items:center;justify-content:center;backdrop-filter:blur(10px);z-index:5}
  .mp-media-video.active ~ .mp-mute-btn{display:flex}
  .mp-info{position:absolute;bottom:20px;left:20px;right:20px;z-index:2}
  .mp-name{font-family:var(--font-d);font-size:28px;font-weight:800;margin-bottom:4px;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
  .mp-meta{display:flex;align-items:center;gap:12px}
  .mp-ville{font-size:14px;color:var(--text2);text-shadow:0 1px 4px rgba(0,0,0,0.5)}
  .mp-rating{background:rgba(255,214,0,0.2);color:#ffd600;padding:4px 10px;border-radius:12px;font-size:14px;font-weight:700}
  .mp-body{flex:1;overflow-y:auto;padding:20px}
  .mp-section{margin-bottom:24px}
  .mp-section h4{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}
  .mp-desc{font-size:14px;line-height:1.7;color:var(--text2)}
  .mp-slots{display:flex;flex-direction:column;gap:10px}
  .mp-footer{padding:16px 20px calc(16px + var(--safe-bottom));border-top:1px solid var(--border2);display:flex;gap:10px;flex-shrink:0}
  .mp-btn{flex:1;padding:16px;border-radius:var(--r-md);font-size:15px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
  .mp-btn.primary{background:var(--accent);color:var(--bg)}
  .mp-btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border2)}
}

/* ══════════════════════════════════════════════════════════════════════════ */
/* TOP PILLS (connectés + destinations secrètes)                               */
/* ══════════════════════════════════════════════════════════════════════════ */
.top-pills{display:flex;align-items:center;gap:6px;flex-shrink:0}
.top-pill{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:50px;font-size:12px;font-weight:700;border:1px solid var(--border2);background:var(--surface);color:var(--text2);cursor:pointer;backdrop-filter:blur(10px);transition:all 0.25s var(--ease);white-space:nowrap}
.top-pill:hover{background:var(--surface2);border-color:rgba(255,255,255,0.15)}
.top-pill:active{transform:scale(0.95)}

/* Pill online — point vert animé */
.tp-online .tp-dot{width:7px;height:7px;border-radius:50%;background:var(--online);box-shadow:0 0 6px var(--onlineGlow);animation:tp-pulse 2s ease-in-out infinite}
@keyframes tp-pulse{0%,100%{box-shadow:0 0 6px var(--onlineGlow)}50%{box-shadow:0 0 14px var(--online),0 0 4px var(--online)}}

/* Pill secret — clé dorée */
.tp-secret{border-color:rgba(255,184,0,0.2);background:rgba(255,184,0,0.06)}
.tp-secret:hover{background:rgba(255,184,0,0.12);border-color:rgba(255,184,0,0.3)}

/* ══════════════════════════════════════════════════════════════════════════ */
/* SB-SECRET — Panel sidebar destinations secrètes                             */
/* ══════════════════════════════════════════════════════════════════════════ */
.sb-secret{display:none;flex-direction:column;padding:24px 24px 24px;overflow-y:auto;flex:1}

.sb-secret-header{text-align:center;margin-bottom:24px}
.sb-secret-icon{font-size:48px;margin-bottom:8px;filter:drop-shadow(0 4px 12px rgba(255,184,0,0.3))}
.sb-secret-header h2{font-family:var(--font-d);font-size:24px;font-weight:800;margin-bottom:6px}
.sb-secret-sub{font-size:13px;color:var(--text3);line-height:1.5}

.sb-secret-body{display:flex;flex-direction:column;gap:14px}

.sb-secret-card{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-md);padding:16px;transition:border-color 0.3s}
.sb-secret-card:hover{border-color:rgba(255,184,0,0.2)}
.sb-secret-card-icon{font-size:24px;margin-bottom:8px}
.sb-secret-card h3{font-size:14px;font-weight:700;margin-bottom:6px;color:var(--text)}
.sb-secret-card p{font-size:13px;color:var(--text2);line-height:1.6}
.sb-secret-card p strong{color:var(--accent)}

/* Liste des destinations */
.sb-secret-list{margin-top:8px}
.sb-secret-list-title{font-size:13px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-top:8px}
.sb-secret-item{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-sm);padding:12px;margin-bottom:10px;transition:border-color 0.3s}
.sb-secret-item:hover{border-color:rgba(255,184,0,0.25)}
.sb-secret-item-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.sb-secret-item-name{font-size:14px;font-weight:700;color:var(--text)}
.sb-secret-item-dept{font-size:11px;color:var(--text3);background:var(--surface3);padding:2px 8px;border-radius:10px}
.sb-secret-item-desc{font-size:12px;color:var(--text3);line-height:1.5;margin-bottom:8px}
.sb-secret-item-bar{height:3px;background:var(--surface3);border-radius:2px;overflow:hidden}
.sb-secret-item-fill{height:100%;border-radius:2px;transition:width 0.4s var(--ease)}
.sb-secret-item-meta{font-size:11px;color:var(--text3);margin-top:4px;text-align:right}

/* ══════════════════════════════════════════════════════════════════════════ */
/* SECRET TOAST                                                                 */
/* ══════════════════════════════════════════════════════════════════════════ */
.secret-toast{position:fixed;top:calc(var(--safe-top) + 80px);left:50%;transform:translateX(-50%) translateY(-20px);z-index:200;display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-md);color:var(--text);font-size:13px;font-weight:600;box-shadow:0 8px 32px rgba(0,0,0,0.5);backdrop-filter:blur(20px);opacity:0;transition:all 0.35s var(--ease);pointer-events:none;white-space:nowrap;max-width:90vw}
.secret-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.secret-toast-icon{font-size:18px;flex-shrink:0}

/* ══════════════════════════════════════════════════════════════════════════ */
/* DESKTOP OVERRIDES — top-pills + secret + toast                              */
/* ══════════════════════════════════════════════════════════════════════════ */
@media(min-width:900px){
  .secret-toast{top:calc(var(--safe-top) + 80px);left:calc(300px + (100% - 300px - 420px)/2);transform:translateX(-50%) translateY(-20px)}
  .secret-toast.show{transform:translateX(-50%) translateY(0)}
}

/* Mobile : pills plus compacts */
@media(max-width:480px){
  .top-pill{padding:6px 9px;font-size:11px;gap:4px}
  .top-pills{gap:4px}
}

/* ══════════════════════════════════════════════════════════════════════════ */
/* REGION PICKER                                                               */
/* ══════════════════════════════════════════════════════════════════════════ */
.region-picker{position:relative;flex-shrink:0}
.tp-region{gap:4px}
.tp-region span{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:middle}

.region-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;width:260px;max-height:400px;overflow-y:auto;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-md);box-shadow:0 12px 40px rgba(0,0,0,0.6);backdrop-filter:blur(20px);z-index:100;padding:6px 0}
.region-dropdown.show{display:block}
.region-dropdown::-webkit-scrollbar{width:4px}
.region-dropdown::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px}

.rd-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:background 0.15s,color 0.15s}
.rd-item:hover{background:var(--surface2);color:var(--text)}
.rd-item:active{background:var(--surface3)}
.rd-all{font-weight:700;color:var(--text);border-bottom:1px solid var(--border2);margin-bottom:4px;padding-bottom:12px}
.rd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

@media(max-width:480px){
  .tp-region span{max-width:50px;font-size:10px}
  .region-dropdown{width:220px;right:-40px}
}

/* ─── Feed toggle button (top bar) ─── */
.feed-toggle-btn{
  width:40px;height:40px;
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;cursor:pointer;
  pointer-events:all;position:relative;
  transition:all 0.2s;
  flex-shrink:0;
}
.feed-toggle-btn:hover{border-color:var(--accent);background:var(--surface2)}
.feed-toggle-btn:active{transform:scale(0.93)}
.feed-badge-mini{
  position:absolute;top:-4px;right:-4px;
  background:#ef4444;color:#fff;
  font-size:9px;font-weight:700;
  min-width:16px;height:16px;
  border-radius:8px;display:flex;
  align-items:center;justify-content:center;
  pointer-events:none;
}

/* ─── Pass Rides cards ─── */
.pass-active-card{background:linear-gradient(135deg,#1a2e0a,#162010);border:1px solid #3a5a1a;border-radius:16px;padding:20px;margin-bottom:20px;position:relative}
.pass-active-badge{position:absolute;top:12px;right:12px;font-size:11px;font-weight:700;color:#b8ff00}
.pass-active-name{font-size:18px;font-weight:800;margin-bottom:4px}
.pass-active-credits{font-size:14px;color:var(--text2);margin-bottom:12px}
.pass-progress-bar{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}
.pass-progress-fill{height:100%;background:linear-gradient(90deg,#b8ff00,#4ade80);border-radius:3px;transition:width 0.5s}
.pass-active-info{display:flex;justify-content:space-between;margin-top:10px;font-size:12px;color:var(--text3)}
.pass-active-tap{text-align:center;margin-top:10px;font-size:11px;color:var(--text3);opacity:0.6}

/* ─── Body Pass Rides avec marges internes ─── */
.pass-rides-body{padding:20px 20px 24px;overflow-y:auto;flex:1}

.pass-tiers-title{font-size:16px;font-weight:800;margin-bottom:4px}
.pass-tiers-subtitle{font-size:13px;color:var(--text3);margin-bottom:16px}

/* ─── Pass Tier rows (vertical cards) ─── */
.pass-tiers-list{display:flex;flex-direction:column;gap:10px;padding-bottom:20px}
.pass-tier-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:14px 16px;position:relative;transition:all 0.2s;gap:12px}
.pass-tier-row:hover{border-color:var(--accent);transform:translateY(-1px)}
.pass-tier-row.popular{border-color:#b8ff00;background:linear-gradient(135deg,#1a2e0a,var(--surface2))}
.pass-tier-row.current{border-color:#4ade80;background:linear-gradient(135deg,#0f2a06,var(--surface2))}
.pass-tier-row .pass-popular-badge{position:absolute;top:-8px;left:16px;transform:none;background:#f97316;color:#fff;font-size:9px;font-weight:800;padding:3px 12px;border-radius:10px;white-space:nowrap}
.pass-current-badge{position:absolute;top:-8px;right:16px;background:#4ade80;color:#0a0a0f;font-size:9px;font-weight:800;padding:2px 10px;border-radius:10px;white-space:nowrap}
.pass-tier-row-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.pass-tier-row .pass-tier-icon{font-size:28px;flex-shrink:0;margin-bottom:0}
.pass-tier-row-info{flex:1;min-width:0}
.pass-tier-row .pass-tier-name{font-size:14px;font-weight:700;margin-bottom:2px}
.pass-tier-row .pass-tier-detail{font-size:11px;color:var(--text3);margin-bottom:0}
.pass-tier-row-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.pass-tier-row .pass-tier-price{font-size:16px;font-weight:800;color:#b8ff00;margin-bottom:0}
.pass-tier-row .pass-tier-price span{font-size:10px;font-weight:500;color:var(--text3)}
.pass-tier-row-btns{display:flex;gap:6px}
.pass-tier-voir-btn{padding:6px 12px;border:1px solid var(--border2);border-radius:8px;background:transparent;color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s}
.pass-tier-voir-btn:hover{border-color:#b8ff00;color:#b8ff00}
.pass-tier-buy-btn{padding:6px 12px;border:none;border-radius:8px;background:var(--accent);color:#0a0a0f;font-size:11px;font-weight:700;cursor:pointer;transition:all 0.2s}
.pass-tier-buy-btn:hover{background:#d4ff4a;transform:scale(1.02)}

/* ─── Pass Detail sidebar (à gauche de la sidebar principale, même pattern que tc-panier-sidebar) ─── */
.pass-detail-sidebar{
  position:fixed;
  top:calc(var(--safe-top,0px) + 64px);
  bottom:calc(var(--safe-bottom,0px) + 16px);
  right:calc(400px + 32px + 8px);
  width:380px;
  background:#0c0c14;
  z-index:62;
  display:none;
  flex-direction:column;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-xl,24px);
  box-shadow:-4px 0 30px rgba(0,0,0,0.6);
  overflow:hidden
}
.pass-detail-sidebar.show{display:flex}
.pass-detail-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.08);font-size:15px;font-weight:700;background:#0c0c14;flex-shrink:0}
.pass-detail-close{background:none;border:none;color:var(--text);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:8px}
.pass-detail-close:hover{background:var(--surface2)}
.pass-detail-body{flex:1;overflow-y:auto;padding:20px;scrollbar-width:none;-ms-overflow-style:none}
.pass-detail-body::-webkit-scrollbar{display:none}
.pass-detail-hero{text-align:center;padding:20px 0;margin-bottom:16px}
.pass-detail-icon{font-size:48px;margin-bottom:8px}
.pass-detail-name{font-size:22px;font-weight:800;margin-bottom:6px}
.pass-detail-price{font-size:28px;font-weight:800;color:#b8ff00}
.pass-detail-price span{font-size:13px;font-weight:500;color:var(--text3)}
.pass-detail-current-tag{display:inline-block;margin-top:10px;padding:4px 14px;background:#1a3a0a;border:1px solid #4ade80;border-radius:20px;font-size:12px;font-weight:700;color:#4ade80}
.pass-detail-credits{background:var(--surface2);border-radius:14px;padding:16px;margin-bottom:16px}
.pass-detail-credits-title{font-size:13px;font-weight:700;margin-bottom:6px}
.pass-detail-credits-count{font-size:16px;font-weight:800;color:#b8ff00;margin-bottom:10px}
.pass-detail-expires{font-size:11px;color:var(--text3);margin-top:8px}
.pass-detail-section{margin-bottom:16px}
.pass-detail-section-title{font-size:13px;font-weight:700;color:var(--text2);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.5px}
.pass-detail-item{font-size:13px;color:var(--text);padding:6px 0;line-height:1.4}
.pass-detail-item-light{font-size:12px;color:var(--text3);padding:4px 0;line-height:1.5}
.pass-detail-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.pass-detail-cta{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#b8ff00,#4ade80);color:#0a0a0f;font-size:15px;font-weight:800;cursor:pointer;transition:all 0.2s}
.pass-detail-cta:hover{transform:scale(1.02);filter:brightness(1.1)}
.pass-detail-cta-manage{background:var(--surface3);color:var(--text)}
@media(max-width:900px){
  .pass-detail-sidebar{right:8px;left:calc(var(--lsb-w,56px) + 8px);width:auto;bottom:calc(var(--safe-bottom,0px) + 16px);border-radius:var(--r-lg,12px)}
}

/* ─── Pass Rides panel in sidebar ─── */
.sb-pass-rides{flex:1;display:flex;flex-direction:column;padding:24px 28px 28px;overflow-y:auto}
.sb-pass-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.sb-pass-icon{font-size:28px}
.sb-pass-header h2{font-family:var(--font-d);font-size:22px;font-weight:800}
.sb-pass-sub{font-size:13px;color:var(--text3);line-height:1.5;margin-bottom:20px}
.sb-pass-content .pass-tiers-list{gap:10px}

/* ─── Pass option dans le panier rides ─── */
.tc-pass-option{margin-bottom:10px}
.tc-pass-btn{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface2);border:2px solid var(--border2);border-radius:12px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s}
.tc-pass-btn:hover{border-color:#b8ff00}
.tc-pass-btn.active{border-color:#b8ff00;background:linear-gradient(135deg,#1a2e0a,var(--surface2))}
.tc-pass-icon{font-size:18px}
.tc-btn-pass{background:linear-gradient(135deg,#b8ff00,#4ade80)!important;color:#0a0a0f!important}

/* ─── Pass option dans le panier (2e sidebar) ─── */
.tc-pass-section{margin-bottom:8px}
.tc-pass-panier-btn{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface2);border:2px solid var(--border2);border-radius:14px;color:var(--text);cursor:pointer;transition:all 0.2s;text-align:left}
.tc-pass-panier-btn:hover{border-color:#b8ff00}
.tc-pass-panier-btn.active{border-color:#b8ff00;background:linear-gradient(135deg,#1a2e0a,#0f1a08)}
.tc-pass-panier-icon{font-size:24px;flex-shrink:0}
.tc-pass-panier-info{flex:1;display:flex;flex-direction:column;gap:2px}
.tc-pass-panier-label{font-size:14px;font-weight:700;color:var(--text)}
.tc-pass-panier-sub{font-size:11px;color:var(--text3)}
.tc-pass-panier-check{font-size:18px;flex-shrink:0}
.tc-pass-panier-btn.active .tc-pass-panier-label{color:#b8ff00}

/* ─── Global Loading Overlay ─── */
.vk-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,10,15,0.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.3s;pointer-events:none}
.vk-loading-overlay.show{opacity:1;pointer-events:all}
.vk-loading-card{background:#16161e;border:1px solid #2a2a3a;border-radius:20px;padding:32px 40px;text-align:center;max-width:320px;width:90%;transform:translateY(20px);transition:transform 0.3s}
.vk-loading-overlay.show .vk-loading-card{transform:translateY(0)}
.vk-loading-spinner{width:48px;height:48px;border:3px solid #2a2a3a;border-top-color:#b8ff00;border-radius:50%;animation:vkSpin 0.8s linear infinite;margin:0 auto 16px}
@keyframes vkSpin{to{transform:rotate(360deg)}}
.vk-loading-text{font-size:15px;font-weight:700;color:#e2e8f0;margin-bottom:4px}
.vk-loading-sub{font-size:12px;color:#64748b}
/* Mini inline loader (for buttons, sections) */
.vk-inline-loader{display:inline-flex;align-items:center;gap:6px;color:#94a3b8;font-size:13px}
.vk-inline-loader .vk-dot{width:6px;height:6px;background:#b8ff00;border-radius:50%;animation:vkPulse 1.2s ease-in-out infinite}
.vk-inline-loader .vk-dot:nth-child(2){animation-delay:0.2s}
.vk-inline-loader .vk-dot:nth-child(3){animation-delay:0.4s}
@keyframes vkPulse{0%,80%,100%{opacity:0.3;transform:scale(0.8)}40%{opacity:1;transform:scale(1.2)}}

/* ─── Animated cars (MAPCARS) ─── */
.mc-m{background:transparent!important;border:none!important}
.mc-car-wrap{transition:transform 0.3s linear}
.mc-route{pointer-events:none}

/* ══════════════════════════════════════════════════════════════════════════ */
/* EMPLOI — Agences d'emploi + Offres                                       */
/* ══════════════════════════════════════════════════════════════════════════ */
.emp-marker-wrap{background:transparent!important;border:none!important;overflow:visible!important}
.emp-marker{position:relative;width:56px;height:56px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 24px rgba(59,130,246,0.6),0 0 0 4px rgba(59,130,246,0.3);cursor:pointer;transition:transform 0.2s;border:3px solid #fff}
.emp-marker::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:2px solid #3b82f6;animation:emp-pulse 2s ease-in-out infinite;pointer-events:none}
@keyframes emp-pulse{0%,100%{transform:scale(1);opacity:0.6}50%{transform:scale(1.4);opacity:0}}
.emp-marker:hover{transform:scale(1.15)}
.emp-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;border-radius:10px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 8px rgba(239,68,68,0.5);border:2px solid #fff}
.emp-tip-container{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}
.emp-tip-container .leaflet-tooltip-content{padding:0}
.emp-tooltip{background:rgba(15,23,42,0.92);border:1px solid rgba(59,130,246,0.4);border-radius:10px;padding:6px 12px;color:#f1f5f9;font-size:12px;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:6px}
.emp-tooltip-count{font-size:10px;font-weight:500;color:rgba(59,130,246,0.9);background:rgba(59,130,246,0.12);padding:2px 6px;border-radius:6px}
.emp-sidebar{position:fixed;top:calc(var(--safe-top,0px) + 64px);bottom:calc(var(--safe-bottom,0px) + 16px);right:calc(400px + 32px + 8px);width:360px;background:#0c0c14;z-index:62;display:none;flex-direction:column;border:1px solid rgba(255,255,255,0.08);border-radius:var(--r-xl,24px);box-shadow:-4px 0 30px rgba(0,0,0,0.6);overflow:hidden}
.emp-sidebar.show{display:flex}
@media(max-width:900px){.emp-sidebar{right:calc(var(--lsb-w,56px) + 8px);width:calc(100vw - var(--lsb-w,56px) - 16px)}}
@media(max-width:600px){.emp-sidebar{right:0;width:100vw;border-radius:0;top:0;bottom:0;z-index:300}}
.emp-sb-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.emp-sb-back{background:none;border:none;color:#3b82f6;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:8px}
.emp-sb-back:hover{background:rgba(59,130,246,0.1)}
.emp-sb-title{flex:1}
.emp-sb-name{font-size:16px;font-weight:700;color:#f1f5f9;margin-bottom:2px}
.emp-sb-ville{font-size:12px;color:rgba(255,255,255,0.45)}
.emp-sb-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}
.emp-sb-body::-webkit-scrollbar{width:4px}
.emp-sb-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.emp-info-row{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,0.6);padding:4px 0}
.emp-info-icon{font-size:14px;flex-shrink:0}
.emp-info-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.5;padding:8px 0;border-top:1px solid rgba(255,255,255,0.06)}
.emp-section-title{font-size:13px;font-weight:700;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:1px;padding-bottom:8px}
.emp-offre-card{background:rgba(30,41,59,0.5);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:14px;transition:border-color .2s}
.emp-offre-card:hover{border-color:rgba(59,130,246,0.3)}
.emp-offre-header{margin-bottom:8px}
.emp-offre-titre{font-size:15px;font-weight:600;color:#f1f5f9;margin-bottom:6px;line-height:1.3}
.emp-offre-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.emp-type-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
.emp-type-CDI{background:rgba(34,197,94,0.15);color:#22c55e;border:1px solid rgba(34,197,94,0.3)}
.emp-type-CDD{background:rgba(234,179,8,0.15);color:#eab308;border:1px solid rgba(234,179,8,0.3)}
.emp-type-freelance{background:rgba(168,85,247,0.15);color:#a855f7;border:1px solid rgba(168,85,247,0.3)}
.emp-type-benevole{background:rgba(59,130,246,0.15);color:#3b82f6;border:1px solid rgba(59,130,246,0.3)}
.emp-type-stage{background:rgba(236,72,153,0.15);color:#ec4899;border:1px solid rgba(236,72,153,0.3)}
.emp-salaire{font-size:12px;font-weight:600;color:#22c55e}
.emp-postes{font-size:11px;color:rgba(255,255,255,0.4);font-style:italic}
.emp-offre-desc{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.5;margin-bottom:8px}
.emp-offre-resp{font-size:12px;color:rgba(255,255,255,0.4);line-height:1.4;margin-bottom:10px}
.emp-offre-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.06)}
.emp-expire{font-size:11px;color:rgba(255,255,255,0.3)}
.emp-btn-apply{padding:8px 16px;border-radius:10px;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}
.emp-btn-apply:hover{transform:scale(1.03);box-shadow:0 4px 16px rgba(59,130,246,0.4)}
.emp-btn-applied{padding:8px 16px;border-radius:10px;border:1px solid rgba(34,197,94,0.3);background:rgba(34,197,94,0.1);color:#22c55e;font-size:13px;font-weight:600;cursor:default}
.emp-sb-footer{padding:12px 20px;border-top:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.emp-footer-btn{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(59,130,246,0.2);background:rgba(59,130,246,0.06);color:rgba(59,130,246,0.8);font-size:13px;cursor:pointer;transition:background .2s}
.emp-footer-btn:hover{background:rgba(59,130,246,0.12)}
.emp-loading{text-align:center;padding:40px 20px;color:rgba(255,255,255,0.3);font-size:14px}
.emp-empty{text-align:center;padding:40px 20px;color:rgba(255,255,255,0.25);font-size:14px}

/* -- Marker image bag.png -- */
.emp-marker-img{width:32px;height:32px;object-fit:contain;filter:brightness(1.1)}
/* -- Badge pulsant nombre d'offres -- */
.emp-badge-pulse{position:absolute;top:-8px;right:-8px;min-width:22px;height:22px;border-radius:11px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 8px rgba(239,68,68,0.5);border:2px solid #fff;animation:emp-badge-beat 1.5s ease-in-out infinite}
@keyframes emp-badge-beat{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}

/* -- Sidebar header visuel bag.png -- */
.emp-header-visual{display:flex;align-items:center;gap:14px;padding:8px 0 12px}
.emp-sidebar-img{width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(59,130,246,0.4))}
.emp-header-label{font-size:16px;font-weight:700;color:#f1f5f9;line-height:1.3}
.emp-header-ville{font-size:13px;font-weight:400;color:rgba(255,255,255,0.45)}

/* ══════════════════════════════════════════════════════════════════════════════
   GIFTMAP — Bons géolocalisés + Enseignes sur la carte
   ══════════════════════════════════════════════════════════════════════════════ */

/* Marqueur bon (petit carré vert) */
.giftmap-marker{width:52px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform .15s;box-shadow:0 2px 10px rgba(0,0,0,.35)}
.giftmap-marker:hover{transform:scale(1.12)}
.giftmap-marker.gm-active{background:linear-gradient(135deg,#22c55e,#16a34a);border:2px solid #86efac;color:#fff}
.giftmap-marker.gm-won{background:linear-gradient(135deg,#eab308,#ca8a04);border:2px solid #fde047;color:#fff;cursor:default;opacity:.8}
.giftmap-marker.gm-tried{opacity:.6;cursor:not-allowed}
.giftmap-marker .gm-content{display:flex;align-items:baseline;gap:1px;line-height:1}
.giftmap-marker .gm-amount{font-size:15px;font-weight:800}
.giftmap-marker .gm-euro{font-size:10px;font-weight:700;opacity:.9}
/* Pastille tentatives ratées */
.giftmap-marker .gm-fails{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;border-radius:8px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid #fff}
/* Pastille expiration */
.giftmap-marker .gm-expire{position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);font-size:7px;color:#fde047;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.7);font-weight:600}

/* Marqueur enseigne (logo rond) */
.retailer-map-marker{width:46px;height:46px;border-radius:50%;background:transparent;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:transform .15s}
.retailer-map-marker:hover{transform:scale(1.12)}
.retailer-map-marker img{width:38px;height:38px;border-radius:6px;object-fit:contain;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.retailer-map-marker .rm-amount{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);background:#22c55e;color:#fff;font-size:8px;font-weight:800;padding:1px 5px;border-radius:4px;white-space:nowrap;border:1px solid #86efac}
.retailer-map-marker.rm-locked{opacity:.55;filter:grayscale(.5)}
.retailer-map-marker .rm-locked-amount{background:#475569;border-color:#64748b}

/* Popup giftmap code */
.giftmap-popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99999;display:flex;align-items:center;justify-content:center;animation:gm-fadein .2s ease}
@keyframes gm-fadein{from{opacity:0}to{opacity:1}}
.giftmap-popup{background:#1e293b;border-radius:16px;padding:24px;width:320px;max-width:90vw;box-shadow:0 8px 40px rgba(0,0,0,.5);text-align:center}
.giftmap-popup h3{margin:0 0 4px;color:#f1f5f9;font-size:17px}
.giftmap-popup .gm-popup-amount{font-size:28px;font-weight:800;color:#22c55e;margin:8px 0}
.giftmap-popup .gm-popup-addr{font-size:12px;color:#94a3b8;margin-bottom:14px}
.giftmap-popup input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid #334155;background:#0f172a;color:#f1f5f9;font-size:15px;text-align:center;letter-spacing:2px;font-weight:700;box-sizing:border-box}
.giftmap-popup input:focus{outline:none;border-color:#6366f1}
.giftmap-popup .gm-popup-btn{margin-top:12px;width:100%;padding:12px;border:none;border-radius:10px;background:#22c55e;color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}
.giftmap-popup .gm-popup-btn:hover{background:#16a34a}
.giftmap-popup .gm-popup-btn:disabled{background:#334155;cursor:not-allowed}
.giftmap-popup .gm-popup-close{margin-top:8px;width:100%;padding:8px;border:none;border-radius:8px;background:transparent;color:#64748b;font-size:13px;cursor:pointer}
.giftmap-popup .gm-popup-msg{margin-top:10px;font-size:13px;font-weight:600;padding:8px;border-radius:8px}
.giftmap-popup .gm-popup-msg.success{background:rgba(34,197,94,.15);color:#22c55e}
.giftmap-popup .gm-popup-msg.error{background:rgba(239,68,68,.15);color:#ef4444}
.giftmap-popup .gm-popup-info{font-size:11px;color:#64748b;margin-top:6px}

