/* Portails Immobiliers — Luxe Design System */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --bg: #0f1923;
  --bg-card: rgba(240,236,228,0.04);
  --bg-card-hover: rgba(240,236,228,0.07);
  --border: rgba(201,168,76,0.15);
  --border-hi: rgba(201,168,76,0.3);
  --text: #f0ece4;
  --text-2: rgba(240,236,228,0.6);
  --text-3: rgba(240,236,228,0.35);
  --accent: #c9a84c;
  --accent-dark: #a08040;
  --accent-dim: rgba(201,168,76,0.1);
  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'Inter', system-ui, sans-serif;
  --r: 12px;
  --r-sm: 6px;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--sans); background:var(--bg); color:var(--text); line-height:1.5; }

/* ===== HEADER ===== */
.site-header {
  background: linear-gradient(180deg, rgba(15,25,35,0.95), rgba(15,25,35,0.85)),
              url('https://images.unsplash.com/photo-1580137189272-c9379f8864fd?w=1600&q=80') center/cover;
  padding: 48px 24px 16px;
  text-align: center;
}
.header-inner { max-width: 1000px; margin: 0 auto; }
.header-title {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 600;
  letter-spacing: .02em;
  margin-bottom: 4px;
}
.accent { color: var(--accent); }
.header-sub { color: var(--text-2); font-size: .9rem; margin-bottom: 28px; }

.header-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; max-width: 700px; margin: 0 auto; }
.kpi {
  background: rgba(240,236,228,0.05);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 14px 10px;
  display: flex; flex-direction: column; align-items: center;
  backdrop-filter: blur(8px);
}
.kpi-val { font-size: 1.5rem; font-weight: 700; color: var(--accent); line-height: 1.2; }
.kpi-unit { font-size: .7rem; color: var(--text-3); }
.kpi-label { font-size: .65rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; margin-top: 2px; }

@media (max-width: 600px) { .header-kpis { grid-template-columns: repeat(2, 1fr); } }

/* ===== AD BANNERS ===== */
.ad-banner-top, .ad-banner-bottom {
  text-align: center;
  font-size: .65rem;
  color: var(--text-3);
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 8px;
  border-top: 1px solid var(--border);
  margin-top: 16px;
}
.ad-banner-bottom { margin-top: 0; margin-bottom: 16px; border-top: none; border-bottom: 1px solid var(--border); }

/* ===== TAB NAVIGATION ===== */
.tab-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(15,25,35,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.tab-nav-inner {
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
  max-width: 1200px;
  margin: 0 auto;
}
.tab-nav-inner::-webkit-scrollbar { display: none; }
.tab-btn {
  flex-shrink: 0;
  padding: 14px 18px;
  border: none;
  background: none;
  font-family: var(--sans);
  font-size: .8rem;
  font-weight: 500;
  color: var(--text-3);
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: all .2s;
}
.tab-btn:hover { color: var(--text); background: var(--accent-dim); }
.tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }

/* ===== PANELS ===== */
.panel { display: none; animation: fadeIn .3s ease; }
.panel.active { display: block; }
@keyframes fadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.panel-inner { max-width: 1200px; margin: 0 auto; padding: 32px 24px; }
.panel-inner h2 {
  font-family: var(--serif);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 4px;
}
.panel-inner h3 {
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 500;
  margin-bottom: 12px;
  color: var(--text-2);
}
.source { font-size: .75rem; color: var(--text-3); margin-bottom: 24px; }
.muted { color: var(--text-3); }

/* ===== MARCHE ===== */
.marche-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 32px; }
@media (max-width: 900px) { .marche-grid { grid-template-columns: 1fr; } }

.map-container { width: 100%; height: 450px; border-radius: var(--r); border: 1px solid var(--border); }
.map-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 8px; font-size: .75rem; color: var(--text-2); }
.legend-item { display: flex; align-items: center; gap: 4px; }
.legend-dot { width: 10px; height: 10px; border-radius: 50%; }

