/* MAT — Desktop v4.2.2 */
.d-topbar,.d-nav,.d-hero,.d-stats,.d-main-grid,.d-rando-banner,.d-footer{display:none}
.content{display:block}

@media(min-width:1024px){
  body{max-width:none;background:#f0ebe3;font-family:'Nunito',sans-serif;display:flex;flex-direction:column;min-height:100dvh}

  /* TOPBAR */
  .d-topbar{display:none}
  .d-sep{opacity:.35}

  /* NAV */
  .d-nav{display:flex;position:sticky;top:0;z-index:100;background:#fff;border-bottom:2px solid var(--border,#e8f0ea);box-shadow:0 2px 8px rgba(26,61,43,.08);padding:0 32px}
  .d-nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1400px;margin:0 auto;height:70px;gap:12px}
  .d-nav-logo{display:flex;align-items:center;gap:10px}
  .d-nav-img{width:34px;height:34px;border-radius:8px}
  .d-nav-title{font-size:.95rem;font-weight:900;color:var(--forest)}
  .d-nav-sub{font-size:.62rem;color:var(--sage);font-weight:700;display:block;margin-top:-2px}
  .d-nav-links{display:flex;gap:2px;flex-wrap:wrap}
  .d-nav-links button,.d-nav-links a{background:none;border:none;color:var(--forest);font-family:'Nunito',sans-serif;font-size:.85rem;font-weight:800;cursor:pointer;padding:8px 12px;border-radius:10px;transition:background .15s;text-decoration:none;display:inline-flex;align-items:center}
  .d-nav-links button:hover,.d-nav-links button.active,.d-nav-links a:hover{background:var(--mist);color:var(--forest)}
  .d-nav-ctas{display:flex;gap:8px}
  .d-nav-cta{padding:8px 16px;border-radius:10px;border:none;font-family:'Nunito',sans-serif;font-size:.78rem;font-weight:800;cursor:pointer}
  .d-nav-cta-app{background:#f0f4f8;color:var(--forest)}
  .d-nav-cta-mel{background:linear-gradient(135deg,var(--forest),var(--leaf));color:#fff}

  /* HERO */
  .header{display:none}
  .d-hero{display:block;position:relative;height:340px;overflow:hidden}
  .d-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 35%;filter:brightness(.82)}
  .d-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,61,43,.45) 25%,rgba(26,61,43,.1))}
  .d-hero-inner{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}
  .d-hero-text{flex:1;max-width:560px}
  .d-hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:5px 12px;font-size:.68rem;font-weight:800;color:rgba(255,255,255,.9);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
  .d-hero-title{font-family:'Playfair Display',Georgia,serif;font-size:2.6rem;font-weight:700;color:#fff;margin:0 0 12px;line-height:1.1;text-shadow:0 2px 12px rgba(0,0,0,.3)}
  .d-hero-title em{font-style:italic;color:#a7f3d0}
  .d-hero-desc{font-size:.88rem;color:rgba(255,255,255,.85);line-height:1.6;margin:0 0 20px}
  .d-hero-btns{display:flex;gap:10px;flex-wrap:wrap}
  .d-btn-primary{background:linear-gradient(135deg,var(--leaf),var(--forest));color:#fff;border:none;border-radius:12px;padding:11px 20px;font-family:'Nunito',sans-serif;font-size:.84rem;font-weight:800;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 14px rgba(26,61,43,.4)}
  .d-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(26,61,43,.5)}
  .d-btn-sec{background:rgba(255,255,255,.18);backdrop-filter:blur(4px);color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:12px;padding:11px 20px;font-family:'Nunito',sans-serif;font-size:.84rem;font-weight:800;cursor:pointer;transition:background .15s}
  .d-btn-sec:hover{background:rgba(255,255,255,.28)}

  /* METEO WIDGET */
  .d-hero-meteo{flex-shrink:0;width:220px}
  .d-meteo-card{background:rgba(255,255,255,.18);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.4);border-radius:18px;padding:16px;color:#fff;cursor:pointer;transition:background .2s,box-shadow .2s;box-shadow:0 4px 18px rgba(0,0,0,.2)}
  .d-meteo-card:hover{background:rgba(255,255,255,.28);box-shadow:0 6px 24px rgba(0,0,0,.3)}
  .d-meteo-label{font-size:.65rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.8);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
  .d-meteo-click-hint{font-size:.58rem;color:rgba(255,255,255,.6)}
  .d-meteo-badge{font-size:.6rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.7);margin-bottom:8px}
  .d-meteo-temp{font-size:2.8rem;font-weight:900;line-height:1}
  .d-meteo-temp span{font-size:1.4rem}
  .d-meteo-desc{font-size:.8rem;color:rgba(255,255,255,.85);margin:6px 0 10px}
  .d-meteo-row{display:flex;justify-content:space-between;font-size:.72rem;color:rgba(255,255,255,.7);padding:5px 0;border-top:1px solid rgba(255,255,255,.1)}
  .d-meteo-row strong{color:#fff}

  /* BUS RÉMI card desktop */
  .d-bus-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:.78rem}
  .d-bus-item:last-child{border-bottom:none}
  .d-bus-stop{font-weight:700;color:var(--forest);min-width:64px}
  .d-bus-dir{flex:1;color:var(--sage);font-weight:600}
  .d-bus-time{font-weight:900;color:var(--forest);background:var(--mist);border-radius:6px;padding:2px 8px;font-size:.76rem}
  .d-bus-soon{background:#fef3c7;color:#92400e}
  .d-bus-empty{font-size:.75rem;color:#aaa;padding:8px 0;text-align:center}
  .d-bus-periode{font-size:.62rem;background:var(--mist);color:var(--sage);border-radius:6px;padding:2px 7px;font-weight:800}

  /* Accessibility btn in nav */
  .d-nav-acc{background:#f0f4f8;border:1px solid var(--border,#e8f0ea);border-radius:10px;padding:7px 12px;font-family:'Nunito',sans-serif;font-size:.75rem;font-weight:800;cursor:pointer;color:var(--forest);transition:background .15s;display:inline-flex;align-items:center;gap:4px;flex-shrink:0}
  .d-nav-acc:hover{background:var(--mist)}

  /* STATS */
  .d-stats{display:flex;background:#fff;border-bottom:1px solid var(--border,#e8f0ea);padding:0 32px;justify-content:center;gap:0}
  .d-stat{display:flex;align-items:center;gap:12px;padding:16px 40px;border-right:1px solid var(--border,#e8f0ea)}
  .d-stat:last-child{border-right:none}
  .d-stat-ico{font-size:1.4rem}
  .d-stat-n{font-size:1.6rem;font-weight:900;color:var(--forest);line-height:1}
  .d-stat-l{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--sage)}

  /* MAIN GRID */
  .content{display:none}
  .d-main-grid{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:20px;max-width:1400px;margin:24px auto;padding:0 32px;flex:1}

  /* CARD */
  .d-card{background:#fff;border-radius:18px;border:1px solid var(--border,#e8f0ea);overflow:hidden;margin-bottom:16px;box-shadow:0 2px 8px rgba(26,61,43,.05)}
  .d-card-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f0f4f0}
  .d-card-hdr span{font-size:.82rem;font-weight:900;color:var(--forest)}
  .d-card-hdr button{background:none;border:none;color:var(--sage);font-family:'Nunito',sans-serif;font-size:.74rem;font-weight:800;cursor:pointer}
  .d-card-body{padding:12px 16px}
  .d-loading{font-size:.75rem;color:#aaa;padding:8px 0;text-align:center}

  /* ACTUALITÉS */
  .d-actu-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid #f5f5f5;cursor:pointer;align-items:flex-start}
  .d-actu-item:last-child{border-bottom:none}
  .d-actu-img{width:52px;height:52px;border-radius:10px;object-fit:cover;flex-shrink:0;background:var(--mist)}
  .d-actu-body{flex:1;min-width:0}
  .d-actu-cat{font-size:.58rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--sage);margin-bottom:2px}
  .d-actu-title{font-size:.78rem;font-weight:800;color:var(--forest);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .d-actu-date{font-size:.65rem;color:#aaa;margin-top:3px}
  .d-actu-item:hover .d-actu-title{color:var(--leaf)}

  /* SIGNAL GRID */
  .d-mel-cta-panel + .d-card{margin-top:20px;border-top:2px solid var(--border,#e8f0ea)}
  .d-signal-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px 16px}
  .d-signal-grid button{background:#f4f8f4;border:1px solid var(--border,#e8f0ea);border-radius:12px;padding:12px 8px;font-family:'Nunito',sans-serif;font-size:.76rem;font-weight:800;color:var(--forest);cursor:pointer;transition:background .15s}
  .d-signal-grid button:hover{background:var(--mist)}

  /* FEATURED EVENT */
  #dsk-featured{margin-bottom:16px}
  .d-featured{background:linear-gradient(135deg,var(--forest),var(--leaf));border-radius:18px;padding:20px;color:#fff;position:relative;overflow:hidden}
  .d-featured::before{content:'';position:absolute;right:-20px;top:-20px;width:120px;height:120px;background:rgba(255,255,255,.05);border-radius:50%}
  .d-featured-badge{font-size:.6rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.7);margin-bottom:10px}
  .d-featured-title{font-size:1.1rem;font-weight:900;line-height:1.25;margin-bottom:6px}
  .d-featured-meta{font-size:.72rem;color:rgba(255,255,255,.75);margin-bottom:12px}
  .d-featured-countdown{display:flex;gap:10px}
  .d-countdown-item{text-align:center;background:rgba(255,255,255,.15);border-radius:10px;padding:8px 12px;min-width:48px}
  .d-countdown-n{font-size:1.4rem;font-weight:900;line-height:1}
  .d-countdown-l{font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8}

  /* AGENDA */
  .d-agenda-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid #f5f5f5;align-items:flex-start}
  .d-agenda-item:last-child{border-bottom:none}
  .d-agenda-date{background:var(--mist);border-radius:10px;padding:6px 8px;text-align:center;min-width:40px;flex-shrink:0}
  .d-agenda-day{font-size:1.1rem;font-weight:900;color:var(--forest);line-height:1}
  .d-agenda-mon{font-size:.6rem;text-transform:uppercase;font-weight:800;color:var(--sage)}
  .d-agenda-body{flex:1}
  .d-agenda-title{font-size:.8rem;font-weight:800;color:var(--forest)}
  .d-agenda-time{font-size:.68rem;color:#aaa;margin-top:2px}
  .d-agenda-dot{width:8px;height:8px;border-radius:50%;background:var(--sage);flex-shrink:0;margin-top:6px}

  /* MEL PANEL */
  .d-mel-panel,.d-mel-cta-panel{background:#fff;border-radius:18px;border:1px solid var(--border,#e8f0ea);overflow:hidden;box-shadow:0 2px 8px rgba(26,61,43,.05)}
  .d-mel-cta-panel{padding:0 0 16px}
  .d-mel-cta-btn{display:block;width:calc(100% - 32px);margin:0 16px;background:linear-gradient(135deg,var(--forest),var(--leaf));color:#fff;border:none;border-radius:12px;padding:13px;font-family:'Nunito',sans-serif;font-size:.88rem;font-weight:900;cursor:pointer;letter-spacing:.02em}
  .d-mel-hdr{display:flex;align-items:center;gap:10px;padding:14px 16px;background:linear-gradient(135deg,#f8fdf9,#f0f8f3);border-bottom:1px solid var(--border,#e8f0ea)}
  .d-mel-img{width:38px;height:38px;border-radius:10px;object-fit:contain}
  .d-mel-name{font-size:.82rem;font-weight:900;color:var(--forest)}
  .d-mel-online{font-size:.68rem;font-weight:700;color:#10b981;margin-left:6px}
  .d-mel-sub{font-size:.68rem;color:var(--sage);margin-top:1px}
  .d-mel-bubble{background:#f0f8f3;border-radius:12px;margin:12px 16px;padding:10px 12px;font-size:.78rem;color:var(--forest);line-height:1.5}
  .d-mel-cats{display:flex;flex-wrap:wrap;gap:6px;padding:4px 16px 10px}
  .d-mel-cats button{background:#f0f4f8;border:1px solid var(--border,#e8f0ea);border-radius:8px;padding:5px 10px;font-family:'Nunito',sans-serif;font-size:.7rem;font-weight:800;color:var(--forest);cursor:pointer}
  .d-mel-cats button:hover{background:var(--mist);border-color:var(--sage)}
  .d-mel-form{display:flex;gap:8px;padding:10px 16px;border-top:1px solid var(--border,#e8f0ea)}
  .d-mel-input{flex:1;border:1px solid var(--border,#e8f0ea);border-radius:10px;padding:9px 12px;font-family:'Nunito',sans-serif;font-size:.8rem;outline:none}
  .d-mel-input:focus{border-color:var(--sage)}
  .d-mel-form button[type=submit]{background:linear-gradient(135deg,var(--forest),var(--leaf));color:#fff;border:none;border-radius:10px;width:36px;font-size:1rem;cursor:pointer}

  /* MAIRIE */
  .d-mairie-status{font-size:.82rem;font-weight:800;padding:8px 16px 4px}
  .d-mairie-status.open{color:#10b981}
  .d-mairie-status.closed{color:#ef4444}
  .d-horaires{width:100%;border-collapse:collapse;font-size:.75rem;margin:0 0 10px}
  .d-horaires td{padding:5px 16px;color:#374151}
  .d-horaires td:first-child{color:#6b7280;font-weight:700}
  .d-horaires tr:nth-child(even){background:#f9fafb}
  .d-mairie-actions{display:flex;gap:8px;padding:8px 16px 14px}
  .d-mairie-actions a,.d-mairie-actions button{flex:1;background:#f0f4f8;border:1px solid var(--border,#e8f0ea);border-radius:10px;padding:8px;font-family:'Nunito',sans-serif;font-size:.72rem;font-weight:800;color:var(--forest);cursor:pointer;text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
  .d-mairie-actions a:hover,.d-mairie-actions button:hover{background:var(--mist)}

  /* COLLECTES */
  .d-collecte-item{display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid #f5f5f5}
  .d-collecte-item:last-child{border-bottom:none}
  .d-collecte-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}
  .d-collecte-name{flex:1;font-size:.78rem;font-weight:700;color:var(--forest)}
  .d-collecte-date{font-size:.72rem;font-weight:800;color:var(--forest)}
  .d-collecte-badge{font-size:.62rem;background:#fef3c7;color:#92400e;border-radius:6px;padding:2px 7px;font-weight:800}

  /* ÉLUS */
  .d-elu-item{display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid #f5f5f5;cursor:pointer}
  .d-elu-item:last-child{border-bottom:none}
  .d-elu-item:hover{background:#f9fafb}
  .d-elu-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--mist);display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--forest);font-size:.9rem;flex-shrink:0}
  .d-elu-name{font-size:.8rem;font-weight:800;color:var(--forest)}
  .d-elu-role{font-size:.68rem;color:var(--sage);font-weight:700}

  /* SORTIES LOCALES BANNER (rando + événements) */
  .d-rando-banner{background:linear-gradient(135deg,var(--forest) 0%,var(--leaf) 60%,#4c1d95 100%);padding:40px 32px;margin-top:0}
  .d-rando-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px}
  .d-sorties-inner{flex-wrap:wrap}
  .d-rando-left{flex:1;min-width:200px;color:#fff}
  .d-rando-badge{font-size:.65rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.6);margin-bottom:10px}
  .d-rando-title{font-family:'Playfair Display',Georgia,serif;font-size:2rem;font-weight:700;font-style:italic;margin:0 0 10px;color:#fff;line-height:1.15}
  .d-rando-desc{font-size:.82rem;color:rgba(255,255,255,.8);line-height:1.6;margin:0 0 20px}
  .d-rando-stats{display:flex;gap:32px;flex-shrink:0}
  .d-rando-stat{text-align:center;color:#fff}
  .d-rando-stat strong{display:block;font-size:2rem;font-weight:900;color:#a7f3d0}
  .d-rando-stat span{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6)}
  .d-sorties-sep{width:1px;background:rgba(255,255,255,.2);align-self:stretch;flex-shrink:0;margin:0 8px}
  .d-events-left{flex:1;min-width:200px;color:#fff}
  .d-events-preview{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}
  .d-event-card{background:rgba(255,255,255,.1);border-radius:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.15)}
  .d-event-card-date{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:rgba(221,214,254,.8);margin-bottom:4px}
  .d-event-card-title{font-size:.78rem;font-weight:800;color:#fff;line-height:1.3}
  .d-event-card-place{font-size:.65rem;color:rgba(255,255,255,.6);margin-top:2px}

  /* FOOTER */
  .footer{display:none}
  .d-footer{display:flex;background:#1a3d2b;border-top:1px solid rgba(255,255,255,.1)}
  .d-footer-bottom{max-width:1400px;width:100%;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:5px 32px;font-size:.65rem;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:6px}
  .d-footer-links{display:flex;gap:14px;align-items:center}
  .d-footer-links button{background:none;border:none;color:rgba(255,255,255,.55);font-family:'Nunito',sans-serif;font-size:.65rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:3px;transition:color .15s;padding:0}
  .d-footer-links button:hover{color:rgba(255,255,255,.95)}

  .app-splash{position:fixed!important}
}
html.theme-bleu .d-footer{background:#1a3a5c}
html.theme-sombre .d-footer{background:#0f172a}
.d-featured{cursor:pointer;transition:opacity .15s;}
.d-featured:hover{opacity:.92;}
.d-featured-img{display:block;width:calc(100% + 40px);height:auto;max-height:260px;object-fit:contain;border-radius:14px 14px 0 0;margin:-20px -20px 16px;background:var(--forest);}
@media(min-width:1024px){.d-mobile-only{display:none !important;}}

/* ── Thèmes — overrides desktop spécifiques ── */
html.theme-sombre .d-topbar{background:var(--forest)}
html.theme-sombre .d-nav{background:#1e293b;border-bottom-color:rgba(255,255,255,.08)}
html.theme-sombre .d-nav-title{color:#f1f5f9}
html.theme-sombre .d-nav-links button,html.theme-sombre .d-nav-links a{color:#e2e8f0}
html.theme-sombre .d-stats{background:#1e293b;border-bottom-color:rgba(255,255,255,.08)}
html.theme-sombre .d-stat{border-right-color:rgba(255,255,255,.08)}
html.theme-sombre .d-stat-l{color:#94a3b8}
html.theme-sombre .d-stat-n{color:#f1f5f9}
html.theme-sombre .d-card{background:#1e293b;border-color:rgba(255,255,255,.08)}
html.theme-sombre .d-card-hdr{border-bottom-color:rgba(255,255,255,.08)}
html.theme-sombre .d-card-hdr span{color:#f1f5f9}
html.theme-sombre .d-card-hdr button{color:#94a3b8}
html.theme-sombre .d-actu-title{color:#f1f5f9}
html.theme-sombre .d-actu-item{border-bottom-color:rgba(255,255,255,.06)}
html.theme-sombre .d-bus-item{border-bottom-color:rgba(255,255,255,.06)}
html.theme-sombre .d-bus-stop{color:#f1f5f9}
html.theme-sombre .d-bus-time{color:#f1f5f9;background:#374151}
html.theme-sombre .d-bus-empty,html.theme-sombre .d-empty{color:#94a3b8}
html.theme-sombre .d-agenda-info strong{color:#f1f5f9}
html.theme-sombre .d-agenda-info small{color:#94a3b8}
html.theme-sombre .d-agenda-day{color:#f1f5f9}
html.theme-sombre .d-agenda-item{border-bottom-color:rgba(255,255,255,.06)}
html.theme-sombre .d-horaires td{color:#f1f5f9}
html.theme-sombre .d-horaires td:first-child{color:#94a3b8}
html.theme-sombre .d-horaires tr:nth-child(even){background:rgba(255,255,255,.04)}
html.theme-sombre .d-horaires tr.d-hor-today{background:#2d3748}
html.theme-sombre .d-horaires tr.d-hor-today td{color:#f1f5f9}
html.theme-sombre .d-collecte-name{color:#f1f5f9}
html.theme-sombre .d-collecte-date{color:#f1f5f9}
html.theme-sombre .d-elu-name{color:#f1f5f9}
html.theme-sombre .d-elu-role{color:#94a3b8}
html.theme-sombre .d-mel-cta-panel{background:#1e293b;border-color:rgba(255,255,255,.08)}
html.theme-sombre .d-mel-hdr{background:#2d3748;border-bottom-color:rgba(255,255,255,.08)}
html.theme-sombre .d-mel-bubble{background:#374151;color:#f1f5f9}
html.theme-sombre .d-mel-name{color:#f1f5f9}
html.theme-sombre .d-mel-sub{color:#94a3b8}
html.theme-sombre .d-mel-online{color:#34d399}
html.theme-sombre .d-signal-grid button{background:#2d3748;color:#f1f5f9;border-color:rgba(255,255,255,.08)}
html.theme-sombre .d-mairie-actions a,html.theme-sombre .d-mairie-actions button{background:#2d3748;color:#f1f5f9;border-color:rgba(255,255,255,.08)}
html.theme-sombre .d-nav-acc{background:#2d3748;border-color:rgba(255,255,255,.08);color:#e2e8f0}
html.theme-sombre .d-nav-cta-app{background:#2d3748;color:#e2e8f0}
html.theme-sombre .d-featured-img{background:var(--forest)}
