/* ============================================================
   WOUGGO V2 — app.css
   ============================================================ */

body { background:var(--color-bg); overflow-x:hidden; margin:0; }

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar { position:fixed;top:0;left:0;width:60px;height:100vh;background:#fff;border-right:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;padding:1rem 0;z-index:200; }
.sidebar__logo { margin-bottom:1.25rem; }
.sidebar__links { flex:1;display:flex;flex-direction:column;align-items:center;gap:4px; }
.sidebar__bottom { margin-top:auto; }
.sidebar__item { width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;text-decoration:none;cursor:pointer;color:var(--color-muted);transition:background .15s,color .15s; }
.sidebar__item:hover,.sidebar__item.active { background:var(--color-bg);color:var(--color-accent); }
.sidebar__item svg { width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round; }
@media(max-width:768px){.sidebar{display:none;}}

/* ── Page wrapper ────────────────────────────────────────── */
.page-wrap { margin-left:60px;height:100vh;overflow:hidden; }
@media(max-width:768px){.page-wrap{margin-left:0;}}

/* ── Vues ────────────────────────────────────────────────── */
.view { height:100vh;overflow-y:auto;display:flex;flex-direction:column; }
.view.hidden { display:none; }

/* ══ VUE CHAT ═══════════════════════════════════════════════ */
#view-chat { background:var(--color-bg); }

/* Header — identique à l'original */
.chat-header {
  display:flex;justify-content:space-between;align-items:center;
  padding:.75rem 1rem;
  background:#fff;border-bottom:1px solid var(--color-border);
  position:sticky;top:0;z-index:10;flex-shrink:0;
}
.chat-header__left { display:flex;align-items:center;gap:.75rem; }
.chat-back { display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--color-bg);color:var(--color-txt);text-decoration:none;transition:background .15s; }
.chat-back:hover { background:#F0E8DF; }
.chat-header__title { font-size:1rem;font-weight:700;color:var(--color-txt); }
.location-pill { display:flex;align-items:center;gap:4px;padding:.375rem .875rem;border:1.5px solid var(--color-border-md);border-radius:999px;font-size:var(--text-caption);font-weight:500;color:var(--color-txt);background:#fff;cursor:pointer;transition:all .15s;font-family:inherit; }
.location-pill:hover { border-color:var(--color-accent);color:var(--color-accent); }

/* ── Zone messages ──────────────────────────────────────── */
.chat-messages {
  flex:1; overflow-y:auto;
  padding:1.5rem 1rem;
  display:flex; flex-direction:column;
  gap:1rem;
}

/* Wrapper centré pour chaque ligne de message */
.chat-msg-row {
  display:flex;
  width:100%;
  max-width:760px;
  margin:0 auto;
}

/* Ligne IA : avatar + bulle */
.chat-msg-row--ia {
  align-items:flex-end;
  gap:.75rem;
}

/* Ligne user : bulle à droite */
.chat-msg-row--user {
  justify-content:flex-end;
}

/* Avatar IA — cercle couleur ligne + favicon */
.chat-avatar-ia {
  width:36px; height:36px;
  border-radius:50%;
  background:var(--color-surf);
  border:1.5px solid var(--color-accent);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  align-self:flex-end;
  margin-bottom:2px;
  overflow:hidden;
}
.chat-avatar-ia::after { display:none; }
.chat-avatar-ia img {
  width:22px; height:22px;
  object-fit:contain;
}

/* Bulle IA — hauteur s'adapte au contenu */
.chat-bubble--ia {
  background:#fff; color:var(--color-txt);
  padding:1.125rem 1.375rem;
  border-radius:20px 20px 20px 6px;
  box-shadow:0 2px 12px rgba(0,0,0,.07);
  font-size:var(--text-body); line-height:1.6;
  word-break:break-word;
  display:inline-block;
  max-width:85%;
  width:fit-content;
  height:auto;
  min-height:0;
}
.chat-bubble--ia strong { color:var(--color-accent); }
.chat-bubble--ia p { margin-bottom:.5rem; }
.chat-bubble--ia p:last-child { margin-bottom:0; }

/* Bulle user — hauteur s'adapte au contenu */
.chat-bubble--user {
  background:var(--color-accent); color:#fff;
  padding:.625rem 1.125rem;
  border-radius:22px 22px 6px 22px;
  font-size:var(--text-body); line-height:1.5;
  word-break:break-word;
  display:inline-block;
  max-width:65%;
  width:fit-content;
  height:auto;
  min-height:0;
}

/* Typing indicator — fit-content */
.chat-typing-row {
  display:flex;
  align-items:flex-end;
  gap:.75rem;
  width:100%;
  max-width:760px;
  margin:0 auto;
}
.chat-typing {
  display:inline-flex; gap:5px; align-items:center;
  padding:0;
  background:transparent;
  width:fit-content;
}
.chat-typing span {
  width:7px; height:7px;
  background:var(--color-accent);
  border-radius:50%;
  animation:typing 1.2s infinite;
  opacity:.4;
  flex-shrink:0;
}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-7px);opacity:1}}

