/* ============================================
   CARTE v2 — Command Center Design
   Font: Inter · Dark theme · Squared markers
   ============================================ */

:root{
  --accent:#EF5D1C;--accent-2:#FF8A1E;--accent-glow:rgba(239,93,28,.35);
  --red:#ff4757;--green:#2ed573;--blue:#1e90ff;--amber:#ffa502;--gold:#c9a227;
  --bg:#09090b;--surface:#111113;--surface-2:#19191d;--surface-3:#222228;
  --text:#eeeef0;--text-2:#a1a1aa;--text-3:#71717a;
  --border:rgba(255,255,255,.06);--border-2:rgba(255,255,255,.1);
  --radius:14px;--radius-sm:10px;--radius-xs:6px;
  --nav-h:70px;
  --ease:cubic-bezier(.4,0,.2,1);--bounce:cubic-bezier(.34,1.56,.64,1);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;height:100%;overflow:hidden;overscroll-behavior:none;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}

/* ============================================
   KEYFRAMES
   ============================================ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.8)}}
@keyframes ringRotate{to{transform:rotate(360deg)}}
@keyframes ringDash{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35}100%{stroke-dasharray:89,200;stroke-dashoffset:-124}}
@keyframes markerDrop{0%{opacity:0;transform:translateY(-30px) scale(.7)}60%{transform:translateY(4px) scale(1.05)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes popSlide{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes chipBounce{0%{transform:scale(1)}50%{transform:scale(.92)}100%{transform:scale(1)}}
@keyframes toastIn{from{opacity:0;transform:translateX(40px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px) scale(.95)}}
@keyframes ripple{0%{transform:scale(.8);opacity:1}100%{transform:scale(2.5);opacity:0}}
@keyframes heartbeat{0%,100%{transform:scale(1)}14%{transform:scale(1.3)}28%{transform:scale(1)}42%{transform:scale(1.3)}70%{transform:scale(1)}}
@keyframes geoPulse{0%,100%{box-shadow:0 0 0 0 rgba(30,144,255,.5)}50%{box-shadow:0 0 0 12px rgba(30,144,255,0)}}
@keyframes focusGlow{0%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 10px transparent}100%{box-shadow:0 0 0 0 transparent}}
@keyframes brandPulse{0%,100%{opacity:1}50%{opacity:.6}}

/* GPU */
.custom-marker,.leaflet-popup,.leaflet-tile,.leaflet-marker-icon{
  transform:translate3d(0,0,0);backface-visibility:hidden;
}
.leaflet-tile-container{transform:translate3d(0,0,0)}
.leaflet-zoom-animated{will-change:transform}
.leaflet-tile{will-change:opacity;transition:opacity .15s linear!important}
.leaflet-dragging .custom-marker,.leaflet-dragging .time-ago-badge{transition:none!important}
.leaflet-zooming .custom-marker{transition:none!important}

/* ============================================
   MINI FLOATING BUTTONS
   ============================================ */
.map-fab-group{
  position:fixed;top:calc(var(--nav-h) + 14px);right:14px;z-index:1300;
  display:flex;flex-direction:column;gap:8px;
  animation:fadeIn .4s var(--ease) .3s both;
}
.map-fab{
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);cursor:pointer;transition:all .2s var(--ease);
  text-decoration:none;box-shadow:0 4px 16px rgba(0,0,0,.4);
}
.map-fab:hover{background:var(--surface-3);color:var(--text);transform:scale(1.08)}
.map-fab:active{transform:scale(.95)}
.map-fab-geo.active{color:var(--blue);border-color:rgba(30,144,255,.3);background:rgba(30,144,255,.1);animation:geoPulse 2s ease-in-out infinite}
.map-fab-geo.loading svg{animation:spin .7s linear infinite}
.map-fab-list{background:var(--accent);border-color:transparent;color:#fff}
.map-fab-list:hover{background:var(--accent-2);color:#fff}


/* ============================================
   MAP
   ============================================ */
#map{
  position:fixed;
  top:var(--nav-h);
  left:0;right:0;bottom:0;z-index:1;
  touch-action:manipulation;user-select:none;
}
.leaflet-container{background:var(--bg)}

/* ============================================
   CUSTOM MARKERS — Squared with rounded corners
   ============================================ */
.custom-marker{
  width:52px;height:52px;border-radius:var(--radius-sm);
  background-size:cover;background-position:center;
  border:2.5px solid rgba(255,255,255,.2);
  box-shadow:0 4px 16px rgba(0,0,0,.5),0 0 0 1px rgba(0,0,0,.3);
  transition:transform .15s var(--ease),box-shadow .15s var(--ease),border-color .15s;
  cursor:pointer;position:relative;
  animation:markerDrop .4s var(--bounce) both;
}
.custom-marker::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 40%);
  pointer-events:none;
}
.leaflet-dragging .custom-marker{transition:none!important}
.custom-marker:hover{
  transform:scale(1.12) translateY(-3px);
  box-shadow:0 8px 28px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.1);
  z-index:1000!important;
}

