/* Portails Immobiliers — Luxe Design System v2 */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

:root {
  --bg: #070f18;
  --bg-2: #0d1a26;
  --bg-card: rgba(255,255,255,0.035);
  --bg-card-hover: rgba(255,255,255,0.065);
  --border: rgba(212,175,80,0.14);
  --border-hi: rgba(212,175,80,0.32);
  --text: #ede8de;
  --text-2: rgba(237,232,222,0.62);
  --text-3: rgba(237,232,222,0.36);
  --accent: #d4af57;
  --accent-dark: #a8882e;
  --accent-dim: rgba(212,175,80,0.10);
  --accent-glow: rgba(212,175,80,0.15);
  --serif: 'Fraunces', Georgia, serif;
  --sans: 'DM Sans', system-ui, sans-serif;
  --r: 14px;
  --r-sm: 7px;
  --transition: 220ms cubic-bezier(.4,0,.2,1);
}

* { 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(175deg, rgba(7,15,24,0.72) 0%, rgba(7,15,24,0.50) 55%, rgba(7,15,24,0.82) 100%),
    url('https://images.unsplash.com/photo-1580137189272-c9379f8864fd?w=1800&q=80') center 45%/cover no-repeat;
  padding: 64px 24px 28px;
  text-align: center;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.site-header::after {
  content: '';
  position: absolute;
  bottom: 0; left: 10%; right: 10%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent-glow), var(--accent), var(--accent-glow), transparent);
  opacity: .5;
}
.header-inner { max-width: 1000px; margin: 0 auto; position: relative; z-index: 1; }
.header-eyebrow {
  font-family: var(--sans);
  font-size: .6rem;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
  opacity: .85;
}
.header-title {
  font-family: var(--serif);
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-weight: 400;
  letter-spacing: -.01em;
  line-height: 1.1;
  margin-bottom: 10px;
}
.accent { color: var(--accent); }
.header-sub { color: var(--text-2); font-size: .88rem; letter-spacing: .02em; margin-bottom: 36px; }

.header-kpis {
  display: flex;
  justify-content: center;
  gap: 0;
  max-width: 680px;
  margin: 0 auto;
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  backdrop-filter: blur(12px);
  background: rgba(7,15,24,0.5);
}
.kpi {
  flex: 1;
  padding: 18px 12px;
  display: flex; flex-direction: column; align-items: center;
  border-right: 1px solid var(--border);
}
.kpi:last-child { border-right: none; }
.kpi-val {
  font-family: var(--serif);
  font-size: 1.7rem;
  font-weight: 400;
  color: var(--accent);
  line-height: 1.1;
  letter-spacing: -.02em;
}
.kpi-unit { font-size: .65rem; color: var(--text-3); margin-top: 1px; }
.kpi-label { font-size: .58rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .10em; margin-top: 4px; }

@media (max-width: 600px) {
  .header-kpis { flex-wrap: wrap; }
  .kpi { flex: 0 0 50%; border-bottom: 1px solid var(--border); }
  .kpi:last-child { border-right: none; }
  .kpi:nth-child(even) { border-right: none; }
}