/* Bulle en mode typing — override complet */
.chat-bubble--ia.chat-bubble--typing {
  padding:.5rem .75rem;
  line-height:1;
  width:auto;
  max-width:none;
  min-width:0;
  display:inline-flex;
  align-items:center;
  height:auto;
}

/* ── Suggestions — centrées ─────────────────────────────── */
.chat-suggestions {
  display:flex;gap:.5rem;overflow-x:auto;
  padding:.5rem 1rem;
  scrollbar-width:none;flex-shrink:0;
  justify-content:center;
  flex-wrap:wrap;
  max-width:720px;
  width:100%;
  align-self:center;
}
.chat-suggestions::-webkit-scrollbar{display:none}
.chat-suggestion {
  flex-shrink:0;padding:.375rem .875rem;
  background:#fff;border:1.5px solid var(--color-border-md);border-radius:999px;
  font-size:var(--text-caption);font-weight:500;color:var(--color-txt);cursor:pointer;
  font-family:inherit;white-space:nowrap;transition:all .15s;
}
.chat-suggestion:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff;}

/* ── Barre saisie — centrée, max-width ─────────────────── */
.chat-input-wrap {
  flex-shrink:0;
  padding:.625rem 1rem;
  padding-bottom:calc(.625rem + env(safe-area-inset-bottom));
  background:#fff;border-top:1px solid var(--color-border);
  display:flex;flex-direction:column;align-items:center;gap:.375rem;
}
.chat-input-bar {
  display:flex;gap:.5rem;align-items:flex-end;
  width:100%;max-width:720px;
}
.chat-input {
  flex:1;min-height:44px;max-height:120px;
  padding:.6875rem 1rem;
  border:1.5px solid var(--color-border-md);border-radius:22px;
  font-size:var(--text-body);font-family:inherit;
  resize:none;outline:none;
  background:var(--color-bg);color:var(--color-txt);
  transition:border-color .15s;line-height:1.4;
}
.chat-input:focus{border-color:var(--color-accent);background:#fff;}
.chat-input::placeholder{color:var(--color-muted);}
.chat-send-btn {
  width:44px;height:44px;flex-shrink:0;
  background:var(--color-accent);color:#fff;border-radius:50%;border:none;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .15s,transform .15s;
}
.chat-send-btn:hover{background:var(--color-accent-dark);transform:scale(1.05);}
.chat-send-btn:disabled{background:#DDD5CC;cursor:not-allowed;transform:none;}
.chat-footer-label{text-align:center;font-size:.6875rem;color:var(--color-muted);margin:.375rem 0 0;}

/* ══ VUE RÉSULTATS ══════════════════════════════════════════ */
#view-results { background:var(--color-bg); overflow-y:auto; }

.results-header {
  display:flex; align-items:center; gap:.75rem;
  padding:.75rem 1rem; background:var(--color-surf);
  border-bottom:0.5px solid var(--color-border);
  position:sticky; top:0; z-index:10; flex-shrink:0;
}
.results-back {
  display:flex; align-items:center; gap:.375rem;
  padding:.375rem .875rem; border-radius:var(--wg-r-pill);
  background:var(--color-bg); border:none; cursor:pointer;
  font-size:var(--text-label); font-weight:500;
  color:var(--color-txt); font-family:inherit;
  transition:background var(--wg-transition); white-space:nowrap;
}
.results-back svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.results-back:hover { background:var(--color-deep); }
.results-query {
  font-size:var(--text-label); color:var(--color-sub);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  font-style:italic;
}

.filter-bar {
  display:flex; gap:.5rem; overflow-x:auto;
  padding:.625rem 1rem; scrollbar-width:none;
  flex-shrink:0; background:var(--color-surf);
  border-bottom:0.5px solid var(--color-border);
}
.filter-bar::-webkit-scrollbar { display:none; }
.filter-pill {
  flex-shrink:0; padding:.375rem .875rem; border-radius:var(--wg-r-pill);
  font-size:var(--text-caption); font-weight:500;
  border:1.5px solid var(--color-border-md);
  background:var(--color-surf); color:var(--color-txt);
  cursor:pointer; font-family:inherit; transition:all var(--wg-transition);
  white-space:nowrap;
}
.filter-pill:hover,
.filter-pill.active { background:var(--color-accent); border-color:var(--color-accent); color:#fff; }

/* ── Grille résultats — responsive ───────────────────────── */
.results-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:1rem;
  padding:1rem 1rem 2rem;
  width:100%;
  box-sizing:border-box;
}

/* Desktop large : 4 colonnes max */
@media(min-width:1200px) {
  .results-grid { grid-template-columns:repeat(4, 1fr); }
}

/* Tablette : 3 colonnes */
@media(max-width:1199px) and (min-width:768px) {
  .results-grid { grid-template-columns:repeat(3, 1fr); }
}

/* Mobile paysage : 2 colonnes */
@media(max-width:767px) and (min-width:480px) {
  .results-grid { grid-template-columns:repeat(2, 1fr); }
}

/* Mobile portrait : 1 colonne, centré */
@media(max-width:479px) {
  .results-grid {
    grid-template-columns:1fr;
    max-width:360px;
    margin:0 auto;
    padding:.75rem .75rem 2rem;
  }
}

/* Les cartes .card-lieu dans la grille résultats */
.results-grid .card-lieu {
  width:100%;
  min-width:0;
}

/* Carte résultat */
.result-card{background:#fff;border-radius:14px;border:1px solid var(--color-border);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;}
.result-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(83,40,34,.1);}
.result-card__img{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--color-deep);}
.result-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.result-card:hover .result-card__img img{transform:scale(1.04);}
.result-card__ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;}
.result-card__badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:4px;}
.result-niv{position:absolute;top:8px;right:8px;padding:3px 8px;border-radius:999px;font-size:var(--text-micro);font-weight:700;color:#fff;}
.result-niv--gold{background:#F59E0B;}.result-niv--green{background:#10B981;}
.result-flash{position:absolute;bottom:8px;left:8px;padding:3px 8px;border-radius:999px;font-size:var(--text-micro);font-weight:700;color:#fff;background:var(--color-accent);animation:pulse-flash 1.5s infinite;}
.result-card__body{padding:.875rem;}
.result-card__nom{font-size:var(--text-body);font-weight:700;color:var(--color-txt);margin:0 0 4px;}
.result-card__meta{font-size:var(--text-caption);color:var(--color-sub);margin:0 0 3px;}
.result-card__note{font-size:var(--text-caption);font-weight:600;color:var(--color-txt);margin:0 0 4px;}
.result-card__note span{font-weight:400;color:var(--color-muted);}
.result-card__raison{font-size:.75rem;color:var(--color-accent);font-style:italic;margin:.375rem 0 .625rem;padding:.375rem .625rem;background:var(--color-bg);border-radius:8px;border-left:3px solid var(--color-accent);}
.result-card__actions{display:flex;gap:.5rem;margin-top:.5rem;}

/* ══ VUES DÉTAIL ════════════════════════════════════════════ */
#view-lieu, #view-evenement { background:var(--color-bg); }

/* ── Header flottant ─────────────────────────────────────── */
.dl-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;position:sticky;top:0;z-index:50;background:rgba(254,244,234,.92);backdrop-filter:blur(8px);border-bottom:0.5px solid var(--color-border);}
.dl-btn-icon{width:36px;height:36px;border-radius:50%;background:var(--color-surf);border:0.5px solid var(--color-border-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-txt);transition:background var(--wg-transition);}
.dl-btn-icon:hover{background:var(--color-raised);}
.dl-header-actions{display:flex;gap:.5rem;flex-wrap:wrap;}
.dl-btn-pill{display:inline-flex;align-items:center;gap:5px;padding:.375rem .875rem;background:var(--color-surf);border:0.5px solid var(--color-border-md);border-radius:var(--wg-r-pill);font-size:var(--text-caption);font-weight:500;cursor:pointer;color:var(--color-txt);font-family:inherit;transition:all var(--wg-transition);white-space:nowrap;}
.dl-btn-pill:hover{border-color:var(--color-accent);color:var(--color-accent);}
.dl-btn-pill.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent);}

