/* === BREAKPOINTS: 480px (xs) | 640px (sm) | 768px (md) | 1024px (lg) | 1280px (xl) === */
/* === Z-INDEX LAYERS: 0-5 content | 20 carousel | 50 dropdown | 100 sticky-bar | 180 sidebar | 190 navbar | 200 header/bottom-nav | 400-460 map | 999 float-nav | 2000 share-panel | 9999 overlay | 10000 toast === */
/* === UTILITY === */
.hidden{display:none!important}
/* === TOKENS === */
:root {
  --vert:#038168;--cyan:#0096BB;--gradient:linear-gradient(135deg,#038168,#0096BB);
  /* Mode clair (Magazine) : contraste cards renforcé pour différenciation visuelle */
  --fond:#EEF1F4;--fond-alt:#E5EAEF;--fond-carte:#FFF;
  --texte:#1F2937;--texte-light:#6B7280;--support:#D5DCE3;--accent-chaud:#E8B866;
  --rub-fenetre:#17BEBB;--rub-infos:#F2A922;--rub-agenda:#7B2D8E;--rub-voix:#2E8B57;
  --rub-asso:#D4652F;--rub-revue:#5D6D7E;--rub-archives:#E8A87C;--rub-jeux:#C9A227;--rub-miam:#E67E22;
  --accent-miam:#6B9E7A;
  --font-titre:'Sora',sans-serif;--font-corps:'Source Serif 4',Georgia,serif;
  --font-ui:'DM Sans',sans-serif;--font-mono:'JetBrains Mono',monospace;--font-caveat:'Caveat',cursive;
  --radius-goutte:20px 4px 20px 4px;--radius-goutte-alt:4px 20px 4px 20px;
  --radius-sm:8px;--radius-md:12px;
  --shadow-sm:0 2px 8px rgba(3,129,104,.08);--shadow-md:0 4px 20px rgba(3,129,104,.12);--shadow-lg:0 8px 40px rgba(3,129,104,.16);
  --shadow-card:0 1px 3px rgba(31,41,55,.08),0 4px 12px rgba(31,41,55,.06);
  --transition:.3s cubic-bezier(.4,0,.2,1);--header-h:68px;--navbar-h:52px;
}
/* Box-shadow par défaut sur cards en mode clair (différenciation card vs fond) */
.card,.archive-card,.asso-card,.hp-card,.croise,.dirC-card{box-shadow:var(--shadow-card,none)}
[data-theme="dark"] .card,[data-theme="dark"] .archive-card,[data-theme="dark"] .asso-card,[data-theme="dark"] .hp-card,[data-theme="dark"] .croise,[data-theme="dark"] .dirC-card,[data-variation="2"] .card,[data-variation="2"] .archive-card,[data-variation="2"] .asso-card,[data-variation="2"] .hp-card,[data-variation="2"] .croise,[data-variation="2"] .dirC-card{box-shadow:none}
[data-theme="dark"]{--fond:#161B1F;--fond-alt:#1E2428;--fond-carte:#242A2E;--texte:#F3F4F6;--texte-light:#D9DEE3;--support:#374151;--shadow-sm:0 2px 8px rgba(0,150,187,.12);--shadow-md:0 4px 20px rgba(0,150,187,.18);--shadow-lg:0 8px 40px rgba(0,150,187,.22);--vert:#10B898;--cyan:#1ABFE0}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-corps);font-size:18px;line-height:1.7;color:var(--texte);background:var(--fond);overflow-x:hidden;transition:background .4s,color .4s}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit}
img{max-width:100%;height:auto;display:block}:focus-visible{outline:2px solid var(--vert);outline-offset:2px}
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.rv.vis{opacity:1;transform:translateY(0)}

/* === V2 NUIT DU BUGEY === */
[data-variation="2"]{--fond:#0F1419;--fond-alt:#151B21;--fond-carte:#1A2228;--texte:#E8ECF0;--texte-light:#CEDAE4;--support:#2A3744;--vert:#10B898;--cyan:#1ABFE0}
[data-variation="2"] body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(1px 1px at 10% 20%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 30% 70%,rgba(255,255,255,.3),transparent),radial-gradient(1.5px 1.5px at 55% 15%,rgba(0,150,187,.5),transparent),radial-gradient(1px 1px at 70% 45%,rgba(255,255,255,.35),transparent),radial-gradient(1px 1px at 85% 80%,rgba(3,129,104,.4),transparent),radial-gradient(1.5px 1.5px at 15% 55%,rgba(255,255,255,.25),transparent),radial-gradient(1px 1px at 40% 90%,rgba(0,150,187,.35),transparent),radial-gradient(1px 1px at 90% 25%,rgba(255,255,255,.3),transparent)}
[data-variation="2"] .section-fenetre{background:linear-gradient(180deg,#0F1419 0%,#0D1E1B 50%,#0F1419 100%)}
[data-variation="2"] .section-infos{background:linear-gradient(180deg,#0F1419 0%,#1A1710 50%,#0F1419 100%)}
[data-variation="2"] .section-voix{background:linear-gradient(180deg,#0F1419 0%,#0D1A14 50%,#0F1419 100%)}
[data-variation="2"] .section-asso{background:linear-gradient(180deg,#0F1419 0%,#1A150F 50%,#0F1419 100%)}
[data-variation="2"] .section-revue{background:linear-gradient(180deg,#0F1419 0%,#141719 50%,#0F1419 100%)}
[data-variation="2"] .section-archives{background:linear-gradient(180deg,#0F1419 0%,#1A1714 50%,#0F1419 100%)}
[data-variation="2"] .section-miam{background:linear-gradient(180deg,#0F1419 0%,#121A14 50%,#0F1419 100%)}
[data-variation="2"] .section-jeux{background:linear-gradient(180deg,#0F1419 0%,#1A1810 50%,#0F1419 100%)}
[data-variation="2"] .section-agenda{background:linear-gradient(180deg,#0F1419 0%,#14101C 50%,#0F1419 100%)}
[data-variation="2"] .section-articles{background:linear-gradient(180deg,#0F1419 0%,#140F1A 50%,#0F1419 100%)}
[data-variation="2"] .card{border-left:3px solid var(--card-rub-color,var(--support))}
[data-variation="2"] .card:hover{box-shadow:var(--shadow-md)}
[data-variation="2"] .header{background:rgba(15,20,25,.92);backdrop-filter:blur(12px);border-color:rgba(42,55,68,.6)}
[data-variation="2"] .navbar{background:rgba(15,20,25,.88);backdrop-filter:blur(10px);border-color:rgba(42,55,68,.5)}
[data-variation="2"] .sidebar-inner{background:rgba(26,34,40,.9);backdrop-filter:blur(10px);border-color:rgba(42,55,68,.5)}
[data-variation="2"] .bottom-nav{background:rgba(15,20,25,.95);backdrop-filter:blur(10px)}
[data-variation="2"] .logo-white{display:block!important}
[data-variation="2"] .logo-color{display:none!important}
[data-theme="dark"] .logo-white{display:block!important}
[data-theme="dark"] .logo-color{display:none!important}

/* === V3 MAGAZINE === */
[data-variation="3"] .section-fenetre{background:linear-gradient(180deg,#FAFBFA 0%,#F2FAF9 50%,#FAFBFA 100%)}
[data-variation="3"] .section-infos{background:linear-gradient(180deg,#FAFBFA 0%,#FDFAF3 50%,#FAFBFA 100%)}
[data-variation="3"] .section-voix{background:linear-gradient(180deg,#FAFBFA 0%,#F3FAF6 50%,#FAFBFA 100%)}
[data-variation="3"] .section-asso{background:linear-gradient(180deg,#FAFBFA 0%,#FDF7F4 50%,#FAFBFA 100%)}
[data-variation="3"] .section-revue{background:linear-gradient(180deg,#FAFBFA 0%,#F6F7F8 50%,#FAFBFA 100%)}
[data-variation="3"] .section-archives{background:linear-gradient(180deg,#FAFBFA 0%,#FDF9F6 50%,#FAFBFA 100%)}
[data-variation="3"] .section-miam{background:linear-gradient(180deg,#FAFBFA 0%,#F4FAF5 50%,#FAFBFA 100%)}
[data-variation="3"] .section-jeux{background:linear-gradient(180deg,#FAFBFA 0%,#FCFAF3 50%,#FAFBFA 100%)}
[data-variation="3"] .section-agenda{background:linear-gradient(180deg,#FAFBFA 0%,#F9F5FA 50%,#FAFBFA 100%)}
[data-variation="3"] .section-articles{background:linear-gradient(180deg,#FAFBFA 0%,#FAF5FB 50%,#FAFBFA 100%)}
[data-variation="3"] .card{border-left:3px solid var(--card-rub-color,var(--support))}

/* === HEADER === */
.header{position:sticky;top:0;z-index:200;background:var(--fond-carte);border-bottom:1px solid var(--support);transition:background .4s,border .4s}
.header-inner{max-width:1400px;margin:0 auto;height:var(--header-h);padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.logo-area{display:flex;align-items:center;gap:12px}
.logo-m{width:46px;height:46px;border-radius:var(--radius-goutte);display:flex;align-items:center;justify-content:center;transform:rotate(-4deg);transition:transform var(--transition);flex-shrink:0;overflow:hidden}
.logo-m:hover{transform:rotate(0deg) scale(1.06)}
.logo-m img{width:100%;height:100%;object-fit:contain}
.logo-color{display:block}.logo-white{display:none}
.logo-text h1{font-family:var(--font-titre);font-size:17px;font-weight:700;line-height:1.15;color:var(--vert)}
.logo-text span{display:block;font-size:clamp(13px,.95vw,16px);font-weight:500;color:var(--cyan)}
.header-actions{display:flex;align-items:center;gap:10px}
.theme-switch{width:52px;height:28px;background:var(--support);border-radius:14px;position:relative;transition:background .3s;flex-shrink:0}
.theme-switch::after{content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;background:var(--fond-carte);border-radius:50%;transition:transform .3s;box-shadow:0 1px 4px rgba(0,0,0,.15)}
[data-theme="dark"] .theme-switch{background:var(--vert)}
[data-theme="dark"] .theme-switch::after{transform:translateX(24px)}
.theme-switch-icons{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 6px;font-size:clamp(13px,.95vw,16px);pointer-events:none}
.btn-curieux{display:none;align-items:center;gap:7px;padding:12px 18px;background:var(--vert);color:#fff;font-family:var(--font-ui);font-size:14px;font-weight:600;border-radius:var(--radius-goutte);transition:all var(--transition)}
.btn-curieux:hover{background:#026d58;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-curieux svg{width:18px;height:18px;flex-shrink:0}
.btn-asso-h{display:none;align-items:center;gap:6px;padding:12px 16px;color:var(--rub-asso);border:1.5px solid var(--rub-asso);font-family:var(--font-ui);font-size:14px;font-weight:600;border-radius:var(--radius-goutte-alt);transition:all var(--transition)}
.btn-asso-h:hover{background:var(--rub-asso);color:#fff;transform:translateY(-1px)}
.btn-soutenir-h{display:none;align-items:center;gap:5px;padding:12px 16px;background:linear-gradient(135deg,var(--vert),var(--cyan));color:#fff;font-family:var(--font-ui);font-size:14px;font-weight:800;border-radius:var(--radius-goutte);transition:all var(--transition);box-shadow:0 2px 10px rgba(0,150,187,.35);text-decoration:none}
.btn-soutenir-h:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,150,187,.55)}
@media(min-width:768px){.btn-curieux,.btn-asso-h,.btn-soutenir-h{display:inline-flex}}

/* === NAVBAR === */
.navbar{position:sticky;top:var(--header-h);z-index:190;background:var(--fond-carte);border-bottom:1px solid var(--support);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}
.navbar.hidden{transform:translateY(-100%);pointer-events:none}
.navbar-inner{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:center;overflow:visible;scrollbar-width:none}
.navbar-inner::-webkit-scrollbar{display:none}
@media(max-width:1023px){.navbar-inner{overflow-x:auto;overflow-y:visible}}
.nav-rubs{display:flex;gap:4px;padding:10px 0}
.nav-r{font-family:var(--font-ui);font-size:17px;font-weight:500;padding:8px 14px;border-radius:var(--radius-goutte);color:var(--texte);transition:all var(--transition);white-space:nowrap;display:flex;align-items:center;gap:6px}
.nav-r:hover{background:var(--fond-alt)}.nav-r.active{background:var(--vert);color:#fff}
.nav-r.active .nd{background:#fff!important}
.nd{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* === NAV DROPDOWNS === */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{font-family:var(--font-ui);font-size:17px;font-weight:500;padding:8px 14px;border-radius:var(--radius-goutte);color:var(--texte);transition:all var(--transition);white-space:nowrap;display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer}
.nav-dropdown-toggle:hover{background:var(--fond-alt)}
.nav-dropdown.has-active .nav-dropdown-toggle{background:var(--vert);color:#fff}
.nav-dropdown.has-active .nav-dropdown-toggle .nd{background:#fff!important}
.nav-chevron{font-size:clamp(11px,.8vw,13px);opacity:.6;transition:transform .2s ease}
.nav-dropdown:hover .nav-chevron,.nav-dropdown.open .nav-chevron{transform:rotate(180deg)}
.nav-dropdown-menu{display:none;position:absolute;top:100%;left:0;padding-top:4px;z-index:9999;min-width:200px}
.nav-dropdown-menu-inner{background:var(--fond-carte);border:1px solid var(--support);border-radius:var(--radius-md);padding:6px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:2px}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown.open .nav-dropdown-menu{display:block}
.nav-dropdown-item{font-family:var(--font-ui);font-size:15px;font-weight:500;padding:8px 12px;border-radius:var(--radius-sm);color:var(--texte);transition:all var(--transition);white-space:nowrap;display:flex;align-items:center;gap:8px;text-decoration:none}
.nav-dropdown-item:hover{background:var(--fond-alt)}
.nav-dropdown-item.active{background:var(--vert);color:#fff}
.nav-dropdown-item.active .nd{background:#fff!important}
[data-variation="2"] .nav-dropdown-menu-inner{background:rgba(15,20,25,.95);backdrop-filter:blur(10px);border-color:rgba(42,55,68,.5)}

/* === SIDEBAR === */
.sidebar{position:fixed;left:20px;top:50%;transform:translateY(-50%);z-index:180;display:none}
@media(min-width:1280px){.sidebar{display:flex}}
.sidebar-inner{background:var(--fond-carte);border:1px solid var(--support);border-radius:var(--radius-md);padding:10px 6px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:6px}
.sb-link{width:44px;height:44px;border-radius:var(--radius-goutte);display:flex;align-items:center;justify-content:center;transition:all var(--transition);position:relative;font-size:18px}
.sb-link:hover{transform:scale(1.12)}
.sb-link:hover::after{content:attr(data-tip);position:absolute;left:56px;background:var(--texte);color:var(--fond);padding:5px 12px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);font-weight:500;white-space:nowrap;z-index:100;pointer-events:none;animation:tipIn .2s ease}
@keyframes tipIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
.sb-icon{width:32px;height:32px;border-radius:var(--radius-goutte);display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff}

/* === MAIN === */
.main{padding-bottom:80px;position:relative;z-index:1}
@media(min-width:1024px){.main{padding-bottom:0}}
/* Sidebar flottante retirée 2026-05-02 → margin-left:90px compensateur supprimé 2026-05-03 */
.container{max-width:1400px;margin:0 auto;padding:0 20px}
@media(min-width:1280px){.container{padding:0 40px}}
@media(min-width:1280px){
  .section[class*="section-"]{background:transparent!important}
  .section[class*="section-"]::after{content:'';position:absolute;top:0;bottom:0;left:-90px;right:0;z-index:-1}
  [data-variation="2"] .section-fenetre::after{background:linear-gradient(180deg,#0F1419 0%,#0D1E1B 50%,#0F1419 100%)}
  [data-variation="2"] .section-infos::after{background:linear-gradient(180deg,#0F1419 0%,#1A1710 50%,#0F1419 100%)}
  [data-variation="2"] .section-voix::after{background:linear-gradient(180deg,#0F1419 0%,#0D1A14 50%,#0F1419 100%)}
  [data-variation="2"] .section-asso::after{background:linear-gradient(180deg,#0F1419 0%,#1A150F 50%,#0F1419 100%)}
  [data-variation="2"] .section-revue::after{background:linear-gradient(180deg,#0F1419 0%,#141719 50%,#0F1419 100%)}
  [data-variation="2"] .section-archives::after{background:linear-gradient(180deg,#0F1419 0%,#1A1714 50%,#0F1419 100%)}
  [data-variation="2"] .section-miam::after{background:linear-gradient(180deg,#0F1419 0%,#121A14 50%,#0F1419 100%)}
  [data-variation="2"] .section-jeux::after{background:linear-gradient(180deg,#0F1419 0%,#1A1810 50%,#0F1419 100%)}
  [data-variation="2"] .section-agenda::after{background:linear-gradient(180deg,#0F1419 0%,#14101C 50%,#0F1419 100%)}
  [data-variation="2"] .section-articles::after{background:linear-gradient(180deg,#0F1419 0%,#140F1A 50%,#0F1419 100%)}
  [data-variation="3"] .section-fenetre::after{background:linear-gradient(180deg,#FAFBFA 0%,#F2FAF9 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-infos::after{background:linear-gradient(180deg,#FAFBFA 0%,#FDFAF3 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-voix::after{background:linear-gradient(180deg,#FAFBFA 0%,#F3FAF6 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-asso::after{background:linear-gradient(180deg,#FAFBFA 0%,#FDF7F4 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-revue::after{background:linear-gradient(180deg,#FAFBFA 0%,#F6F7F8 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-archives::after{background:linear-gradient(180deg,#FAFBFA 0%,#FDF9F6 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-miam::after{background:linear-gradient(180deg,#FAFBFA 0%,#F4FAF5 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-jeux::after{background:linear-gradient(180deg,#FAFBFA 0%,#FCFAF3 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-agenda::after{background:linear-gradient(180deg,#FAFBFA 0%,#F9F5FA 50%,#FAFBFA 100%)}
  [data-variation="3"] .section-articles::after{background:linear-gradient(180deg,#FAFBFA 0%,#FAF5FB 50%,#FAFBFA 100%)}
}

/* === BREADCRUMB === */
.breadcrumb{padding:16px 0;font-family:var(--font-ui);font-size:14px;color:var(--texte-light)}
.breadcrumb a{color:var(--vert);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb .sep{margin:0 8px;opacity:.5}

/* === PAGE TITLE + PAGE BASELINE — canonical in components.css === */

/* === HERO === */
.hero{padding:48px 0 0;text-align:center;position:relative}
.hero-title h2{font-family:var(--font-titre);font-size:clamp(1.9rem,4.5vw,3rem);font-weight:800;line-height:1.15;margin-bottom:14px;letter-spacing:-.02em}
.hero-title .vt{color:var(--vert)}.hero-title .cy{color:var(--cyan)}
.hero-title p{font-size:17px;color:var(--texte-light);max-width:700px;margin:0 auto 28px}

/* Homepage map full-width (compensateurs -90px obsolètes depuis 03/05) */
.homepage-map-fw{position:relative;width:100%;margin-left:0}
.homepage-map-fw #homepage-map{height:50vh;min-height:400px;background:var(--fond-alt)}
.homepage-map-bar{position:relative;padding:18px 24px;background:linear-gradient(135deg,rgba(3,129,104,.92),rgba(0,150,187,.88));display:flex;align-items:center;justify-content:space-between;z-index:400;flex-wrap:wrap;gap:12px;border-radius:0 0 12px 12px}
.btn-explorer{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:#fff;color:#038168;font-family:var(--font-ui);font-size:15px;font-weight:700;text-decoration:none;border-radius:20px 4px 20px 4px;box-shadow:0 4px 20px rgba(0,0,0,.25);transition:transform .2s,box-shadow .2s}
.btn-explorer:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 6px 28px rgba(0,0,0,.35)}
.btn-explorer .arrow-icon{width:20px;height:20px;flex-shrink:0}
@media(max-width:768px){.btn-explorer{font-size:13px;padding:12px 20px}}
/* Homepage map tabs */
.hm-tabs{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--fond-alt);border-bottom:1px solid var(--support);overflow-x:auto;scrollbar-width:none;z-index:400}
.hm-tabs::-webkit-scrollbar{display:none}
.hm-tab{padding:7px 16px;border-radius:20px;font-family:var(--font-ui);font-size:14px;font-weight:500;border:2px solid transparent;background:transparent;color:var(--texte);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s;white-space:nowrap}
.hm-tab:hover{background:var(--fond-carte)}
.hm-tab.active{background:var(--vert);color:#fff}
.hm-tab-count{background:rgba(0,0,0,.1);padding:1px 7px;border-radius:10px;font-size:clamp(13px,.95vw,16px)}
.hm-tab.active .hm-tab-count{background:rgba(255,255,255,.3)}
.hm-tabs-sep{width:1px;height:20px;background:var(--support);flex-shrink:0;margin:0 4px}
.hm-chip{padding:4px 10px;border-radius:12px;font-family:var(--font-ui);font-size:13px;font-weight:500;border:1.5px solid var(--support);background:transparent;color:var(--texte-light);cursor:pointer;transition:all .2s;white-space:nowrap}
.hm-chip:hover{border-color:var(--vert);color:var(--vert)}
.hm-chip.active{background:var(--cyan);color:#fff;border-color:var(--cyan)}

/* === SECTIONS === */
.section{padding:56px 0;position:relative;transition:background .4s}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:16px}
.section-title{font-family:var(--font-titre);font-size:24px;font-weight:700;display:flex;align-items:center;gap:10px}
.section-dot{width:12px;height:12px;border-radius:var(--radius-goutte);flex-shrink:0}
.section-link{font-family:var(--font-ui);font-size:15px;font-weight:600;color:var(--cyan);display:flex;align-items:center;gap:5px;transition:color var(--transition)}
.section-link:hover{color:var(--vert)}
.arrow-icon{width:14px;height:14px}
.section-subtitle{font-family:var(--font-titre);font-size:16px;font-weight:600;color:var(--texte-light);margin-bottom:20px;display:flex;align-items:center;gap:8px}

/* === GRIDS === */
.articles-grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1fr}
@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}}
.grid-3{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:768px){.grid-4{grid-template-columns:repeat(4,1fr)}}
.grid-6{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:640px){.grid-6{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.grid-6{grid-template-columns:repeat(6,1fr)}}

/* === SUB-TYPE FILTER PILLS === */
.hm-type-pills{display:flex;gap:6px;padding:6px 16px 10px;overflow-x:auto;scrollbar-width:none;background:var(--fond-alt);border-bottom:1px solid var(--support);flex-wrap:wrap}
.hm-type-pills::-webkit-scrollbar{display:none}
.hm-type-pill{padding:4px 12px;border-radius:var(--radius-goutte-alt);font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:500;text-transform:uppercase;letter-spacing:.04em;border:1.5px solid var(--support);background:transparent;color:var(--texte-light);cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.hm-type-pill:hover{border-color:var(--rub-agenda);color:var(--rub-agenda)}
.hm-type-pill.active{background:var(--rub-agenda);color:#fff;border-color:var(--rub-agenda)}
.hm-type-pill .tp-icon{font-style:normal;font-size:clamp(13px,.95vw,16px)}

/* === MAP SIDEBAR (left column filters) === */
.map-with-sidebar{position:relative}
.map-sidebar{position:absolute;top:0;left:0;bottom:0;width:220px;z-index:450;background:var(--fond-carte);border-right:1px solid var(--support);overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:5px;scrollbar-width:thin}
[data-variation="2"] .map-sidebar{background:rgba(26,34,40,.94);backdrop-filter:blur(10px)}
[data-variation="3"] .map-sidebar{background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}
.map-sidebar::-webkit-scrollbar{width:4px}.map-sidebar::-webkit-scrollbar-thumb{background:var(--support);border-radius:4px}
.map-sidebar-title{font-family:var(--font-titre);font-size:13px;font-weight:700;color:var(--texte-light);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;padding-bottom:8px;border-bottom:1px solid var(--support);display:flex;align-items:center;gap:6px}
.map-sidebar .hm-type-pill{width:100%;justify-content:flex-start;padding:6px 10px;font-size:clamp(13px,.95vw,16px)}
.map-sidebar-toggle{display:none;position:absolute;top:8px;left:8px;z-index:460;width:36px;height:36px;border-radius:var(--radius-goutte);background:var(--fond-carte);border:1px solid var(--support);color:var(--texte);align-items:center;justify-content:center;box-shadow:var(--shadow-sm);font-size:16px}
@media(max-width:767px){
  .map-sidebar{display:none;width:180px}
  .map-sidebar.open{display:flex}
  .map-sidebar-toggle{display:flex}
}

/* === AGENDA 2 COLONNES === */
.agenda-2col{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.agenda-2col{grid-template-columns:1fr 1fr}}
.cal-visual{background:var(--fond-carte);border:1px solid var(--support);border-radius:var(--radius-md);padding:20px}
.cal-visual-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-visual-month{font-family:var(--font-titre);font-size:18px;font-weight:700;color:#7B2D8E}
.cal-visual-nav{display:flex;gap:6px}
.cal-visual-nav button{width:32px;height:32px;border-radius:var(--radius-goutte-alt);background:var(--fond-alt);color:var(--texte);display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}
.cal-visual-nav button:hover{background:#7B2D8E;color:#fff}
.cal-visual-nav svg{width:16px;height:16px}
.cal-grid-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-grid-day-label{font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--texte-light);text-align:center;padding:6px 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-grid-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:14px;font-weight:500;border-radius:var(--radius-sm);color:var(--texte-light);transition:background var(--transition),color var(--transition);position:relative;cursor:default}
.cal-grid-cell.has-event{color:var(--texte);font-weight:700;cursor:pointer}
.cal-grid-cell.has-event::after{content:'';position:absolute;bottom:4px;width:5px;height:5px;border-radius:50%;background:#7B2D8E}
.cal-grid-cell.has-event:hover{background:rgba(123,45,142,.12)}
.cal-grid-cell.today{background:rgba(123,45,142,.15);color:#7B2D8E;font-weight:800}
.cal-grid-cell.empty{visibility:hidden}
.cal-month{background:var(--fond-carte);border:1px solid var(--support);border-radius:var(--radius-md);padding:24px;margin-top:8px}
.cal-week-title{font-family:var(--font-titre);font-size:16px;font-weight:700;color:#7B2D8E;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.cal-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--support);align-items:flex-start}
.cal-item:last-child{border-bottom:none;padding-bottom:0}
.cal-date{flex-shrink:0;width:52px;text-align:center;background:var(--fond-alt);border-radius:var(--radius-sm);padding:8px 6px}
.cal-date-day{display:block;font-family:var(--font-titre);font-size:24px;font-weight:800;color:#7B2D8E;line-height:1}
.cal-date-dow{display:block;font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--texte-light);margin-top:2px}
.cal-info{flex:1;min-width:0}
.cal-info-title{font-family:var(--font-ui);font-size:15px;font-weight:600;margin-bottom:4px}
.cal-info-loc{font-family:var(--font-ui);font-size:14px;color:var(--texte-light);display:flex;align-items:center;gap:4px;margin-bottom:6px}
.cal-info-loc svg{width:13px;height:13px;color:#7B2D8E;flex-shrink:0}
.cal-tags{display:flex;gap:6px;flex-wrap:wrap}
.cal-tag{font-family:var(--font-mono);font-size:clamp(11px,.8vw,13px);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#7B2D8E;padding:3px 8px;background:rgba(123,45,142,.08);border-radius:var(--radius-goutte-alt)}

/* === ART-CARD ("Sur la carte") === */
.art-card{background:var(--fond-carte);border:1px solid var(--support);border-left:3px solid transparent;border-radius:var(--radius-goutte);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}
.art-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-left-color:var(--card-rub-color)}
.art-card-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--fond-alt)}
.art-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.art-card:hover .art-card-img img{transform:scale(1.06)}
.art-card-img::before{content:'';position:absolute;inset:6px;border:1.5px solid var(--card-rub-color,rgba(255,255,255,.5));border-radius:3px;z-index:3;pointer-events:none;clip-path:polygon(0 0,14px 0,14px 1.5px,1.5px 1.5px,1.5px 14px,0 14px,0 100%,0 calc(100% - 14px),1.5px calc(100% - 14px),1.5px calc(100% - 1.5px),14px calc(100% - 1.5px),14px 100%,100% 100%,calc(100% - 14px) 100%,calc(100% - 14px) calc(100% - 1.5px),calc(100% - 1.5px) calc(100% - 1.5px),calc(100% - 1.5px) calc(100% - 14px),100% calc(100% - 14px),100% 0,100% 14px,calc(100% - 1.5px) 14px,calc(100% - 1.5px) 1.5px,calc(100% - 14px) 1.5px,calc(100% - 14px) 0)}
.art-card-img::after{content:'Lire \2192';position:absolute;bottom:10px;right:10px;padding:5px 12px;background:var(--vert);color:#fff;font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);font-weight:600;border-radius:var(--radius-goutte);opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s;z-index:5}
.art-card:hover .art-card-img::after{opacity:1;transform:translateY(0)}
.art-card-rub-badge{position:absolute;top:8px;left:8px;padding:4px 10px;color:#fff;font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-goutte);z-index:5}
.art-card-body{padding:14px}
.art-card-tag{font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:block}
.art-card-title{font-family:var(--font-titre);font-size:18px;font-weight:600;line-height:1.35;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-card-loc{font-family:var(--font-ui);font-size:13px;color:var(--texte-light);display:flex;align-items:center;gap:4px}
.art-card-loc svg{width:12px;height:12px;flex-shrink:0}

/* === SUB-PILL (CartoMedia page override) — canonical base in components.css === */
.carto-fw .sub-pill{border-radius:20px;border:2px solid transparent;background:transparent;color:var(--texte)}
.carto-fw .sub-pill:hover{background:var(--fond-carte)}
.carto-fw .sub-pill.active{background:var(--rub-agenda);color:#fff}
.sub-pill-count{background:rgba(0,0,0,.1);padding:1px 7px;border-radius:10px;font-size:clamp(13px,.95vw,16px)}
.sub-pill.active .sub-pill-count{background:rgba(255,255,255,.3)}

/* === FULL-WIDTH CARTOMEDIA SECTION === */
.carto-fw{position:relative;width:100vw;margin-left:calc(-50vw + 50%)}
.carto-fw #cartomedia-map{height:60vh;min-height:500px;background:var(--fond-alt)}
/* CartoMedia page — map wrapper (in container, not full-width) */
.carto-map-wrap{margin-top:24px}
/* CartoMedia page — tabs */
.carto-tabs{display:flex;gap:8px;margin:24px 0 20px;flex-wrap:wrap}
.carto-tab{padding:10px 22px;border-radius:20px 4px 20px 4px;font-family:var(--font-ui);font-size:14px;font-weight:600;border:2px solid var(--support);background:transparent;color:var(--texte);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s,color .2s,border-color .2s}
.carto-tab[data-tab="evenements"]:hover{border-color:#7B2D8E;color:#7B2D8E}
.carto-tab[data-tab="evenements"].active{background:#7B2D8E;color:#fff;border-color:#7B2D8E}
.carto-tab[data-tab="sites"]:hover{border-color:#038168;color:#038168}
.carto-tab[data-tab="sites"].active{background:#038168;color:#fff;border-color:#038168}
.carto-tab-count{background:rgba(0,0,0,.12);padding:2px 8px;border-radius:10px;font-size:clamp(13px,.95vw,16px);font-weight:500}
.carto-tab.active .carto-tab-count{background:rgba(255,255,255,.25)}
/* CartoMedia page — grid */
.carto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:32px}
.carto-loading{grid-column:1/-1;padding:40px;text-align:center;color:var(--texte-light);font-family:var(--font-ui);font-size:14px}
/* Site cards — flip */
.site-card{perspective:900px;height:300px;cursor:pointer;border-radius:var(--radius-goutte);overflow:visible}
.site-card-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.site-card.flipped .site-card-inner{transform:rotateY(180deg)}
.site-card-front,.site-card-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-goutte);overflow:hidden;background:var(--fond-carte);border:1px solid var(--support)}
.site-card-back{transform:rotateY(180deg);display:flex;flex-direction:column;padding:20px}
/* Front */
.site-card-img{height:155px;background:var(--fond-alt);overflow:hidden}
.site-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.site-card-front:hover .site-card-img img{transform:scale(1.06)}
.site-card-body{padding:14px}
.site-card-title{font-family:var(--font-titre);font-size:16px;font-weight:600;line-height:1.35;margin-bottom:5px;color:var(--texte)}
.site-card-loc{font-family:var(--font-ui);font-size:13px;color:var(--texte-light);display:flex;align-items:center;gap:4px;margin-bottom:6px}
.site-card-loc svg{flex-shrink:0;stroke:var(--texte-light)}
.site-card-flip-hint{position:absolute;bottom:10px;right:12px;font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);color:var(--texte-light);opacity:.6;display:flex;align-items:center;gap:4px}
/* Back */
.site-card-back-title{font-family:var(--font-titre);font-size:14px;font-weight:700;color:var(--texte);margin-bottom:8px;line-height:1.3}
.site-card-back-desc{font-family:var(--font-ui);font-size:14px;color:var(--texte-light);line-height:1.55;flex:1;overflow-y:auto;margin-bottom:10px}
.site-card-back-info{font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);color:var(--texte-light);display:flex;flex-wrap:wrap;gap:6px 12px;margin-bottom:12px}
.site-card-back-info svg{flex-shrink:0;stroke:var(--texte-light)}
.site-card-back-info span{display:inline-flex;align-items:center;gap:4px}
.site-card-go{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:14px;font-weight:600;color:#fff;background:#038168;border-radius:var(--radius-goutte);padding:10px 18px;text-decoration:none;transition:background .2s;align-self:flex-start}
.site-card-go:hover{background:#026b56}
.site-card-back-close{position:absolute;top:10px;right:12px;font-size:clamp(13px,.95vw,16px);color:var(--texte-light);opacity:.6}
.site-card-desc{font-family:var(--font-ui);font-size:14px;color:var(--texte-light);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:6px}
.site-type-badge,.ev-type-badge{display:inline-block;padding:3px 10px;border-radius:4px 12px 4px 12px;font-family:var(--font-mono);font-size:clamp(11px,.8vw,13px);font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:rgba(123,45,142,.12);color:#7B2D8E;margin-top:4px}
.carto-empty{color:var(--texte-light);font-family:var(--font-ui);font-size:14px;padding:24px}
/* ── Agenda 2-col layout ── */
.agenda-2col{display:grid;grid-template-columns:340px 1fr;gap:28px;margin-bottom:32px;align-items:start}
@media(max-width:900px){.agenda-2col{grid-template-columns:1fr;gap:24px}}
.agenda-col-cal,.agenda-col-list{min-width:0}
.agenda-col-list .ev-list-wrap{max-height:none;height:100%;min-height:400px}
/* ── Calendar widget (CartoMedia agenda-2col override) ── */
.agenda-col-cal .cal-visual{border-radius:12px;margin-bottom:20px}
.agenda-col-cal .cal-visual-month{color:var(--texte)}
.agenda-col-cal .cal-visual-nav button{border:1px solid var(--support);border-radius:8px;background:transparent;cursor:pointer}
.agenda-col-cal .cal-visual-nav button:hover{background:var(--fond-alt)}
.agenda-col-cal .cal-visual-nav svg{stroke:var(--texte)}
.cal-grid-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.cal-grid-day-label{text-align:center;font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:600;text-transform:uppercase;color:var(--texte-light);padding:4px 0;letter-spacing:.05em}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-cell{position:relative;text-align:center;padding:8px 4px;font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--texte);border-radius:8px;cursor:default;transition:background .15s}
.cal-empty{visibility:hidden}
.cal-has-event{cursor:pointer;font-weight:700;color:#7B2D8E}
.cal-has-event:hover{background:rgba(123,45,142,.1)}
.cal-today{background:var(--fond-alt);font-weight:700}
.cal-selected{background:rgba(123,45,142,.18)!important}
.cal-dot{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);min-width:14px;height:14px;border-radius:7px;background:#7B2D8E;color:#fff;font-size:clamp(11px,.8vw,13px);font-weight:700;font-family:var(--font-mono);line-height:14px;text-align:center;padding:0 3px}
/* ── Calendar events list ── */
.cal-events-list{max-height:400px;overflow-y:auto}
.cal-day-title{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--texte);padding:12px 0 8px;border-bottom:1px solid var(--support);margin-bottom:12px}
/* ── Horizontal event card (calendar list) ── */
.ev-card-h{display:flex;gap:14px;padding:12px;background:var(--fond-carte);border:1px solid var(--support);border-radius:12px;margin-bottom:10px;transition:border-color .2s}
.ev-card-h:hover{border-color:#7B2D8E}
.ev-card-h-body{flex:1;min-width:0}
.ev-card-h .ev-title{font-family:var(--font-titre);font-size:14px;font-weight:600;line-height:1.35;margin-bottom:4px;color:var(--texte)}
.ev-card-h .ev-loc{font-family:var(--font-ui);font-size:13px;color:var(--texte-light);display:flex;align-items:center;gap:4px;margin-bottom:4px}
.ev-card-h .ev-loc svg{flex-shrink:0;stroke:var(--texte-light)}
.ev-prix{font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);color:var(--texte-light);margin-left:8px}
.ev-desc{font-family:var(--font-ui);font-size:13px;color:var(--texte-light);line-height:1.4;margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ev-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
/* ── Event list (chrono) ── */
.ev-list-wrap{max-height:620px;overflow-y:auto;background:var(--fond-carte);border:1px solid var(--support);border-radius:12px;padding:16px}
.ev-list-header{font-family:var(--font-ui);font-size:14px;font-weight:600;color:#7B2D8E;padding-bottom:12px;margin-bottom:12px;border-bottom:2px solid rgba(123,45,142,.15);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ev-list-clear{font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);font-weight:600;color:#7B2D8E;background:rgba(123,45,142,.1);border:none;border-radius:12px;padding:3px 12px;cursor:pointer;transition:background .2s}
.ev-list-clear:hover{background:rgba(123,45,142,.2)}
/* Event row */
.ev-row{display:flex;align-items:flex-start;gap:14px;padding:10px 0;border-bottom:1px solid var(--support);transition:background .15s}
.ev-row:last-child{border-bottom:none}
.ev-row:hover{background:var(--fond-alt);border-radius:8px;margin:0 -8px;padding-left:8px;padding-right:8px}
.ev-row-date{flex-shrink:0;width:44px;text-align:center;background:rgba(123,45,142,.08);border-radius:8px;padding:6px 4px}
.ev-row-day{display:block;font-family:var(--font-titre);font-size:20px;font-weight:800;color:#7B2D8E;line-height:1.1}
.ev-row-mon{display:block;font-family:var(--font-mono);font-size:clamp(13px,.95vw,16px);font-weight:600;color:#7B2D8E;text-transform:uppercase;letter-spacing:.04em}
.ev-row-body{flex:1;min-width:0}
.ev-row-title{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--texte);line-height:1.35;margin-bottom:3px}
.ev-row-meta{font-family:var(--font-ui);font-size:13px;color:var(--texte-light);display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.ev-row-meta svg{flex-shrink:0;stroke:var(--texte-light)}
.ev-row .ev-type-badge{flex-shrink:0;font-size:clamp(11px,.8vw,13px);align-self:center}
.ev-row-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center;align-self:center}
.ev-row{cursor:pointer}
.ev-row.ev-row-active{background:rgba(123,45,142,.06);border-radius:8px;margin:0 -8px;padding-left:8px;padding-right:8px;border-color:rgba(123,45,142,.2)}
/* ── Event detail panel ── */
.ev-detail{background:var(--fond-carte);border:1px solid rgba(123,45,142,.2);border-radius:12px;padding:20px;animation:slideDown .25s ease}
.ev-detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.ev-detail-icon{font-size:28px;margin-right:12px}
.ev-detail-title{font-family:var(--font-titre);font-size:17px;font-weight:700;color:var(--texte);line-height:1.35;flex:1}
.ev-detail-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--support);background:transparent;cursor:pointer;font-size:14px;color:var(--texte-light);transition:background .2s;flex-shrink:0;margin-left:8px}
.ev-detail-close:hover{background:var(--fond-alt)}
.ev-detail-desc{font-family:var(--font-ui);font-size:14px;color:var(--texte-light);line-height:1.6;margin-bottom:14px}
.ev-detail-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-family:var(--font-ui);font-size:13px;color:var(--texte-light);margin-bottom:14px}
.ev-detail-meta span{display:inline-flex;align-items:center;gap:5px}
.ev-detail-meta svg{flex-shrink:0;stroke:var(--texte-light)}
.ev-detail-actions{display:flex;gap:10px;flex-wrap:wrap}
.ev-detail-go{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:14px;font-weight:600;color:#fff;background:#7B2D8E;border-radius:var(--radius-goutte);padding:8px 18px;text-decoration:none;transition:background .2s}
.ev-detail-go:hover{background:#6a2479}
/* ── Sites toolbar ── */
.sites-toolbar-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.sites-search-wrap{flex:1;min-width:200px;max-width:360px;position:relative;display:flex;align-items:center;background:var(--fond-carte);border:1px solid var(--support);border-radius:var(--radius-goutte);padding:0 14px;transition:border-color .2s}
.sites-search-wrap:focus-within{border-color:#038168}
.sites-search-wrap svg{flex-shrink:0;stroke:var(--texte-light)}
.sites-search-wrap input{border:none;background:none;font-family:var(--font-ui);font-size:16px;color:var(--texte);padding:10px 10px;width:100%;outline:none}
.sites-search-wrap input::placeholder{color:var(--texte-light)}
.sites-view-toggle{display:flex;gap:4px;background:var(--fond-alt);border-radius:8px;padding:3px}
.sites-view-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s,color .2s}
.sites-view-btn svg{stroke:var(--texte-light)}
.sites-view-btn.active{background:var(--fond-carte);box-shadow:var(--shadow-sm)}
.sites-view-btn.active svg{stroke:#038168}
.sites-count{font-family:var(--font-mono);font-size:13px;color:var(--texte-light);margin-left:auto}
/* ── Theme filter pills ── */
.sites-themes{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.site-theme-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:20px;font-family:var(--font-ui);font-size:14px;font-weight:500;border:1.5px solid var(--support);background:transparent;color:var(--texte);cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.site-theme-pill:hover{border-color:var(--pill-color,#038168);color:var(--pill-color,#038168)}
.site-theme-pill.active{background:var(--pill-color,#038168);color:#fff;border-color:var(--pill-color,#038168)}
.site-theme-count{font-size:clamp(13px,.95vw,16px);background:rgba(0,0,0,.08);padding:1px 7px;border-radius:10px}
.site-theme-pill.active .site-theme-count{background:rgba(255,255,255,.25)}
/* ── Sous-type sub-filters ── */
.sites-sous-themes{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;padding-left:4px;animation:slideDown .25s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.site-sous-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:14px;font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);font-weight:500;border:1px solid var(--support);background:transparent;color:var(--texte-light);cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.site-sous-pill:hover{border-color:var(--pill-color,#038168);color:var(--pill-color,#038168)}
.site-sous-pill.active{background:var(--pill-color,#038168);color:#fff;border-color:var(--pill-color,#038168)}
.site-sous-pill .site-theme-count{font-size:clamp(11px,.8vw,13px);background:rgba(0,0,0,.06);padding:0 6px;border-radius:8px}
.site-sous-pill.active .site-theme-count{background:rgba(255,255,255,.25)}
/* ── Sites grid ── */
.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-bottom:20px}
.site-card-img-empty{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--fond-alt) 40%,var(--support))}
.site-card-placeholder{font-size:42px;opacity:.7;filter:grayscale(.15)}
/* ── Sites compact list ── */
.sites-list-compact{display:flex;flex-direction:column;gap:2px}
.site-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;transition:background .15s}
.site-row:hover{background:var(--fond-alt)}
.site-row-icon{font-size:18px;width:28px;text-align:center;flex-shrink:0}
.site-row-body{flex:1;min-width:0;display:flex;align-items:baseline;gap:8px}
.site-row-name{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--texte);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.site-row-commune{font-family:var(--font-ui);font-size:clamp(13px,.95vw,16px);color:var(--texte-light);white-space:nowrap}
.site-row .site-type-badge{flex-shrink:0;font-size:clamp(11px,.8vw,13px)}
/* ── Load more button ── */
.btn-load-more{font-family:var(--font-ui);font-size:14px;font-weight:600;color:#038168;background:rgba(3,129,104,.08);border:1.5px solid rgba(3,129,104,.2);border-radius:var(--radius-goutte);padding:12px 28px;cursor:pointer;transition:background .2s,border-color .2s}
.btn-load-more:hover{background:rgba(3,129,104,.15);border-color:#038168}
/* ── Recits section ── */
.section-recits .section-dot{background:#E8A87C!important}
.recits-baseline{color:var(--texte-light);font-family:var(--font-ui);font-size:14px;margin-bottom:20px}