/* Featured */
.custom-marker.marker-featured{
  width:66px!important;height:66px!important;
  border:3px solid var(--red)!important;
  box-shadow:0 6px 24px rgba(255,71,87,.5),0 0 0 1px rgba(0,0,0,.3)!important;
  z-index:9999!important;border-radius:var(--radius)!important;
}
.featured-marker-badge{display:none}

/* Color borders */
.marker-red{border-color:var(--red);box-shadow:0 4px 16px rgba(255,71,87,.35),0 0 0 1px rgba(0,0,0,.3)}
.marker-red:hover{box-shadow:0 8px 28px rgba(255,71,87,.45),0 0 0 1px rgba(255,255,255,.1)}
.marker-amber{border-color:var(--amber);box-shadow:0 4px 16px rgba(255,165,2,.35),0 0 0 1px rgba(0,0,0,.3)}
.marker-amber:hover{box-shadow:0 8px 28px rgba(255,165,2,.45),0 0 0 1px rgba(255,255,255,.1)}
.marker-gold{border-color:var(--gold);box-shadow:0 4px 16px rgba(201,162,39,.35),0 0 0 1px rgba(0,0,0,.3)}
.marker-gold:hover{box-shadow:0 8px 28px rgba(201,162,39,.45),0 0 0 1px rgba(255,255,255,.1)}

/* Time badge — pill at bottom */
.time-ago-badge{
  position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);
  background:var(--surface);color:var(--text);font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:100px;white-space:nowrap;z-index:10;
  border:1px solid var(--border-2);letter-spacing:.2px;
  box-shadow:0 2px 8px rgba(0,0,0,.5);
}
.marker-amber .time-ago-badge{background:var(--amber);color:#000;border-color:transparent}
.marker-red .time-ago-badge.time-lost{background:var(--red);color:#fff;border-color:transparent}
.marker-gold .time-ago-badge{background:var(--gold);color:#000;border-color:transparent}
.custom-marker:hover .time-ago-badge{transform:translateX(-50%) scale(1.1)}

/* Clusters — minimal design */
.marker-cluster{
  background:var(--surface-2)!important;
  border:2px solid var(--border-2)!important;
  border-radius:var(--radius-sm)!important;
  box-shadow:0 4px 16px rgba(0,0,0,.4)!important;
  transition:transform .15s var(--ease)!important;
}
.marker-cluster:hover{transform:scale(1.08)}
.marker-cluster div{
  background:transparent!important;color:var(--text)!important;
  font-weight:800!important;font-size:12px!important;font-family:'Inter',sans-serif!important;
}
.marker-cluster-small{width:36px!important;height:36px!important}
.marker-cluster-medium{width:42px!important;height:42px!important;border-color:var(--amber)!important}
.marker-cluster-large{width:50px!important;height:50px!important;border-color:var(--red)!important}

/* ============================================
   FOCUS MODE
   ============================================ */
#map.focus-mode .custom-marker:not(.focused){
  opacity:.25!important;filter:grayscale(.8) brightness(.6)!important;
  transform:scale(.82)!important;transition:all .3s var(--ease)!important;
}
#map.focus-mode .custom-marker.focused{
  z-index:9999!important;
  animation:focusGlow .6s var(--ease);
}
#map.focus-mode .marker-cluster{opacity:.3!important;filter:grayscale(.6)!important}

/* ============================================
   POPUP — Redesigned card
   ============================================ */
.leaflet-popup-content-wrapper{
  background:var(--surface)!important;color:var(--text)!important;
  border-radius:var(--radius)!important;
  border:1px solid var(--border-2)!important;
  box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 0 1px rgba(0,0,0,.2)!important;
  padding:0!important;overflow:hidden!important;
  animation:popSlide .35s var(--bounce) both!important;
}
.leaflet-popup-content-wrapper::before{display:none}
.leaflet-popup-tip{background:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:none!important}
.leaflet-popup-content{margin:0!important;width:min(92vw,340px)!important}

.popup-inner{position:relative;overflow:hidden;background:var(--surface)}

/* Image */
.popup-img-wrap{
  position:relative;width:100%;height:200px;
  background:var(--surface-2);overflow:hidden;
}
.popup-img-wrap::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:80px;
  background:linear-gradient(to top,var(--surface),transparent);pointer-events:none;z-index:1;
}
.popup-img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.popup-img.lazy{opacity:0;transition:opacity .3s}
.popup-img.lazy.loaded{opacity:1}
.popup-img-wrap:hover .popup-img{transform:scale(1.05)}