/* ── Body ────────────────────────────────────────────────── */
.dl-body{
  padding:1.5rem;
  padding-bottom:100px;
  max-width:1060px;
  margin:0 auto;
}

/* ── Top : titre + badges ────────────────────────────────── */
.dl-top{margin-bottom:1.25rem;}
.dl-titre{font-size:var(--text-h1);font-weight:700;color:var(--color-txt);margin-bottom:.625rem;line-height:1.25;}
.dl-badges{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.625rem;}
.dl-badge{padding:3px 10px;border-radius:var(--wg-r-pill);font-size:var(--text-micro);font-weight:600;}
.dl-badge--verifie{background:var(--color-success-light);color:var(--color-success-txt);}
.dl-badge--business{background:var(--color-gold-bg);color:var(--color-gold);}
.dl-badge--ouvert{background:var(--color-success-light);color:var(--color-success-txt);}
.dl-badge--ferme{background:var(--color-danger-bg);color:var(--color-danger);}
.dl-badge--cat{background:var(--color-raised);color:var(--color-sub);}
.dl-sous-titre{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:var(--text-caption);color:var(--color-sub);}
.dl-dot{width:3px;height:3px;background:var(--color-muted);border-radius:50%;}
.dl-note-inline{color:var(--color-accent);font-weight:600;}
.dl-avis-link{text-decoration:underline;cursor:pointer;}
.dl-prix{font-weight:600;color:var(--color-txt);}

