:root{--floating-top:90px;--floating-margin:10px;--search-height:58px;--header-height:70px;--viewport-height:100dvh;--toolbar-height:0;--list-extra-offset:0px}
html,body{height:100%;min-height:100%;overflow:hidden}
body{margin:0;font-family:Arial,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;min-height:100%;display:flex;flex-direction:column;box-sizing:border-box}
body.welcome-open{overflow:hidden}
header{background:#111;color:#fff;display:flex;align-items:center;justify-content:center;position:fixed;top:0;left:0;right:0;z-index:5000;padding:14px 0;font-size:2.2rem;font-weight:900;letter-spacing:1px;box-shadow:0 2px 5px rgba(0,0,0,.25)}
header::after{content:"";flex:0 0 var(--scrollbar-width,0px);height:0;display:block}
.site-title{color:#fff;text-decoration:none;display:inline-block;letter-spacing:inherit}
.site-title:visited{color:#fff}
.site-title:hover{color:#fff}
.site-title:focus-visible{outline:2px solid #fff;outline-offset:4px}
.header-icons{position:absolute;right:20px;top:50%;transform:translateY(-50%);display:flex;gap:8px}
.header-icon{background:transparent;border:none;width:36px;height:26px;padding:0;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;position:relative}
.header-icon svg{width:26px;height:26px;color:#fff;pointer-events:none}
.header-icon:focus-visible{outline:2px solid #fff;outline-offset:3px}
.header-icon:hover{background:rgba(255,255,255,.12)}
.compass-trigger.locating svg{
  animation:spin .8s linear infinite;
}
@keyframes spin{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}
.filter-trigger.active{background:rgba(59,130,246,.35)}
.view-toolbar{position:fixed;top:calc(var(--header-height));left:0;right:0;z-index:1600;display:flex;justify-content:center;align-items:center;padding:8px 16px;background:#000;}
.view-toolbar[aria-hidden="true"]{display:none}
.view-count{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#fff;font-weight:600;font-size:.95rem;white-space:nowrap;text-align:left}
.view-toggle{display:inline-flex;gap:0;background:rgba(17,17,17,.92);border-radius:999px;box-shadow:0 14px 32px -18px rgba(15,23,42,.6);overflow:hidden;pointer-events:auto}
.view-toggle button{appearance:none;border:none;padding:8px 18px;font-size:.9rem;font-weight:600;color:rgba(248,250,252,.75);background:transparent;cursor:pointer;transition:background .25s ease,color .25s ease,opacity .25s ease;opacity:.45}
.view-toggle button.active{background:#fff;color:#111;opacity:1}
.view-toggle button:not(.active){opacity:.45}
.view-toggle button:not(.active):hover{background:rgba(255,255,255,.12)}
.view-toggle button:disabled{opacity:.45;cursor:not-allowed}
.print-button{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#fff;border:none;border-radius:999px;padding:7px 18px;font-weight:600;font-size:.85rem;color:#0f172a;cursor:pointer;box-shadow:0 12px 32px -20px rgba(15,23,42,.8);display:flex;align-items:center;gap:6px}
.print-button:hover{background:#f4f4f4}
.print-button:disabled{opacity:.5;cursor:not-allowed;visibility:hidden}
.print-button svg{width:16px;height:16px}
.print-button[hidden]{display:none}
@media (max-width:767px){
  .print-button{display:none!important}
}
.welcome-overlay{position:fixed;inset:0;background:rgba(15,23,42,.75);display:flex;align-items:center;justify-content:center;padding:16px;z-index:3500;opacity:0;pointer-events:none;transition:opacity .25s ease}
.welcome-overlay.visible{opacity:1;pointer-events:auto}
.welcome-content{background:#0b1220;border-radius:16px;max-width:520px;width:100%;padding:28px 32px;box-shadow:0 32px 64px -32px rgba(8,12,24,.85);color:rgba(244,247,254,.92);line-height:1.55;text-align:left;border:1px solid rgba(59,130,246,.35)}
.welcome-content h2{margin:0 0 12px;font-size:1.6rem;color:#f8fafc;font-weight:800}
.welcome-content p{margin:10px 0;color:rgba(226,232,240,.92)}
.welcome-content ul{margin:12px 0 18px 0;padding-left:22px;font-size:.95rem;color:rgba(226,232,240,.92)}
.welcome-steps{list-style:none;padding:0;margin:16px 0 0 0;display:flex;flex-direction:column;gap:12px}
.welcome-steps li{display:flex;gap:12px;align-items:flex-start}
.welcome-step-icon{width:38px;height:38px;border-radius:50%;background:rgba(37,99,235,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.welcome-step-icon svg{width:22px;height:22px;color:#fff}
.welcome-step-text{flex:1 1 auto}
.welcome-actions{display:flex;justify-content:flex-end}
.welcome-actions button{appearance:none;border:none;background:#2563eb;color:#fff;font-weight:600;padding:10px 18px;border-radius:999px;font-size:.95rem;cursor:pointer;box-shadow:0 16px 32px -24px rgba(15,23,42,.8)}
.header-icon[data-tooltip]::after,
.header-icon[data-tooltip]::before{display:none}
@media (hover:hover) and (pointer:fine){
  .header-icon[data-tooltip]::after,
  .header-icon[data-tooltip]::before{
    position:absolute;
    left:50%;
    opacity:0;
    pointer-events:none;
    transition:opacity .15s ease,transform .15s ease;
    display:block;
  }
  .header-icon[data-tooltip]::after{
    content:attr(data-tooltip);
    top:calc(100% + 8px);
    transform:translate(-50%,0);
    background:rgba(17,17,17,.9);
    color:#fff;
    padding:6px 10px;
    border-radius:6px;
    font-size:12px;
    white-space:nowrap;
    z-index:2100;
  }
  .header-icon[data-tooltip]::before{
    content:"";
    top:100%;
    transform:translate(-50%,0);
    border:6px solid transparent;
    border-top-color:transparent;
    border-bottom-color:rgba(17,17,17,.9);
    z-index:2100;
  }
  .header-icon[data-tooltip]:hover::after,
  .header-icon[data-tooltip]:focus-visible::after{
    opacity:1;
    transform:translate(-50%,4px);
  }
  .header-icon[data-tooltip]:hover::before,
  .header-icon[data-tooltip]:focus-visible::before{
    opacity:1;
    transform:translate(-50%,4px);
  }
  .header-icon[data-tooltip-align="right"]::after{
    left:auto;
    right:0;
    transform:translate(-8px,0);
  }
  .header-icon[data-tooltip-align="right"]:hover::after,
  .header-icon[data-tooltip-align="right"]:focus-visible::after{
    transform:translate(-8px,4px);
  }
  .header-icon[data-tooltip-align="right"]::before{
    left:auto;
    right:6px;
    transform:translate(0,0);
  }
  .header-icon[data-tooltip-align="right"]:hover::before,
  .header-icon[data-tooltip-align="right"]:focus-visible::before{
    transform:translate(0,4px);
  }
}
#map{flex:1;margin-top:calc(var(--header-height) + var(--toolbar-height));height:calc(var(--viewport-height) - var(--header-height) - var(--toolbar-height));min-height:200px}
.results-list{position:relative;margin-top:calc(var(--header-height) + var(--toolbar-height) + var(--list-extra-offset));height:calc(var(--viewport-height) - var(--header-height) - var(--toolbar-height) - var(--list-extra-offset));overflow-y:auto;padding:16px;display:none;background:rgba(15,23,42,.04)}
.results-list::after{content:"";display:block;height:16px}
.results-list.active{display:block}
.list-card{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 18px 36px -24px rgba(15,23,42,.6);margin-bottom:14px;line-height:1.45}
.list-card-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.list-card-header h3{margin:0;font-size:1.05rem;flex:1 1 auto;color:#0f172a}
.list-card-header .list-distance{font-size:.85rem;font-weight:600;color:#1d4ed8}
.list-rank,
.print-rank{width:26px;height:26px;aspect-ratio:1/1;flex:0 0 26px;border-radius:999px;background:#111;color:#fff;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;text-align:center;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.list-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px;font-size:.82rem;color:#475569}
.list-meta .badge{display:inline-flex;align-items:center;gap:6px;background:rgba(37,99,235,.1);color:#1d4ed8;padding:4px 9px;border-radius:999px;font-weight:600}
.list-meta .badge::before{content:"";width:8px;height:8px;border-radius:50%;display:inline-block;background:currentColor}
.list-card address{font-style:normal;margin:6px 0;color:#1f2937;font-size:.92rem}
.list-line{font-size:.85rem;color:#1f2937;margin:4px 0}
.list-line strong{font-weight:600;color:#0f172a}
.list-notes{margin-top:8px;font-size:.85rem;color:#475569}
.list-notes br{margin-bottom:4px}
.list-card .actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.list-card .actions a{flex:0 1 auto;background:#2563eb;color:#fff;border-radius:6px;padding:7px 14px;font-size:.85rem;text-decoration:none;font-weight:600;box-shadow:0 10px 20px -18px rgba(37,99,235,.6)}
.list-card .actions a.secondary{background:#2563eb;color:#fff;box-shadow:0 10px 20px -18px rgba(37,99,235,.6)}
.list-empty{margin:28px 0;text-align:center;color:#475569;font-size:.9rem}
.list-more{display:block;margin:16px auto 20px;padding:10px 22px;border-radius:999px;border:none;background:#111;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;box-shadow:0 12px 28px -20px rgba(15,23,42,.6);text-transform:uppercase;letter-spacing:.5px}
.list-more:hover{background:#222}
.menu-toggle{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:36px;height:26px;background:transparent;border:none;padding:0;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;z-index:2300}
.menu-toggle:focus-visible{outline:2px solid #fff;outline-offset:3px}
.menu-toggle span{display:block;height:3px;background:#fff;border-radius:2px;transition:transform .2s ease,opacity .2s ease}
.menu-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.menu-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
nav.menu{position:absolute;top:100%;left:12px;background:#111;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 10px 24px rgba(0,0,0,.35);padding:10px 0;min-width:160px;display:none;flex-direction:column;z-index:1}
nav.menu.open{display:flex}
nav.menu a{color:#fff;text-decoration:none;padding:9px 18px;font-size:16px;font-weight:600;letter-spacing:.5px}
nav.menu a:hover{background:rgba(255,255,255,.08)}
.search-toast{position:fixed;top:10px;right:5px;z-index:2200;background:rgba(17,17,17,.95);color:#fff;border-radius:10px;box-shadow:0 18px 40px -20px rgba(0,0,0,.55);padding:12px 14px;width:min(360px,calc(100vw - 40px));transform:translateY(-24px);opacity:0;pointer-events:none;display:flex;flex-direction:column;gap:10px;transition:transform .25s ease,opacity .2s ease;--address-open-offset:60px;outline:none;}
.search-toast.open{transform:translateY(var(--address-open-offset));opacity:1;pointer-events:auto;}
.search-toast label{font-size:.85rem;color:#cbd5f5}
.search-toast form{display:flex;flex-direction:column;gap:10px}
.search-toast form .toast-row{display:flex;align-items:center;gap:10px}
.search-toast form .toast-row{display:flex;align-items:center;gap:10px}
.search-toast input{flex:1 1 auto;min-width:0;padding:8px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:rgba(15,23,42,.65);color:#f8fafc}
.search-toast input:focus{outline:2px solid rgba(59,130,246,.8)}
.search-toast .toast-actions{display:flex;gap:10px;justify-content:flex-end;flex:0 0 auto;flex-wrap:nowrap}
.search-toast button{border:none;border-radius:6px;padding:7px 12px;font-weight:600;font-size:.85rem;cursor:pointer}
.search-toast button:disabled{opacity:.45;cursor:not-allowed}
.address-toast{position:fixed;top:10px;right:5px;z-index:2200;background:rgba(17,17,17,.95);border-radius:10px;box-shadow:0 18px 40px -20px rgba(0,0,0,.55);padding:12px 14px;width:min(360px,calc(100vw - 40px));transform:translateY(-24px);opacity:0;pointer-events:none;display:flex;transition:transform .25s ease,opacity .2s ease;--address-open-offset:60px;}
.address-toast.open{transform:translateY(var(--address-open-offset));opacity:1;pointer-events:auto;}
.address-toast form{width:100%;}
.address-toast input{width:100%;background:rgba(15,23,42,.65);border:1px solid rgba(255,255,255,.2);color:#f8fafc;padding:8px 10px;border-radius:6px;font-size:.85rem;}
.address-toast input::placeholder{color:rgba(203,213,245,.75);}
.address-toast input:focus{outline:2px solid rgba(59,130,246,.8);outline-offset:0;}
.map-toast{
  position:fixed;
  background:rgba(17,17,17,.94);
  color:#fff;
  padding:10px 18px;
  border-radius:10px;
  box-shadow:0 22px 40px -24px rgba(0,0,0,.9);
  font-size:.9rem;
  opacity:0;
  min-width:200px;
  max-width:320px;
  pointer-events:none;
  transform:translate(-50%,18px);
  transform-origin:top center;
  transition:opacity .15s ease,transform .2s ease;
  z-index:5200;
}
.map-toast.visible{
  opacity:1;
  transform:translate(-50%,0);
}
.search-toast .apply-search{background:#2563eb;color:#fff}
.search-toast .apply-search:hover{background:#1f4fd3}
.search-toast .clear-search{background:rgba(255,255,255,.12);color:#fff}
.search-toast .clear-search:hover{background:rgba(255,255,255,.22)}
.search-toast .clear-search.inactive{background:rgba(255,255,255,.08);color:rgba(255,255,255,.65)}
.search-toast .clear-search.inactive:hover{background:rgba(255,255,255,.12)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;overflow:visible;padding:10px 16px;background:#fff;color:#111;font-weight:600;border-radius:8px;box-shadow:0 8px 20px -12px rgba(15,23,42,.6);z-index:6000}
.bottom-controls{position:absolute;bottom:14px;left:0;right:0;z-index:1000;pointer-events:none;min-height:0;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:0 var(--floating-margin,10px)}
.bottom-controls > *{pointer-events:auto}
.legend{position:static;background:rgba(255,255,255,.95);border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.2);padding:8px 10px;font-size:12px;line-height:1.35;width:max-content;min-width:150px;flex:0 0 auto}
.legend .row{display:flex;align-items:center;gap:8px;margin:4px 0;cursor:pointer}
.legend input[type=checkbox]{margin:0}
.legend-title{font-weight:600;margin-bottom:4px}
.filter-cluster{position:static;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.day-filter{display:flex;gap:6px;flex:0 0 auto;align-items:center;flex-wrap:nowrap}
.day-filter .day-btn{flex:0 0 auto;background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:6px 14px;font-size:12px;font-weight:600;color:#1f2937;box-shadow:0 1px 3px rgba(15,23,42,.12);transition:all .2s ease;white-space:nowrap}
.day-filter .day-btn.active{background:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 12px 24px -14px rgba(37,99,235,.7)}
.day-filter .day-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}
.day-filter .day-btn:not(.active):hover{background:rgba(37,99,235,.06)}
.bottom-controls button,.bottom-controls input,.bottom-controls label,.bottom-controls .legend,.bottom-controls .day-filter,.bottom-controls .distance-filter{pointer-events:auto;touch-action:auto}
.swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid #999}
.distance-filter{position:relative;flex:0 0 auto;display:flex;align-items:center}
.distance-filter[hidden]{display:none!important}
.distance-btn{background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:6px 28px 6px 14px;font-size:12px;font-weight:600;color:#1f2937;box-shadow:0 1px 3px rgba(15,23,42,.12);cursor:pointer;transition:all .2s ease;position:relative}
.distance-btn::after{content:"\25BE";position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;color:inherit}
.distance-btn:hover{background:rgba(37,99,235,.06)}
.distance-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}
.distance-menu{position:absolute;bottom:110%;left:0;right:0;background:rgba(17,24,39,.95);border-radius:12px;padding:10px;box-shadow:0 24px 36px -22px rgba(0,0,0,.65);display:flex;flex-direction:column;gap:6px;z-index:1500}
.distance-menu[hidden]{display:none}
.distance-menu button{background:transparent;border:1px solid rgba(255,255,255,.2);color:#f8fafc;font-weight:600;padding:8px;border-radius:8px;font-size:12px;cursor:pointer}
.distance-menu button.active{background:#2563eb;border-color:#2563eb}
.distance-menu button:hover{background:rgba(255,255,255,.08)}
.location-pill{position:fixed;top:calc(var(--header-height) + var(--toolbar-height) + 12px);left:50%;transform:translateX(-50%);background:rgba(17,24,39,.92);color:#f8fafc;padding:12px 44px 12px 20px;border-radius:999px;font-size:13px;font-weight:500;box-shadow:0 18px 32px -20px rgba(15,23,42,.6);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:1400;max-width:min(380px,70vw);width:min(90vw,380px);text-align:center;line-height:1.45}
.location-pill.visible{opacity:1;transform:translate(-50%,12px);pointer-events:auto;cursor:pointer}
.location-pill .location-text{display:block;text-align:center}
.location-pill .location-close{position:absolute;top:8px;right:12px;background:transparent;border:none;color:inherit;font-size:16px;line-height:1;cursor:pointer;padding:4px;border-radius:4px}
.location-pill .location-close:hover{background:rgba(255,255,255,.12)}
.location-pill .location-close:focus-visible{outline:2px solid rgba(255,255,255,.65);outline-offset:2px}
.popup-card{width:240px;padding:4px 6px 5px;background:#fff;border-radius:8px;animation:fadeIn .25s ease}
.popup-card h3{margin:2px 0 6px;font-size:15px}
.popup-card .info-line{font-size:13px;margin:6px 0;display:grid;grid-template-columns:20px 1fr;gap:8px;align-items:flex-start}
.popup-card .info-line .icon{font-size:16px;line-height:1;text-align:center}
.popup-card .info-line.caution{color:#111;font-weight:600}
.popup-card .info-line.caution .icon{font-size:18px;color:#000}
.popup-card .info-line .icon{font-size:16px;line-height:1}
.popup-card .buttons{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.popup-card .btn{flex:1 1 48%;background:#2e86de;color:#fff;text-align:center;text-decoration:none;font-size:13px;padding:5px 0;border-radius:5px;transition:background .2s}
.popup-card .btn:hover{background:#1d6fd8}
.popup-card .notes{font-size:12px;color:#555;margin-top:10px;line-height:1.5;display:flex;gap:9px;align-items:flex-start}
.popup-card .notes .icon{font-size:16px;line-height:1}
.leaflet-popup-content-wrapper{padding:2px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.leaflet-popup-content{margin:0}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@media (max-width:600px){
  header{justify-content:flex-start;padding:12px 0}
  .menu-toggle{position:static;margin-left:16px;top:auto;transform:none;z-index:4000}
  .site-title{margin-left:12px;font-size:1.4rem}
  .header-icons{position:static;margin-left:auto;margin-right:16px;transform:none;gap:6px}
  .header-icon{width:32px;height:24px}
  .header-icon svg{width:22px;height:22px}
  .search-toast{top:calc(var(--header-height) + var(--toolbar-height));left:max(50px,var(--floating-margin));right:var(--floating-margin);width:auto;border-radius:0 0 10px 10px}
  .address-toast{top:calc(var(--header-height) + var(--toolbar-height));left:max(50px,var(--floating-margin));right:var(--floating-margin);width:auto;border-radius:0 0 10px 10px}
  nav.menu{left:16px}
  .distance-filter{width:100%;justify-content:flex-end}
}

@media (min-width:601px){
  .search-toast,
  .address-toast{
    transform:translateY(-30px);
    transition:opacity .25s ease;
    padding: 6px 14px;
  }
  .search-toast.open,
  .address-toast.open{
    transform:translateY(calc(var(--address-open-offset) + 4px));
  }
}