.table-scroll { max-height: 450px; overflow-y: auto; border-radius: var(--r); border: 1px solid var(--border); }
.data-table { width: 100%; border-collapse: collapse; font-size: .82rem; }
.data-table th {
  text-align: left; padding: 10px 12px;
  background: rgba(201,168,76,0.08);
  color: var(--text-3);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  position: sticky; top: 0;
  border-bottom: 1px solid var(--border);
}
.data-table td { padding: 8px 12px; border-bottom: 1px solid rgba(240,236,228,0.04); }
.data-table tr:hover { background: var(--accent-dim); }
.data-table .num { text-align: right; font-variant-numeric: tabular-nums; }

.chart-section { margin-top: 24px; }
.chart-section canvas { max-height: 350px; }

/* ===== QUARTIERS ===== */
.quartiers-layout { display: grid; grid-template-columns: 1fr 380px; gap: 24px; }
@media (max-width: 900px) { .quartiers-layout { grid-template-columns: 1fr; } }
.poi-filters { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.poi-btn {
  padding: 5px 12px; border: 1px solid var(--border); border-radius: 20px;
  background: transparent; font-family: var(--sans); font-size: .72rem; font-weight: 500;
  color: var(--text-3); cursor: pointer; transition: all .2s;
}
.poi-btn:hover { border-color: var(--accent); color: var(--accent); }
.poi-btn.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }

.quartiers-list { max-height: 520px; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; }
.quartier-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: 12px 16px; transition: border-color .2s;
}
.quartier-card:hover { border-color: var(--accent); }
.quartier-header { display: flex; justify-content: space-between; align-items: baseline; }
.quartier-header h4 { font-size: .9rem; font-weight: 600; }
.quartier-price { color: var(--accent); font-weight: 700; font-size: .9rem; }
.quartier-stats { display: flex; gap: 12px; font-size: .72rem; color: var(--text-3); margin-top: 4px; }

/* ===== AGENCES ===== */
.agency-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }
.agency-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 20px; transition: border-color .2s, background .2s;
}
.agency-card:hover { border-color: var(--border-hi); background: var(--bg-card-hover); }
.agency-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 8px; }
.agency-name { font-weight: 600; font-size: .95rem; }
.agency-rating { text-align: right; white-space: nowrap; }
.stars { color: #f5a623; font-size: .9rem; }
.rating-num { font-weight: 600; font-size: .8rem; margin-left: 4px; }
.reviews-count { font-size: .7rem; color: var(--text-3); }
.agency-addr { font-size: .8rem; color: var(--text-2); margin-bottom: 4px; }
.agency-phone { font-size: .82rem; margin-bottom: 10px; }
.agency-phone a { color: var(--accent); text-decoration: none; }
.agency-actions { display: flex; gap: 8px; }

/* Buttons */
.btn-outline {
  display: inline-block; padding: 6px 16px; border: 1px solid var(--border-hi);
  border-radius: 20px; font-size: .75rem; font-weight: 500;
  color: var(--text-2); text-decoration: none; transition: all .2s;
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }
.btn-gold {
  display: inline-block; padding: 6px 16px;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  border: none; border-radius: 20px; font-size: .75rem; font-weight: 600;
  color: var(--bg); text-decoration: none; transition: opacity .2s;
}
.btn-gold:hover { opacity: .85; }

/* ===== PROGRAMMES ===== */
.programmes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 20px; }
.programme-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 24px; position: relative;
}
.programme-card:hover { border-color: var(--border-hi); }
.programme-status {
  display: inline-block; padding: 3px 10px; border-radius: 20px;
  font-size: .65rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em;
  background: var(--accent-dim); color: var(--accent); margin-bottom: 12px;
}
.programme-card h4 { font-family: var(--serif); font-size: 1.1rem; margin-bottom: 4px; }
.programme-promoteur { font-size: .8rem; color: var(--accent); margin-bottom: 8px; }
.programme-desc { font-size: .82rem; color: var(--text-2); margin-bottom: 16px; line-height: 1.5; }
.programme-details { display: flex; flex-direction: column; gap: 6px; }
.prog-detail { display: flex; justify-content: space-between; font-size: .8rem; padding: 4px 0; border-bottom: 1px solid rgba(240,236,228,0.04); }
.prog-label { color: var(--text-3); text-transform: uppercase; font-size: .7rem; letter-spacing: .04em; }