/* ── Slider photos ───────────────────────────────────────── */
.dl-slider {
  position:relative; width:100%; height:340px;
  overflow:hidden; border-radius:var(--wg-r-xl);
  margin-bottom:1.5rem; background:var(--color-raised);
  cursor:grab;
}
.dl-slider:active { cursor:grabbing; }
.dl-slider-track {
  display:flex; height:100%;
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.dl-slide { flex-shrink:0; width:100%; height:100%; }
.dl-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.dl-slider-ph {
  width:100%; height:280px; border-radius:var(--wg-r-xl);
  background:var(--color-raised); display:flex;
  align-items:center; justify-content:center;
  font-size:4rem; margin-bottom:1.5rem;
}

/* Boutons prev/next */
.dl-slider-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.88); backdrop-filter:blur(6px);
  border:0.5px solid var(--color-border-md); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--color-txt); transition:background var(--wg-transition);
  z-index:5;
}
.dl-slider-btn:hover { background:#fff; }
.dl-slider-btn--prev { left:12px; }
.dl-slider-btn--next { right:12px; }

/* Dots */
.dl-slider-dots {
  position:absolute; bottom:12px; left:50%; transform:translateX(-50%);
  display:flex; gap:5px; z-index:5;
}
.dl-slider-dot {
  width:6px; height:6px; border-radius:50%;
  background:rgba(255,255,255,.5); cursor:pointer;
  transition:all .2s;
}
.dl-slider-dot.active { background:#fff; width:18px; border-radius:3px; }

/* Compteur */
.dl-slider-counter {
  position:absolute; top:12px; right:12px;
  background:rgba(0,0,0,.45); color:#fff; backdrop-filter:blur(4px);
  border-radius:20px; padding:3px 10px;
  font-size:var(--text-micro); font-weight:600; z-index:5;
}

@media(max-width:600px){
  .dl-slider { height:260px; border-radius:0; margin-left:-1.25rem; margin-right:-1.25rem; width:calc(100% + 2.5rem); }
}

/* ── Mini-carte Leaflet ───────────────────────────────────── */
.dl-mini-map {
  width:100%; height:280px;
  border-radius:var(--wg-r-lg);
  overflow:hidden; margin-top:.875rem;
  border:0.5px solid var(--color-border);
  cursor:pointer;
  z-index:0;
}
.dl-mini-map--hidden { display:none; }

/* ── Card adresse ────────────────────────────────────────── */
.dl-adresse-card {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--color-raised); border-radius:var(--wg-r-lg);
  padding:.875rem 1rem; gap:1rem;
  border:0.5px solid var(--color-border);
}
.dl-adresse-info {
  display:flex; align-items:flex-start; gap:.625rem; flex:1; min-width:0;
}
.dl-adresse-info svg { flex-shrink:0; color:var(--color-accent); margin-top:2px; }
.dl-adresse-rue  { font-size:var(--text-label); font-weight:500; color:var(--color-txt); }
.dl-adresse-ville{ font-size:var(--text-caption); color:var(--color-sub); margin-top:2px; }
.dl-adresse-link {
  font-size:var(--text-caption); font-weight:600; color:var(--color-accent);
  text-decoration:none; white-space:nowrap; flex-shrink:0;
  transition:opacity var(--wg-transition);
}
.dl-adresse-link:hover { opacity:.75; }

/* ── Layout 2 colonnes ───────────────────────────────────── */
.dl-main-grid{display:grid;grid-template-columns:1fr 300px;gap:2.5rem;align-items:start;}
@media(max-width:900px){
  .dl-main-grid{grid-template-columns:1fr;}
  .dl-col-right{display:block;} /* visible sur mobile sous la colonne gauche */
}

/* ── Sections ────────────────────────────────────────────── */
.dl-section{padding:1.25rem 0;border-bottom:0.5px solid var(--color-border);}
.dl-section:last-child{border-bottom:none;}
.dl-section-title{font-size:var(--text-h3);font-weight:700;color:var(--color-txt);margin-bottom:.875rem;}
.dl-section-sub{font-size:var(--text-caption);font-weight:400;color:var(--color-sub);margin-left:.375rem;}

/* ── Host ────────────────────────────────────────────────── */
.dl-host-row{display:flex;align-items:center;gap:.875rem;}
.dl-host-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-h3);font-weight:700;flex-shrink:0;}
.dl-host-name{font-size:var(--text-label);font-weight:600;color:var(--color-txt);}
.dl-host-sub{font-size:var(--text-caption);color:var(--color-sub);}

