:root {
  --terra-900: #3D1F0A;
  --terra-800: #6B3210;
  --terra-700: #A04A18;
  --terra-600: #C8601E;
  --terra-500: #E07830;
  --terra-400: #F0A060;
  --terra-300: #F5C090;
  --terra-200: #FAE0C8;
  --terra-100: #FDF3EB;
  --terra-50:  #FEF9F5;
  --ocre-400: #D4A030;
  --ocre-200: #F5E4A8;
  --soil-800: #4A3728;
  --soil-600: #7A5C44;
  --soil-400: #A88060;
  --soil-200: #E8D8C8;
  --soil-100: #F5EDE4;
  --ok-main:  #2E8B57; --ok-bg: #E8F5EE; --ok-text: #1A5C38;
  --warn-main:#D4881A; --warn-bg:#FEF3DC; --warn-text:#8B5A00;
  --full-main:#C0392B; --full-bg:#FDECEA; --full-text:#7B1A14;
  --ink:  #2C1A0E; --ink-2: #5A3D28; --ink-3: #967860;
  --bg:   #FEF9F5; --white: #FFFFFF;
  --border: rgba(160,74,24,.14);
  --radius: 12px;
  --shadow: 0 2px 20px rgba(61,31,10,.08);
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Source Sans 3', 'Segoe UI', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);min-height:100vh}

/* ── HEADER ── */
.header{position:sticky;top:0;z-index:1000;background:rgba(254,249,245,.93);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.header-inner{max-width:1100px;margin:0 auto;padding:.7rem 1.5rem;display:flex;align-items:center;gap:1.5rem}
.logo{display:flex;align-items:center;gap:.65rem;text-decoration:none;flex-shrink:0}
.logo-svg{width:36px;height:36px;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:1.2rem;color:var(--ink);letter-spacing:-.01em;line-height:1.1}
.logo-text em{color:var(--terra-600);font-style:italic}
.logo-sub{font-size:.62rem;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase;display:block}
.nav{display:flex;gap:.2rem;flex:1}
.nav-link{padding:.38rem .85rem;border-radius:8px;font-size:.875rem;color:var(--ink-3);text-decoration:none;transition:all .15s;font-weight:400}
.nav-link:hover,.nav-link.active{background:var(--terra-200);color:var(--terra-800)}
.btn-signal-header{display:flex;align-items:center;gap:.4rem;padding:.45rem 1.1rem;background:var(--terra-600);color:white;border:none;border-radius:20px;font-size:.875rem;font-family:var(--font-body);cursor:pointer;flex-shrink:0;transition:background .15s,transform .1s;font-weight:600}
.btn-signal-header:hover{background:var(--terra-700);transform:translateY(-1px)}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;background:var(--terra-800);padding:3.5rem 1.5rem 2.5rem;text-align:center}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(ellipse 60% 40% at 80% 20%,rgba(200,96,30,.25) 0%,transparent 60%),radial-gradient(ellipse 40% 50% at 15% 80%,rgba(61,31,10,.4) 0%,transparent 60%);pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:620px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);color:var(--terra-300);border:1px solid rgba(240,160,96,.3);border-radius:20px;font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;padding:.3rem 1rem;margin-bottom:1rem}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,2.9rem);color:white;line-height:1.15;margin-bottom:.75rem;font-weight:700}
.hero-title em{color:var(--terra-400);font-style:italic;font-weight:400}
.hero-sub{font-size:.95rem;color:rgba(255,255,255,.72);margin-bottom:1.75rem;line-height:1.65}
.search-wrapper{display:flex;align-items:center;background:white;border-radius:50px;padding:.35rem .35rem .35rem 1rem;gap:.5rem;max-width:460px;margin:0 auto 1.75rem;box-shadow:0 4px 28px rgba(61,31,10,.25)}
.search-icon{color:var(--ink-3);flex-shrink:0}
.search-input{flex:1;border:none;outline:none;font-family:var(--font-body);font-size:.9rem;color:var(--ink);background:transparent}
.search-btn{padding:.5rem 1.3rem;background:var(--terra-600);color:white;border:none;border-radius:40px;font-size:.875rem;font-family:var(--font-body);cursor:pointer;transition:background .15s;white-space:nowrap;font-weight:600}
.search-btn:hover{background:var(--terra-700)}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}
.hstat{text-align:center}
.hstat-num{display:block;font-family:var(--font-display);font-size:1.65rem;color:white;line-height:1}
.hstat-label{font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em}
.hstat-sep{width:1px;height:28px;background:rgba(255,255,255,.18)}
.hero-leaf{position:absolute;border-radius:50%;pointer-events:none}
.hero-leaf-1{width:320px;height:320px;top:-110px;right:-90px;background:rgba(200,96,30,.12)}
.hero-leaf-2{width:200px;height:200px;bottom:-80px;left:-60px;background:rgba(61,31,10,.25)}