/* Status badge — top left */
.popup-status-badge{
  position:absolute;top:12px;left:12px;padding:5px 12px;
  border-radius:100px;font-weight:700;font-size:10px;
  text-transform:uppercase;letter-spacing:.8px;z-index:2;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.badge-perdu{background:rgba(255,71,87,.85);color:#fff}
.badge-errant{background:rgba(255,165,2,.85);color:#000}
.badge-decede{background:rgba(201,162,39,.85);color:#000}

/* Body */
.popup-body{padding:16px 18px 18px}
.popup-title{
  font-size:1.15rem;font-weight:800;margin:0 0 10px;color:var(--text);
  display:flex;align-items:center;gap:6px;line-height:1.3;
}
.sexe-icon{font-size:1rem;opacity:.6}

.popup-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.popup-info{
  font-size:12px;color:var(--text-2);display:flex;align-items:center;gap:6px;
}
.popup-info strong{color:var(--text);font-weight:600}

.popup-desc{
  background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:10px 12px;margin:10px 0;line-height:1.5;font-size:12px;
  color:var(--text-2);max-height:80px;overflow-y:auto;
}
.popup-desc::-webkit-scrollbar{width:3px}
.popup-desc::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}

.popup-actions{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;
}

/* Popup buttons */
.btn-popup{
  flex:1;display:flex;align-items:center;justify-content:center;gap:5px;
  padding:10px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:12px;
  text-decoration:none;transition:all .15s var(--ease);cursor:pointer;
  border:1px solid var(--border);font-family:inherit;
}
.btn-popup.primary{
  background:var(--accent);border-color:transparent;color:#fff;
  box-shadow:0 2px 10px var(--accent-glow);
}
.btn-popup.primary:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}
.btn-popup.secondary{background:var(--surface-2);color:var(--text-2)}
.btn-popup.secondary:hover{background:var(--surface-3);color:var(--text)}

.btn-popup.seen-btn{
  background:rgba(46,213,115,.12);color:var(--green);border-color:rgba(46,213,115,.2);
}
.btn-popup.seen-btn:hover{background:rgba(46,213,115,.2);transform:translateY(-1px)}

/* Close button */
.leaflet-popup-close-button{
  position:absolute!important;top:12px!important;right:12px!important;left:auto!important;
  width:30px!important;height:30px!important;padding:0!important;
  background:rgba(0,0,0,.6)!important;backdrop-filter:blur(8px)!important;
  color:#fff!important;border:1px solid rgba(255,255,255,.1)!important;
  border-radius:50%!important;font-size:18px!important;font-weight:400!important;
  line-height:28px!important;text-align:center!important;cursor:pointer!important;
  z-index:1000!important;transition:all .2s var(--ease)!important;opacity:1!important;
}
.leaflet-popup-close-button:hover{
  background:var(--red)!important;border-color:transparent!important;
  transform:scale(1.1)!important;
}

/* ============================================
   LOADING OVERLAY
   ============================================ */
.loading-overlay{
  position:fixed;inset:0;background:var(--bg);z-index:9999;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;
}
.loading-ring{width:48px;height:48px;position:relative}
.loading-ring-inner{
  width:100%;height:100%;border:3px solid var(--surface-3);
  border-top-color:var(--accent);border-radius:50%;
  animation:spin .8s linear infinite;
}
.loading-text{display:flex;flex-direction:column;align-items:center;gap:6px}
.loading-brand{
  font-size:14px;font-weight:800;letter-spacing:2px;
  color:var(--accent);animation:brandPulse 2s ease-in-out infinite;
}
.loading-sub{font-size:12px;color:var(--text-3);font-weight:500}

/* ============================================
   TOAST
   ============================================ */
.toast-container{
  position:fixed;top:calc(var(--nav-h) + 12px);
  right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
  background:var(--surface);border:1px solid var(--border-2);
  border-radius:var(--radius-sm);padding:10px 14px;
  min-width:240px;max-width:360px;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  display:flex;align-items:center;gap:10px;
  animation:toastIn .35s var(--bounce);
  pointer-events:auto;position:relative;
  font-size:12px;font-weight:500;
}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.info{border-left:3px solid var(--blue)}
.toast-icon{font-size:18px;flex-shrink:0}
.toast-content{flex:1;color:var(--text);line-height:1.4}
.toast-close{
  background:none;border:none;color:var(--text-3);font-size:16px;cursor:pointer;
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:all .15s;flex-shrink:0;padding:0;
}
.toast-close:hover{background:rgba(255,255,255,.08);color:var(--text)}

/* ============================================
   GEOLOCATION BUTTON
   ============================================ */
.geoloc-btn{display:none}

/* User position marker */
.user-marker{
  width:16px;height:16px;background:var(--blue);
  border:3px solid #fff;border-radius:50%;
  box-shadow:0 0 0 3px rgba(30,144,255,.3),0 0 20px rgba(30,144,255,.5),0 4px 12px rgba(0,0,0,.3);
  animation:heartbeat 1.5s ease-in-out infinite;position:relative;
}
.user-marker::before{
  content:'';position:absolute;inset:-8px;border:2px solid var(--blue);
  border-radius:50%;animation:ripple 2s ease-out infinite;
}
.user-marker::after{
  content:'';position:absolute;inset:-14px;border:1.5px solid var(--blue);
  border-radius:50%;animation:ripple 2s ease-out .5s infinite;
}

/* ============================================
   LEAFLET ENHANCEMENTS
   ============================================ */
.leaflet-tile-pane{filter:none}
.leaflet-tile-container{font-size:0;line-height:0}
.leaflet-tile-container img{display:block;border:none;margin:0;padding:0;max-width:100.5%;max-height:100.5%}
.leaflet-tile{border:none!important;outline:none!important}
.leaflet-control-zoom{border:none!important;border-radius:var(--radius-sm)!important;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.4)!important}
.leaflet-control-zoom a{
  background:var(--surface)!important;color:var(--text)!important;
  border:none!important;border-bottom:1px solid var(--border)!important;
  width:34px!important;height:34px!important;line-height:34px!important;
  font-size:16px!important;transition:background .15s!important;
}
.leaflet-control-zoom a:hover{background:var(--surface-3)!important}
.leaflet-control-zoom a:last-child{border-bottom:none!important}

/* ============================================
   PULL TO REFRESH (disabled but styled)
   ============================================ */
.pull-to-refresh{
  position:fixed;top:var(--nav-h);left:50%;transform:translateX(-50%) translateY(-100%);
  background:var(--surface);backdrop-filter:blur(12px);padding:10px 20px;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  display:flex;align-items:center;gap:8px;z-index:9998;
  transition:transform .3s var(--bounce);box-shadow:0 4px 16px rgba(0,0,0,.4);
  border:1px solid var(--border);border-top:none;opacity:0;pointer-events:none;
}
.pull-to-refresh.visible{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.pull-to-refresh .spinner{width:16px;height:16px;border:2px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%}
.pull-to-refresh.visible .spinner{animation:spin .6s linear infinite}
.pull-to-refresh .text{color:var(--text-2);font-size:12px;font-weight:600}

/* ============================================
   FAB — Hidden (replaced by cmd-btn-accent)
   ============================================ */
.fab-list,.fab{display:none}

/* ============================================
   RESPONSIVE — Mobile
   ============================================ */
@media(max-width:768px){
  #map{top:var(--nav-h);bottom:0}

  .map-fab-group{right:10px;top:calc(var(--nav-h) + 10px)}
  .map-fab{width:36px;height:36px}

  .toast-container{top:calc(var(--nav-h) + 10px);right:10px;left:10px}
  .toast{min-width:0;width:100%}
}

@media(max-width:640px){
  .leaflet-popup-content{width:min(90vw,300px)!important}
  .popup-img-wrap{height:160px}
  .popup-body{padding:12px 14px 14px}
  .popup-title{font-size:1rem;margin:0 0 8px}
  .popup-info{font-size:11px}
  .popup-desc{font-size:11px;padding:8px 10px}
  .btn-popup{padding:8px 12px;font-size:11px}
}

@media(max-width:400px){
  .leaflet-popup-content{width:min(85vw,240px)!important}
  .popup-img-wrap{height:120px!important}
  .popup-body{padding:8px 10px 10px!important}
  .popup-title{font-size:.85rem!important}
  .popup-info{font-size:10px!important}
  .popup-actions{gap:5px}
  .btn-popup{padding:6px 8px!important;font-size:10px!important;flex:1;min-width:0}
  .leaflet-popup-close-button{width:26px!important;height:26px!important;font-size:14px!important;line-height:24px!important;top:8px!important;right:8px!important}
  .leaflet-control-zoom a{width:28px!important;height:28px!important;line-height:28px!important;font-size:14px!important}
}

/* Landscape */
@media(max-width:900px) and (orientation:landscape){
  :root{--nav-h:50px}
  .popup-img-wrap{height:100px}
  .popup-body{padding:8px 10px}
  .popup-title{font-size:.9rem}
  .popup-info{font-size:10px}
  .btn-popup{padding:6px 10px;font-size:11px}
  .leaflet-popup-content{width:min(50vw,260px)!important}
}