/* ── Flash ───────────────────────────────────────────────── */
.dl-flash{display:flex;align-items:flex-start;gap:.75rem;background:var(--color-accent-dim);border:0.5px solid rgba(240,94,43,.25);border-radius:var(--wg-r-lg);padding:.875rem 1rem;margin-bottom:1rem;}
.dl-flash-icon{font-size:1.25rem;flex-shrink:0;}
.dl-flash-txt{font-size:var(--text-label);font-weight:600;color:var(--color-accent);}
.dl-flash-expire{font-size:var(--text-caption);color:var(--color-sub);margin-top:2px;}

/* ── Description ─────────────────────────────────────────── */
.dl-desc{font-size:var(--text-body);color:var(--color-sub);line-height:1.65;}
.dl-desc--collapsed{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.dl-show-more{font-size:var(--text-label);font-weight:600;color:var(--color-txt);text-decoration:underline;cursor:pointer;background:none;border:none;font-family:inherit;margin-top:.5rem;padding:0;}

/* ── Tags ────────────────────────────────────────────────── */
.dl-tags-wrap{display:flex;flex-wrap:wrap;gap:.5rem;}
.dl-tag{padding:6px 14px;border:0.5px solid var(--color-border-md);border-radius:var(--wg-r-pill);font-size:var(--text-caption);color:var(--color-sub);}

/* ── Horaires ────────────────────────────────────────────── */
.dl-horaires{display:grid;grid-template-columns:auto 1fr;gap:5px 1.25rem;}
.dl-h-jour{font-size:var(--text-label);color:var(--color-sub);}
.dl-h-jour.today{font-weight:700;color:var(--color-txt);}
.dl-h-heure{font-size:var(--text-label);color:var(--color-txt);}
.dl-h-heure.open{color:var(--color-success-txt);font-weight:600;}
.dl-h-heure.ferme{color:var(--color-danger);}

/* ── Section header avec bouton PDF ─────────────────────── */
.dl-section-header {
  display:flex; align-items:center;
  justify-content:space-between;
  margin-bottom:.875rem;
}
.dl-section-header .dl-section-title { margin-bottom:0; }

.dl-menu-pdf-btn {
  display:inline-flex; align-items:center; gap:.375rem;
  padding:.375rem .875rem;
  background:var(--color-raised);
  border:0.5px solid var(--color-border-md);
  border-radius:var(--wg-r-pill);
  font-size:var(--text-caption); font-weight:600;
  color:var(--color-txt); text-decoration:none;
  transition:all var(--wg-transition);
  white-space:nowrap;
  flex-shrink:0;
}
.dl-menu-pdf-btn:hover {
  background:var(--color-accent-dim);
  border-color:var(--color-accent);
  color:var(--color-accent);
}
.dl-menu-pdf-btn svg { stroke:currentColor; flex-shrink:0; }
.dl-menu{display:flex;flex-direction:column;gap:1rem;}
.dl-menu-cat{font-size:var(--text-micro);font-weight:700;color:var(--color-txt);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;}
.dl-menu-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:0.5px solid var(--color-border);}
.dl-menu-item:last-child{border-bottom:none;}
.dl-menu-nom{font-size:var(--text-label);color:var(--color-txt);}
.dl-menu-prix{font-size:var(--text-label);font-weight:700;color:var(--color-gold);flex-shrink:0;margin-left:1rem;}

