*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a0e1a;--bg2:#111827;--bg3:#1a2236;--bg4:#243049;
  --tx:#e8ecf4;--tx2:#8b95a8;--tx3:#5a6578;
  --ac:#00d4aa;--ac2:#00b894;--blue:#4ea8f6;--red:#ef4444;--yel:#f59e0b;
  --grn:#10b981;--ora:#f97316;--pur:#a78bfa;--pink:#f472b6;
  --bd:#1e293b;--r:6px
}
html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--tx)}
.mono{font-family:'JetBrains Mono',monospace}
#app{width:100%;height:100vh;overflow:hidden}

#sidebar{position:fixed;left:0;top:0;width:340px;height:100vh;background:var(--bg2);display:flex;flex-direction:column;border-right:1px solid var(--bd);z-index:1000;overflow:hidden}
.sb-head{padding:16px 20px;background:linear-gradient(135deg,var(--bg3),var(--bg2));border-bottom:1px solid var(--bd)}
.sb-head h1{font-size:16px;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.sb-head h1 .icon{font-size:20px}
.sb-head p{font-size:11px;color:var(--tx3);margin-top:4px;letter-spacing:.3px}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:10px 16px;border-bottom:1px solid var(--bd)}
.st{text-align:center;padding:4px 0}
.st b{font-size:18px;color:var(--ac);display:block;font-family:'JetBrains Mono',monospace;font-weight:700}
.st small{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.6px}

.tabs{display:flex;border-bottom:1px solid var(--bd);background:var(--bg3);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.tabs::-webkit-scrollbar{display:none}
.tab{flex-shrink:0;padding:10px 12px;text-align:center;font-size:11px;font-weight:700;color:var(--tx3);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.tab:hover{color:var(--tx2)}.tab.on{color:var(--ac);border-bottom-color:var(--ac)}

.tc{display:none;flex:1;flex-direction:column;overflow:hidden;opacity:0;transition:opacity .15s}
.tc.on{display:flex;opacity:1}

.vswitch{display:flex;gap:3px;padding:8px 16px;border-bottom:1px solid var(--bd)}
.vb{flex:1;padding:6px 4px;text-align:center;font-size:11px;font-weight:600;color:var(--tx3);cursor:pointer;border-radius:var(--r);border:1px solid transparent;transition:.15s;background:none}
.vb:hover{color:var(--tx2);background:var(--bg3)}
.vb.on{color:var(--ac);border-color:rgba(0,212,170,.3);background:rgba(0,212,170,.06)}

.sbox{padding:8px 16px;border-bottom:1px solid var(--bd)}
.sbox input{width:100%;padding:8px 12px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);color:var(--tx);font-size:12px;outline:none;font-family:'DM Sans',sans-serif;transition:border .2s}
.sbox input:focus{border-color:var(--ac)}.sbox input::placeholder{color:var(--tx3)}

.rlist{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--bg4) var(--bg2)}
.rlist::-webkit-scrollbar{width:4px}.rlist::-webkit-scrollbar-track{background:var(--bg2)}.rlist::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}

.ri{padding:10px 16px;border-bottom:1px solid rgba(30,41,59,.5);cursor:pointer;transition:background .12s;display:flex;align-items:center;gap:10px}
.ri:hover{background:var(--bg3)}
.rn{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;font-family:'JetBrains Mono',monospace}
.rn.t3{background:var(--yel);color:#000}.rn.t10{background:var(--ac);color:#000}.rn.rest{background:var(--bg4);color:var(--tx2)}
.rinfo{flex:1;min-width:0}.rname{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rdet{font-size:11px;color:var(--tx3);margin-top:2px;display:flex;gap:6px;flex-wrap:wrap}.rdet span{white-space:nowrap}
.rbadge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:11px;font-weight:700;margin-left:4px;letter-spacing:.3px}
.rbadge.desert{background:rgba(239,68,68,.15);color:var(--red)}.rbadge.partial{background:rgba(245,158,11,.15);color:var(--yel)}.rbadge.covered{background:rgba(16,185,129,.15);color:var(--grn)}
.rsc{width:44px;text-align:center;flex-shrink:0}
.rsc b{font-size:16px;font-weight:700;display:block;font-family:'JetBrains Mono',monospace}
.rsc small{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px}

.lsec{padding:12px 16px;border-bottom:1px solid var(--bd)}
.lsec h3{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;font-weight:700}
.lt{display:flex;flex-direction:column;gap:8px}
.lt label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:11px;transition:color .15s}
.lt label:hover{color:var(--tx)}
.lt input[type="checkbox"],.lt input[type="radio"]{accent-color:var(--ac);width:14px;height:14px;cursor:pointer}