/* ===== 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(7,15,24,0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}
.tab-nav-inner {
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
  max-width: 1200px;
  margin: 0 auto;
  justify-content: center;
  padding: 0 8px;
}
.tab-nav-inner::-webkit-scrollbar { display: none; }
.tab-btn {
  flex-shrink: 0;
  padding: 15px 17px;
  border: none;
  background: none;
  font-family: var(--sans);
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .03em;
  color: var(--text-3);
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--transition), border-color var(--transition), background var(--transition);
  position: relative;
}
.tab-btn:hover { color: var(--text-2); }
.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(8px); } to { opacity:1; transform:translateY(0); } }
.panel-inner { max-width: 1200px; margin: 0 auto; padding: 40px 28px; }
.panel-inner h2 {
  font-family: var(--serif);
  font-size: 1.7rem;
  font-weight: 400;
  letter-spacing: -.01em;
  margin-bottom: 4px;
  line-height: 1.2;
}
.panel-inner h3 {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 400;
  margin-bottom: 14px;
  color: var(--text-2);
}
.source { font-size: .72rem; color: var(--text-3); margin-bottom: 28px; letter-spacing: .04em; }
.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: 22px 24px;
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition);
}
.agency-card:hover {
  border-color: var(--border-hi);
  background: var(--bg-card-hover);
  box-shadow: 0 8px 32px rgba(0,0,0,.28);
}
.agency-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; margin-bottom: 10px; }
.agency-name { font-family: var(--serif); font-weight: 400; font-size: 1.05rem; letter-spacing: -.01em; }
.agency-rating { text-align: right; white-space: nowrap; }
.stars { color: #e8a820; font-size: .85rem; letter-spacing: -.02em; }
.rating-num { font-weight: 600; font-size: .78rem; margin-left: 4px; color: var(--text-2); }
.reviews-count { font-size: .68rem; color: var(--text-3); }
.agency-addr { font-size: .78rem; color: var(--text-2); margin-bottom: 4px; }
.agency-phone { font-size: .8rem; margin-bottom: 12px; }
.agency-phone a { color: var(--accent); text-decoration: none; }
.agency-actions { display: flex; gap: 8px; }

/* Buttons */
.btn-outline {
  display: inline-block; padding: 7px 18px;
  border: 1px solid var(--border-hi);
  border-radius: 6px; font-size: .73rem; font-weight: 500; letter-spacing: .02em;
  color: var(--text-2); text-decoration: none;
  transition: border-color var(--transition), color var(--transition), background var(--transition);
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }
.btn-gold {
  display: inline-block; padding: 7px 18px;
  background: var(--accent);
  border: none; border-radius: 6px; font-size: .73rem; font-weight: 600; letter-spacing: .02em;
  color: #070f18; text-decoration: none; transition: opacity var(--transition), box-shadow var(--transition);
}
.btn-gold:hover { opacity: .88; box-shadow: 0 4px 16px rgba(212,175,80,.3); }

/* ===== 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: 26px 24px; position: relative;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.programme-card:hover { border-color: var(--border-hi); box-shadow: 0 8px 28px rgba(0,0,0,.22); }
.programme-status {
  display: inline-block; padding: 3px 10px; border-radius: 4px;
  font-size: .62rem; font-weight: 600; text-transform: uppercase; letter-spacing: .07em;
  background: var(--accent-dim); color: var(--accent); margin-bottom: 14px;
  border: 1px solid var(--border);
}
.programme-card h4 { font-family: var(--serif); font-size: 1.15rem; font-weight: 400; margin-bottom: 4px; letter-spacing: -.01em; }
.programme-promoteur { font-size: .78rem; color: var(--accent); margin-bottom: 10px; letter-spacing: .02em; }
.programme-desc { font-size: .82rem; color: var(--text-2); margin-bottom: 18px; line-height: 1.6; }
.programme-details { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--border); padding-top: 14px; }
.prog-detail { display: flex; justify-content: space-between; font-size: .78rem; padding: 7px 0; border-bottom: 1px solid rgba(237,232,222,0.04); }
.prog-label { color: var(--text-3); text-transform: uppercase; font-size: .65rem; letter-spacing: .06em; }

/* ===== 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: 48px 24px 36px;
  border-top: 1px solid var(--border);
  background: var(--bg-2);
}
.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-data a:hover { text-decoration: underline; }
.footer-copy { font-size: .68rem; color: var(--text-3); margin-top: 12px; }

.footer-portails { margin: 24px 0 20px; }
.footer-portails-label {
  font-size: .65rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--text-3); margin-bottom: 10px;
}
.footer-portails-links { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.footer-portal-card {
  display: flex; flex-direction: column; align-items: flex-start;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 12px 16px; max-width: 260px;
  text-decoration: none; transition: border-color .2s;
}
.footer-portal-card:hover { border-color: var(--accent); }
.fpc-name { font-size: .8rem; font-weight: 600; color: var(--accent); margin-bottom: 4px; }
.fpc-desc { font-size: .7rem; color: var(--text-3); line-height: 1.4; text-align: left; }

/* ===== 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:var(--bg-2); border:1px solid var(--border); border-radius:8px; padding:1.5rem; }
.maire-card h3 { font-family:var(--serif); font-size:1.4rem; color:var(--text); margin-bottom:.5rem; }
.parti-badge { display:inline-block; background:rgba(255,255,255,0.05); color:var(--accent); 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 var(--accent); color:var(--accent); border-radius:4px; font-size:.85rem; text-decoration:none; transition:all .2s; }
.btn-outline:hover { background:var(--accent); color:var(--bg); }
.bar-row { display:flex; align-items:center; gap:.75rem; margin:.4rem 0; }
.bar-label { flex:0 0 160px; font-size:.8rem; color:var(--text-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bar-wrap { flex:1; background:rgba(255,255,255,0.05); border-radius:2px; height:8px; }
.bar-fill { height:8px; background:linear-gradient(90deg,var(--accent),#a08030); border-radius:2px; transition:width .6s ease; }
.bar-pct { flex:0 0 40px; text-align:right; font-size:.8rem; color:var(--accent); font-weight:500; }
.politique-card h4 { color:var(--accent); font-size:.9rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1rem; padding-bottom:.5rem; border-bottom:1px solid var(--border); }

/* ─── ACTUALITÉS ────────────────────────────────────────────────────────── */
.news-list { display:grid; gap:1rem; padding:1.5rem 0; }
.news-card { background:var(--bg-2); border:1px solid var(--border); border-radius:8px; padding:1.5rem; transition:border-color .2s; }
.news-card:hover { border-color:var(--accent); }
.news-meta { display:flex; gap:1rem; margin-bottom:.75rem; }
.news-date { font-size:.8rem; color:var(--accent); }
.news-source { font-size:.8rem; color:var(--text-3); }
.news-title { margin-bottom:.5rem; }
.news-title a { color:var(--text); text-decoration:none; font-family:var(--serif); font-size:1.05rem; }
.news-title a:hover { color:var(--accent); }
.news-resume { color:var(--text-2); font-size:.875rem; line-height:1.6; }

