/* =============================================================
 * TDF — Archive commune (taxonomy-region.php)
 * Scope .cmn-region, tokens autonomes (mêmes valeurs que les
 * singles → rendu cohérent), SANS reset universel agressif :
 * les cartes TDF (events/immo) et les widgets open-data gardent
 * ainsi leur propre style intact.
 * ============================================================= */

.cmn-region {
  --bg:#FFFFFF; --bg-soft:#F7F7F8; --bg-subtle:#FAFAFB;
  --border:#ECECEE; --border-md:#DDDDE0;
  --ink:#14131F; --ink-soft:#3A3850; --ink-muted:#74738A; --ink-light:#ADAABF;
  --accent:#F91942; --accent-soft:#FEE7EC; --accent-hover:#E20D36;
  --green:#16A34A; --green-soft:#DCFCE7;
  --shadow-xs:0 1px 2px rgba(20,19,31,.04);
  --shadow-md:0 4px 12px rgba(20,19,31,.06),0 2px 4px rgba(20,19,31,.04);
  --shadow-lg:0 22px 48px rgba(20,19,31,.14),0 6px 12px rgba(20,19,31,.06);
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:20px; --r-pill:999px;
  font-family:'Raleway',system-ui,sans-serif; font-size:15px; line-height:1.55; color:var(--ink);
}
.cmn-region * { box-sizing:border-box; }
.cmn-region a { color:inherit; text-decoration:none; }
.cmn-region img { max-width:100%; }
.cmn-region .ac { color:var(--accent); }

/* Scroll vertical (body d'archive Listeo neutralisé côté PHP) */
body.cmn-commune-archive,
body.cmn-commune-archive #wrapper { height:auto!important; min-height:0!important; max-height:none!important; overflow:visible!important; }
html { overflow-y:auto; }

/* ── Conteneur ──────────────────────────────────────────── */
.cmn-region .cmn-wrap { max-width:1120px; margin:0 auto; padding:0 16px; }
@media (min-width:1024px){ .cmn-region .cmn-wrap { padding:0 24px; } }