#mc{position:fixed;left:340px;top:0;right:0;bottom:0;overflow:hidden}
#map{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--bg)}

#legend{position:absolute;bottom:12px;right:10px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);z-index:500;box-shadow:0 8px 24px rgba(0,0,0,.4);backdrop-filter:blur(8px);max-height:calc(100vh - 80px);overflow-y:auto}
#legend.collapsed{padding:0}
#legend .leg-toggle{display:flex;align-items:center;gap:6px;padding:8px 12px;cursor:pointer;font-size:11px;font-weight:600;color:var(--tx2);user-select:none;border-bottom:1px solid var(--bd)}
#legend.collapsed .leg-toggle{border-bottom:none}
#legend .leg-body{padding:8px 12px}
#legend.collapsed .leg-body{display:none}
#legend h4{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;font-weight:700}
.lr{display:flex;align-items:center;gap:6px;margin:2px 0;font-size:11px;color:var(--tx2)}
.lc{width:14px;height:8px;border-radius:2px;flex-shrink:0}

#ipanel{position:absolute;top:12px;right:12px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:16px 20px;z-index:500;max-width:340px;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;backdrop-filter:blur(8px)}
#ipanel h3{font-size:14px;font-weight:700;margin-bottom:8px;padding-right:24px;line-height:1.3}
.igrid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.ii{font-size:11px}.il{color:var(--tx3);font-size:11px}.iv{font-weight:600;font-family:'JetBrains Mono',monospace;font-size:13px}
.closebtn{position:absolute;top:8px;right:12px;cursor:pointer;color:var(--tx3);font-size:20px;line-height:1;padding:4px;transition:color .15s}.closebtn:hover{color:var(--tx)}
.sbadge{display:inline-block;padding:3px 12px;border-radius:4px;font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace;margin-top:2px}
.cov-bar{height:4px;border-radius:2px;background:var(--bg4);margin-top:4px;overflow:hidden}
.cov-fill{height:100%;border-radius:2px;transition:width .3s}