/* ── FILTERS ── */
.filters-bar{max-width:1100px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.filter-pills{display:flex;gap:.45rem;flex-wrap:wrap}
.pill{display:flex;align-items:center;gap:.4rem;padding:.33rem .85rem;border-radius:20px;border:1px solid var(--border);background:white;font-size:.82rem;font-family:var(--font-body);color:var(--ink-2);cursor:pointer;transition:all .15s}
.pill:hover{border-color:var(--terra-500);color:var(--terra-700)}
.pill.active{background:var(--terra-200);border-color:var(--terra-500);color:var(--terra-800);font-weight:600}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-ok{background:var(--ok-main)} .dot-warn{background:var(--warn-main)} .dot-full{background:var(--full-main)}
.filter-right{display:flex;align-items:center;gap:.75rem}
.result-count{font-size:.82rem;color:var(--ink-3)}
.btn-locate{display:flex;align-items:center;gap:.4rem;padding:.33rem .85rem;border-radius:20px;border:1px solid var(--border);background:white;font-size:.82rem;font-family:var(--font-body);color:var(--terra-700);cursor:pointer;transition:all .15s}
.btn-locate:hover{background:var(--terra-100);border-color:var(--terra-400)}

/* ── MAIN ── */
.main-content{max-width:1100px;margin:0 auto;padding:0 1.5rem 3rem}
.view{width:100%}
.view.hidden{display:none}
.view.active{display:block}

/* ── MAP ── */
#map{width:100%;height:540px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);margin-top:1rem}
.leaflet-popup-content-wrapper{border-radius:10px !important;box-shadow:0 4px 20px rgba(61,31,10,.14) !important;font-family:var(--font-body) !important}
.leaflet-popup-content{margin:.75rem 1rem !important;font-size:.875rem}
.popup-title{font-weight:600;color:var(--ink);margin-bottom:.2rem;font-family:var(--font-display)}
.popup-addr{font-size:.8rem;color:var(--ink-3);margin-bottom:.5rem}
.popup-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;padding:.2rem .6rem;border-radius:4px;margin-bottom:.6rem}
.popup-btn{display:block;width:100%;padding:.4rem;background:var(--terra-600);color:white;border:none;border-radius:6px;font-size:.8rem;font-family:var(--font-body);cursor:pointer;text-align:center;font-weight:600}
.popup-when{font-size:.72rem;color:var(--ink-3);margin-top:.35rem;text-align:center}
.marker-ok{background:var(--ok-main);border:2px solid white;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 5px rgba(0,0,0,.3)}
.marker-warn{background:var(--warn-main);border:2px solid white;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 5px rgba(0,0,0,.3)}
.marker-full{background:var(--full-main);border:2px solid white;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 5px rgba(0,0,0,.3)}
.marker-unknown{background:var(--soil-400);border:2px solid white;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 5px rgba(0,0,0,.3)}

