﻿/* Dashboard vulnerabilites public — styles (extracted from inline) */

:root{--bg:#eef5f3;--surface:#fff;--soft:#f7fbfa;--tint:#edf7f5;--ink:#172126;--muted:#63757a;--line:#dce9e5;--teal:#39c1bc;--teal2:#1fa7a2;--shadow:0 14px 34px rgba(22,34,38,.08);--blue:#2f7ea1;--green:#9fca74;--yellow:#e8d783;--orange:#de8d4a;--red:#c8524c;--darkred:#8e2f3e;--grey:#a6b0b4}
*{box-sizing:border-box} body{margin:0;background:linear-gradient(180deg,#edf6f5,#f8fbfa);color:var(--ink);font-family:Inter,Arial,sans-serif} button,input,select{font:inherit} h1,h2,h3,p{margin:0} p{color:var(--muted);line-height:1.48} .app{padding:18px 22px 26px;display:grid;gap:14px}
.hero{background:var(--surface);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:18px 22px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center} h1{font-size:30px;letter-spacing:-.04em;line-height:1.05;margin-bottom:6px} .hero p{max-width:1050px;font-size:13px} .kpis{display:grid;grid-template-columns:repeat(3,112px);gap:8px} .kpi{border:1px solid #d8e9e5;background:#f4faf8;border-radius:18px;padding:11px} .kpi strong{display:block;font-size:24px;letter-spacing:-.04em} .kpi span{font-size:11px;color:var(--muted)}
.bailleur-strip{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:12px;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:10px;position:sticky;top:8px;z-index:900;backdrop-filter:blur(8px)} .btile{border:1px solid #dbe8e4;background:linear-gradient(180deg,#fff,#f6faf8);border-radius:18px;padding:9px;cursor:default;min-height:120px;transition:.18s;display:flex;flex-direction:column;gap:7px;box-shadow:none} .btile:hover{transform:none;box-shadow:none} .btile.active,.btile.collectif{background:linear-gradient(180deg,#eaf8f6,#fff);border-color:#8edbd7;box-shadow:none} .btile.dim,.btile.muted{filter:grayscale(1);opacity:.48} .blogo{height:52px;border-radius:12px;border:1px solid #e2eeeb;background:#fff;display:flex;align-items:center;justify-content:center;padding:5px;overflow:hidden} .blogo img{max-width:100%;max-height:100%;object-fit:contain} .fallback-logo{font-weight:900;color:#24524f;font-size:15px} .bname{font-size:11px;font-weight:900;line-height:1.15;color:#27383c;min-height:24px} .bstat{display:flex;justify-content:space-between;gap:6px;border-top:1px solid #e5efec;padding-top:6px;margin-top:auto;align-items:flex-end} .bstat strong{font-size:20px;letter-spacing:-.04em} .bstat span{font-size:10px;color:var(--muted);text-align:right;line-height:1.1}
.main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(360px,1fr);gap:14px;align-items:stretch} .map-card,.side-card{background:var(--surface);border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);overflow:hidden} .map-card{position:relative;min-height:675px;height:100%;display:flex;flex-direction:column} #map{flex:1 1 auto;min-height:675px;height:100%;width:100%;background:#e9f0ee} .map-filters{position:absolute;top:14px;left:14px;z-index:650;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:22px;box-shadow:0 14px 32px rgba(22,34,38,.15);padding:11px;width:min(292px,calc(100% - 28px));backdrop-filter:blur(7px);display:grid;gap:6px} .filter-title{font-weight:900;font-size:12px;display:flex;justify-content:space-between;gap:8px;align-items:center}.filter-line{display:grid;grid-template-columns:1fr;gap:4px;align-items:stretch}.filter-label{font-size:10.5px;font-weight:900;color:#285653;line-height:1}.search-line{position:relative}.search-line input{width:100%;padding-left:34px}.search-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);z-index:1;color:#557176;font-weight:900}.frow{display:grid;grid-template-columns:1fr 1fr;gap:7px} select,input{border:1px solid #d7e8e4;border-radius:999px;padding:8px 10px;background:#fff;color:#244b48;font-weight:750;font-size:12px;min-width:0}.checks{display:flex;gap:6px;flex-wrap:wrap}.geo-shortcuts{display:grid;grid-template-columns:1fr 1fr;gap:6px}.chip{border:1px solid #d6e8e4;border-radius:999px;background:#fff;color:#285653;font-weight:850;padding:7px 8px;cursor:pointer;font-size:12px;line-height:1.08;text-align:center}.chip.active{background:linear-gradient(180deg,var(--teal),var(--teal2));color:white;border-color:transparent}.reset{border:0;background:#eaf4f1;color:#285653;border-radius:999px;padding:7px 9px;font-weight:900;font-size:12px;cursor:pointer}.multi{position:relative;min-width:0}.multi-btn{width:100%;border:1px solid #d7e8e4;border-radius:999px;padding:8px 28px 8px 10px;background:#fff;color:#244b48;font-weight:850;font-size:12px;min-width:0;text-align:left;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}.multi-btn::after{content:"⌄";position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#557176;font-weight:900}.multi.open .multi-btn{border-color:#64cfc8;box-shadow:0 0 0 3px rgba(57,193,188,.13)}.multi-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 5px);background:#fff;border:1px solid #d7e8e4;border-radius:16px;box-shadow:0 16px 34px rgba(22,34,38,.18);padding:8px;z-index:900;max-height:260px;overflow:auto}.multi.open .multi-menu{display:grid;gap:4px}.multi-options{display:grid;gap:4px;max-height:190px;overflow:auto;padding-right:2px}.multi-actions{position:sticky;bottom:-8px;background:#fff;border-top:1px solid #e1efec;margin:4px -8px -8px;padding:8px;display:flex;gap:6px;justify-content:flex-end;border-radius:0 0 16px 16px}.multi-action{border:1px solid #d7e8e4;border-radius:999px;background:#fff;color:#285653;font-size:11px;font-weight:900;padding:7px 9px;cursor:pointer}.multi-action.primary{background:linear-gradient(180deg,var(--teal),var(--teal2));color:#fff;border-color:transparent}.multi-option{display:grid;grid-template-columns:18px minmax(0,1fr);gap:6px;align-items:center;border-radius:10px;padding:5px 6px;font-size:12px;font-weight:750;color:#244b48;cursor:pointer}.multi-option:hover{background:#eef8f6}.multi-option input{width:14px;height:14px;accent-color:var(--teal);padding:0}.multi-empty{font-size:12px;color:var(--muted);padding:7px}.map-note{font-size:10.5px;color:#557176;line-height:1.28;background:#eef8f6;border:1px solid #d5ebe8;border-radius:14px;padding:7px}
.side-card{padding:16px;display:flex;flex-direction:column;gap:14px} .side-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px} .side-head h2{font-size:21px;letter-spacing:-.03em} .side-head p{font-size:12px;margin-top:4px} .control-block{border:1px solid #e0ece8;background:#f8fbfa;border-radius:20px;padding:12px;display:grid;gap:10px} .control-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:#5b6f75} .horizon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px} .metric-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px} .metric-kpi{border:1px solid #d7e8e4;background:#f5fbf9;border-radius:16px;padding:10px} .metric-kpi strong{display:block;font-size:21px;letter-spacing:-.04em} .metric-kpi span{display:block;color:var(--muted);font-size:10px;line-height:1.18}
.bar-list{display:grid;gap:8px} .bar-tools{display:flex;justify-content:flex-end}.bar-all{border:1px solid #d6e8e4;border-radius:999px;background:#fff;color:#285653;font-size:11px;font-weight:900;padding:7px 10px;cursor:pointer}.bar-all:hover{border-color:#64cfc8}.bar-row{border:0;width:100%;display:grid;grid-template-columns:92px 1fr 64px;gap:8px;align-items:center;font-size:12px;background:transparent;padding:0;cursor:pointer;text-align:left;color:inherit}.bar-row.off{opacity:.38}.bar-row.off .fill{width:0!important}.bar-row.off .dot{background:#c7d2d1!important}.bar-row:focus-visible{outline:3px solid rgba(57,193,188,.28);outline-offset:3px;border-radius:12px}.bar-label{display:flex;align-items:center;gap:7px} .dot{width:12px;height:12px;border-radius:50%;display:inline-block;background:var(--c)} .track{height:10px;background:#eaf1ef;border-radius:999px;overflow:hidden} .fill{height:100%;background:var(--c);border-radius:999px} .bar-value{font-weight:900;text-align:right}
.donut-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px} .donut-card{border:1px solid #e0ece8;background:#fff;border-radius:18px;padding:12px;display:grid;grid-template-columns:94px 1fr;gap:12px;align-items:start} .donut-plot{display:grid;place-items:center;gap:4px} .donut-title{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#5b6f75} .donut{width:84px;height:84px;border-radius:50%;position:relative;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)} .donut::after{content:"";position:absolute;inset:16px;background:#fff;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.04)} .donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center;z-index:2;line-height:1} .donut-center strong{font-size:28px;letter-spacing:-.04em;color:#243638} .donut-center span{font-size:10px;color:var(--muted)} .donut-meta{display:grid;gap:5px} .donut-legend{display:grid;gap:3px} .donut-leg-row{display:grid;grid-template-columns:12px 1fr auto;gap:6px;align-items:center;font-size:11px} .donut-leg-row .dot{width:10px;height:10px} .donut-dominant{font-size:11px;color:#345d5b;border-top:1px solid #e5efec;padding-top:6px;margin-top:4px;line-height:1.3} .subtle{font-size:11px;color:var(--muted);line-height:1.3}
.below{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px} .card{background:var(--surface);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:15px} .card h3{font-size:17px;letter-spacing:-.03em;margin-bottom:10px} .mini-list{display:grid;gap:8px} .mini-row{display:grid;grid-template-columns:1fr 90px;gap:10px;align-items:center;font-size:12px} .mini-row strong{text-align:right} .tagline{background:#f3faf8;border:1px solid #d9ebe7;border-radius:18px;padding:11px;font-size:12px;color:#345d5b;line-height:1.4}
.leaflet-popup-content{font-family:Inter,Arial,sans-serif;font-size:12px} .pop-title{font-size:15px;font-weight:900;margin-bottom:4px} .pop-meta{color:#65777d;margin-bottom:8px;line-height:1.35} .pop-grid{display:grid;grid-template-columns:1fr auto;gap:5px 10px;min-width:240px} .pop-grid strong{text-align:right} .risk-pill{display:inline-block;border-radius:999px;padding:3px 8px;color:#fff;font-weight:900;font-size:11px;background:var(--c)}
.dpe-card{display:flex;flex-direction:column;gap:7px}.dpe-caption{font-size:12px;font-weight:900;color:#172126}.dpe-caption.bottom{margin-top:2px}.dpe-unit{font-size:10px;color:var(--muted);margin-top:auto}.dpe-scale{display:grid;gap:6px;min-height:210px}.dpe-row{display:grid;grid-template-columns:minmax(0,1fr) 60px;gap:8px;align-items:center}.dpe-track{width:100%;display:flex;align-items:center}.dpe-bar{height:26px;min-width:128px;background:var(--c);clip-path:polygon(0 0,calc(100% - 13px) 0,100% 50%,calc(100% - 13px) 100%,0 100%);display:flex;align-items:center;justify-content:space-between;padding:0 18px 0 10px;font-weight:950;box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}.dpe-bar .range{font-size:11px;white-space:nowrap}.dpe-bar .letter{font-size:17px;line-height:1;margin-left:10px}.dpe-count{text-align:right;font-weight:900;font-size:12px;color:#243638}.dpe-missing{font-size:11px;color:var(--muted);border-top:1px solid #e5efec;padding-top:5px}.dpe-source-note{font-size:10px;color:var(--muted);line-height:1.25}
.risk-matrix-section{background:var(--surface);border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:18px;display:grid;gap:14px}.risk-matrix-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}.risk-matrix-title h2{font-size:24px;letter-spacing:-.035em;margin-bottom:5px}.risk-matrix-title p{font-size:13px;max-width:980px}.matrix-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.matrix-toolbar-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;color:#5b6f75;width:100%;margin-top:2px}.matrix-chip{border:1px solid #d7e8e4;background:#f7fbfa;color:#25524f;border-radius:999px;padding:8px 12px;cursor:pointer;font-weight:900;font-size:13px}.matrix-chip.active{background:linear-gradient(180deg,var(--teal),var(--teal2));color:white;border-color:transparent;box-shadow:0 10px 20px rgba(31,167,162,.16)}.matrix-grid{display:grid;gap:14px}.matrix-row{border:1px solid #e0ece8;background:linear-gradient(180deg,#fbfdfc,#f7faf9);border-radius:24px;padding:14px}.matrix-row-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;margin-bottom:12px;flex-wrap:wrap}.matrix-row-head h3{font-size:18px;margin:0}.matrix-row-head p{font-size:12px}.matrix-track{display:grid;grid-template-columns:repeat(4,minmax(205px,1fr));gap:12px}.matrix-card{border:1px solid #e0ece8;background:#fff;border-radius:20px;padding:14px;display:grid;grid-template-columns:130px minmax(0,1fr);gap:14px;align-items:center;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.matrix-card:hover{transform:translateY(-2px);box-shadow:0 14px 24px rgba(22,34,38,.09);border-color:#89d5cf}.matrix-card.dim{opacity:.36}.matrix-card-title{grid-column:1/-1;font-weight:950;font-size:15px}.matrix-donut{width:116px;height:116px;border-radius:50%;position:relative;background:#eaf1ef;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)}.matrix-donut::after{content:"";position:absolute;inset:20px;background:#fff;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.04)}.matrix-center{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;line-height:1}.matrix-center strong{font-size:28px;letter-spacing:-.04em}.matrix-center span{font-size:11px;color:var(--muted)}.matrix-legend{display:grid;gap:6px;align-content:center}.matrix-leg-row{display:grid;grid-template-columns:12px minmax(0,1fr) auto;gap:7px;align-items:center;font-size:12px}.matrix-leg-row strong{text-align:right}.matrix-dominant{grid-column:1/-1;border-top:1px solid #e5efec;margin-top:2px;padding-top:8px;font-size:12px;color:#3e6461;line-height:1.35}.matrix-empty{border:1px dashed #d8e9e5;border-radius:18px;background:#f8fbfa;color:var(--muted);padding:18px;text-align:center;font-size:13px}@media(max-width:1320px){.matrix-track{grid-template-columns:repeat(2,minmax(205px,1fr))}}@media(max-width:720px){.matrix-track{grid-template-columns:1fr}.matrix-card{grid-template-columns:112px minmax(0,1fr)}}
@media(max-width:1320px){.bailleur-strip{grid-template-columns:repeat(4,1fr)}.main-grid,.below{grid-template-columns:1fr}.map-card{height:620px;min-height:620px}.map-card #map{height:100%;min-height:620px}} @media(max-width:720px){.app{padding:12px}.hero{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,1fr)}.bailleur-strip{grid-template-columns:repeat(2,1fr);position:static}.map-filters{position:relative;top:auto;left:auto;margin:10px;width:auto}.map-card{display:flex;flex-direction:column}.frow,.filter-line,.geo-shortcuts,.metric-kpis,.horizon-grid,.donut-grid{grid-template-columns:1fr}}
/* Couche EPCI · vulnérabilité spécifique personnes âgées */
.age-epci-panel{margin:10px 0 12px;padding:10px;border:1px solid rgba(31,103,100,.18);border-radius:18px;background:rgba(255,255,255,.75);box-shadow:0 4px 18px rgba(20,60,60,.08)}
.age-epci-panel .age-title{font-weight:800;color:#173b3a;font-size:13px;margin-bottom:2px}
.age-epci-panel .age-sub{font-size:11px;color:#6b7c7a;line-height:1.25;margin-bottom:8px}
.age-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:8px}
.age-btn{border:1px solid rgba(31,103,100,.18);background:#fff;color:#173b3a;border-radius:12px;padding:8px 6px;font-weight:800;font-size:12px;cursor:pointer}
.age-btn.active{background:#35c2bf;color:#fff;border-color:#35c2bf}
.age-opacity{display:flex;align-items:center;gap:8px;font-size:11px;color:#6b7c7a}
.age-opacity input{width:100%}
.age-legend{display:grid;grid-template-columns:repeat(3,22px);grid-auto-rows:16px;gap:2px;margin-top:8px}
.age-legend span{display:block;border-radius:3px;border:1px solid rgba(0,0,0,.08)}
.age-loading{font-size:11px;color:#6b7c7a;margin-top:6px}
.bubble-marker{background:transparent;border:0;}
.bubble-public{width:var(--s);height:var(--s);border-radius:50%;background:var(--c);border:0;box-shadow:none;opacity:.8;}
.public-popup .pop-grid{grid-template-columns:1fr auto;}
/* Identité SAT-ellites + modèle public stabilisé */
a{color:inherit;text-decoration:none}
body{background:#fff;color:#171717;font-family:'Acumin',Inter,Arial,Helvetica,sans-serif}
.topbar{position:sticky;top:0;z-index:1200;background:rgba(255,255,255,.90);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.topbar .wrap{max-width:1440px;margin:0 auto;padding:20px 28px;display:flex;gap:24px;align-items:center;justify-content:space-between}
.brand{font-family:'Acumin',Inter,Arial,sans-serif;font-size:15px;letter-spacing:.10em;text-transform:uppercase;color:#111}
.nav{display:flex;gap:26px;font-size:14px;color:#666;flex-wrap:wrap;align-items:center}
.nav a{padding-bottom:5px;border-bottom:1px solid transparent}
.nav a:hover,.nav a.active{color:#111;border-bottom-color:#111}
.app{max-width:1440px;margin:0 auto;padding:20px 28px 34px;background:#fff;gap:16px}
.hero{background:#fff;border:1px solid #e7e3dc;border-radius:0;box-shadow:none;padding:24px 0 26px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:28px;align-items:end;border-left:0;border-right:0;border-top:0}
.hero-copy{display:block}.hero-text{max-width:820px}.hero .kicker{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#7a746d;margin:0 0 10px;font-weight:600}
.hero h1{font-family:'Oswald','Acumin',Arial,sans-serif;font-size:54px;line-height:.92;font-weight:300;letter-spacing:-.045em;margin:0 0 12px;color:#111;max-width:980px}
.hero .dashboard-subtitle{font-size:17px;line-height:1.35;color:#2f2f2f;margin:0 0 12px;font-weight:400}
.hero p{max-width:790px;font-size:13px;line-height:1.55;color:#62625f}
.kpis{display:grid;grid-template-columns:repeat(3,118px);gap:8px}.kpi{border:1px solid #e4e0d8;background:#fff;border-radius:0;padding:12px 12px;box-shadow:none}.kpi strong{font-size:25px;color:#111}.kpi span{font-size:10.5px;color:#666;text-transform:uppercase;letter-spacing:.08em;line-height:1.2}
/* Cadres de lecture : sobres ; commandes : arrondies */
.bailleur-strip{background:#fff;border:1px solid #e7e3dc;border-radius:0;box-shadow:none;padding:12px;top:64px;backdrop-filter:none}
.btile{border:1px solid #e8e5df;background:#fff;border-radius:0;box-shadow:none;cursor:default;min-height:92px;gap:8px;justify-content:space-between}
.btile.active,.btile.collectif{background:#fbfaf7;border-color:#d8d0c4}
.btile:hover{transform:none;box-shadow:none}.blogo{border-radius:0;border-color:#ece8e2;height:58px}.bname{display:none}.bstat{border-top-color:#ece8e2}
.main-grid{display:grid;grid-template-columns:1fr;gap:14px;align-items:stretch}
.map-card,.side-card,.card,.tagline,.risk-matrix-section,.matrix-row,.matrix-card,.donut-card,.control-block,.metric-kpi{background:#fff;border:1px solid #e7e3dc;border-radius:0;box-shadow:none}
.map-card{--dashboard-sticky-top:172px;position:relative;z-index:1;isolation:isolate;min-height:720px;height:100vh;display:grid;grid-template:1fr/1fr;overflow:visible}
#map{grid-area:1/1;min-height:720px;height:100%;width:100%;background:#eef2f0;border-radius:0;overflow:hidden;z-index:1}
.map-controls{grid-area:1/1;align-self:start;justify-self:end;position:sticky;top:var(--dashboard-sticky-top);z-index:31;margin:14px;width:min(340px,calc(100% - 28px));display:grid;gap:8px;pointer-events:none}
.map-controls>*{pointer-events:auto}
.map-filters,.map-filter-card{position:relative;top:auto;left:auto;z-index:30;margin:0;background:rgba(255,255,255,.95);border:1px solid rgba(221,216,207,.92);border-radius:22px;box-shadow:0 14px 34px rgba(22,34,38,.13);padding:11px;width:100%;backdrop-filter:blur(7px);display:grid;gap:6px}
.filter-title .reset,.reset,.chip,.multi-btn,.multi-action,select,input,.bar-all,.matrix-chip,.age-btn{border-radius:999px}
button,.chip,.multi-btn,.multi-action,.bar-row,.bar-all,.matrix-chip,.age-btn,input,select{transition:border-color .16s ease,box-shadow .16s ease,background .16s ease,transform .16s ease}
.chip:hover,.multi-btn:hover,.multi-action:hover,.bar-all:hover,.matrix-chip:hover,.age-btn:hover{border-color:#9ed9d4;box-shadow:0 8px 18px rgba(22,34,38,.06)}
.map-note,.tagline{border-radius:16px;background:#fbfaf7;border-color:#e7e3dc;color:#666}
.dashboard-map-selects{display:grid;gap:7px;padding:9px;border:1px solid #e7e3dc;background:#fbfaf7;border-radius:18px}.dashboard-map-selects select{background:#fff}.dashboard-map-selects .filter-label{color:#5d6868}
.side-card{padding:14px;display:grid;gap:14px}.control-block{padding:12px}.metric-kpi{background:#fbfaf7}.donut-card,.matrix-card{background:#fff}.risk-matrix-section{padding:18px}
.matrix-row{background:#fbfaf7}.matrix-card:hover{transform:none;box-shadow:0 8px 18px rgba(22,34,38,.06);border-color:#9ed9d4}
/* Bulles publiques : agrégation et nombres visibles */
.volume-cluster{border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:900;border:2px solid rgba(255,255,255,.85);box-shadow:0 8px 18px rgba(54,29,92,.25);line-height:1}
.volume-cluster.is-hover{transform:scale(1.06);box-shadow:0 10px 22px rgba(22,34,38,.28)}
.volume-cluster span{display:grid;place-items:center;width:100%;height:100%;border-radius:50%;text-shadow:0 1px 2px rgba(0,0,0,.25);font-size:clamp(10px,28%,18px);padding:2px;text-align:center}
.public-bubble-icon{background:transparent;border:0}.bubble-marker,.bubble-public{display:none}
.map-card .leaflet-control-container .leaflet-top,.map-card .leaflet-control-container .leaflet-bottom{z-index:20}
.map-card .leaflet-control{position:relative;z-index:20}.leaflet-bar{border:0!important;box-shadow:0 8px 22px rgba(22,34,38,.12)!important}.leaflet-bar a{border-bottom:1px solid #ece8e2!important}.map-card .leaflet-control-zoom a{border-radius:999px!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{border-radius:0;box-shadow:0 18px 38px rgba(22,34,38,.15)}
@media(max-width:1100px){.topbar .wrap{align-items:flex-start}.nav{gap:18px}.hero{grid-template-columns:1fr;align-items:start}.kpis{grid-template-columns:repeat(3,minmax(0,1fr));width:100%}.map-card{--dashboard-sticky-top:300px;height:100vh!important;min-height:680px!important}.map-card #map{height:100%;min-height:680px}}
@media(max-width:720px){.topbar .wrap{padding:16px 18px}.app{padding:14px 14px 24px}.hero{padding-top:18px}.hero h1{font-size:40px}.kpis{grid-template-columns:repeat(2,1fr)}.bailleur-strip{top:0}.map-controls{position:absolute;top:10px;right:10px;margin:0;width:min(320px,calc(100% - 20px))}.map-card{display:flex;flex-direction:column;overflow:hidden;min-height:680px;height:100vh}.map-card{border-left:0;border-right:0}.nav{font-size:13px;gap:14px}.main-grid,.below{grid-template-columns:1fr}}
/* Passe 1 — harmonisation DA SAT-ellites
   États d’interface en noir/blanc, hover gris, typographies secondaires allégées.
   La couleur reste réservée aux données métier : bulles, aplats, barres, pastilles,
   niveaux de vulnérabilité, DPE/GES et indicateurs cartographiques. */
:root{
  --ui-ink:#111;
  --ui-muted:#666;
  --ui-line:#ded9d1;
  --ui-hover:#f1f1f1;
  --ui-soft:#f3f3f3;
  --ui-focus:rgba(17,17,17,.18);
}
/* Allègement typographique des contrôles */
.filter-title,
.filter-label,
.chip,
.multi-btn,
.multi-action,
.reset,
.bar-all,
.matrix-chip,
.age-btn,
select,
input,
.dashboard-map-selects select,
.horizon-grid button,
.control-label,
.matrix-toolbar-title{
  font-weight:600 !important;
  letter-spacing:.01em;
}
.filter-title{font-size:12px;color:var(--ui-ink)}
.filter-label,.control-label,.matrix-toolbar-title{color:var(--ui-muted) !important}
select,
input,
.multi-btn,
.dashboard-map-selects select{
  color:var(--ui-ink) !important;
  border-color:var(--ui-line) !important;
  background:#fff !important;
  box-shadow:none !important;
}
select:hover,
input:hover,
.multi-btn:hover,
.dashboard-map-selects select:hover{
  background:var(--ui-hover) !important;
  border-color:#bdb8b0 !important;
  box-shadow:none !important;
}
select:focus,
input:focus,
.multi-btn:focus,
.multi-btn:focus-visible,
.dashboard-map-selects select:focus{
  outline:none !important;
  border-color:#bdb8b0 !important;
  box-shadow:0 0 0 3px var(--ui-focus) !important;
}
/* Boutons, chips et raccourcis : inactif blanc/noir, actif noir/blanc */
.chip,
.multi-action,
.reset,
.bar-all,
.matrix-chip,
.age-btn,
.horizon-grid button{
  background:#fff !important;
  color:var(--ui-ink) !important;
  border:1px solid var(--ui-line) !important;
  box-shadow:none !important;
  background-image:none !important;
}
.chip:hover,
.multi-action:hover,
.reset:hover,
.bar-all:hover,
.matrix-chip:hover,
.age-btn:hover,
.horizon-grid button:hover{
  background:var(--ui-hover) !important;
  color:var(--ui-ink) !important;
  border-color:#bdb8b0 !important;
  box-shadow:none !important;
}
.chip.active,
.multi-action.primary,
.matrix-chip.active,
.age-btn.active,
.horizon-grid button.active{
  background:var(--ui-ink) !important;
  color:#fff !important;
  border-color:transparent !important;
  background-image:none !important;
  box-shadow:none !important;
}
.chip.active:hover,
.multi-action.primary:hover,
.matrix-chip.active:hover,
.age-btn.active:hover,
.horizon-grid button.active:hover{
  background:#000 !important;
  color:#fff !important;
  border-color:transparent !important;
}
/* Menus déroulants territoriaux : ouverture par ombre douce */
.multi.open .multi-btn{
  border-color:#bdb8b0 !important;
  box-shadow:0 8px 18px rgba(0,0,0,.08) !important;
}
.multi-menu{
  border-color:var(--ui-line) !important;
  box-shadow:0 18px 34px rgba(0,0,0,.12) !important;
}
.multi-option{
  font-weight:500 !important;
  color:var(--ui-ink) !important;
}
.multi-option:hover{
  background:var(--ui-hover) !important;
}
.multi-option input,
.layer-toggle input,
.age-opacity input{
  accent-color:var(--ui-ink) !important;
}
/* Lignes et cartes de légende : garder les couleurs de données, calmer l’interface */
.bar-row,
.matrix-card,
.donut-card,
.control-block,
.metric-kpi,
.card,
.tagline,
.map-note,
.dashboard-map-selects,
.age-epci-panel{
  border-color:#e7e3dc !important;
  box-shadow:none !important;
}
.bar-row{
  font-weight:500 !important;
  color:var(--ui-ink) !important;
  border-radius:14px;
  padding:5px 6px;
  border:1px solid transparent !important;
}
.bar-row:hover{
  background:var(--ui-hover) !important;
  border-color:transparent !important;
  box-shadow:none !important;
}
.bar-row:not(.off){
  background:transparent;
}
.bar-row.off,
.matrix-card.dim,
.btile.dim,
.btile.muted{
  opacity:.42 !important;
}
.bar-label,
.bar-value,
.matrix-card-title,
.matrix-row-head h3{
  color:var(--ui-ink) !important;
}
.matrix-card:hover{
  background:var(--ui-hover) !important;
  border-color:#d2cdc5 !important;
  box-shadow:none !important;
  transform:none !important;
}
.matrix-card.dim:hover{
  background:#fff !important;
}
.matrix-row,
.risk-matrix-section,
.control-block,
.metric-kpi,
.donut-card,
.card{
  background:#fff !important;
}
.map-note,
.tagline,
.dashboard-map-selects,
.age-epci-panel{
  background:#fbfaf7 !important;
  color:var(--ui-muted) !important;
}
/* Logos bailleurs / partenaires : actif par ombre douce, pas par turquoise */
.bailleur-strip{
  background:#fff !important;
  border-color:#e7e3dc !important;
  box-shadow:none !important;
}
.btile{
  border-color:#e2ddd4 !important;
  background:#fff !important;
  box-shadow:none !important;
}
.btile:hover{
  transform:translateY(-1px) !important;
  border-color:#bdb8b0 !important;
  background:var(--ui-hover) !important;
  box-shadow:none !important;
}
.btile.active,
.btile.collectif{
  border-color:#e2ddd4 !important;
  background:#fff !important;
  box-shadow:0 12px 28px rgba(0,0,0,.18) !important;
}
.btile.dim .blogo,
.btile.muted .blogo{
  filter:grayscale(1);
}
.fallback-logo{
  color:var(--ui-ink) !important;
}
/* Contrôles Leaflet et popups sobres */
.leaflet-bar{
  border:0 !important;
  box-shadow:0 8px 18px rgba(0,0,0,.12) !important;
}
.leaflet-bar a:hover{
  background:var(--ui-hover) !important;
  color:var(--ui-ink) !important;
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
  box-shadow:0 18px 38px rgba(0,0,0,.14) !important;
}
/* Focus clavier accessible mais discret */
.chip:focus-visible,
.multi-action:focus-visible,
.reset:focus-visible,
.bar-all:focus-visible,
.matrix-chip:focus-visible,
.age-btn:focus-visible,
.horizon-grid button:focus-visible,
.bar-row:focus-visible,
.matrix-card:focus-visible,
.btile:focus-visible,
select:focus-visible,
input:focus-visible{
  outline:2px solid rgba(17,17,17,.32) !important;
  outline-offset:3px;
  box-shadow:none !important;
}
/* Protection explicite des couleurs métier */
.volume-cluster,
.volume-cluster span,
.public-bubble-icon,
.bubble-marker,
.bubble-public,
.risk-pill,
.dot,
.fill,
.dpe-bar,
.dpe-bar .letter,
.donut,
.donut-plot,
.donut-legend .dot,
.matrix-donut,
.matrix-center,
.matrix-leg-row .dot,
.age-legend span,
.swatch{
  forced-color-adjust:auto;
}


/* UX carte / synthèse stabilisée : colonne gauche et synthèse dans le flux normal */
.dashboard-shell{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;align-items:start}
.app-sidebar{position:sticky;top:82px;z-index:860;display:grid;gap:12px;align-self:start;max-height:calc(100vh - 96px);overflow:auto;padding-right:2px}
.sidebar-block{background:#fff;border:1px solid #e7e3dc;box-shadow:none;padding:13px;display:grid;gap:10px}
.sidebar-title{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#6f6a63;font-weight:650;margin-bottom:1px}
.active-readout{display:flex;flex-wrap:wrap;gap:7px}.active-chip{border:1px solid #ded9d1;background:#fff;color:#111;border-radius:999px;padding:7px 9px;font-size:11px;font-weight:600;line-height:1.1}
.app-sidebar .view-switch{position:static!important;top:auto!important;z-index:auto!important;width:100%;display:grid;grid-template-columns:1fr;gap:7px;background:transparent!important;border:0!important;box-shadow:none!important;backdrop-filter:none!important;padding:0!important;border-radius:0!important}
.app-sidebar .view-switch button,.module-pill{width:100%!important;justify-content:flex-start!important;border:1px solid #ded9d1!important;background:#fff!important;color:#111!important;border-radius:999px!important;padding:10px 12px!important;font-size:12px!important;font-weight:650!important;box-shadow:none!important;background-image:none!important;transform:none!important;display:flex;align-items:center;gap:8px;text-align:left;cursor:pointer}
.app-sidebar .view-switch button:hover,.module-pill:hover{background:#f1f1f1!important;border-color:#bdb8b0!important;color:#111!important;transform:none!important}.app-sidebar .view-switch button.active,.module-pill.active{background:#111!important;color:#fff!important;border-color:#111!important;box-shadow:none!important}.module-pill.inactive{opacity:.58;cursor:default;background:#fff!important;color:#777!important;border-color:#ded9d1!important}.module-pill.inactive:hover{background:#fff!important;border-color:#ded9d1!important;color:#777!important}
.filter-group{border:1px solid #e7e3dc;background:#fbfaf7;display:grid;gap:0}.filter-group>summary{list-style:none;cursor:pointer;padding:11px 12px;font-size:12.5px;font-weight:700;color:#111;display:flex;align-items:center;justify-content:space-between;gap:10px}.filter-group>summary::-webkit-details-marker{display:none}.filter-group>summary::after{content:'⌄';font-size:13px;color:#6f6a63;transition:transform .16s ease}.filter-group[open]>summary::after{transform:rotate(180deg)}.filter-group-body{padding:0 10px 11px;display:grid;gap:8px}
.horizon-buttons{display:grid;grid-template-columns:1fr 1fr;gap:7px}.horizon-buttons button{border:1px solid #ded9d1;background:#fff;color:#111;border-radius:999px;padding:9px 10px;font-size:12px;font-weight:650;cursor:pointer}.horizon-buttons button.active{background:#111;color:#fff;border-color:#111}
.dashboard-shell .map-filters,.dashboard-shell .map-filter-card{position:relative!important;top:auto!important;left:auto!important;right:auto!important;margin:0!important;width:auto!important;box-shadow:none!important;border-radius:0!important;background:transparent!important;border:0!important;padding:0!important;backdrop-filter:none!important;z-index:auto!important}.dashboard-shell .map-note,.dashboard-shell .dashboard-map-selects,.dashboard-shell .age-toggle-row{background:#fff!important;border:1px solid #e7e3dc!important;border-radius:0!important;box-shadow:none!important}.age-toggle-row{display:grid;gap:8px;padding:10px}.age-opacity{display:flex;align-items:center;gap:8px;font-size:11px;color:#6b7c7a}.age-opacity input{width:100%}.age-legend{display:grid;grid-template-columns:repeat(3,22px);grid-auto-rows:16px;gap:2px}.age-legend span{display:block;border-radius:3px;border:1px solid rgba(0,0,0,.08)}.age-loading{font-size:11px;color:#6b7c7a}.legacy-controls{display:none!important}
.dashboard-shell .main-grid{min-width:0}.dashboard-shell .main-grid.dashboard-view-map{grid-template-columns:1fr!important}.dashboard-shell .main-grid.dashboard-view-map .side-card{display:none!important}.dashboard-shell .main-grid.dashboard-view-map .map-card{display:flex!important;height:calc(100vh - 96px)!important;min-height:680px!important}.dashboard-shell .main-grid.dashboard-view-synth{grid-template-columns:1fr!important}.dashboard-shell .main-grid.dashboard-view-synth .map-card{display:none!important}.dashboard-shell .main-grid.dashboard-view-synth .side-card{display:grid!important;min-height:620px}.app.view-map .risk-matrix-section,.app.view-map .below{display:none!important}.app.view-synth .risk-matrix-section,.app.view-synth .below{display:grid!important}
.app.view-synth .bailleur-strip{position:relative!important;top:auto!important;z-index:auto!important}.dashboard-view-synth .side-card,.dashboard-view-synth .control-block,.dashboard-view-synth .metric-kpis,.dashboard-view-synth .donut-grid{position:relative!important;top:auto!important;left:auto!important;right:auto!important;transform:none!important;overflow:visible!important}.dashboard-view-synth .side-card{align-self:start!important;height:auto!important;min-height:0!important;display:grid!important;align-content:start!important}.dashboard-view-synth .control-block{display:grid!important}
@media(max-width:1100px){.dashboard-shell{grid-template-columns:1fr}.app-sidebar{position:relative;top:auto;max-height:none;overflow:visible}.dashboard-shell .main-grid.dashboard-view-map .map-card{height:680px!important;min-height:680px!important}}

/* Correctif typographie ciblé — géographie + synthèse vulnérabilités */
.app-sidebar .filter-group-body .chip,
.app-sidebar .geo-shortcuts .chip,
.app-sidebar .map-filters .chip,
.app-sidebar .map-filter-card .chip,
.app-sidebar .multi-btn,
.app-sidebar .multi-option,
.app-sidebar .multi-action,
.app-sidebar .reset,
.app-sidebar select,
.app-sidebar input{
  font-size:11px !important;
  line-height:1.15 !important;
  font-weight:600 !important;
}
.app-sidebar .geo-shortcuts .chip,
.app-sidebar .map-filters .chip,
.app-sidebar .map-filter-card .chip{
  padding:6px 8px !important;
}
.app-sidebar .filter-label,
.app-sidebar .map-note,
.app-sidebar .multi-empty{
  font-size:10.5px !important;
  line-height:1.25 !important;
}
.app-sidebar .filter-title,
.app-sidebar .filter-title span,
.app-sidebar .filter-title span::after{
  font-size:11px !important;
  line-height:1.2 !important;
}

/* Synthèse : contrôles et légendes à l'échelle du reste de l'interface */
.dashboard-view-synth .control-label,
.dashboard-view-synth .matrix-toolbar-title,
.dashboard-view-synth .donut-title{
  font-size:10px !important;
  line-height:1.15 !important;
  font-weight:650 !important;
}
.dashboard-view-synth .bar-all,
.dashboard-view-synth .bar-row,
.dashboard-view-synth .bar-label,
.dashboard-view-synth .bar-value,
.dashboard-view-synth .matrix-chip,
.dashboard-view-synth .horizon-grid button,
.dashboard-view-synth .age-btn,
.dashboard-view-synth .donut-leg-row,
.dashboard-view-synth .matrix-leg-row{
  font-size:11px !important;
  line-height:1.18 !important;
  font-weight:600 !important;
}
.dashboard-view-synth .bar-all,
.dashboard-view-synth .matrix-chip,
.dashboard-view-synth .horizon-grid button,
.dashboard-view-synth .age-btn{
  padding:6px 9px !important;
}
.dashboard-view-synth .bar-row{
  grid-template-columns:86px 1fr 56px !important;
  gap:7px !important;
  padding:4px 5px !important;
}
.dashboard-view-synth .bar-label{
  align-items:center !important;
  gap:6px !important;
}
.dashboard-view-synth .dot,
.dashboard-view-synth .bar-label .dot,
.dashboard-view-synth .donut-leg-row .dot,
.dashboard-view-synth .matrix-leg-row .dot{
  width:10px !important;
  height:10px !important;
  min-width:10px !important;
  flex:0 0 10px !important;
  aspect-ratio:1 / 1 !important;
  border-radius:50% !important;
  display:inline-block !important;
  padding:0 !important;
}
.dashboard-view-synth .track{
  height:8px !important;
}
.dashboard-view-synth .metric-kpi strong{
  font-size:19px !important;
}
.dashboard-view-synth .metric-kpi span,
.dashboard-view-synth .subtle,
.dashboard-view-synth .donut-dominant,
.dashboard-view-synth .matrix-dominant,
.dashboard-view-synth .dpe-source-note,
.dashboard-view-synth .dpe-unit,
.dashboard-view-synth .dpe-missing{
  font-size:10.5px !important;
  line-height:1.25 !important;
}
.dashboard-view-synth .matrix-card-title,
.dashboard-view-synth .matrix-row-head h3,
.dashboard-view-synth .card h3{
  font-size:14px !important;
  line-height:1.2 !important;
  font-weight:700 !important;
}
.dashboard-view-synth .matrix-row-head p,
.dashboard-view-synth .risk-matrix-title p{
  font-size:11.5px !important;
  line-height:1.35 !important;
}
.dashboard-view-synth .risk-matrix-title h2{
  font-size:22px !important;
}
.dashboard-view-synth .dpe-caption{
  font-size:11px !important;
  font-weight:700 !important;
}
.dashboard-view-synth .dpe-bar .range,
.dashboard-view-synth .dpe-count{
  font-size:10.5px !important;
}
.dashboard-view-synth .dpe-bar .letter{
  font-size:15px !important;
}

/* Correctif ciblé final — critères latéraux fermés + boutons matrice homogènes */
.app-sidebar .filter-group > summary,
.app-sidebar .filter-group-body .chip,
.app-sidebar .geo-shortcuts .chip,
.app-sidebar .map-filters .chip,
.app-sidebar .map-filter-card .chip,
.app-sidebar .horizon-buttons button,
.app-sidebar .module-pill,
.app-sidebar .multi-btn,
.app-sidebar .multi-option,
.app-sidebar .multi-action,
.app-sidebar .reset,
.app-sidebar select,
.app-sidebar input{
  font-size:11px !important;
  line-height:1.15 !important;
  font-weight:600 !important;
}
.app-sidebar .filter-group > summary{
  padding:10px 11px !important;
}
.app-sidebar .filter-group > summary::after{
  font-size:11px !important;
}
.app-sidebar .filter-group-body .chip,
.app-sidebar .geo-shortcuts .chip,
.app-sidebar .map-filters .chip,
.app-sidebar .map-filter-card .chip,
.app-sidebar .horizon-buttons button{
  padding:6px 8px !important;
}

/* La matrice Vulnerabilites par horizon est hors .dashboard-view-synth : ciblage direct */
.app.view-synth .risk-matrix-section .matrix-toolbar-title{
  font-size:10px !important;
  line-height:1.15 !important;
  font-weight:650 !important;
  letter-spacing:.08em !important;
}
.app.view-synth .risk-matrix-section .matrix-chip{
  font-size:11px !important;
  line-height:1.15 !important;
  font-weight:650 !important;
  padding:6px 10px !important;
  border-radius:999px !important;
  min-height:0 !important;
}
.app.view-synth .risk-matrix-section .matrix-chip.active{
  font-size:11px !important;
  line-height:1.15 !important;
  font-weight:650 !important;
}

/* Ajustement UX ciblé — mode de lecture séparé, lecture active dans le haut */
.hero-active-readout{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.hero-active-label{
  font-size:10.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#6f6a63;
  font-weight:650;
}
.hero-active-readout .active-readout{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.dashboard-left-rail{
  position:sticky;
  top:82px;
  z-index:860;
  align-self:start;
  max-height:calc(100vh - 96px);
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
  gap:12px;
  min-height:0;
}
.dashboard-left-rail .mode-block{
  position:relative;
  z-index:2;
}
.dashboard-left-rail .view-switch{
  width:100%;
  display:grid;
  grid-template-columns:1fr;
  gap:7px;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  padding:0!important;
  border-radius:0!important;
}
.dashboard-left-rail .view-switch button{
  width:100%!important;
  justify-content:flex-start!important;
  border:1px solid #ded9d1!important;
  background:#fff!important;
  color:#111!important;
  border-radius:999px!important;
  padding:10px 12px!important;
  font-size:12px!important;
  font-weight:650!important;
  box-shadow:none!important;
  background-image:none!important;
  transform:none!important;
  display:flex;
  align-items:center;
  gap:8px;
  text-align:left;
  cursor:pointer;
}
.dashboard-left-rail .view-switch button:hover{
  background:#f1f1f1!important;
  border-color:#bdb8b0!important;
  color:#111!important;
  transform:none!important;
}
.dashboard-left-rail .view-switch button.active{
  background:#111!important;
  color:#fff!important;
  border-color:#111!important;
  box-shadow:none!important;
}
.dashboard-left-rail .app-sidebar{
  position:relative!important;
  top:auto!important;
  z-index:auto!important;
  max-height:none!important;
  overflow:auto!important;
  min-height:0;
  align-self:stretch;
  padding-right:2px;
}
@media(max-width:1100px){
  .dashboard-left-rail{
    position:relative;
    top:auto;
    max-height:none;
    overflow:visible;
  }
  .dashboard-left-rail .app-sidebar{
    overflow:visible!important;
  }
}
@media(max-width:720px){
  .hero-active-readout{
    align-items:flex-start;
    flex-direction:column;
    gap:7px;
  }
}