.leaflet-container{background:var(--bg)!important}
.leaflet-control-zoom{border:1px solid var(--bd)!important;border-radius:var(--r)!important;overflow:hidden}
.leaflet-control-zoom a{background:var(--bg2)!important;color:var(--tx)!important;border-bottom-color:var(--bd)!important;width:32px!important;height:32px!important;line-height:32px!important;font-size:16px!important}
.leaflet-control-zoom a:hover{background:var(--bg3)!important}
.leaflet-popup-content-wrapper{background:var(--bg2)!important;color:var(--tx)!important;border-radius:var(--r)!important;border:1px solid var(--bd)!important;box-shadow:0 8px 24px rgba(0,0,0,.4)!important}
.leaflet-popup-tip{background:var(--bg2)!important}
.leaflet-popup-content{font-size:11px;margin:8px 12px;font-family:'DM Sans',sans-serif}
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:rgba(78,168,246,.25)!important}
.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:var(--blue)!important;color:#fff!important;font-weight:700;font-family:'JetBrains Mono',monospace}
.mcl-orl{background:rgba(16,185,129,.25)!important}.mcl-orl div{background:var(--grn)!important;color:#fff!important;font-weight:700}
.mcl-pharma{background:rgba(244,114,182,.2)!important}.mcl-pharma div{background:var(--pink)!important;color:#fff!important;font-weight:700}
.mcl-ehpad{background:rgba(167,139,250,.2)!important}.mcl-ehpad div{background:var(--pur)!important;color:#fff!important;font-weight:700}
.mcl-hop{background:rgba(249,115,22,.2)!important}.mcl-hop div{background:var(--ora)!important;color:#fff!important;font-weight:700}

#loading{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10000;gap:16px;transition:opacity .35s ease}
#loading.hide{opacity:0;pointer-events:none}
#loading h2{font-size:14px;font-weight:600;color:var(--tx2)}
.loading-card{width:min(520px,86vw);padding:20px;border:1px solid var(--bd);border-radius:10px;background:linear-gradient(135deg,var(--bg2),var(--bg3));box-shadow:0 8px 24px rgba(0,0,0,.4)}
.loading-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.loading-step{font-size:12px;color:var(--tx)}
.loading-pct{font-size:11px;color:var(--tx2);font-family:'JetBrains Mono',monospace}
.loading-track{height:8px;background:var(--bg4);border-radius:999px;overflow:hidden}
.loading-fill{height:100%;width:0;background:linear-gradient(90deg,var(--ac),var(--blue));transition:width .25s ease}
.loading-file{margin-top:8px;font-size:11px;color:var(--tx3)}

.guide-overlay{position:fixed;inset:0;background:rgba(10,14,26,.62);display:flex;align-items:center;justify-content:center;z-index:9000;opacity:0;pointer-events:none;transition:opacity .25s ease}
.guide-overlay.show{opacity:1;pointer-events:auto}
.guide-overlay.hide{opacity:0;pointer-events:none}
.guide-card{width:min(560px,92vw);background:linear-gradient(135deg,var(--bg2),var(--bg3));border:1px solid var(--bd);border-radius:10px;box-shadow:0 18px 36px rgba(0,0,0,.45);padding:16px 18px}
.guide-card h3{font-size:15px;font-weight:700;line-height:1.35;margin-bottom:10px}
.guide-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin:0 0 12px;padding:0}
.guide-li{padding:8px 10px;background:rgba(36,48,73,.45);border:1px solid rgba(255,255,255,.04);border-radius:6px}
.guide-li div{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px}
.guide-li small{display:block;margin-top:3px;font-size:11px;color:var(--tx2);font-style:italic}
.guide-actions{display:flex;align-items:center;gap:12px}
.guide-actions button{font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer}
#guide-explore{border:1px solid var(--ac);background:rgba(0,212,170,.15);color:var(--ac);padding:8px 12px;border-radius:6px;font-weight:600}
.guide-link{border:none;background:transparent;color:var(--tx2);text-decoration:underline;padding:2px 0}
.guide-link:hover{color:var(--tx)}

@keyframes pulse-border{0%,100%{opacity:.6}50%{opacity:1}}

/* --- Mobile: drag handle (hidden on desktop) --- */
.sb-handle{display:none}

/* --- Tablet (≤768px): bottom sheet layout --- */
@media(max-width:768px){
  .sb-handle{display:flex;justify-content:center;padding:8px 0 4px;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .sb-pill{width:36px;height:4px;border-radius:99px;background:var(--tx3);opacity:.5}

  #sidebar{left:0;top:auto;bottom:0;width:100%;height:65vh;border-right:none;border-top:1px solid var(--bd);transition:height .28s ease}
  #sidebar.sb-collapsed{height:54px;overflow:hidden}
  #sidebar.sb-expanded{height:65vh;overflow:hidden}
  #sidebar.sb-collapsed .sb-head,
  #sidebar.sb-collapsed .stats,
  #sidebar.sb-collapsed .tc,
  #sidebar.sb-collapsed .vswitch,
  #sidebar.sb-collapsed .sbox,
  #sidebar.sb-collapsed .rlist,
  #sidebar.sb-collapsed .lsec,
  #sidebar.sb-collapsed .l-advanced,
  #sidebar.sb-collapsed>div:nth-child(5){display:none}
  #sidebar.sb-collapsed .tabs{border-bottom:none}

  #mc{left:0;top:0;right:0;bottom:54px}
  #sidebar.sb-expanded~#mc,
  #sidebar:not(.sb-collapsed)~#mc{bottom:65vh}

  #legend{bottom:8px;right:8px;max-width:180px;font-size:11px}
  #legend .lr{gap:4px;margin:1px 0}
  #legend .lc{width:12px;height:6px}

  #ipanel{top:auto;bottom:62vh;right:8px;left:8px;max-width:none}
  #detail-panel{width:100%;height:70vh;top:auto;bottom:0;right:0;border-left:none;border-top:1px solid var(--bd);transform:translateY(100%)}
  #detail-panel.open{transform:translateY(0)}

  .tabs{flex-wrap:nowrap;overflow-x:auto}
  .tab{padding:12px 14px;min-height:44px;font-size:12px}
  .vb{min-height:44px;padding:10px 6px;font-size:12px}
  .lt label{min-height:44px;padding:4px 0}
  .lt input[type="checkbox"],.lt input[type="radio"]{width:18px;height:18px}
  .preset-btn{min-height:44px;padding:10px 14px;font-size:12px}
  .sbox input{font-size:16px;padding:10px 12px}
  .ri{padding:12px 16px;min-height:48px}
  .closebtn{font-size:24px;padding:10px}
  .dp-close{font-size:28px;padding:10px}
  .dp-grid,.dp-eco,.dp-age-grid{grid-template-columns:1fr 1fr}
}

.preset-row{display:flex;flex-wrap:wrap;gap:8px}
.preset-btn{padding:6px 12px;border-radius:999px;border:1px solid var(--bd);background:var(--bg3);color:var(--tx2);font-size:11px;font-weight:700;cursor:pointer;transition:.15s}
.preset-btn:hover{color:var(--tx);border-color:#334155}
.preset-btn.on{border-color:var(--ac);background:rgba(0,212,170,.1);color:var(--ac)}

.l-advanced{border-bottom:1px solid var(--bd)}
.l-advanced>summary{list-style:none;cursor:pointer;padding:12px 16px;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--tx2);user-select:none}
.l-advanced>summary::-webkit-details-marker{display:none}
.l-advanced>summary::after{content:"▼";float:right;color:var(--tx3);font-size:11px}
.l-advanced[open]>summary::after{content:"▲"}

.ip-summary{padding:10px 12px;border-radius:6px;margin-bottom:10px;border-left:3px solid var(--ac)}
.ip-summary.green{background:rgba(0,212,170,.06);border-left-color:var(--grn)}
.ip-summary.yellow{background:rgba(245,158,11,.08);border-left-color:var(--yel)}
.ip-summary.red{background:rgba(239,68,68,.08);border-left-color:var(--red)}
.ip-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.2px;margin-bottom:6px}
.ip-summary-text{font-size:12px;line-height:1.5;color:var(--tx)}

#detail-panel{position:fixed;right:0;top:0;height:100vh;width:420px;z-index:1100;background:var(--bg2);border-left:1px solid var(--bd);transform:translateX(100%);transition:transform .24s ease;display:flex;flex-direction:column;box-shadow:-18px 0 28px rgba(0,0,0,.35)}
#detail-panel.open{transform:translateX(0)}
#detail-panel-content{padding:18px 18px 24px;overflow-y:auto;flex:1}
.dp-close{position:absolute;top:10px;right:12px;border:none;background:none;color:var(--tx2);font-size:24px;cursor:pointer;line-height:1;padding:4px;z-index:2}
.dp-close:hover{color:var(--tx)}
.dp-head{padding-right:28px}
.dp-head h3{font-size:16px;line-height:1.3;margin-bottom:8px}
.dp-head-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dp-score{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px}
.dp-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--bd)}
.dp-tag.green{color:var(--grn);border-color:rgba(16,185,129,.45)}
.dp-tag.yellow{color:var(--yel);border-color:rgba(245,158,11,.45)}
.dp-tag.red{color:var(--red);border-color:rgba(239,68,68,.45)}
.dp-sec{padding-top:14px;margin-top:14px;border-top:1px solid var(--bd)}
.dp-sec h4{font-size:12px;color:var(--tx2);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.dp-radar-wrap{display:flex;justify-content:center}
.dp-radar-web{fill:none;stroke:var(--bd);stroke-width:1}
.dp-radar-axis{stroke:#334155;stroke-width:1}
.dp-radar-fill{fill:rgba(0,212,170,.2);stroke:var(--ac);stroke-width:2}
.dp-radar-label{font-size:11px;fill:var(--tx2)}
.dp-note{margin-top:8px;font-size:11px;line-height:1.45;color:var(--tx3)}
.dp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dp-metric{background:var(--bg3);border:1px solid var(--bd);border-radius:6px;padding:8px}
.dp-metric span{display:block;font-size:11px;color:var(--tx3)}
.dp-metric b{font-size:12px;font-weight:700;color:var(--tx);font-family:'JetBrains Mono',monospace}
.dp-zaa-total{display:inline-block;padding:4px 10px;border-radius:6px;background:rgba(0,212,170,.12);border:1px solid rgba(0,212,170,.35);font-size:12px;font-weight:700;color:var(--ac);font-family:'JetBrains Mono',monospace}
.dp-bars{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.dp-bar{display:grid;grid-template-columns:72px 1fr 40px;align-items:center;gap:8px;font-size:11px;color:var(--tx2)}
.dp-ztrack{position:relative;height:8px;background:var(--bg3);border-radius:999px;overflow:hidden;border:1px solid var(--bd)}
.dp-zzero{position:absolute;left:50%;top:-1px;bottom:-1px;width:1px;background:#64748b;transform:translateX(-50%)}
.dp-zfill{position:absolute;top:0;height:100%}
.dp-zfill.positive{background:linear-gradient(90deg,var(--blue),var(--ac))}
.dp-zfill.negative{background:linear-gradient(90deg,var(--red),var(--yel))}
.dp-bar b{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--tx);text-align:right}
.dp-chips{display:flex;flex-wrap:wrap;gap:6px}
.dp-chips span{font-size:11px;padding:3px 8px;border:1px solid var(--bd);background:var(--bg3);border-radius:999px;color:var(--tx2)}
.dp-eco{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dp-eco div{display:flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--bd);border-radius:6px;padding:7px 8px;font-size:11px;color:var(--tx2)}
.dp-eco b{font-family:'JetBrains Mono',monospace;color:var(--tx)}
.dp-eco span{font-size:11px;color:var(--tx3)}
.dp-eco-far{font-size:10px;color:var(--tx3);opacity:.6;margin-left:auto}

.dp-pyramid{display:flex;flex-direction:column;gap:9px}
.dp-pyramid-empty{font-size:11px;color:var(--tx3);padding:8px 10px;border:1px dashed var(--bd);border-radius:6px;background:var(--bg3)}
.dp-pyramid-bar{width:100%;padding:6px;background:var(--bg3);border:1px solid var(--bd);border-radius:8px}
.dp-pyramid-bar svg{display:block;width:100%;height:28px}
.dp-pyramid-legend{display:flex;flex-wrap:wrap;gap:7px 10px}
.dp-pyramid-li{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--tx2);line-height:1.35}
.dp-pyramid-li i{width:10px;height:10px;border-radius:2px;display:inline-block;flex-shrink:0}
.dp-pyramid-li b{font-weight:700;color:var(--tx)}
.dp-pipeline-label{font-size:11px;color:var(--tx2)}
.dp-pipeline-bar{height:8px;border-radius:999px;border:1px solid var(--bd);background:var(--bg3);overflow:hidden}
.dp-pipeline-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),#78c0ff)}
.dp-age-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dp-age-stat{background:var(--bg3);border:1px solid var(--bd);border-radius:6px;padding:8px}
.dp-age-stat span{display:block;font-size:11px;color:var(--tx3)}
.dp-age-stat b{display:block;margin-top:2px;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700}

.dp-proj{display:flex;flex-direction:column;gap:8px}
.dp-proj-row{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:8px;font-size:11px;color:var(--tx2)}
.dp-proj-year{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--tx3)}
.dp-proj-bar{height:10px;background:var(--bg3);border-radius:999px;overflow:hidden;border:1px solid var(--bd)}
.dp-proj-bar i{display:block;height:100%;border-radius:999px}
.dp-proj-row b{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--tx);white-space:nowrap}
.dp-proj-note{font-size:11px;color:var(--tx3);font-style:italic;padding-top:4px;border-top:1px solid var(--bd)}