/* ── Localisation ────────────────────────────────────────── */
.dl-adresse{font-size:var(--text-label);color:var(--color-sub);margin-bottom:.875rem;}
.dl-map-placeholder{display:flex;align-items:center;justify-content:center;gap:.5rem;height:140px;background:var(--color-raised);border:0.5px solid var(--color-border);border-radius:var(--wg-r-lg);font-size:var(--text-label);color:var(--color-sub);cursor:pointer;transition:background var(--wg-transition);margin-top:.75rem;}
.dl-map-placeholder:hover{background:var(--color-deep);}

/* ── Avis ────────────────────────────────────────────────── */
.dl-avis-item{padding:.875rem 0;border-bottom:0.5px solid var(--color-border);}
.dl-avis-item:last-child{border-bottom:none;}
.dl-avis-head{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;}
.dl-avis-avatar{width:38px;height:38px;border-radius:50%;background:var(--color-accent-dim);display:flex;align-items:center;justify-content:center;font-size:var(--text-label);font-weight:700;color:var(--color-accent);flex-shrink:0;}
.dl-avis-meta{flex:1;min-width:0;}
.dl-avis-nom{font-size:var(--text-label);font-weight:600;color:var(--color-txt);}
.dl-avis-date{font-size:var(--text-caption);color:var(--color-sub);}
.dl-avis-etoiles-row{display:flex;gap:2px;flex-shrink:0;}
.dl-avis-txt{font-size:var(--text-label);color:var(--color-sub);line-height:1.55;margin-top:.25rem;}
.dl-avis-vide{font-size:var(--text-label);color:var(--color-muted);font-style:italic;padding:.5rem 0;}