/* ===== ANNONCES ===== */
.annonces-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.annonce-platform {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 28px; text-align: center;
}
.annonce-platform h3 { font-family: var(--serif); font-size: 1.2rem; margin-bottom: 8px; }
.annonce-platform p { font-size: .82rem; color: var(--text-2); margin-bottom: 16px; }
.annonce-links { display: flex; gap: 10px; justify-content: center; }

/* ===== DEMOGRAPHIE ===== */
.demo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 20px; }
.demo-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 20px;
}
.demo-card h3 { font-size: .95rem; }

/* ===== FISCALITE ===== */
.fisc-content { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 900px) { .fisc-content { grid-template-columns: 1fr; } }
.fisc-table-wrap { border-radius: var(--r); border: 1px solid var(--border); overflow: hidden; }

/* ===== ACTUALITES ===== */
.news-list { display: flex; flex-direction: column; gap: 12px; }
.news-card {
  display: flex; gap: 16px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 16px 20px;
}
.news-date { flex-shrink: 0; font-size: .75rem; color: var(--text-3); min-width: 100px; }
.news-content h4 { font-size: .9rem; margin-bottom: 4px; }
.news-content h4 a { color: var(--text); text-decoration: none; }
.news-content h4 a:hover { color: var(--accent); }
.news-content p { font-size: .8rem; color: var(--text-2); line-height: 1.5; }

/* ===== EVENEMENTS ===== */
.events-list { display: flex; flex-direction: column; gap: 12px; }
.event-card {
  display: flex; gap: 20px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 20px; transition: border-color .2s;
}
.event-card:hover { border-color: var(--border-hi); }
.event-date {
  flex-shrink: 0; width: 70px; text-align: center;
  display: flex; flex-direction: column; justify-content: center;
}
.event-day { font-family: var(--serif); font-size: 1.2rem; font-weight: 600; color: var(--accent); }
.event-month { font-size: .7rem; color: var(--text-3); text-transform: uppercase; }
.event-info h4 { font-size: .95rem; margin-bottom: 4px; }
.event-info p { font-size: .82rem; color: var(--text-2); }

/* ===== POLITIQUE ===== */
.politique-content { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 900px) { .politique-content { grid-template-columns: 1fr; } }
.maire-card, .election-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r);
  padding: 24px;
}
.maire-card h3, .election-card h3 { font-family: var(--serif); font-size: 1rem; margin-bottom: 12px; color: var(--accent); }
.maire-info h4 { font-size: 1.1rem; margin-bottom: 8px; }
.maire-info p { font-size: .85rem; color: var(--text-2); margin-bottom: 4px; line-height: 1.5; }

.election-results { display: flex; flex-direction: column; gap: 10px; }
.result-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.result-name { font-size: .82rem; flex: 1; min-width: 140px; }
.result-pct { font-size: .82rem; font-weight: 600; color: var(--accent); width: 50px; text-align: right; }
.bar { flex: 2; height: 8px; background: rgba(240,236,228,0.06); border-radius: 4px; overflow: hidden; min-width: 100px; }
.bar-fill { height: 100%; background: var(--accent); border-radius: 4px; }
.bar-fill-alt { background: rgba(240,236,228,0.25); }
.bar-fill-third { background: rgba(240,236,228,0.12); }
.election-turnout { font-size: .75rem; color: var(--text-3); margin-top: 12px; }

/* ===== FOOTER ===== */
.site-footer { text-align: center; padding: 32px 24px; }
.footer-inner { max-width: 800px; margin: 0 auto; }
.footer-data { font-size: .75rem; color: var(--text-3); margin-bottom: 4px; }
.footer-data a { color: var(--accent); text-decoration: none; }
.footer-copy { font-size: .7rem; color: var(--text-3); }

/* ===== RESPONSIVE ===== */
@media (max-width: 600px) {
  .agency-grid { grid-template-columns: 1fr; }
  .programmes-grid { grid-template-columns: 1fr; }
  .annonces-grid { grid-template-columns: 1fr; }
  .demo-grid { grid-template-columns: 1fr; }
  .politique-content { grid-template-columns: 1fr; }
  .map-container { height: 320px; }
  .quartiers-layout { grid-template-columns: 1fr; }
  .news-card { flex-direction: column; gap: 8px; }
  .event-card { flex-direction: column; gap: 8px; }
  .event-date { width: auto; flex-direction: row; gap: 6px; }
}