@media(max-width:480px){
  #sidebar{height:60vh}
  #sidebar.sb-expanded{height:60vh}
  #sidebar.sb-expanded~#mc,
  #sidebar:not(.sb-collapsed)~#mc{bottom:60vh}

  .stats{grid-template-columns:1fr 1fr;gap:2px;padding:6px 12px}
  .st b{font-size:15px}
  .st small{font-size:10px}

  .sb-head h1{font-size:14px}
  .sb-head p{font-size:10px}
  .rname{font-size:12px}
  .rdet{font-size:10px}

  #ipanel{bottom:auto;top:8px;left:6px;right:6px;padding:12px 14px}
  #ipanel h3{font-size:13px}

  #detail-panel{height:80vh}
  #detail-panel-content{padding:14px 14px 20px}
  .dp-head h3{font-size:14px}
  .dp-grid,.dp-eco,.dp-age-grid{grid-template-columns:1fr}
  .dp-bar{grid-template-columns:56px 1fr 32px;font-size:10px}

  #legend{bottom:6px;right:6px;max-width:150px}
  #legend .leg-toggle{padding:6px 10px;font-size:10px}
  #legend .leg-body{padding:6px 10px}
  #legend h4{font-size:10px}
  #legend .lr{font-size:10px}

  .guide-card{width:96vw;padding:12px 14px}
  .guide-card h3{font-size:13px}
  .guide-li div{font-size:11px}
  .guide-li small{font-size:10px}

  .loading-card{width:92vw;padding:14px}
}