/* ─── ÉVÉNEMENTS ────────────────────────────────────────────────────────── */
.events-list { display:grid; gap:1rem; padding:1.5rem 0; }
.event-card { background:var(--bg-2); border:1px solid var(--border); 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:var(--accent); font-weight:500; }
.event-type { font-size:.7rem; background:rgba(255,255,255,0.05); color:var(--text-2); 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:var(--text); text-decoration:none; font-family:var(--serif); }
.event-info h4 a:hover { color:var(--accent); }
.event-lieu { font-size:.8rem; color:var(--accent); margin-bottom:.4rem; }
.event-info p { color:var(--text-2); 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:var(--bg-2); border:1px solid var(--border); border-radius:8px; padding:1.5rem; }
.demo-card h3 { font-size:.9rem; text-transform:uppercase; letter-spacing:.08em; color:var(--accent); margin-bottom:1rem; }
.demo-logements { background:var(--bg-2); border:1px solid var(--border); 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 rgba(255,255,255,0.05); }
.stat-row:last-child { border-bottom:none; }
.stat-row span { color:var(--text-2); font-size:.875rem; }
.stat-row strong { color:var(--accent); font-size:1rem; }

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

/* ─── MISC ──────────────────────────────────────────────────────────────── */
.muted { color:var(--text-3); font-size:.875rem; }
.source { font-size:.75rem; color:var(--text-3); 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 var(--border);
  margin: 1.5rem 0;
  z-index: 0;
}
.leaflet-container { background: var(--bg-2); }
.leaflet-popup-content-wrapper {
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.leaflet-popup-tip { background: var(--bg); }
.leaflet-popup-content { font-family: var(--sans); font-size: .85rem; }
.leaflet-popup-content strong { color: var(--accent); }
.map-legend {
  display: flex; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1rem; padding: .75rem 1rem;
  background: var(--bg-2); border-radius: 6px; border: 1px solid var(--border);
  font-size: .8rem;
}
.legend-item { display: flex; align-items: center; gap: .4rem; color: var(--text-2); }
.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 var(--border); background: transparent; color: var(--text-2); border-radius: 20px; cursor: pointer; font-size: .8rem; transition: all .2s; }
.infra-btn.active, .infra-btn:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.marche-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.marche-stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 1.2rem 1.5rem;
  text-align: center;
  transition: border-color var(--transition);
}
.marche-stat-card:hover { border-color: var(--border-hi); }
.marche-stat-val { font-family: var(--serif); font-size: 2rem; color: var(--accent); font-weight: 400; letter-spacing: -.02em; }
.marche-stat-label { font-size: .68rem; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; margin-top: .4rem; }


