:root{
  --bg:#0f1115; --panel:#171a21; --panel-2:#1f242e; --border:#2a313d;
  --text:#e6e9ef; --muted:#8a93a3; --accent:#4f8cff;
  --green:#22c55e; --yellow:#eab308; --err:#f87171;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg); color:var(--text); font-size:14px;
}
h1{font-size:18px;margin:0}
h2{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 8px}
code{background:var(--panel-2);padding:1px 5px;border-radius:4px;font-size:12px}
.muted{color:var(--muted)}

/* ---- Overlays (boot / login / config error) ---- */
.overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--bg);z-index:1000;padding:20px}
.overlay[hidden]{display:none}
.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;
  padding:28px;width:100%;max-width:380px;box-shadow:0 10px 40px rgba(0,0,0,.4)}
.card h1{margin-bottom:6px}
.card p{margin:8px 0;line-height:1.5}

/* ---- Formulaires ---- */
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
input,select{width:100%;background:var(--panel-2);border:1px solid var(--border);
  color:var(--text);border-radius:8px;padding:9px 10px;font-size:14px;outline:none}
input:focus,select:focus{border-color:var(--accent)}
button{cursor:pointer;border:none;border-radius:8px;font-size:14px;font-weight:600;
  padding:10px 12px;background:var(--accent);color:#fff;width:100%;margin-top:12px}
button:hover{filter:brightness(1.08)}
button:disabled{opacity:.5;cursor:not-allowed}
button.ghost{background:var(--panel-2);color:var(--text);border:1px solid var(--border);
  font-weight:500;width:auto;margin:0}
button.ghost:hover{background:var(--border)}

.msg{font-size:12.5px;margin:10px 0 0;min-height:1em;line-height:1.4}
.msg.ok{color:var(--green)} .msg.err{color:var(--err)} .msg.info{color:var(--muted)}
.hint{font-size:11.5px;margin:6px 0}

/* ---- App layout ---- */
#app{display:flex;height:100vh;width:100vw}
#app[hidden]{display:none}
#sidebar{width:340px;min-width:340px;height:100vh;overflow-y:auto;
  background:var(--panel);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:16px;gap:14px}
#map{flex:1;height:100vh;background:#000}

.side-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.side-head .muted{font-size:12px;margin:2px 0 0}

.block{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px}
.block.grow{flex:1;min-height:120px;display:flex;flex-direction:column}

.coords{display:flex;gap:8px}
.coords>div{flex:1}

/* ---- Filtres / chips ---- */
.filters{display:flex;flex-wrap:wrap;gap:6px}
.chip{width:auto;margin:0;background:var(--panel);border:1px solid var(--border);
  color:var(--muted);font-weight:500;padding:6px 10px;font-size:12.5px}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---- Toggles ---- */
.toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);
  margin:6px 0;cursor:pointer}
.toggle input{width:auto;margin:0}

/* ---- Légende ---- */
.legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.legend li{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;cursor:pointer}
.legend li:hover{background:var(--panel)}
.legend .dot{width:12px;height:12px;border-radius:3px;flex:none}
.legend .count{margin-left:auto;color:var(--muted);font-size:12px}

/* ---- Liste points ---- */
.badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 8px;font-size:11px;margin-left:4px}
.pt-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}
.pt-item{display:flex;align-items:center;gap:8px;padding:7px 6px;border-radius:6px;cursor:pointer}
.pt-item:hover{background:var(--panel)}
.pt-item .pt-dot{width:10px;height:10px;border-radius:50%;flex:none}
.pt-item .pt-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pt-item .pt-del{width:auto;margin:0;background:transparent;color:var(--muted);
  padding:2px 6px;font-size:14px;border-radius:4px}
.pt-item .pt-del:hover{background:var(--err);color:#fff}
.dot-partenaire{background:var(--green)} .dot-independant{background:var(--yellow)}

.io{display:flex;gap:8px;flex-wrap:wrap}
.file-label{display:inline-flex;align-items:center;cursor:pointer}

/* ---- Labels carte (divIcon) ---- */
.arr-badge{display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;color:#fff;font-weight:700;font-size:14px;
  border:2px solid rgba(255,255,255,.85);box-shadow:0 1px 6px rgba(0,0,0,.5)}
.quartier-label{color:#fff;font-size:11px;font-weight:600;white-space:nowrap;
  text-shadow:0 0 3px #000,0 0 3px #000,0 0 4px #000}
.leaflet-div-icon{background:transparent;border:none}