/* ── Formulaire notation ─────────────────────────────────── */
.dl-avis-form {
  background:var(--color-raised);
  border-radius:var(--wg-r-lg);
  padding:1rem; margin-bottom:1.25rem;
  border:0.5px solid var(--color-border);
}
.dl-avis-form-label {
  font-size:var(--text-label); font-weight:600;
  color:var(--color-txt); margin-bottom:.625rem;
}
.dl-avis-stars-input {
  display:flex; gap:6px; margin-bottom:.875rem;
}
.dl-avis-star-btn {
  width:32px; height:32px; border:none; background:none;
  cursor:pointer; padding:0; border-radius:4px;
  transition:transform .1s;
}
.dl-avis-star-btn:hover { transform:scale(1.15); }
.dl-avis-star-btn svg {
  width:28px; height:28px; display:block;
}
.dl-avis-star-btn svg path { fill:var(--color-border-md); transition:fill .15s; }
.dl-avis-star-btn.hovered svg path,
.dl-avis-star-btn.selected svg path { fill:var(--color-gold); }

.dl-avis-textarea {
  width:100%; border:0.5px solid var(--color-border-md);
  border-radius:var(--wg-r-md); padding:.625rem .875rem;
  font-size:var(--text-label); font-family:inherit;
  color:var(--color-txt); background:var(--color-surf);
  resize:none; outline:none; margin-bottom:.75rem;
  transition:border-color var(--wg-transition);
}
.dl-avis-textarea:focus { border-color:var(--color-accent); }
.dl-avis-textarea::placeholder { color:var(--color-muted); }

.dl-avis-submit {
  width:100%; padding:.75rem; border-radius:var(--wg-r-md);
  background:var(--color-accent); color:#fff; border:none;
  font-size:var(--text-label); font-weight:600; font-family:inherit;
  cursor:pointer; transition:background var(--wg-transition);
}
.dl-avis-submit:hover:not(:disabled) { background:var(--color-accent-dark); }
.dl-avis-submit:disabled {
  background:var(--color-border); color:var(--color-muted); cursor:not-allowed;
}

/* Mini-carte cachée si pas de coords */
.dl-mini-map--hidden { display:none; }

/* ── Bloc publicitaire colonne droite ────────────────────── */
.dl-pub-block { margin-top:.75rem; }

.dl-pub-card {
  display:block; text-decoration:none;
  background:var(--color-surf);
  border:0.5px solid var(--color-border-md);
  border-radius:var(--wg-r-xl);
  overflow:hidden;
  transition:box-shadow var(--wg-transition);
}
.dl-pub-card:hover { box-shadow:var(--wg-shadow-md); }