/* ═══════════════════════════════════════════════════════════════════════════
   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: 2px;
}
.ad-notice {
  display: block;
  font-size: .6rem;
  color: var(--text-3);
  font-style: italic;
  margin-bottom: 4px;
  opacity: .7;
}
.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-nav-inner { justify-content: flex-start; }
  .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; }
.annonce-logo-pap      { color: #007bff; }
.annonce-logo-ma       { color: #6c3fc5; }

.annonces-grid-wide { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.annonce-platform-featured {
  border-color: var(--border-hi);
}
.annonce-platform-estimation {
  border-color: var(--border-hi);
  background: var(--accent-dim);
}
.annonce-platform-header {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px;
}
.annonce-badge {
  font-size: .62rem; padding: 3px 9px; border-radius: 20px;
  background: var(--accent-dim); color: var(--accent);
  border: 1px solid var(--border); white-space: nowrap;
}
.annonce-links-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.btn-annonce { display: block; text-align: center; padding: 9px 12px; font-size: .78rem; }

.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);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE BOTTOM NAV — barre de navigation fixe en bas (≤ 768px)
   ═══════════════════════════════════════════════════════════════════════════ */

.mobile-nav { display: none; }
.mobile-sheet { display: none; }

@media (max-width: 768px) {
  .tab-nav { display: none; }
  body { padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px)); }

  /* Barre du bas */
  .mobile-nav {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: calc(64px + env(safe-area-inset-bottom, 0px));
    padding-bottom: env(safe-area-inset-bottom, 0px);
    background: rgba(12, 20, 30, 0.97);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-top: 1px solid var(--border-hi);
    z-index: 200;
  }
  .mnav-btn {
    flex: 1;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 4px;
    border: none; background: none;
    color: var(--text-3);
    font-family: var(--sans);
    font-size: 0.52rem; font-weight: 500;
    text-transform: uppercase; letter-spacing: .06em;
    cursor: pointer; padding: 8px 2px;
    transition: color .15s;
    -webkit-tap-highlight-color: transparent;
  }
  .mnav-btn svg { width: 22px; height: 22px; flex-shrink: 0; }
  .mnav-btn:active { opacity: .65; }
  .mnav-btn.active { color: var(--accent); }

  /* Drawer "Plus" */
  .mobile-sheet {
    display: block;
    position: fixed; inset: 0;
    z-index: 300;
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s;
  }
  .mobile-sheet.open { pointer-events: auto; opacity: 1; }
  .msheet-backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.6);
    backdrop-filter: blur(4px);
  }
  .msheet-panel {
    position: absolute; bottom: 0; left: 0; right: 0;
    background: var(--bg);
    border-top: 1px solid var(--border-hi);
    border-radius: 18px 18px 0 0;
    padding: 10px 16px calc(72px + env(safe-area-inset-bottom, 0px));
    transform: translateY(100%);
    transition: transform .3s cubic-bezier(.32,.72,0,1);
  }
  .mobile-sheet.open .msheet-panel { transform: translateY(0); }
  .msheet-handle {
    width: 36px; height: 4px;
    background: var(--border-hi);
    border-radius: 2px;
    margin: 0 auto 16px;
  }
  .msheet-title {
    font-size: .65rem; text-transform: uppercase; letter-spacing: .1em;
    color: var(--text-3); margin-bottom: 12px; text-align: center;
  }
  .msheet-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  }
  .msheet-btn {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 6px; padding: 14px 6px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--r);
    color: var(--text-3);
    font-family: var(--sans);
    font-size: .65rem; font-weight: 500;
    text-align: center; cursor: pointer;
    transition: all .15s;
    -webkit-tap-highlight-color: transparent;
  }
  .msheet-btn svg { width: 22px; height: 22px; }
  .msheet-btn.active { color: var(--accent); border-color: var(--border-hi); background: var(--accent-dim); }
  .msheet-btn:active { opacity: .65; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   TIME-ADAPTIVE THEMES — 6 periodes journee/nuit
   Detectees via JS (classe sur <html>) avec transition douce
   ═══════════════════════════════════════════════════════════════════════════ */

/* Variables sky du header */
:root {
  --sky-a:#c4ddf2; --sky-b:#92c0ec; --sky-c:#64a8de;
  --glow-x:50%; --glow-y:25%; --glow-color:rgba(255,250,200,0.04);
  --mt-back:#284060; --mt-front:#1a3050;
  --lk-a:#58a8d4; --lk-b:#3080b0;
  --nav-bg:rgba(240,234,224,0.96);
  --kpi-bg:rgba(240,234,224,0.38);
  --theme-td:1.4s;
}

/* Override root => LIGHT MATIN (nouveau defaut — plus sombre) */
:root {
  --bg:#f2ede5; --bg-2:#ece7de;
  --bg-card:rgba(0,0,0,0.04); --bg-card-hover:rgba(0,0,0,0.075);
  --border:rgba(26,64,110,0.13); --border-hi:rgba(26,64,110,0.27);
  --text:#0a1c2e; --text-2:rgba(10,28,46,0.62); --text-3:rgba(10,28,46,0.34);
  --accent:#1a58a0; --accent-dark:#0f4080;
  --accent-dim:rgba(26,88,160,0.08); --accent-glow:rgba(26,88,160,0.12);
}

/* NUIT 22h-5h */
html.t-nuit {
  --bg:#03060e; --bg-2:#070f1c;
  --bg-card:rgba(255,255,255,0.028); --bg-card-hover:rgba(255,255,255,0.055);
  --border:rgba(130,170,240,0.10); --border-hi:rgba(130,170,240,0.24);
  --text:#d4e4f8; --text-2:rgba(212,228,248,0.60); --text-3:rgba(212,228,248,0.30);
  --accent:#86b4ec; --accent-dark:#5490d4;
  --accent-dim:rgba(134,180,236,0.10); --accent-glow:rgba(134,180,236,0.14);
  --sky-a:#010408; --sky-b:#050b16; --sky-c:#0a1624;
  --glow-x:70%; --glow-y:22%; --glow-color:rgba(130,200,255,0.09);
  --mt-back:#0c1628; --mt-front:#080e1c;
  --lk-a:#0a1422; --lk-b:#050c14;
  --nav-bg:rgba(3,6,14,0.96); --kpi-bg:rgba(3,6,14,0.5);
}

/* AUBE 5h-8h */
html.t-aube {
  --bg:#100620; --bg-2:#180a28;
  --bg-card:rgba(255,255,255,0.04); --bg-card-hover:rgba(255,255,255,0.075);
  --border:rgba(230,140,190,0.12); --border-hi:rgba(230,140,190,0.28);
  --text:#f0dcea; --text-2:rgba(240,220,234,0.62); --text-3:rgba(240,220,234,0.32);
  --accent:#e898c4; --accent-dark:#d068a0;
  --accent-dim:rgba(232,152,196,0.10); --accent-glow:rgba(232,152,196,0.14);
  --sky-a:#180a28; --sky-b:#6c1c52; --sky-c:#c04e7e;
  --glow-x:62%; --glow-y:60%; --glow-color:rgba(255,130,180,0.30);
  --mt-back:#22082a; --mt-front:#140618;
  --lk-a:#7e2054; --lk-b:#260620;
  --nav-bg:rgba(16,6,32,0.96); --kpi-bg:rgba(16,6,32,0.5);
}

/* APRES-MIDI 12h-17h */
html.t-apm {
  --bg:#f5f0e6; --bg-2:#ede8dc;
  --bg-card:rgba(0,0,0,0.04); --bg-card-hover:rgba(0,0,0,0.075);
  --border:rgba(8,80,160,0.12); --border-hi:rgba(8,80,160,0.26);
  --text:#0a1c2e; --text-2:rgba(10,28,46,0.62); --text-3:rgba(10,28,46,0.34);
  --accent:#0660b4; --accent-dark:#044898;
  --accent-dim:rgba(6,96,180,0.08); --accent-glow:rgba(6,96,180,0.12);
  --sky-a:#f2e8d4; --sky-b:#e4d8c0; --sky-c:#c0dcf2;
  --glow-x:54%; --glow-y:12%; --glow-color:rgba(255,235,160,0.42);
  --mt-back:#2e4866; --mt-front:#1c3048;
  --lk-a:#96cce8; --lk-b:#50a0d0;
  --nav-bg:rgba(240,236,228,0.97); --kpi-bg:rgba(240,236,228,0.40);
}

/* COUCHER 17h-20h */
html.t-coucher {
  --bg:#060408; --bg-2:#0c070c;
  --bg-card:rgba(255,255,255,0.035); --bg-card-hover:rgba(255,255,255,0.065);
  --border:rgba(240,128,68,0.12); --border-hi:rgba(240,128,68,0.26);
  --text:#f6e8d8; --text-2:rgba(246,232,216,0.62); --text-3:rgba(246,232,216,0.32);
  --accent:#ec8c54; --accent-dark:#c06028;
  --accent-dim:rgba(236,140,84,0.10); --accent-glow:rgba(236,140,84,0.14);
  --sky-a:#080402; --sky-b:#500c04; --sky-c:#c03816;
  --glow-x:48%; --glow-y:52%; --glow-color:rgba(255,128,30,0.46);
  --mt-back:#140804; --mt-front:#0c0602;
  --lk-a:#742408; --lk-b:#220802;
  --nav-bg:rgba(6,4,8,0.96); --kpi-bg:rgba(6,4,8,0.5);
}

/* SOIREE 20h-22h */
html.t-soiree {
  --bg:#030508; --bg-2:#080e18;
  --bg-card:rgba(255,255,255,0.03); --bg-card-hover:rgba(255,255,255,0.055);
  --border:rgba(200,158,80,0.10); --border-hi:rgba(200,158,80,0.22);
  --text:#ecdac6; --text-2:rgba(236,218,198,0.62); --text-3:rgba(236,218,198,0.30);
  --accent:#cea456; --accent-dark:#a07830;
  --accent-dim:rgba(206,164,86,0.10); --accent-glow:rgba(206,164,86,0.14);
  --sky-a:#020408; --sky-b:#0a1626; --sky-c:#121c34;
  --glow-x:66%; --glow-y:26%; --glow-color:rgba(196,156,80,0.11);
  --mt-back:#0a1020; --mt-front:#060c16;
  --lk-a:#0c1a30; --lk-b:#060c18;
  --nav-bg:rgba(3,5,8,0.96); --kpi-bg:rgba(3,5,8,0.5);
}

/* ─── HEADER PHOTO ADAPTATIVE ────────────────────────────────────────────── */
.h-photo { position:absolute; inset:0; overflow:hidden; z-index:0; }
.h-photo-img { width:100%; height:100%; object-fit:cover; object-position:center 45%; opacity:0; transition:opacity 1.4s ease; }
.h-photo-img.loaded { opacity:1; }

/* ─── HEADER PAYSAGE ──────────────────────────────────────────────────────── */
.site-header {
  background: linear-gradient(185deg, var(--sky-a) 0%, var(--sky-b) 55%, var(--sky-c) 100%);
  padding: 80px 24px 64px;
  transition: background var(--theme-td) ease;
}
.site-header::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(ellipse 55% 40% at var(--glow-x) var(--glow-y), var(--glow-color) 0%, transparent 68%);
  transition: all var(--theme-td) ease;
}
.header-sky-lueur {
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background: radial-gradient(ellipse 58% 48% at 22% 12%, rgba(255,255,255,0.028) 0%, transparent 65%);
  animation: sky-lueur 11s ease-in-out infinite alternate;
}
@keyframes sky-lueur {
  from { opacity:.5; transform:translate(-4%,-2%); }
  to   { opacity:1;  transform:translate(4%, 2%); }
}
.header-etoiles { position:absolute; inset:0; pointer-events:none; opacity:0; transition:opacity var(--theme-td) ease; z-index:1; }
html.t-nuit .header-etoiles, html.t-soiree .header-etoiles { opacity:1; }
html.t-aube .header-etoiles { opacity:0.28; }
.h-star {
  position:absolute; border-radius:50%; background:#fff;
  animation: star-twinkle var(--st,3s) ease-in-out infinite alternate;
  animation-delay: var(--sd,0s);
}
@keyframes star-twinkle {
  from { opacity:var(--o1,.3); transform:scale(1); }
  to   { opacity:var(--o2,.9); transform:scale(1.6); }
}
.header-montagnes {
  position:absolute; bottom:0; left:0; right:0; height:52%;
  pointer-events:none; z-index:1;
  transition: all var(--theme-td) ease;
}
.header-montagnes svg { width:100%; height:100%; display:block; }
.header-lac { position:absolute; bottom:0; left:0; right:0; height:20%; pointer-events:none; z-index:1; }
.header-lac-fond {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, var(--lk-a), var(--lk-b));
  transition:background var(--theme-td) ease;
}
.header-lac-reflet {
  position:absolute; inset:0;
  background:repeating-linear-gradient(
    90deg, transparent, transparent 38px,
    rgba(255,255,255,0.015) 38px, rgba(255,255,255,0.015) 39px
  );
  animation:lac-reflet 14s linear infinite;
}
.header-lac-eclat { position:absolute; top:0; left:0; right:0; height:28%; background:linear-gradient(to bottom,rgba(255,255,255,0.06),transparent); }
@keyframes lac-reflet { from{transform:translateX(0)} to{transform:translateX(39px)} }