/* ── LIST ── */
.list-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;padding-top:1rem}
.bulle-card{background:white;border-radius:var(--radius);border:1px solid var(--border);padding:1rem 1.1rem;display:flex;gap:.85rem;align-items:flex-start;transition:box-shadow .15s,transform .15s;cursor:pointer}
.bulle-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.card-status-bar{width:4px;border-radius:4px;flex-shrink:0;align-self:stretch;min-height:48px}
.bar-ok{background:var(--ok-main)} .bar-warn{background:var(--warn-main)} .bar-full{background:var(--full-main)} .bar-unknown{background:var(--soil-200)}
.card-body{flex:1;min-width:0}
.card-name{font-size:.9rem;font-weight:600;color:var(--ink);margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-addr{font-size:.8rem;color:var(--ink-3);margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.badge{font-size:.73rem;padding:.2rem .6rem;border-radius:4px;font-weight:600}
.badge-ok{background:var(--ok-bg);color:var(--ok-text)} .badge-warn{background:var(--warn-bg);color:var(--warn-text)} .badge-full{background:var(--full-bg);color:var(--full-text)} .badge-unknown{background:var(--soil-100);color:var(--soil-600)}
.card-when{font-size:.73rem;color:var(--ink-3)}
.card-btn{flex-shrink:0;padding:.35rem .7rem;border:1px solid var(--border);background:var(--bg);border-radius:8px;font-size:.8rem;font-family:var(--font-body);color:var(--terra-700);cursor:pointer;transition:all .15s;align-self:center}
.card-btn:hover{background:var(--terra-100);border-color:var(--terra-400)}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto auto;gap:1rem;padding-top:1rem}
.stat-card{background:white;border-radius:var(--radius);border:1px solid var(--border);padding:1.25rem}
.stat-card-wide{grid-column:1/-1}
.stat-card-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);margin-bottom:1rem;font-weight:600}
.donut-wrap{position:relative;width:160px;height:160px;margin:0 auto 1rem}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.donut-center span{display:block;font-family:var(--font-display);font-size:1.65rem;color:var(--ink);line-height:1}
.donut-center small{font-size:.7rem;color:var(--ink-3)}
.legend{display:flex;flex-direction:column;gap:.5rem}
.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--ink-2)}
.legend-item strong{margin-left:auto;font-weight:600;color:var(--ink)}
.recent-list{display:flex;flex-direction:column;gap:.6rem;overflow-y:auto;max-height:260px}
.recent-item{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem .75rem;background:var(--bg);border-radius:8px;font-size:.82rem}
.recent-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.recent-info{flex:1;min-width:0}
.recent-place{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent-when{font-size:.73rem;color:var(--ink-3)}

/* ── MODAL STEPS ── */
.modal-steps{display:flex;align-items:center;gap:.5rem;margin-bottom:1.4rem}
.modal-step{display:flex;align-items:center;gap:.4rem}
.step-dot{width:24px;height:24px;border-radius:50%;background:var(--bg);border:1.5px solid var(--border);color:var(--ink-3);font-size:.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .25s;flex-shrink:0}
.step-dot.active{background:var(--terra-600);border-color:var(--terra-600);color:white}
.step-dot.done{background:var(--terra-200);border-color:var(--terra-500);color:var(--terra-800)}
.step-label{font-size:.8rem;color:var(--ink-3);transition:color .25s}
.modal-step:has(.step-dot.active) .step-label{color:var(--ink);font-weight:600}
.step-line{flex:1;height:1.5px;background:var(--border);border-radius:2px;transition:background .25s}
.step-line.done{background:var(--terra-400)}

/* ── BULLE SEARCH ── */
.bulle-search-wrap{position:relative;display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;padding:.5rem .75rem;gap:.5rem;background:var(--bg);transition:border-color .15s;margin-bottom:.6rem}
.bulle-search-wrap:focus-within{border-color:var(--terra-500);background:white}
.search-icon-sm{color:var(--ink-3);flex-shrink:0}
.bulle-search-input{flex:1;border:none;outline:none;font-family:var(--font-body);font-size:.9rem;color:var(--ink);background:transparent}
.bulle-search-clear{background:none;border:none;color:var(--ink-3);cursor:pointer;font-size:1.1rem;padding:0 .2rem;line-height:1;transition:color .15s}
.bulle-search-clear:hover{color:var(--ink)}
.bulle-search-hint{font-size:.78rem;color:var(--ink-3);padding:.2rem .25rem .4rem}
.bulle-search-results{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:.35rem;margin-bottom:.5rem}
.bulle-search-results::-webkit-scrollbar{width:4px}
.bulle-search-results::-webkit-scrollbar-thumb{background:var(--terra-300);border-radius:2px}
.bulle-result-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border:1px solid var(--border);border-radius:9px;cursor:pointer;background:white;transition:all .15s}
.bulle-result-item:hover{border-color:var(--terra-400);background:var(--terra-50)}
.bri-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.bri-info{flex:1;min-width:0}
.bri-name{font-size:.85rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bri-addr{font-size:.75rem;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bri-meta{display:flex;align-items:center;gap:.4rem;flex-shrink:0}
.bri-cp{font-size:.73rem;background:var(--terra-200);color:var(--terra-800);padding:.15rem .45rem;border-radius:4px;font-weight:600}
.bri-dist{font-size:.72rem;color:var(--ink-3)}
.bri-chevron{color:var(--terra-400);font-size:.9rem}
.bulle-search-empty{text-align:center;padding:1.25rem 0;color:var(--ink-3);font-size:.85rem}
.bulle-search-empty-icon{font-size:1.6rem;margin-bottom:.4rem}
.modal-geolocate-row{border-top:1px solid var(--border);padding-top:.75rem;margin-top:.25rem}
.btn-geolocate-modal{display:flex;align-items:center;gap:.45rem;padding:.4rem .85rem;border:1px solid var(--border);border-radius:20px;background:white;font-size:.825rem;font-family:var(--font-body);color:var(--terra-700);cursor:pointer;transition:all .15s;width:100%;justify-content:center;font-weight:600}
.btn-geolocate-modal:hover{background:var(--terra-100);border-color:var(--terra-400)}

/* ── STEP 2 ── */
.btn-change-bulle{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--terra-600);background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-body);margin-bottom:.1rem;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s}
.btn-change-bulle:hover{text-decoration-color:var(--terra-500)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(40,15,5,.55);display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px);animation:fadeIn .2s ease}
.modal-overlay.hidden{display:none}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:white;border-radius:16px;padding:1.75rem;width:100%;max-width:440px;position:relative;animation:slideUp .25s ease;box-shadow:0 10px 48px rgba(61,31,10,.22);max-height:90vh;overflow-y:auto}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}
.modal-close{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border-radius:50%;border:none;background:var(--bg);color:var(--ink-3);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.modal-close:hover{background:var(--terra-200);color:var(--terra-800)}
.modal-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.1rem}
.modal-icon{font-size:1.5rem;flex-shrink:0}
.modal-title{font-family:var(--font-display);font-size:1.15rem;color:var(--ink);font-weight:700}
.modal-addr{font-size:.8rem;color:var(--ink-3);margin-top:.1rem}
.modal-section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);font-weight:600;margin-bottom:.6rem}
.optional{font-size:.7rem;text-transform:none;letter-spacing:0;color:var(--ink-3);font-weight:400}

