:root{
  --lavender-rail:#a78bfa;
  --blue-train:#0ea5e9;
  --bg:#f5f7fb; --panel:rgba(255,255,255,.65); --border:rgba(0,0,0,.15);
  --text:#111; --muted:rgba(0,0,0,.65);
  --green-track:#146c2e; --green-lane:#00a86b; --orange:#F57C00; --purple:#6d28d9;
  --shadow: 0 8px 30px rgba(0,0,0,.08); --bike-swatch-h: 2px;
}
html,body{height:100%;margin:0}
body{background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif}
#map{position:absolute;inset:0}

.panel{position:absolute;top:56px;left:12px;display:flex;flex-direction:column;gap:12px;z-index:2000}
.card{backdrop-filter:blur(10px);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:12px;color:var(--text);max-width:460px;box-shadow:var(--shadow)}
h2,h3{margin:0 0 6px 0;font-size:14px;font-weight:700}
.subtitle{font-size:11px;color:var(--muted);margin-top:-2px}
.label{font-size:11px;color:var(--muted)}
.row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.col{display:flex;flex-direction:column;gap:8px}
input[type="range"]{width:100%}
.legend{list-style:none;padding:0;margin:4px 0 0 0}
.legend li{display:flex;align-items:center;gap:8px;font-size:11px;margin:6px 0}
.swatch{display:inline-block;width:14px;height:10px;border-radius:4px}

.line{display:inline-block;width:28px;height:12px;position:relative;vertical-align:middle;color:#222}
.line::after{content:"";position:absolute;left:0;right:0;top:50%;height:var(--bike-swatch-h);transform:translateY(-50%);background:currentColor;border-radius:2px}
.line.track{color:var(--green-track)} .line.lane{color:var(--green-lane)} .line.shared{color:var(--orange)} .line.transit{color:var(--purple)}

.footer{position:fixed;left:12px;bottom:8px;right:auto;padding:4px 10px;border-radius:10px;background:rgba(255,255,255,.6);backdrop-filter:blur(8px);font-size:11px;line-height:1.2;color:#111;text-align:left;box-shadow:var(--shadow);display:inline-block;max-width:60vw}
.status{font-size:11px;color:var(--muted);margin-top:6px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center}
.check{display:flex;align-items:center;gap:8px;font-size:12px}

.searchbar{position:relative; margin-top:8px}
.searchbox{display:flex; gap:8px; align-items:center; width:100%;}
.searchbox input{flex:1; border:1px solid var(--border); border-radius:12px; padding:10px 12px; font-size:13px; background:#fff; box-shadow:var(--shadow)}
.searchbox button{border:0;border-radius:12px;padding:10px 12px;background:#111;color:#fff;font-size:12px;cursor:pointer; box-shadow:var(--shadow)}
.searchbox button:hover{opacity:.9}
.results{position:absolute; left:0; right:0; top:100%; margin-top:6px; border:1px solid var(--border); background:#fff; border-radius:12px; overflow:hidden; box-shadow:var(--shadow); max-height:240px; overflow-y:auto; z-index:20}
.result{padding:8px 10px; font-size:13px; cursor:pointer}
.result[aria-selected="true"], .result:hover{background:#eef2ff}
.result small{display:block; color:#6b7280}

.loadrow{display:flex;align-items:center;gap:8px;font-size:12px;margin:6px 0}
.loadrow .status-text{color:var(--text)}
.loadrow .status-text.loading{color:#2563eb;font-weight:500}
@media (prefers-reduced-motion: reduce){
  .loading-dot{animation:none;opacity:1}
  .panel{transition:none}
}

.line.train{color:#6d28d9}

.panel{transition:transform .25s ease;max-width:460px}
.panel.closed{transform:translateX(calc(-100% - 24px))}
@media (max-width:768px){.panel{max-width:86vw}}

.menu-btn{position:fixed;top:12px;left:12px;z-index:3200;border:1px solid var(--border);border-radius:12px;padding:8px 12px;background:var(--panel);color:var(--text);font-weight:600;font-size:13px;cursor:pointer;backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.menu-btn:focus{outline:2px solid #93c5fd;outline-offset:2px}
.menu-btn:hover{opacity:.95}

/* === Persistent, compact legend pinned above the footer === */
#legendCard{
  position:fixed;
  left:12px;
  bottom:56px;   /* sits just above the map credits */
  z-index:3000;
  max-width:220px;
  padding:8px 10px;
  border-radius:12px;
  background:var(--panel, rgba(255,255,255,0.9));
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow, 0 6px 20px rgba(0,0,0,.12));
}

#legendCard h3{ margin:0 0 4px 0; font-size:12px; line-height:1.2; }
#legendCard .legend{ list-style:none; padding:0; margin:0; }
#legendCard .legend li{ margin:4px 0; font-size:10px; line-height:1.2; display:flex; align-items:center; gap:6px; }
#legendCard .legend .swatch{ width:12px; height:8px; border-radius:3px; display:inline-block; }


/* === Mobile legend collision avoidance === */
@media (max-width: 768px){
  /* When the left panel is OPEN, dock legend to bottom-right to avoid overlap */
  .panel:not(.closed) ~ #legendCard{
    left: auto;
    right: 12px;
  }
  /* Make the card extra compact on small screens */
  #legendCard{
    max-width: 180px;
    padding: 6px 8px;
  }
  #legendCard h3{ font-size:11px; }
  #legendCard .legend li{ font-size:9px; margin:3px 0; }
  #legendCard .legend .swatch{ width:10px; height:7px; }
}