/* ── HERO ──────────────────────────────────────────────── */
.cmn-region .cmn-hero { position:relative; min-height:52vh; display:flex; align-items:flex-end; overflow:hidden; background:#1a1825; }
@media (min-width:1024px){ .cmn-region .cmn-hero { min-height:58vh; max-height:600px; } }
.cmn-region .cmn-hero-img { position:absolute; inset:0; }
.cmn-region .cmn-hero-img img { width:100%; height:100%; object-fit:cover; }
.cmn-region .cmn-hero-img::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,19,31,.35) 0%,rgba(20,19,31,.05) 30%,rgba(20,19,31,.9) 100%); }
.cmn-region .cmn-hero-in { position:relative; z-index:2; width:100%; max-width:1120px; margin:0 auto; padding:0 16px 30px; color:#fff; }
@media (min-width:1024px){ .cmn-region .cmn-hero-in { padding:0 24px 40px; } }
.cmn-region .cmn-hero-eyebrow { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:#fff; opacity:.85; margin-bottom:10px; }
.cmn-region .cmn-hero-eyebrow svg { width:14px; height:14px; }
.cmn-region .cmn-hero-title { font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(34px,7vw,66px); line-height:1; letter-spacing:-0.03em; margin:0 0 8px; color:#fff !important; }
.cmn-region .cmn-hero-meta { font-size:14px; color:#fff; opacity:.9; }

/* ── NAV sticky ─────────────────────────────────────────── */
.cmn-region .cmn-nav { position:sticky; top:0; z-index:30; background:rgba(255,255,255,.93); backdrop-filter:blur(12px); border-bottom:1px solid var(--border); margin:0 -16px 22px; }
@media (min-width:768px){ .cmn-region .cmn-nav { top:79px; margin:0 0 26px; } }
.cmn-region .cmn-nav-track { display:flex; gap:6px; overflow-x:auto; scrollbar-width:none; padding:10px 16px; max-width:1120px; margin:0 auto; }
.cmn-region .cmn-nav-track::-webkit-scrollbar { display:none; }
.cmn-region .cmn-nav-chip { flex:0 0 auto; display:inline-flex; align-items:center; padding:7px 14px; background:var(--bg-soft); border:1px solid var(--border); color:var(--ink-soft); border-radius:var(--r-pill); font-size:12.5px; font-weight:600; white-space:nowrap; transition:all .15s; }
.cmn-region .cmn-nav-chip:hover { background:#fff; border-color:var(--border-md); color:var(--ink); }
.cmn-region .cmn-nav-chip.is-active { background:var(--accent); border-color:var(--accent); color:#fff; }

/* ── Recherche ──────────────────────────────────────────── */
.cmn-region .cmn-search { display:flex; gap:8px; margin:0 0 18px; background:#fff; border:1px solid var(--border); border-radius:var(--r-pill); padding:6px 6px 6px 16px; box-shadow:none; }
.cmn-region .cmn-search svg { width:18px; height:18px; color:var(--ink-muted); align-self:center; flex-shrink:0; }
.cmn-region .cmn-search input { flex:1; border:none; outline:none; font-family:inherit; font-size:14.5px; color:var(--ink); background:transparent; min-width:0; box-shadow:none; margin-bottom:0; }
.cmn-region .cmn-search button { border:none; background:var(--accent); color:#fff; border-radius:var(--r-pill); padding:10px 18px; font-family:'Poppins',sans-serif; font-weight:600; font-size:13.5px; cursor:pointer; transition:background .15s; }
.cmn-region .cmn-search button:hover { background:var(--accent-hover); }

/* ── Panneau de résultats ──────────────────────────────── */
.cmn-region .cmn-results { display:none; margin-bottom:26px; background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-md); overflow:hidden; }
.cmn-region .cmn-results.open { display:block; }
.cmn-region .cmn-results-head { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; border-bottom:1px solid var(--border); }
.cmn-region .cmn-results-head b { font-family:'Poppins',sans-serif; font-size:14px; }
.cmn-region .cmn-results-clear { border:none; background:var(--bg-soft); border-radius:var(--r-pill); padding:6px 12px; font-size:12px; font-weight:600; color:var(--ink-soft); cursor:pointer; }
.cmn-region .cmn-results-grp { padding:10px 16px; border-bottom:1px solid var(--border); }
.cmn-region .cmn-results-grp:last-child { border-bottom:none; }
.cmn-region .cmn-results-grp h4 { font-family:'Poppins',sans-serif; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin:0 0 8px; }
.cmn-region .cmn-res { display:flex; align-items:center; gap:8px; padding:7px 0; color:var(--ink); font-size:14px; }
.cmn-region .cmn-res:hover { color:var(--accent); }
.cmn-region .cmn-res-t { display:flex; flex-direction:column; }
.cmn-region .cmn-res-sub { font-size:12px; color:var(--ink-muted); font-weight:400; }
.cmn-region .cmn-res .ar { margin-left:auto; color:var(--ink-light); }
.cmn-region .cmn-res .ar svg { width:14px; height:14px; }
.cmn-region .cmn-results-empty { padding:18px 16px; color:var(--ink-muted); font-size:13.5px; }

/* ── Chiffres clés (strip) ─────────────────────────────── */
.cmn-region .cmn-specs { display:flex; gap:10px; overflow-x:auto; scrollbar-width:none; margin:0 -16px 26px; padding:0 16px; }
.cmn-region .cmn-specs::-webkit-scrollbar { display:none; }
.cmn-region .cmn-stat { flex:0 0 auto; min-width:130px; background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:14px 16px; box-shadow:var(--shadow-xs); }
.cmn-region .cmn-stat-v { font-family:'Poppins',sans-serif; font-size:22px; font-weight:700; letter-spacing:-0.02em; color:var(--ink); line-height:1; }
.cmn-region .cmn-stat-l { font-size:11px; color:var(--ink-muted); margin-top:6px; }

/* ── Section ────────────────────────────────────────────── */
.cmn-region .sec { margin-bottom:46px; }
.cmn-region .sec-head { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
.cmn-region .sec-title { font-family:'Poppins',sans-serif; font-size:clamp(20px,2.6vw,26px); font-weight:600; color:var(--ink); letter-spacing:-0.02em; margin:0; }
.cmn-region .sec-link { font-size:13px; color:var(--accent); font-weight:600; white-space:nowrap; }

/* ── Filtres lieux + carte ─────────────────────────────── */
.cmn-region .cmn-poi-bar { display:flex; align-items:center; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.cmn-region .cmn-pills { display:flex; gap:6px; overflow-x:auto; scrollbar-width:none; flex:1 1 auto; }
.cmn-region .cmn-pills::-webkit-scrollbar { display:none; }
.cmn-region .cmn-pill { flex:0 0 auto; display:inline-flex; align-items:center; gap:6px; padding:7px 13px; background:#fff; border:1px solid var(--border); color:var(--ink-soft); border-radius:var(--r-pill); font-family:inherit; font-size:12.5px; font-weight:600; cursor:pointer; transition:all .15s; }
.cmn-region .cmn-pill .dot { width:8px; height:8px; border-radius:50%; background:var(--c,var(--accent)); }
.cmn-region .cmn-pill.is-active { background:var(--ink); border-color:var(--ink); color:#fff; }
.cmn-region .cmn-pill .ct { font-size:10px; opacity:.7; }
.cmn-region .cmn-map-btn { flex:0 0 auto; display:inline-flex; align-items:center; gap:7px; padding:8px 15px; background:var(--accent-soft); color:var(--accent); border:none; border-radius:var(--r-pill); font-family:'Poppins',sans-serif; font-size:12.5px; font-weight:600; cursor:pointer; transition:all .15s; }
.cmn-region .cmn-map-btn:hover { background:var(--accent); color:#fff; }
.cmn-region .cmn-map-btn svg { width:15px; height:15px; }
.cmn-region .cmn-map-btn .lbl-hide { display:none; }
.cmn-region .cmn-map-btn.open .lbl-show { display:none; }
.cmn-region .cmn-map-btn.open .lbl-hide { display:inline; }
.cmn-region .cmn-map-wrap { display:none; margin-bottom:16px; }
.cmn-region .cmn-map-wrap.open { display:block; }
.cmn-region #cmnMap { width:100%; height:420px; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--border); }

/* ── Cartes ".sim" (style "à proximité") ───────────────── */
.cmn-region .similars-wrap { position:relative; }
.cmn-region .similars { display:flex; gap:10px; overflow-x:auto; scrollbar-width:none; margin:0 -16px; padding:4px 20px 8px; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; }
.cmn-region .similars::-webkit-scrollbar { display:none; }
.cmn-region .sim { flex:0 0 240px; background:#fff; border:1px solid var(--border); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-xs); text-decoration:none; color:inherit; display:block; scroll-snap-align:center; transition:transform .22s cubic-bezier(.22,.61,.36,1), box-shadow .22s, border-color .22s; }
.cmn-region .sim:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--border-md); }
.cmn-region .similars--lg > .sim { flex:0 0 290px; }
.cmn-region .similars--lg > .sim .sim-img { height:172px; }
.cmn-region .sim.is-hidden { display:none; }
.cmn-region .sim-img { width:100%; height:132px; position:relative; display:flex; align-items:flex-end; padding:10px; background:#eee; }
.cmn-region .sim-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cmn-region .sim-img-tag { position:relative; background:rgba(20,19,31,.8); color:#fff; font-size:10px; font-weight:600; padding:3px 8px; border-radius:var(--r-pill); }
.cmn-region .sim-body { padding:12px; }
.cmn-region .sim-loc { font-size:10.5px; color:var(--c,var(--accent)); letter-spacing:.04em; text-transform:uppercase; font-weight:600; margin-bottom:4px; }
.cmn-region .sim-title { font-family:'Poppins',sans-serif; font-size:13.5px; font-weight:600; color:var(--ink); line-height:1.25; margin-bottom:5px; }
.cmn-region .sim-price-row { display:flex; align-items:baseline; justify-content:space-between; }
.cmn-region .sim-price { font-family:'Poppins',sans-serif; font-size:15px; font-weight:700; color:var(--ink); }
.cmn-region .sim-cmp { display:inline-flex; align-items:center; gap:3px; font-size:10.5px; color:var(--accent); font-weight:600; border:1px solid var(--accent-soft); background:var(--accent-soft); padding:3px 7px; border-radius:var(--r-pill); }
.cmn-region .sim-cmp svg { width:10px; height:10px; }
.cmn-region .cmn-empty { padding:34px; text-align:center; color:var(--ink-muted); border:1px dashed var(--border-md); border-radius:var(--r-lg); }

/* ── Grid-TDF (immo + événements) ──────────────────────── */
.cmn-region .cmn-tdf { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
@media (min-width:1000px){ .cmn-region .cmn-tdf { grid-template-columns:repeat(3,1fr); gap:18px; } }
.cmn-region .cmn-tdf > .listing-card-container-nl { float:none; margin:0; width:auto; max-width:none; min-width:0; }
@media (max-width:768px){
  .cmn-region .cmn-tdf { display:flex; flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; scroll-snap-type:x mandatory; scrollbar-width:none; margin:0 -16px; padding:0 20px 14px; gap:12px; }
  .cmn-region .cmn-tdf::-webkit-scrollbar { display:none; }
  .cmn-region .cmn-tdf > .listing-card-container-nl { flex:0 0 80%; scroll-snap-align:center; }
}

/* ── Infos pratiques (cartes éditables : mairie, transports…) ── */
.cmn-region .cmn-info-grid { display:grid; grid-template-columns:1fr; gap:14px; }
@media (min-width:640px){ .cmn-region .cmn-info-grid { grid-template-columns:1fr 1fr; } }
@media (min-width:1024px){ .cmn-region .cmn-info-grid { grid-template-columns:repeat(4,1fr); gap:16px; } }
.cmn-region .cmn-info-card { background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); padding:18px; box-shadow:var(--shadow-xs); }
.cmn-region .cmn-info-h { font-family:'Poppins',sans-serif; font-weight:600; font-size:14px; color:var(--ink); margin-bottom:10px; }
.cmn-region .cmn-info-row { display:flex; justify-content:space-between; gap:10px; padding:7px 0; border-bottom:1px dashed var(--border); font-size:12.5px; color:var(--ink-soft); }
.cmn-region .cmn-info-row:last-of-type { border-bottom:none; }
.cmn-region .cmn-info-row > span:last-child { font-weight:600; color:var(--ink); text-align:right; }
.cmn-region .cmn-info-link { display:inline-block; margin-top:10px; font-size:13px; font-weight:600; color:var(--accent); }

/* ── Au quotidien : widgets bruts (pas de container stylisé) ── */
.cmn-region .cmn-od-grid { display:grid; grid-template-columns:1fr; gap:30px; }
@media (min-width:900px){ .cmn-region .cmn-od-grid { grid-template-columns:1fr 1fr; } }
.cmn-region .cmn-od-h { font-family:'Poppins',sans-serif; font-weight:600; font-size:14px; margin:0 0 10px; color:var(--ink); }

/* ── À propos ───────────────────────────────────────────── */
.cmn-region .cmn-about { display:grid; grid-template-columns:1fr; gap:24px; }
@media (min-width:900px){ .cmn-region .cmn-about { grid-template-columns:1fr 1.5fr; gap:48px; } }
.cmn-region .cmn-quote { font-family:'Poppins',sans-serif; font-size:22px; line-height:1.25; font-weight:600; font-style:italic; color:var(--ink); padding-left:18px; border-left:3px solid var(--accent); margin:0; }
.cmn-region .cmn-quote-attr { font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-muted); margin-top:12px; padding-left:21px; }
.cmn-region .cmn-prose { font-size:15.5px; line-height:1.7; color:var(--ink-soft); }
.cmn-region .cmn-prose > * { margin:0 0 12px; }
.cmn-region .cmn-prose h2, .cmn-region .cmn-prose h3 { font-family:'Poppins',sans-serif; font-size:18px; font-weight:600; color:var(--ink); margin-top:6px; }
.cmn-region .cmn-prose strong { color:var(--ink); }

/* ── Communes voisines ─────────────────────────────────── */
.cmn-region .cmn-villes { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (min-width:700px){ .cmn-region .cmn-villes { grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px){ .cmn-region .cmn-villes { grid-template-columns:repeat(6,1fr); gap:14px; } }
.cmn-region .cmn-ville { position:relative; border-radius:var(--r); overflow:hidden; aspect-ratio:3/4; display:flex; align-items:flex-end; background:var(--ink); color:#fff; box-shadow:var(--shadow-xs); transition:transform .2s,box-shadow .2s; }
.cmn-region .cmn-ville:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.cmn-region .cmn-ville img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; transition:transform .5s; }
.cmn-region .cmn-ville:hover img { transform:scale(1.07); }
.cmn-region .cmn-ville::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 38%,rgba(0,0,0,.8)); z-index:1; }
.cmn-region .cmn-ville-b { position:relative; z-index:2; padding:12px; }
.cmn-region .cmn-ville-n { font-family:'Poppins',sans-serif; font-weight:600; font-size:14px; line-height:1.1; }
.cmn-region .cmn-ville-c { font-size:10.5px; color:rgba(255,255,255,.78); margin-top:3px; }

/* ── CTA autopromo ──────────────────────────────────────── */
.cmn-region .cmn-cta { background:linear-gradient(135deg,var(--ink) 0%,#2a2541 100%); border-radius:var(--r-lg); padding:36px 24px; position:relative; overflow:hidden; color:#fff; }
@media (min-width:768px){ .cmn-region .cmn-cta { padding:48px; display:grid; grid-template-columns:1.6fr 1fr; gap:40px; align-items:center; } }
.cmn-region .cmn-cta::before { content:""; position:absolute; right:-110px; top:-110px; width:380px; height:380px; border-radius:50%; background:radial-gradient(circle,rgba(249,25,66,.3),transparent 65%); }
.cmn-region .cmn-cta-k { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); font-weight:700; margin-bottom:10px; position:relative; }
.cmn-region .cmn-cta-t { font-family:'Poppins',sans-serif; font-size:clamp(22px,3.5vw,32px); line-height:1.1; font-weight:700; position:relative; color:#fff !important; }
.cmn-region .cmn-cta-s { font-size:14.5px; color:rgba(255,255,255,.82) !important; margin-top:10px; line-height:1.6; position:relative; }
.cmn-region .cmn-cta-btn { display:inline-flex; align-items:center; gap:8px; margin-top:20px; padding:13px 24px; background:var(--accent); color:#fff; border-radius:var(--r); font-family:'Poppins',sans-serif; font-weight:600; font-size:14.5px; box-shadow:0 10px 24px rgba(249,25,66,.4); position:relative; transition:transform .15s; }
.cmn-region .cmn-cta-btn:hover { transform:translateY(-2px); }
.cmn-region .cmn-cta-btn svg { width:16px; height:16px; }

/* ── Pin Leaflet colorée + icône (hors scope, global) ──── */
.leaflet-div-icon.cmn-pin-wrap, .cmn-pin-wrap { background:transparent!important; border:0!important; }
.cmn-pin { width:32px; height:32px; }
.cmn-pin::before { content:""; position:absolute; left:0; top:0; width:30px; height:30px; background:var(--c,#F91942); border:2px solid #fff; border-radius:50% 50% 50% 0; transform:rotate(-45deg); box-shadow:0 3px 8px rgba(20,19,31,.35); }
.cmn-pin .cmn-pin-i { position:absolute; left:15px; top:14px; transform:translate(-50%,-50%); z-index:1; color:#fff; line-height:0; }
.cmn-pin .cmn-pin-i svg { width:14px; height:14px; }
.cmn-pin .cmn-pin-i i { font-size:13px; color:#fff; }

/* Popup « card » des marqueurs (calque de la card .resto de single-event) */
.cmn-pop-wrap .leaflet-popup-content-wrapper { padding:0; border-radius:var(--r); box-shadow:var(--shadow-lg); overflow:hidden; }
.cmn-pop-wrap .leaflet-popup-content { margin:0; line-height:1.45; }
.cmn-pop-wrap .leaflet-popup-tip { box-shadow:var(--shadow-md); }
.cmn-pop {
  display:grid; grid-template-columns:74px 1fr; gap:0;
  background:#fff; color:inherit; text-decoration:none;
  font-family:'Raleway',system-ui,sans-serif; min-height:74px;
}
.cmn-pop-img { background:var(--bg-soft); position:relative; overflow:hidden; }
.cmn-pop-img::after { content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--c,var(--accent)); }
.cmn-pop-img img { width:100%; height:100%; object-fit:cover; display:block; }
.cmn-pop-body { padding:9px 12px; display:flex; flex-direction:column; justify-content:center; gap:3px; min-width:0; }
.cmn-pop-cat { font-size:10.5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--c,var(--accent)); }
.cmn-pop-name { font-family:'Poppins',sans-serif; font-size:13.5px; font-weight:600; color:var(--ink); letter-spacing:-0.01em; line-height:1.25; }
.cmn-pop-foot { display:flex; align-items:center; gap:8px; margin-top:2px; flex-wrap:wrap; }
.cmn-pop-rating { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; color:var(--ink); }
.cmn-pop-rating svg { width:11px; height:11px; color:#F0A20F; }
.cmn-pop-status { font-size:10px; font-weight:600; padding:2px 7px; border-radius:var(--r-pill); letter-spacing:.04em; text-transform:uppercase; }
.cmn-pop-status.open { background:var(--green-soft); color:var(--green); }
.cmn-pop-status.closing-soon { background:#FEF3C7; color:#B45309; }
.cmn-pop-status.closed { background:var(--bg-soft); color:var(--ink-muted); }
.cmn-pop-status.cat { background:var(--bg-soft); color:var(--ink-soft); }