/* ─── POLITIQUE ─────────────────────────────────────────────────────────── */
.politique-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; padding:1.5rem 0; }
.politique-card { background:#0a1520; border:1px solid #2a3a4a; border-radius:8px; padding:1.5rem; }
.maire-card h3 { font-family:'Playfair Display',serif; font-size:1.4rem; color:#f0ece4; margin-bottom:.5rem; }
.parti-badge { display:inline-block; background:#1a2a3a; color:#c9a84c; font-size:.75rem; padding:.2rem .8rem; border-radius:20px; margin-bottom:1rem; letter-spacing:.05em; text-transform:uppercase; }
.btn-outline { display:inline-block; margin-top:1rem; padding:.5rem 1.2rem; border:1px solid #c9a84c; color:#c9a84c; border-radius:4px; font-size:.85rem; text-decoration:none; transition:all .2s; }
.btn-outline:hover { background:#c9a84c; color:#0f1923; }
.bar-row { display:flex; align-items:center; gap:.75rem; margin:.4rem 0; }
.bar-label { flex:0 0 160px; font-size:.8rem; color:#a09880; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bar-wrap { flex:1; background:#1a2a3a; border-radius:2px; height:8px; }
.bar-fill { height:8px; background:linear-gradient(90deg,#c9a84c,#a08030); border-radius:2px; transition:width .6s ease; }
.bar-pct { flex:0 0 40px; text-align:right; font-size:.8rem; color:#c9a84c; font-weight:500; }
.politique-card h4 { color:#c9a84c; font-size:.9rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1rem; padding-bottom:.5rem; border-bottom:1px solid #2a3a4a; }

/* ─── ACTUALITÉS ────────────────────────────────────────────────────────── */
.news-list { display:grid; gap:1rem; padding:1.5rem 0; }
.news-card { background:#0a1520; border:1px solid #2a3a4a; border-radius:8px; padding:1.5rem; transition:border-color .2s; }
.news-card:hover { border-color:#c9a84c; }
.news-meta { display:flex; gap:1rem; margin-bottom:.75rem; }
.news-date { font-size:.8rem; color:#c9a84c; }
.news-source { font-size:.8rem; color:#606870; }
.news-title { margin-bottom:.5rem; }
.news-title a { color:#f0ece4; text-decoration:none; font-family:'Playfair Display',serif; font-size:1.05rem; }
.news-title a:hover { color:#c9a84c; }
.news-resume { color:#a09880; font-size:.875rem; line-height:1.6; }

/* ─── ÉVÉNEMENTS ────────────────────────────────────────────────────────── */
.events-list { display:grid; gap:1rem; padding:1.5rem 0; }
.event-card { background:#0a1520; border:1px solid #2a3a4a; border-radius:8px; padding:1.5rem; display:flex; gap:1.5rem; }
.event-date { flex:0 0 120px; display:flex; flex-direction:column; gap:.4rem; }
.event-day { font-size:.8rem; color:#c9a84c; font-weight:500; }
.event-type { font-size:.7rem; background:#1a2a3a; color:#a09880; padding:.2rem .6rem; border-radius:20px; text-align:center; text-transform:uppercase; letter-spacing:.05em; }
.event-info h4 { margin-bottom:.3rem; }
.event-info h4 a { color:#f0ece4; text-decoration:none; font-family:'Playfair Display',serif; }
.event-info h4 a:hover { color:#c9a84c; }
.event-lieu { font-size:.8rem; color:#c9a84c; margin-bottom:.4rem; }
.event-info p { color:#a09880; font-size:.875rem; line-height:1.6; }

/* ─── DÉMOGRAPHIE ───────────────────────────────────────────────────────── */
.demo-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; padding:1.5rem 0; }
.demo-card { background:#0a1520; border:1px solid #2a3a4a; border-radius:8px; padding:1.5rem; }
.demo-card h3 { font-size:.9rem; text-transform:uppercase; letter-spacing:.08em; color:#c9a84c; margin-bottom:1rem; }
.demo-logements { background:#0a1520; border:1px solid #2a3a4a; border-radius:8px; padding:1.5rem; margin-bottom:1.5rem; }
.stat-row { display:flex; justify-content:space-between; align-items:center; padding:.5rem 0; border-bottom:1px solid #1a2a3a; }
.stat-row:last-child { border-bottom:none; }
.stat-row span { color:#a09880; font-size:.875rem; }
.stat-row strong { color:#c9a84c; font-size:1rem; }

/* ─── FISCALITÉ ─────────────────────────────────────────────────────────── */
.fisc-content { padding:1.5rem 0; }
.fisc-note { font-size:.8rem; color:#606870; margin-top:1rem; font-style:italic; line-height:1.6; }
.fisc-table-wrap { margin-top:1.5rem; overflow-x:auto; }

/* ─── MISC ──────────────────────────────────────────────────────────────── */
.muted { color:#606870; font-size:.875rem; }
.source { font-size:.75rem; color:#606870; margin-bottom:1.5rem; text-transform:uppercase; letter-spacing:.06em; }

/* ─── CARTES LEAFLET ────────────────────────────────────────────────────── */
#marche-map, #quartiers-map {
  height: 480px;
  width: 100%;
  border-radius: 8px;
  border: 1px solid #2a3a4a;
  margin: 1.5rem 0;
  z-index: 0;
}
.leaflet-container { background: #0a1520; }
.leaflet-popup-content-wrapper {
  background: #0f1923;
  color: #f0ece4;
  border: 1px solid #2a3a4a;
  border-radius: 6px;
}
.leaflet-popup-tip { background: #0f1923; }
.leaflet-popup-content { font-family: 'Inter', sans-serif; font-size: .85rem; }
.leaflet-popup-content strong { color: #c9a84c; }
.map-legend {
  display: flex; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1rem; padding: .75rem 1rem;
  background: #0a1520; border-radius: 6px; border: 1px solid #2a3a4a;
  font-size: .8rem;
}
.legend-item { display: flex; align-items: center; gap: .4rem; color: #a09880; }
.legend-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.infra-filter { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.infra-btn { padding: .3rem .8rem; border: 1px solid #2a3a4a; background: transparent; color: #a09880; border-radius: 20px; cursor: pointer; font-size: .8rem; transition: all .2s; }
.infra-btn.active, .infra-btn:hover { background: #c9a84c; color: #0f1923; border-color: #c9a84c; }
.marche-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.marche-stat-card { background: #0a1520; border: 1px solid #2a3a4a; border-radius: 8px; padding: 1rem 1.5rem; text-align: center; }
.marche-stat-val { font-family: 'Playfair Display', serif; font-size: 1.8rem; color: #c9a84c; font-weight: 600; }
.marche-stat-label { font-size: .75rem; color: #606870; text-transform: uppercase; letter-spacing: .06em; margin-top: .3rem; }


/* ═══════════════════════════════════════════════════════════════════════════
   PUBLICITÉ — slots discrets mais bien positionnés
   ═══════════════════════════════════════════════════════════════════════════ */

.ad-slot {
  position: relative;
  text-align: center;
  padding: 8px 16px 12px;
  background: rgba(201,168,76,0.03);
  border-top: 1px solid rgba(201,168,76,0.08);
  border-bottom: 1px solid rgba(201,168,76,0.08);
}
.ad-slot-top { max-width: 100%; }
.ad-slot-mid { margin: 24px auto 0; max-width: 360px; border-radius: var(--r); border: 1px solid rgba(201,168,76,0.08); }
.ad-slot-footer { max-width: 360px; margin: 0 auto 20px; border-radius: var(--r); border: 1px solid rgba(201,168,76,0.08); }
.ad-label {
  display: block;
  font-size: .55rem;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 4px;
}
.ad-placeholder {
  display: flex; align-items: center; justify-content: center;
  height: 60px; border-radius: 6px;
  background: rgba(240,236,228,0.02);
  border: 1px dashed rgba(201,168,76,0.12);
  font-size: .7rem; color: var(--text-3);
  font-style: italic;
}
.ad-slot-top .ad-placeholder { height: 50px; max-width: 728px; margin: 0 auto; }
.ad-slot-mid .ad-placeholder,
.ad-slot-footer .ad-placeholder { height: 250px; max-width: 300px; margin: 0 auto; }

/* Slot agence partenariat */
.ad-agency-slot {
  border: 1px dashed rgba(201,168,76,0.25) !important;
  background: rgba(201,168,76,0.02) !important;
  display: flex; align-items: center; justify-content: center;
}
.ad-agency-inner { text-align: center; padding: 8px; }
.ad-agency-title { font-family: var(--serif); font-size: 1rem; margin: 8px 0 4px; color: var(--text); }
.ad-agency-sub { font-size: .75rem; color: var(--text-2); margin-bottom: 14px; line-height: 1.5; }

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — améliorations mobile-first
   ═══════════════════════════════════════════════════════════════════════════ */

/* Tab scroll indicator sur mobile */
.tab-scroll-hint {
  display: none;
  position: absolute; right: 0; top: 0; bottom: 0; width: 40px;
  background: linear-gradient(to right, transparent, rgba(15,25,35,0.95));
  pointer-events: none;
}
@media (max-width: 768px) {
  .tab-scroll-hint { display: block; }
  .tab-nav { position: sticky; top: 0; }
  .tab-btn { padding: 12px 14px; font-size: .75rem; }
}

/* Header responsive */
@media (max-width: 480px) {
  .site-header { padding: 28px 16px 12px; }
  .header-title { font-size: 1.6rem; }
  .header-kpis { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .kpi { padding: 10px 8px; }
  .kpi-val { font-size: 1.3rem; }
}

/* Panel inner padding réduit sur mobile */
@media (max-width: 600px) {
  .panel-inner { padding: 20px 16px; }
  .panel-inner h2 { font-size: 1.2rem; }
}

/* Cartes empilées sur mobile (déjà géré partiellement, on renforce) */
@media (max-width: 600px) {
  .agency-grid  { grid-template-columns: 1fr; }
  .programmes-grid { grid-template-columns: 1fr; }
  .annonces-grid { grid-template-columns: 1fr; }
  .demo-grid { grid-template-columns: 1fr; }
  .politique-grid { grid-template-columns: 1fr; }
  .map-container, #marche-map, #quartiers-map { height: 280px; }
  .quartiers-layout { grid-template-columns: 1fr; }
  .marche-grid { grid-template-columns: 1fr; }
  .news-card { flex-direction: column; gap: 6px; }
  .event-card { flex-direction: column; gap: 10px; }
  .event-date { flex-direction: row; gap: 8px; width: auto; }
  .fisc-content { grid-template-columns: 1fr; }
  .table-scroll { font-size: .75rem; }
  .data-table th, .data-table td { padding: 6px 8px; }
  .ad-slot-top .ad-placeholder { height: 50px; max-width: 100%; }
}

/* Annonces — boutons centrés mobile */
@media (max-width: 480px) {
  .annonce-links { flex-direction: column; align-items: center; }
  .annonce-platform { padding: 20px 16px; }
}

/* Éviter overflow horizontal global */
body { overflow-x: hidden; }
.panel-inner { overflow-x: hidden; }

/* ═══════════════════════════════════════════════════════════════════════════
   LOADING ANIMATION
   ═══════════════════════════════════════════════════════════════════════════ */

@keyframes pulse-opacity {
  0%, 100% { opacity: .4; }
  50%       { opacity: 1;  }
}
.loading-pulse { animation: pulse-opacity 1.4s ease-in-out infinite; }


/* ═══════════════════════════════════════════════════════════════════════════
   ANNONCES — logos plateforme + affiliation
   ═══════════════════════════════════════════════════════════════════════════ */

.annonce-logo {
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 10px;
  padding: 6px 0;
}
.annonce-logo-seloger  { color: #e3000f; }
.annonce-logo-lbc      { color: #ff6e14; }
.annonce-logo-bienici  { color: #3b82f6; }

.affil-notice    { font-size: .7rem; color: var(--text-3); font-style: italic; }
.affil-disclaimer {
  margin-top: 16px; padding: 10px 16px;
  font-size: .75rem; color: var(--text-3); font-style: italic;
  border-left: 2px solid var(--border);
}