.dl-pub-label {
  font-size:var(--text-micro);
  font-weight:500;
  color:var(--color-muted);
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:.5rem .875rem .25rem;
}
.dl-pub-img {
  width:100%;
  aspect-ratio:16/7;
  object-fit:cover;
  display:block;
}
.dl-pub-body {
  padding:.875rem;
}
.dl-pub-titre {
  font-size:var(--text-label);
  font-weight:700;
  color:var(--color-txt);
  margin-bottom:.25rem;
}
.dl-pub-desc {
  font-size:var(--text-caption);
  color:var(--color-sub);
  line-height:1.5;
  margin-bottom:.625rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.dl-pub-cta {
  display:inline-flex;
  align-items:center;
  gap:.375rem;
  font-size:var(--text-caption);
  font-weight:600;
  color:var(--color-accent);
}

/* Pub fictive */
.dl-pub-card--fictive {
  background:linear-gradient(135deg, var(--color-raised) 0%, #fff 100%);
  border-style:dashed;
  cursor:default;
}
.dl-pub-fictive-hero {
  display:flex; align-items:center; gap:.875rem;
  background:var(--color-accent-dim);
  padding:1rem .875rem;
  font-size:2rem;
}
.dl-pub-fictive-tag {
  font-size:var(--text-label); font-weight:700;
  color:var(--color-accent);
}
.dl-pub-fictive-sub {
  font-size:var(--text-caption); color:var(--color-sub);
  margin-top:2px;
}
.dl-pub-cta-btn {
  display:inline-flex; align-items:center;
  padding:.5rem 1rem;
  background:var(--color-accent); color:#fff;
  border-radius:var(--wg-r-pill);
  font-size:var(--text-caption); font-weight:600;
  text-decoration:none;
  transition:background var(--wg-transition);
  margin-top:.25rem;
}
.dl-pub-cta-btn:hover { background:var(--color-accent-dark); }

/* ── Carte droite supprimée ──────────────────────────────── */
.dl-mini-map-right { display:none; }
.dl-col-right{position:sticky;top:80px;}
.dl-contact-card{background:var(--color-surf);border:0.5px solid var(--color-border-md);border-radius:var(--wg-r-xl);padding:1.25rem;box-shadow:var(--wg-shadow-md);}
.dl-contact-prix{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem;}
.dl-contact-prix-val{font-size:var(--text-h2);font-weight:700;color:var(--color-txt);}
.dl-contact-prix-label{font-size:var(--text-caption);color:var(--color-sub);}
.dl-contact-note{display:flex;align-items:center;gap:.5rem;font-size:var(--text-caption);margin-bottom:1rem;border-top:0.5px solid var(--color-border);padding-top:.75rem;}
.dl-contact-note-avis{text-decoration:underline;cursor:pointer;color:var(--color-sub);}
.dl-contact-mention{font-size:var(--text-micro);color:var(--color-muted);text-align:center;margin-top:.75rem;}

/* ── CTAs ────────────────────────────────────────────────── */
.dl-cta{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1rem;border-radius:var(--wg-r-lg);font-size:var(--text-label);font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none;margin-bottom:.5rem;transition:all var(--wg-transition);border:none;}
.dl-cta--whatsapp{background:#25D366;color:#fff;}
.dl-cta--whatsapp:hover{background:#1DA851;}
.dl-cta--secondary{background:transparent;color:var(--color-txt);border:0.5px solid var(--color-border-md);}
.dl-cta--secondary:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-dim);}
.dl-cta--ghost{background:var(--color-raised);color:var(--color-txt);}
.dl-cta--ghost:hover{background:var(--color-deep);}
.dl-cta--parcours{background:var(--color-accent-dim);color:var(--color-accent);}
.dl-cta--parcours:hover{background:rgba(240,94,43,.18);}
.dl-cta--sm{padding:.625rem 1rem;font-size:var(--text-caption);flex:1;}

/* ── Barre mobile ────────────────────────────────────────── */
.dl-mobile-bar{display:none !important;}

/* ══ BOTTOM NAV ════════════════════════════════════════════ */
.bottom-nav{display:none;}
@media(max-width:768px){
  .bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid var(--color-border);align-items:center;justify-content:space-around;z-index:200;padding-bottom:env(safe-area-inset-bottom);}
  .page-wrap{padding-bottom:64px;}
  .detail-header{position:fixed;}
}
.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:44px;color:var(--color-muted);text-decoration:none;cursor:pointer;transition:color .15s;}
.bottom-nav__item.active{color:var(--color-accent);}
.bottom-nav__label{font-size:var(--text-micro);font-weight:500;}
.bnav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;}
.bnav-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.bnav-center{position:relative;}
.bnav-fab{width:52px;height:52px;background:var(--color-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-16px;box-shadow:0 4px 16px rgba(249,115,22,.4);}
.bnav-fab svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}

/* ── Misc ─────────────────────────────────────────────────── */
.villes-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;}
.ville-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem 1rem;border-radius:8px;cursor:pointer;transition:background .15s;}
.ville-item:hover{background:var(--color-bg);}
.ville-item__nom{font-weight:600;color:var(--color-txt);}
.ville-item__pays{font-size:var(--text-label);color:var(--color-sub);}
@keyframes pulse-flash{0%,100%{opacity:1}50%{opacity:.7}}