.choice-row{display:flex;gap:.6rem;margin-bottom:1.25rem}
.choice{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;text-align:center;background:white}
.choice:hover{border-color:var(--terra-400);background:var(--terra-50)}
.choice.selected-ok{border-color:var(--ok-main);background:var(--ok-bg)}
.choice.selected-warn{border-color:var(--warn-main);background:var(--warn-bg)}
.choice.selected-full{border-color:var(--full-main);background:var(--full-bg)}
.choice-emoji{font-size:1.3rem}
.choice-label{font-size:.8rem;font-weight:600;color:var(--ink)}
.choice-sub{font-size:.7rem;color:var(--ink-3)}

/* ── AUTEUR / ANONYMAT ── */
.author-row{margin-bottom:1rem}
.author-toggle{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}
.author-toggle-label{font-size:.82rem;color:var(--ink-2);cursor:pointer;display:flex;align-items:center;gap:.45rem;user-select:none}
.toggle-switch{position:relative;width:36px;height:20px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-track{position:absolute;inset:0;border-radius:20px;background:var(--soil-200);transition:background .2s;cursor:pointer}
.toggle-switch input:checked + .toggle-track{background:var(--terra-500)}
.toggle-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:white;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);pointer-events:none}
.toggle-switch input:checked ~ .toggle-thumb{transform:translateX(16px)}
.author-name-input{width:100%;border:1px solid var(--border);border-radius:8px;padding:.5rem .75rem;font-family:var(--font-body);font-size:.875rem;color:var(--ink);outline:none;background:var(--bg);transition:border-color .15s}
.author-name-input:focus{border-color:var(--terra-500);background:white}
.author-name-input:disabled{opacity:.45;cursor:not-allowed;background:var(--soil-100)}
.author-anon-chip{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--ink-3);margin-top:.35rem;padding:.25rem .6rem;background:var(--soil-100);border-radius:20px}

