:root{
  /* palette bleue (noms hérités --teal* = bleus) */
  --teal:#0b73d6; --teal-dark:#0a5eb0; --teal-700:#084a8f;
  --ink:#0f172a; --muted:#64748b; --soft:#94a3b8;
  --bg:#f5f7f9; --surface:#ffffff; --line:#e6ebf0;
  --accent:#e0a44b; --accent-soft:#fdf3e3; --accent-ink:#9a6b16;
  --radius:16px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(15,23,42,.04),0 8px 24px -12px rgba(15,23,42,.12);
  --shadow-lg:0 24px 60px -20px rgba(15,23,42,.32);
  --shadow-pop:0 12px 34px -10px rgba(15,23,42,.22);
  --maxw:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
a{color:var(--teal-dark); text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 20px}
h1,h2,h3,strong{font-family:"Sora",system-ui,sans-serif}
:focus-visible{outline:2.5px solid var(--teal); outline-offset:2px; border-radius:6px}
button{font-family:inherit}

/* Header */
.site-header{position:sticky; top:0; z-index:30; background:rgba(255,255,255,.9); backdrop-filter:blur(10px); border-bottom:1px solid var(--line)}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:12px; height:62px}
.brand{display:flex; align-items:center; gap:11px; color:var(--ink); min-width:0}
.brand:hover{text-decoration:none}
.brand-mark{display:grid; place-items:center; width:38px; height:38px; border-radius:11px; background:linear-gradient(135deg,var(--teal),var(--teal-700)); color:#fff; flex:0 0 auto}
.brand-mark.sm{width:32px; height:32px; border-radius:9px}
.brand-text{display:flex; flex-direction:column; line-height:1.05; min-width:0}
.brand-text strong{font-size:16px; letter-spacing:-.01em; white-space:nowrap}
.brand-text em{font-style:normal; font-size:12px; color:var(--muted); font-weight:500}
.header-by{font-size:13px; color:var(--muted); white-space:nowrap}
.header-by a{font-weight:600}

/* Hero */
.hero{background:linear-gradient(150deg,#07294f 0%,#0b73d6 52%,#22d3ee 100%); color:#fff; padding:54px 0 64px; position:relative; overflow:hidden}
.hero::after{content:""; position:absolute; inset:0; background:radial-gradient(900px 380px at 80% -10%,rgba(255,255,255,.14),transparent 60%); pointer-events:none}
.hero h1{margin:0 0 8px; font-size:clamp(28px,4.6vw,46px); letter-spacing:-.025em; font-weight:800; line-height:1.08}
.hero-sub{margin:0 0 26px; font-size:clamp(15px,2vw,18px); color:rgba(255,255,255,.84); max-width:50ch}
.searchbar{position:relative; max-width:680px; display:flex; align-items:center; background:#fff; border-radius:14px; box-shadow:var(--shadow-lg); padding:0 12px; transition:box-shadow .2s}
.searchbar:focus-within{box-shadow:0 0 0 4px rgba(255,255,255,.3),var(--shadow-lg)}
.search-ico{color:var(--muted); flex:0 0 auto; margin-left:4px}
#q{flex:1; border:0; outline:0; background:transparent; font-size:17px; padding:18px 10px; color:var(--ink); font-family:inherit; min-width:0}
#q::-webkit-search-cancel-button,#q::-webkit-search-decoration{-webkit-appearance:none; appearance:none}
.q-clear{border:0; background:#f1f5f9; color:var(--muted); width:30px; height:30px; border-radius:50%; display:grid; place-items:center; cursor:pointer; flex:0 0 auto}
.q-clear[hidden]{display:none}
.q-clear:hover{background:#e2e8f0; color:var(--ink)}
.hero-stat{margin:18px 0 0; font-size:14px; color:rgba(255,255,255,.85)}
.hero-stat strong{color:#fff}

/* Controls */
.controls{background:var(--surface); border-bottom:1px solid var(--line); position:sticky; top:62px; z-index:20}
.controls .wrap{padding-top:14px; padding-bottom:14px}
.filters{display:flex; flex-wrap:wrap; gap:12px; align-items:flex-end}

/* Custom dropdown */
.dd{position:relative; display:flex; flex-direction:column}
.dd-label{font-size:11px; font-weight:600; color:var(--soft); text-transform:uppercase; letter-spacing:.05em; margin:0 0 4px 2px}
.dd-btn{display:flex; align-items:center; gap:10px; border:1px solid var(--line); background:#fff; border-radius:var(--radius-sm); padding:10px 12px; font-size:14px; color:var(--ink); cursor:pointer; min-width:210px; transition:border-color .15s,box-shadow .15s; font-weight:500}
.dd-btn:hover{border-color:#cdd6df}
.dd-btn .dd-val{flex:1; text-align:left; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.dd-btn .dd-chev{flex:0 0 auto; color:var(--muted); transition:transform .2s}
.dd.open .dd-btn{border-color:var(--teal); box-shadow:0 0 0 3px rgba(37,99,235,.16)}
.dd.open .dd-chev{transform:rotate(180deg)}
.dd.active .dd-btn{border-color:var(--teal); background:#eef4fe; color:var(--teal-700)}
.dd-panel{position:absolute; top:calc(100% + 6px); left:0; z-index:40; min-width:100%; width:max-content; max-width:300px; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow-pop); padding:6px; animation:pop .14s ease}
@keyframes pop{from{opacity:0; transform:translateY(-4px)}to{opacity:1; transform:none}}
.dd-panel[hidden]{display:none}
.dd-search{display:flex; align-items:center; gap:7px; padding:7px 9px; margin-bottom:4px; border:1px solid var(--line); border-radius:8px}
.dd-search svg{color:var(--soft); flex:0 0 auto}
.dd-search input{border:0; outline:0; font-size:14px; font-family:inherit; flex:1; min-width:0; background:transparent}
.dd-list{max-height:300px; overflow-y:auto; scrollbar-width:thin}
.dd-opt{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:9px 11px; border-radius:8px; font-size:14px; color:var(--ink); cursor:pointer; white-space:nowrap}
.dd-opt:hover,.dd-opt.hl{background:#f1f5f9}
.dd-opt[aria-selected="true"]{background:#e8effd; color:var(--teal-700); font-weight:600}
.dd-opt .o-n{font-size:12px; color:var(--soft); font-variant-numeric:tabular-nums}
.dd-opt[aria-selected="true"] .o-n{color:var(--teal)}
.dd-none{padding:12px; text-align:center; color:var(--soft); font-size:13px}

.chips{display:flex; gap:8px; overflow-x:auto; padding:14px 0 2px; scrollbar-width:thin; -webkit-overflow-scrolling:touch}
.chip{flex:0 0 auto; border:1px solid var(--line); background:#fff; color:var(--muted); border-radius:999px; padding:7px 14px; font-size:13px; font-weight:500; cursor:pointer; white-space:nowrap; transition:.15s}
.chip:hover{border-color:var(--teal); color:var(--teal-dark)}
.chip[aria-pressed="true"]{background:var(--teal-700); border-color:var(--teal-700); color:#fff}
.chip .c-n{opacity:.6; margin-left:5px; font-variant-numeric:tabular-nums}
.chip[aria-pressed="true"] .c-n{opacity:.85}

/* Results meta */
.results-meta{display:flex; align-items:center; justify-content:space-between; gap:12px; margin:24px 0 16px; min-height:24px}
#count{font-size:14px; color:var(--muted); font-weight:500}
#count b{color:var(--ink); font-family:"Sora"}
.link-btn{display:inline-flex; align-items:center; gap:6px; border:0; background:none; color:var(--teal-dark); font-size:13px; font-weight:600; cursor:pointer}
.link-btn[hidden]{display:none}
.link-btn:hover{text-decoration:underline}

/* Grid + cards */
.grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; margin-bottom:8px}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px 18px 16px; cursor:pointer; transition:border-color .16s,box-shadow .16s,transform .16s; display:flex; flex-direction:column; gap:10px; text-align:left; animation:cardin .34s both}
@keyframes cardin{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
.card:hover{border-color:var(--teal); box-shadow:var(--shadow); transform:translateY(-2px)}
.card-top{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
.card-name{font-family:"Sora"; font-weight:600; font-size:16px; letter-spacing:-.01em; line-height:1.25}
.card-cat{font-size:11px; font-weight:600; color:var(--teal-dark); background:#e8effd; border-radius:6px; padding:3px 8px; white-space:nowrap; flex:0 0 auto}
.card-met{font-size:13.5px; color:var(--muted); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.card-foot{display:flex; align-items:center; flex-wrap:wrap; gap:8px 12px; margin-top:auto; padding-top:6px; font-size:12.5px; color:var(--soft)}
.card-foot .loc{display:inline-flex; align-items:center; gap:5px; color:var(--ink); font-weight:500}
.card-foot svg{flex:0 0 auto}
.dist-badge{display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:600; color:var(--accent-ink); background:var(--accent-soft); border:1px solid #f3e2c2; border-radius:999px; padding:3px 9px}
.card-contacts{display:flex; gap:7px; margin-left:auto}
.card-contacts span{display:grid; place-items:center; width:26px; height:26px; border-radius:8px; background:#f1f5f9; color:var(--muted)}

/* Loading + empty + more */
.loading{display:flex; align-items:center; justify-content:center; gap:10px; padding:60px 0; color:var(--muted); font-size:14px}
.loading[hidden]{display:none}
.spinner{width:18px; height:18px; border:2.5px solid #d8e2e6; border-top-color:var(--teal); border-radius:50%; animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center; padding:48px 0; color:var(--muted)}
.more-wrap{display:flex; justify-content:center; margin:28px 0 48px}
.btn-more{border:1px solid var(--line); background:#fff; color:var(--ink); font-weight:600; font-size:14px; padding:12px 26px; border-radius:999px; cursor:pointer; transition:.15s}
.btn-more:hover{border-color:var(--teal); color:var(--teal-dark); box-shadow:var(--shadow)}
.btn-ghost{border:1px solid var(--line); background:#fff; padding:9px 18px; border-radius:999px; cursor:pointer; font-weight:600; margin-top:12px}
.btn-ghost:hover{border-color:var(--teal); color:var(--teal-dark)}

/* Footer */
.header-actions{display:flex; align-items:center; gap:16px}
.btn-cta{display:inline-flex; align-items:center; gap:7px; background:linear-gradient(135deg,#0b73d6,#22d3ee); color:#fff; font-weight:600; font-size:13.5px; padding:9px 16px; border-radius:10px; box-shadow:0 4px 14px rgba(11,115,214,.35); white-space:nowrap; transition:transform .15s,box-shadow .15s; border:0; cursor:pointer; font-family:inherit}
.btn-cta:hover{text-decoration:none; transform:translateY(-1px); box-shadow:0 8px 20px rgba(11,115,214,.45)}

.site-footer{background:#0a1020; color:#aeb8c7; margin-top:24px}
.footer-top{display:grid; grid-template-columns:1.7fr 1fr 1fr 1.2fr; gap:34px 28px; padding:50px 20px 32px}
.f-brand-row{display:flex; align-items:center; gap:12px; margin-bottom:14px}
.f-brand-row .brand-mark{background:linear-gradient(135deg,#0b73d6,#22d3ee)}
.f-brand strong{color:#fff; font-family:"Sora",sans-serif; font-size:16px; line-height:1.15; display:block}
.f-brand strong span{font-weight:500; color:#8aa0b8; font-size:13px}
.f-brand p{margin:0 0 10px; font-size:13.5px; color:#8aa0b8; max-width:34ch; line-height:1.55}
.f-stat{font-size:12.5px!important; color:#5dd6f0!important; font-weight:600}
.f-col h4{margin:0 0 13px; color:#fff; font-family:"Sora",sans-serif; font-size:13px; letter-spacing:.02em}
.f-col a{display:block; color:#aeb8c7; font-size:13.5px; font-weight:500; padding:5px 0}
.f-col a:hover{color:#5dd6f0; text-decoration:none}
.footer-bottom{display:flex; flex-wrap:wrap; gap:8px 20px; justify-content:space-between; align-items:center; padding:18px 20px; border-top:1px solid rgba(255,255,255,.08); font-size:12.5px; color:#6b7a8d}
.footer-bottom a{color:#5dd6f0; font-weight:600}
@media (max-width:760px){.footer-top{grid-template-columns:1fr 1fr; gap:30px 20px}}
@media (max-width:460px){.footer-top{grid-template-columns:1fr}}

/* Drawer detail */
.overlay{position:fixed; inset:0; background:rgba(15,23,42,.45); z-index:40; animation:fade .2s}
.overlay[hidden]{display:none}
@keyframes fade{from{opacity:0}to{opacity:1}}
.drawer{position:fixed; top:0; right:0; height:100%; width:min(440px,100%); background:#fff; z-index:50; box-shadow:var(--shadow-lg); overflow-y:auto; animation:slide .26s cubic-bezier(.2,.7,.3,1)}
.drawer[hidden]{display:none}
@keyframes slide{from{transform:translateX(100%)}to{transform:translateX(0)}}
.d-head{position:sticky; top:0; background:linear-gradient(150deg,#0b73d6,#22d3ee); color:#fff; padding:22px 22px 20px}
.d-close{position:absolute; top:14px; right:14px; border:0; background:rgba(255,255,255,.16); color:#fff; width:34px; height:34px; border-radius:50%; cursor:pointer; display:grid; place-items:center}
.d-close:hover{background:rgba(255,255,255,.28)}
.d-cat{display:inline-block; font-size:11px; font-weight:600; background:rgba(255,255,255,.18); padding:4px 10px; border-radius:999px; margin-bottom:10px}
.d-name{font-family:"Sora"; font-size:22px; font-weight:700; line-height:1.2; margin:0}
.d-sub{margin:6px 0 0; color:rgba(255,255,255,.85); font-size:14px}
.d-body{padding:22px}
.d-row{display:flex; gap:12px; padding:13px 0; border-bottom:1px solid var(--line); align-items:flex-start}
.d-row:last-child{border-bottom:0}
.d-ico{flex:0 0 auto; width:34px; height:34px; border-radius:9px; background:#e8effd; color:var(--teal-dark); display:grid; place-items:center}
.d-k{font-size:11px; text-transform:uppercase; letter-spacing:.04em; color:var(--soft); font-weight:600}
.d-v{font-size:15px; color:var(--ink); word-break:break-word}
.d-v a{font-weight:600}
.d-dist{margin:0 0 4px; display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:600; color:var(--accent-ink); background:var(--accent-soft); border:1px solid #f3e2c2; border-radius:999px; padding:5px 12px}
.d-map{display:inline-flex; align-items:center; gap:6px; margin-top:4px; font-size:13px; font-weight:600}
.d-actions{display:flex; gap:10px; padding:0 22px 26px; flex-wrap:wrap}
.d-actions a{flex:1 1 130px; text-align:center; padding:12px; border-radius:11px; font-weight:600; font-size:14px; display:inline-flex; align-items:center; justify-content:center; gap:7px}
.d-call{background:var(--teal-700); color:#fff}
.d-call:hover{background:var(--teal-dark); text-decoration:none}
.d-mail{background:#e8effd; color:var(--teal-dark)}
.d-mail:hover{text-decoration:none; background:#dbe7fd}

@media (max-width:600px){
  .hero{padding:38px 0 44px}
  .header-inner{gap:10px}
  .header-by{display:none}
  .header-actions{gap:0}
  .btn-cta span{display:none}      /* CTA en icône seule sur mobile */
  .btn-cta{padding:10px 12px}
  .brand-mark{width:34px; height:34px}
  .brand-text strong{font-size:15px}
  .filters{gap:10px}
  .dd{flex:1 1 46%}
  .dd-btn{min-width:0; width:100%}
  .grid{grid-template-columns:1fr}
}
/* ---- Logo animé + animations SVG ---- */
.brand-mark{background:linear-gradient(135deg,#0b73d6 0%,#22d3ee 100%); background-size:220% 220%; animation:gshift 7s ease-in-out infinite; transition:transform .25s}
.brand:hover .brand-mark{transform:translateY(-1px) scale(1.07) rotate(-4deg)}
.brand-mark svg path{stroke-dasharray:64; stroke-dashoffset:64; animation:draw .9s ease forwards}
.brand-mark svg path:nth-child(2){animation-delay:.14s}
.brand-mark svg path:nth-child(3){animation-delay:.3s}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes gshift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.hero-deco{position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.55; pointer-events:none}
.hero .wrap{position:relative; z-index:1}
.hero-deco circle{fill:none; stroke:rgba(255,255,255,.45); stroke-width:1.4; transform-box:view-box}
.hero-deco .b1{animation:floatA 10s ease-in-out infinite}
.hero-deco .b2{animation:floatB 13s ease-in-out infinite}
.hero-deco .b3{animation:floatA 16s ease-in-out infinite reverse}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(46px,-54px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(-58px,40px)}}

.searchbar:focus-within .search-ico{color:var(--teal)}
.card:hover .card-contacts span{background:#e8effd; color:var(--teal-dark)}
.card-contacts span{transition:background .16s,color .16s}

/* ---- Vue carte ---- */
.grid[hidden]{display:none}
.meta-right{display:flex; align-items:center; gap:14px}
.viewtoggle{display:inline-flex; background:#eef2f6; border:1px solid var(--line); border-radius:999px; padding:3px}
.vt{display:inline-flex; align-items:center; gap:6px; border:0; background:none; color:var(--muted); font-size:13px; font-weight:600; padding:7px 13px; border-radius:999px; cursor:pointer}
.vt.active{background:#fff; color:var(--teal-dark); box-shadow:0 1px 3px rgba(15,23,42,.14)}
.mapwrap[hidden]{display:none}
.mapwrap{margin:0 0 44px}
#map{height:560px; width:100%; border-radius:var(--radius); border:1px solid var(--line); box-shadow:var(--shadow); z-index:1}
.legend{display:flex; flex-wrap:wrap; gap:9px 16px; padding:14px 4px 2px; font-size:12.5px; color:var(--muted)}
.legend .lg{display:inline-flex; align-items:center; gap:7px}
.legend .dot{width:11px; height:11px; border-radius:50%; flex:0 0 auto; box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.map-note{font-size:12px; color:var(--soft); margin:6px 2px 0}
.legend .lg-hint{color:var(--muted); font-size:12.5px}
.cbub{display:grid; place-items:center; border-radius:50%; background:linear-gradient(135deg,#0b73d6,#22d3ee); color:#fff; font-family:"Sora",sans-serif; font-weight:700; border:2px solid #fff; box-shadow:0 5px 16px rgba(11,115,214,.45); cursor:pointer; transition:transform .14s; line-height:1}
.cbub:hover{transform:scale(1.09)}

/* ---- Badge non vérifié + formulaire d'ajout + toast ---- */
.unverif{display:inline-flex; align-items:center; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:#b45309; background:#fff7ed; border:1px solid #fed7aa; border-radius:999px; padding:2px 8px}
.addform{padding:20px 22px 26px; display:flex; flex-direction:column; gap:13px}
.addform label{display:flex; flex-direction:column; gap:5px; font-size:12.5px; font-weight:600; color:var(--muted)}
.addform label b{color:#dc2626}
.addform input,.addform select{border:1px solid var(--line); border-radius:10px; padding:11px 12px; font-size:15px; font-family:inherit; color:var(--ink); background:#fff; width:100%}
.addform input:focus,.addform select:focus{outline:2px solid var(--teal); border-color:var(--teal)}
.addform .addrow{display:flex; gap:12px}
.addform .addrow label{flex:1}
.addform .hp{position:absolute!important; left:-9999px!important; width:1px; height:1px; opacity:0}
.addnote{font-size:12px; color:var(--soft); line-height:1.5; margin:2px 0 0}
.addnote b{color:#dc2626}
.addmsg{font-size:13px; font-weight:600; padding:10px 12px; border-radius:9px; background:#e8effd; color:var(--teal-dark)}
.addmsg.err{background:#fef2f2; color:#dc2626}
.add-submit{border:0; cursor:pointer; font-family:inherit; background:linear-gradient(135deg,#0b73d6,#22d3ee); color:#fff; font-weight:700; font-size:15px; padding:13px; border-radius:11px; margin-top:4px; box-shadow:0 4px 14px rgba(11,115,214,.35)}
.add-submit:hover{box-shadow:0 8px 20px rgba(11,115,214,.45)}
.add-submit:disabled{opacity:.6; cursor:default}
.toast{position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(20px); display:flex; align-items:center; gap:9px; background:#0f172a; color:#fff; font-size:14px; font-weight:500; padding:13px 20px; border-radius:12px; box-shadow:var(--shadow-lg); z-index:60; opacity:0; pointer-events:none; transition:opacity .25s,transform .25s; max-width:90%; text-align:left}
.toast svg{flex:0 0 auto; color:#34d399}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
.mk{width:14px; height:14px; border-radius:50%; border:2px solid #fff; box-shadow:0 1px 3px rgba(0,0,0,.35)}
.leaflet-popup-content{font-family:"Inter",sans-serif; margin:12px 14px}
.pp-name{font-family:"Sora"; font-weight:700; font-size:14px; color:var(--ink)}
.pp-met{font-size:12.5px; color:var(--muted); margin:3px 0 9px}
.pp-link{display:inline-block; font-size:13px; font-weight:600; color:#fff!important; background:var(--teal); padding:6px 12px; border-radius:8px; cursor:pointer}

@media (prefers-reduced-motion:reduce){*{animation:none!important; transition:none!important; scroll-behavior:auto}
  .brand-mark svg path{stroke-dashoffset:0}}