/* ─── TAB NAV + MOBILE NAV ────────────────────────────────────────────────── */
.tab-nav { background: var(--nav-bg); transition:background var(--theme-td) ease; }
.header-kpis { background: var(--kpi-bg) !important; transition:background var(--theme-td) ease; }

@media (max-width:768px) {
  .mobile-nav { background: var(--nav-bg) !important; border-top-color:var(--border-hi) !important; transition:background var(--theme-td) ease; }
  .msheet-panel { background:var(--bg) !important; transition:background var(--theme-td) ease; }
}

/* ─── BODY + FOOTER ───────────────────────────────────────────────────────── */
body, .site-footer { transition:background var(--theme-td) ease, color var(--theme-td) ease; }

/* ─── LEAFLET ─────────────────────────────────────────────────────────────── */
.leaflet-container { background:var(--bg-2) !important; }
.leaflet-popup-content-wrapper, .leaflet-popup-tip { background:var(--bg) !important; color:var(--text) !important; }
html:not(.t-nuit):not(.t-aube):not(.t-coucher):not(.t-soiree) .leaflet-tile-pane { filter:saturate(0.88) brightness(1.02); }

/* ─── LOGOS ANNONCES (light theme) ───────────────────────────────────────── */
html:not(.t-nuit):not(.t-aube):not(.t-coucher):not(.t-soiree) .annonce-logo-seloger { color:#cc0008; }
html:not(.t-nuit):not(.t-aube):not(.t-coucher):not(.t-soiree) .annonce-logo-lbc    { color:#e05c0e; }
html:not(.t-nuit):not(.t-aube):not(.t-coucher):not(.t-soiree) .annonce-logo-bienici { color:#2060d8; }

/* ─── BTN GOLD (dark text sur accent clair en mode jour) ─────────────────── */
.btn-gold { color: var(--bg); }

/* ─── THEME PICKER FLOTTANT ─────────────────────────────────────────────── */
.theme-picker { position:fixed; bottom:24px; right:20px; z-index:500; }
.theme-picker-btn {
  width:44px; height:44px; border-radius:50%;
  background:var(--accent); color:#fff; border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; box-shadow:0 4px 16px var(--accent-glow);
  transition:all .2s ease;
}
.theme-picker-btn:hover { transform:scale(1.08); }
.theme-menu {
  position:absolute; bottom:52px; right:0;
  background:var(--bg); border:1px solid var(--border-hi);
  border-radius:14px; padding:14px;
  width:200px;
  box-shadow:0 8px 32px var(--gshadow, rgba(0,0,0,.25));
  display:none; opacity:0;
  transform:translateY(8px);
  transition:opacity .2s, transform .2s;
}
.theme-menu.open { display:block; opacity:1; transform:translateY(0); }
.theme-menu-title { font-size:.65rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-3); margin-bottom:10px; }
.theme-options { display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-bottom:10px; }
.theme-opt {
  padding:7px 6px; border:1px solid var(--border); border-radius:8px;
  background:var(--bg-card); color:var(--text-2);
  font-family:var(--sans); font-size:.72rem; cursor:pointer;
  transition:all .15s; text-align:center;
}
.theme-opt:hover, .theme-opt.active { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); }
.theme-auto-btn {
  width:100%; padding:8px; border:1px solid var(--border-hi); border-radius:8px;
  background:var(--accent-dim); color:var(--accent);
  font-family:var(--sans); font-size:.72rem; cursor:pointer;
  transition:all .15s;
}
.theme-auto-btn.active { background:var(--accent); color:var(--bg); }
@media (max-width:768px) {
  .theme-picker { bottom:80px; }
}