.modal-textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:.6rem .75rem;font-family:var(--font-body);font-size:.875rem;color:var(--ink);resize:none;outline:none;background:var(--bg);margin-bottom:1rem;transition:border-color .15s}
.modal-textarea:focus{border-color:var(--terra-500);background:white}
.submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--terra-600);color:white;border:none;border-radius:10px;font-size:.9rem;font-family:var(--font-body);font-weight:700;cursor:pointer;transition:background .15s,transform .1s;letter-spacing:.01em}
.submit-btn:hover{background:var(--terra-700)}
.submit-btn:active{transform:scale(.98)}
.modal-footer-note{text-align:center;font-size:.73rem;color:var(--ink-3);margin-top:.75rem}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);background:var(--terra-800);color:white;padding:.6rem 1.25rem;border-radius:20px;font-size:.875rem;z-index:3000;box-shadow:0 4px 20px rgba(61,31,10,.25);animation:toastIn .3s ease;white-space:nowrap}
.toast.hidden{display:none}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ── BOUTON PROPOSER (filters bar desktop) ── */
.btn-propose {
  display: flex; align-items: center; gap: .4rem;
  padding: .33rem .85rem; border-radius: 20px;
  border: 1px solid var(--terra-400);
  background: var(--terra-100);
  font-size: .82rem; font-family: var(--font-body);
  color: var(--terra-700); cursor: pointer; transition: all .15s;
  font-weight: 600;
}
.btn-propose:hover { background: var(--terra-200); border-color: var(--terra-600); }

/* ── BOUTON TRI PAR DISTANCE ── */
.btn-sort-dist {
  display: flex; align-items: center; gap: .4rem;
  padding: .33rem .85rem; border-radius: 20px;
  border: 1px solid var(--border);
  background: white;
  font-size: .82rem; font-family: var(--font-body);
  color: var(--ink-2); cursor: pointer; transition: all .15s;
}
.btn-sort-dist:hover { border-color: var(--terra-500); color: var(--terra-700); }
.btn-sort-dist.active {
  background: var(--terra-200);
  border-color: var(--terra-500);
  color: var(--terra-800);
  font-weight: 600;
}

/* ── DISTANCE BADGE SUR LES CARTES ── */
.dist-badge {
  display: inline-flex; align-items: center; gap: .25rem;
  font-size: .72rem; color: var(--ink-3);
  background: var(--soil-100);
  border-radius: 4px; padding: .15rem .45rem;
  font-weight: 500;
}

/* ── BOUTON WHATSAPP SHARE ── */
.btn-whatsapp {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .3rem .7rem;
  background: #25D366; color: white;
  border: none; border-radius: 8px;
  font-size: .75rem; font-family: var(--font-body);
  font-weight: 600; cursor: pointer;
  transition: background .15s, transform .1s;
  text-decoration: none;
  white-space: nowrap;
}
.btn-whatsapp:hover { background: #128C7E; transform: translateY(-1px); }
.btn-whatsapp svg { flex-shrink: 0; }

/* ── BADGES CONTRIBUTEURS ── */
.contributors-list {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: .75rem;
}
.contributor-badge {
  display: flex; align-items: center; gap: .6rem;
  background: var(--terra-50);
  border: 1px solid var(--terra-200);
  border-radius: 10px;
  padding: .5rem .85rem;
  transition: transform .15s;
}
.contributor-badge:hover { transform: translateY(-2px); }
.contributor-badge.rank-1 { background: #FFF8E7; border-color: #F0C060; }
.contributor-badge.rank-2 { background: #F5F5F5; border-color: #C0C0C0; }
.contributor-badge.rank-3 { background: #FFF0E8; border-color: #CD7F32; }
.contributor-medal { font-size: 1.2rem; }
.contributor-info {}
.contributor-name {
  font-size: .85rem; font-weight: 600; color: var(--ink);
  display: block;
}
.contributor-count {
  font-size: .72rem; color: var(--ink-3);
  display: block;
}
.contributors-note {
  font-size: .78rem; color: var(--ink-3);
  text-align: center; margin-top: .25rem;
}
.contributors-empty {
  text-align: center; padding: 1.5rem 0;
  color: var(--ink-3); font-size: .875rem;
}

/* Popup WhatsApp share */
.popup-share-row {
  margin-top: .5rem;
  display: flex; justify-content: center;
}

/* ── FORMULAIRE PROPOSITION ── */
.proposal-form{display:flex;flex-direction:column;gap:.9rem}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.pf-field{display:flex;flex-direction:column;gap:.3rem}
.pf-label{font-size:.75rem;font-weight:600;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.3rem}
.pf-req{color:var(--terra-600);font-size:.85rem;font-weight:700}
.pf-opt{font-size:.7rem;color:var(--ink-3);text-transform:none;letter-spacing:0;font-weight:400}
.pf-input{
  border:1.5px solid var(--border);border-radius:9px;
  padding:.55rem .8rem;font-family:var(--font-body);
  font-size:.9rem;color:var(--ink);outline:none;
  background:var(--bg);transition:border-color .15s,background .15s;
}
.pf-input:focus{border-color:var(--terra-500);background:white}
.pf-input.error{border-color:var(--full-main);background:#FDECEA}
.pf-input-sm{max-width:160px}
.pf-error{font-size:.75rem;color:var(--full-main);font-weight:500}
.pf-error.hidden{display:none}

.pf-notice{
  display:flex;align-items:flex-start;gap:.5rem;
  background:var(--terra-100);border:1px solid var(--terra-300);
  border-radius:9px;padding:.65rem .8rem;
  font-size:.78rem;color:var(--terra-700);line-height:1.5;
}
.pf-notice svg{flex-shrink:0;margin-top:1px;color:var(--terra-600)}

/* Success state */
.proposal-success{text-align:center;padding:.5rem 0}
.ps-icon{font-size:3rem;margin-bottom:.75rem}
.ps-text{font-size:.9rem;color:var(--ink-2);line-height:1.65;margin-top:.5rem;margin-bottom:1rem}
.ps-summary{
  background:var(--soil-100);border-radius:10px;
  padding:.85rem 1rem;text-align:left;
  font-size:.82rem;color:var(--ink-2);line-height:1.7;
  border:1px solid var(--border);
}
.ps-summary strong{color:var(--ink);font-weight:600}

@media(max-width:480px){
  .pf-row{grid-template-columns:1fr}
  .btn-propose span{display:none}
}

.bottom-nav{display:none}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE
══════════════════════════════════════════════════════════════ */
@media(max-width:700px){

  /* ── NAV ── */
  .nav{display:none}
  .btn-signal-header{display:none}
  .app-nav-inner{padding:.6rem 1rem;gap:.5rem}
  .app-nav-tabs{display:none}
  .conn-status{display:none}

  /* ── HERO / LANDING ── */
  .hero{padding:2rem 1rem 1.5rem}
  .hero-title{font-size:1.7rem}
  .landing-title{font-size:1.9rem !important;line-height:1.15}
  .landing-sub{font-size:.9rem}
  .landing-search{max-width:100%;margin-bottom:1.25rem}
  .landing-actions{gap:.6rem}
  .btn-hero-primary,.btn-hero-secondary{
    padding:.65rem 1.1rem;font-size:.875rem;
  }
  .landing-stats{gap:.6rem;margin-top:.5rem}
  .lstat-num{font-size:1.3rem}
  .lstat-label{font-size:.6rem}
  .lstat-sep{height:22px}

  /* ── CONCEPT SECTION ── */
  .concept-inner{grid-template-columns:1fr;gap:.75rem}
  .concept-section{padding:2rem 1rem 1.5rem}

  /* ── APP NAV LOGO ── */
  .app-logo-sub{display:none}
  .app-logo-text{font-size:.95rem}
  .app-logo-svg{width:26px;height:26px}
  .btn-signal-nav{padding:.4rem .75rem;font-size:.8rem}

  /* ── FILTERS ── */
  .filters-bar{
    padding:.5rem .75rem;
    gap:.4rem;
    flex-wrap:wrap;
  }
  .filter-pills{gap:.3rem;flex-wrap:wrap}
  .pill{padding:.28rem .65rem;font-size:.75rem}
  .filter-right{
    width:100%;
    justify-content:space-between;
    gap:.4rem;
  }
  .result-count{font-size:.75rem}
  .btn-locate,.btn-propose{
    padding:.28rem .65rem;font-size:.75rem;
  }
  .btn-propose span{display:none} /* icône seulement */

  /* ── MAIN CONTENT ── */
  .main-content{padding:0 .75rem 5rem}

  /* ── MAP ── */
  #map{
    height:calc(100vh - 240px);
    min-height:320px;
    border-radius:8px;
  }

  /* ── LIST ── */
  .list-container { grid-template-columns: 1fr; gap: .6rem; }
  .bulle-card {
    padding: .8rem .85rem;
    gap: .5rem;
    flex-wrap: wrap;        /* évite le débordement */
    align-items: flex-start;
  }
  .card-body { flex: 1; min-width: 0; }  /* empêche le texte de déborder */
  .card-name { font-size: .85rem; white-space: normal; word-break: break-word; }
  .card-addr { font-size: .75rem; white-space: normal; word-break: break-word; }
  /* Boutons carte en ligne sous le contenu */
  .bulle-card > div:last-child {
    width: 100%;
    flex-direction: row !important;
    justify-content: flex-end;
    gap: .4rem;
  }
  .card-btn { padding: .3rem .65rem; font-size: .75rem; }
  .btn-whatsapp { padding: .3rem .65rem; font-size: .75rem; }

  /* ── MODAL — bouton soumettre toujours visible ── */
  .modal {
    padding: 1rem;
    max-height: 88vh;
    margin: 0;
    border-radius: 16px 16px 0 0;
    width: 100%;
    max-width: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .modal-overlay { align-items: flex-end; padding: 0; }
  /* Réduire les espacements dans la modale */
  .modal-header { margin-bottom: .75rem; }
  .modal-section-label { margin-bottom: .4rem; }
  .modal-textarea { margin-bottom: .6rem; rows: 2; }
  .choice-row { gap: .35rem; }
  .choice { padding: .5rem .25rem; }
  .choice-emoji { font-size: 1rem; }
  .choice-label { font-size: .7rem; }
  .choice-sub { font-size: .62rem; }
  .pf-row { grid-template-columns: 1fr; }
  .modal-steps { margin-bottom: .75rem; }

  /* ── BOTTOM NAV ── */
  .bottom-nav{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;
    z-index:900;
    background:white;
    border-top:1px solid var(--border);
    box-shadow:0 -4px 20px rgba(61,31,10,.1);
    height:60px;
    align-items:stretch;
  }
  .bottom-nav-item{
    flex:1;display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    gap:2px;padding:.35rem .4rem;
    background:none;border:none;cursor:pointer;
    font-family:var(--font-body);
    color:var(--ink-3);font-size:.63rem;font-weight:600;
    letter-spacing:.02em;text-transform:uppercase;
    transition:color .15s,background .15s;
    -webkit-tap-highlight-color:transparent;
    position:relative;
  }
  .bottom-nav-item svg{transition:transform .15s}
  .bottom-nav-item.active{color:var(--terra-600)}
  .bottom-nav-item.active svg{transform:translateY(-2px)}
  .bottom-nav-item:active{background:var(--terra-50)}
  .bottom-nav-item.active::after{
    content:'';display:block;
    width:4px;height:4px;border-radius:50%;
    background:var(--terra-600);
    position:absolute;bottom:5px;
  }
  .bottom-nav-item.nav-signal{
    color:white;
    background:var(--terra-600);
    border-radius:14px 14px 0 0;
    margin:0 .4rem;
    font-size:.65rem;
  }
  .bottom-nav-item.nav-signal:active{background:var(--terra-700)}
  .bottom-nav-item.nav-signal.active{color:white}
  .bottom-nav-item.nav-signal::after{display:none}

  /* Bouton "Proposer" dans la bottom nav — orange clair */
  .bottom-nav-item.nav-propose{
    color:var(--terra-700);
    background:var(--terra-100);
    border-top:2px solid var(--terra-400);
    font-size:.6rem;
    font-weight:700;
  }
  .bottom-nav-item.nav-propose:active{background:var(--terra-200)}
  .bottom-nav-item.nav-propose::after{display:none}

  /* Cacher le bouton proposer de la barre de filtre sur mobile (remplacé par bottom nav) */
  .btn-propose { display: none !important; }

  /* ── TOP NAV MOBILE — géré directement dans index.html ── */
  .top-nav-propose { display: none !important; }
  .btn-propose-nav { display: none !important; }
}

/* Très petits écrans */
@media(max-width:380px){
  .landing-title{font-size:1.65rem !important}
  .btn-hero-primary,.btn-hero-secondary{
    width:100%;justify-content:center;
  }
  .landing-actions{flex-direction:column;align-items:stretch}
}
