
:root{--bg:#e0e5ec;--surface:#e0e5ec;--ink:#1a1a1a;--ink-soft:#4a4a4a;--line:rgba(0,0,0,.06);--accent:#1e56c4;--accent-ink:#fff;--parking-mark:#111827;--live-ok:#16a34a;--live-full:#dc2626;--live-stale:#9ca3af;--neu-light:#ffffff;--neu-dark:#a3b1c6;--neu-elev:6px 6px 16px var(--neu-dark),-6px -6px 16px var(--neu-light);--neu-elev-sm:4px 4px 10px var(--neu-dark),-4px -4px 10px var(--neu-light);--neu-elev-xs:2px 2px 5px var(--neu-dark),-2px -2px 5px var(--neu-light);--neu-inset:inset 4px 4px 8px var(--neu-dark),inset -4px -4px 8px var(--neu-light);--neu-inset-xs:inset 2px 2px 4px var(--neu-dark),inset -2px -2px 4px var(--neu-light);--hl:linear-gradient(to right,transparent,var(--line) 18%,var(--line) 82%,transparent);--ease:cubic-bezier(0.16,1,0.3,1);--t-fast:150ms;color-scheme:light}
:root[data-theme="dark"]{--bg:#1a1a1a;--surface:#1a1a1a;--ink:#f4f4f4;--ink-soft:#a0a0a0;--line:rgba(255,255,255,.06);--accent:#4f82e8;--parking-mark:#fff;--neu-light:#2a2a2a;--neu-dark:#000;--neu-elev:6px 6px 16px var(--neu-dark),-6px -6px 16px var(--neu-light);--neu-elev-sm:4px 4px 10px var(--neu-dark),-4px -4px 10px var(--neu-light);--neu-elev-xs:2px 2px 5px var(--neu-dark),-2px -2px 5px var(--neu-light);--neu-inset:inset 4px 4px 8px var(--neu-dark),inset -4px -4px 8px var(--neu-light);--neu-inset-xs:inset 2px 2px 4px var(--neu-dark),inset -2px -2px 4px var(--neu-light);color-scheme:dark}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font:16px/1.55 system-ui,-apple-system,Segoe UI,sans-serif;padding:2rem 1rem;display:flex;justify-content:center;min-height:100vh}
main{width:100%;max-width:720px}
a{color:inherit}
.icon-svg,.parking-icon{display:block;flex-shrink:0}
.crumb-row{display:flex;gap:.9rem;align-items:center;margin:0 0 1.25rem;flex-wrap:wrap}
.crumb-row .crumb{margin:0;flex:1;min-width:0}
.crumb-row .compact-search{margin:0;flex:0 0 auto;min-width:220px;max-width:340px}
@media(max-width:600px){.crumb-row{flex-direction:column;align-items:stretch}.crumb-row .compact-search{max-width:none}}
.crumb{font-size:.88rem;color:var(--ink-soft);margin:0 0 1.25rem}
.crumb a{text-decoration:none}
.crumb a:hover{text-decoration:underline}
.crumb .sep{margin:0 .4rem;color:var(--ink-soft);opacity:.65}
.hero{display:flex;align-items:center;gap:.85rem;margin:0 0 1.1rem}
.hero .pico{flex-shrink:0}
.hero h1{font-size:clamp(1.55rem,1.2rem + 1.4vw,2.15rem);line-height:1.1;margin:0;letter-spacing:-.015em}
.lede{color:var(--ink-soft);margin:0 0 2rem;font-size:.98rem}
.card{background:var(--surface);border:0;border-radius:18px;overflow:hidden;margin:0 0 1.75rem;box-shadow:var(--neu-inset)}
.card h2{font-size:1rem;font-weight:600;margin:0;padding:.95rem 1.15rem;background:transparent;letter-spacing:-.005em}
.card h2:not(:only-child){border-bottom:1px solid transparent;border-image:var(--hl) 1}
.card h2:first-child:last-child{border-bottom:0}
dl{margin:0;display:grid;grid-template-columns:minmax(140px,40%) 1fr}
dt,dd{margin:0;padding:.72rem 1rem;border-bottom:1px solid transparent;border-image:var(--hl) 1;font-size:.94rem}
dt{color:var(--ink-soft);font-weight:500}
dd{color:var(--ink);overflow-wrap:anywhere}
dl>:nth-last-child(-n+2){border-bottom:0}
@media(max-width:520px){dl{grid-template-columns:1fr}dt{padding-bottom:.1rem;border-bottom:0}dd{padding-top:.1rem}}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:.6rem 1rem;border-bottom:1px solid transparent;border-image:var(--hl) 1}
tbody tr:last-child th,tbody tr:last-child td{border-bottom:0}
th{color:var(--ink-soft);font-weight:500}
.tag-row{display:flex;flex-wrap:wrap;gap:.35rem;padding:.75rem 1rem .9rem;font-size:.82rem}
.tag{display:inline-flex;align-items:center;background:var(--surface);color:var(--accent);border:0;border-radius:999px;padding:.25rem .75rem;font-weight:500;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast)}
.tag:hover{box-shadow:var(--neu-elev-sm);color:color-mix(in srgb,var(--accent) 80%,var(--ink))}
.dot{display:inline-block;width:.75rem;height:.75rem;border-radius:50%;vertical-align:middle;margin-right:.5rem}
.dot.live{background:var(--live-ok);box-shadow:0 0 0 0 color-mix(in srgb,var(--live-ok) 55%,transparent);animation:pulse 2s infinite}
.dot.full{background:var(--live-full)}
.dot.stale{background:var(--live-stale)}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--live-ok) 55%,transparent)}70%{box-shadow:0 0 0 .6rem rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}
.live-card .live-count{padding:1.05rem 1rem .3rem;margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.01em}
.live-card .live-count strong{font-size:1.7rem;font-weight:800}
.live-card .live-meta{padding:0 1rem 1rem;margin:0;color:var(--ink-soft);font-size:.85rem}
.live-card .live-stale-note{color:var(--live-stale)}
.live-card .live-note{padding:.6rem 1rem;margin:0;border-top:1px solid transparent;border-image:var(--hl) 1;font-size:.8rem;color:var(--ink-soft);line-height:1.45}
.tariff-bucket{padding:.9rem 1rem;border-bottom:1px solid transparent;border-image:var(--hl) 1}
.tariff-bucket:last-of-type{border-bottom:0}
.tariff-bucket h3{font-size:.92rem;font-weight:600;margin:0 0 .45rem;color:var(--ink);letter-spacing:-.005em}
.tariff-window{color:var(--ink-soft);font-weight:400;font-size:.85rem;margin-left:.25rem}
.card .tariff-dl{display:grid;grid-template-columns:1fr auto;gap:.22rem .75rem;margin:0;font-size:.93rem}
.card .tariff-dl dt,.card .tariff-dl dd{padding:.08rem 0;border:0;font-size:.93rem}
.card .tariff-dl dt{color:var(--ink-soft);font-weight:400}
.card .tariff-dl dd{color:var(--ink);text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.tariff-free{padding:.1rem 0;margin:0;color:var(--live-ok);font-weight:700}
.tariff-note{padding:.7rem 1rem;margin:0;color:var(--ink-soft);font-size:.78rem;font-style:italic;border-top:1px solid transparent;border-image:var(--hl) 1}
.ai-summary{padding:.9rem 1rem;margin:0;color:var(--ink);font-size:.95rem}
.ai-summary p{margin:.7rem 0}
.ai-summary p:first-child{margin-top:0}
.ai-summary p:last-child{margin-bottom:0}
.qa-list{padding:.6rem 1rem 1.1rem;margin:0;display:flex;flex-direction:column;gap:.65rem}
.qa-item{background:var(--surface);border:0;border-radius:14px;padding:.85rem 1.05rem;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast)}
.qa-item[open]{box-shadow:var(--neu-inset-xs)}
.qa-item summary{list-style:none;cursor:pointer;color:var(--ink);font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:.85rem;padding:0;line-height:1.4}
.qa-item summary::-webkit-details-marker{display:none}
.qa-item summary::after{content:'›';flex-shrink:0;width:1.2rem;height:1.2rem;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:400;line-height:1;color:var(--ink-soft);transition:transform var(--t-fast) var(--ease),color var(--t-fast)}
.qa-item[open] summary::after{transform:rotate(90deg);color:var(--accent)}
.qa-item summary:hover::after{color:var(--accent)}
.qa-item .qa-answer{padding:.7rem 0 .1rem;color:var(--ink-soft);font-size:.95rem;line-height:1.55}
.source-list{padding:.75rem 1rem;margin:0;border-top:1px solid transparent;border-image:var(--hl) 1;font-size:.82rem;color:var(--ink-soft)}
.source-list a{color:var(--ink-soft);text-decoration:none}
.source-list a:hover{text-decoration:underline;color:var(--accent)}
.map-card{padding:0}
.map-wrap{position:relative;height:340px;background:color-mix(in srgb,var(--ink) 4%,var(--bg))}
.map-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--ink-soft);font-size:.95rem;text-align:center;padding:1rem}
.map-card-empty .map-wrap{height:140px}
#map{height:100%;width:100%;background:inherit}
#map.leaflet-container{font:inherit}
.leaflet-control-attribution{font-size:10px!important;opacity:.72;padding:1px 6px!important;background:color-mix(in srgb,var(--bg) 90%,transparent)!important;color:var(--ink-soft)!important}
.leaflet-control-attribution a{color:var(--ink-soft)!important;text-decoration:none}
.leaflet-control-attribution a:hover{text-decoration:underline}
.leaflet-control-attribution svg,.leaflet-attribution-flag{display:none!important}
.leaflet-control-attribution a[href*="leaflet"],.leaflet-control-attribution a[title*="Leaflet"]{display:none!important}
.leaflet-control-zoom a{background:var(--bg)!important;color:var(--ink)!important;border-color:var(--line)!important}
.leaflet-control-zoom a:hover{background:color-mix(in srgb,var(--ink) 5%,var(--bg))!important}
.vpp-marker{width:36px;height:36px;display:grid;place-items:center;background:color-mix(in srgb,var(--surface) 96%,#fff);border:2px solid #fff;border-radius:10px;box-shadow:0 4px 10px rgba(0,0,0,.25)}
.vpp-marker-sm{width:26px;height:26px;border-width:1.5px;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.map-parking-icon{width:22px;height:22px}
.vpp-marker-sm .map-parking-icon{width:16px;height:16px}
.map-approx{padding:.55rem 1rem;font-size:.8rem;color:var(--ink-soft);border-top:1px solid transparent;border-image:var(--hl) 1}
.map-actions{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-top:1px solid transparent;border-image:var(--hl) 1;flex-wrap:wrap}
.route-btn{display:inline-flex;align-items:center;justify-content:center;background:#1e56c4;color:#fff;text-decoration:none;padding:.5rem .95rem;border-radius:999px;font-size:.88rem;font-weight:600;letter-spacing:.005em;box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast)}
.route-btn:hover{background:#1849a8;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.22)}
.route-btn:active{transform:translateY(0);box-shadow:0 1px 3px rgba(0,0,0,.2) inset}
.route-alt{font-size:.82rem;color:var(--ink-soft)}
.route-alt>summary{cursor:pointer;list-style:none;padding:.35rem .6rem;border-radius:8px;transition:background var(--t-fast)}
.route-alt>summary::-webkit-details-marker{display:none}
.route-alt>summary::after{content:" ▾";font-size:.7em;opacity:.7;margin-left:.2em}
.route-alt[open]>summary::after{content:" ▴"}
.route-alt>summary:hover{background:color-mix(in srgb,var(--ink) 5%,transparent)}
.route-alt a{display:inline-block;margin:.35rem .55rem 0 0;padding:.4rem .75rem;border-radius:999px;background:var(--surface);color:var(--ink);text-decoration:none;font-size:.82rem;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast)}
.route-alt a:hover{box-shadow:var(--neu-elev-sm)}
.type-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 1.5rem;padding:0}
.type-tabs a{padding:.45rem .95rem;border:0;border-radius:999px;text-decoration:none;color:var(--ink-soft);font-size:.86rem;font-weight:500;white-space:nowrap;background:var(--surface);box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast),background var(--t-fast)}
.type-tabs a.active{background:var(--accent);color:#fff;box-shadow:var(--neu-inset-xs)}
.type-tabs a:hover:not(.active){box-shadow:var(--neu-elev-sm);color:var(--ink)}
.type-tabs .count{opacity:.72;margin-left:.2rem;font-weight:400}
.fac-list{list-style:none;margin:0;padding:0}
.fac-list li{border-bottom:1px solid transparent;border-image:var(--hl) 1}
.fac-list li:last-child{border-bottom:0}
.fac-row{display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;padding:.85rem 1rem;text-decoration:none;color:inherit;align-items:center;border-left:3px solid transparent;transition:background var(--t-fast),border-left-color var(--t-fast)}
.fac-row:hover{background:color-mix(in srgb,var(--accent) 6%,var(--surface));border-left-color:color-mix(in srgb,var(--accent) 60%,transparent)}
.fac-row .fac-icon{width:34px;height:34px;display:grid;place-items:center;flex-shrink:0}
.fac-body{min-width:0}
.fac-name{font-weight:600;font-size:.97rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fac-meta{color:var(--ink-soft);font-size:.82rem;margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fac-live{font-size:.85rem;color:var(--ink-soft);text-align:right;flex-shrink:0;min-width:72px}
.fac-live-on{color:var(--live-ok);font-weight:700}
.fac-live-full{color:var(--live-full);font-weight:700}
.fac-empty{padding:2rem 1rem;text-align:center;color:var(--ink-soft);font-size:.95rem}
.poi-cta{padding:1rem 1.25rem;text-align:center}
.poi-cta a{font-weight:600;color:var(--accent);text-decoration:none;font-size:1rem}
.poi-cta a:hover{text-decoration:underline}
.search-bar{display:flex;align-items:center;gap:.5rem;margin:0 0 1.5rem;background:var(--accent);border-radius:999px;padding:.4rem .4rem .4rem 1.4rem;box-shadow:inset 4px 4px 8px color-mix(in srgb,#000 35%,transparent),inset -4px -4px 8px color-mix(in srgb,#fff 18%,transparent);transition:box-shadow var(--t-fast)}
.search-bar:focus-within{box-shadow:inset 4px 4px 8px color-mix(in srgb,#000 35%,transparent),inset -4px -4px 8px color-mix(in srgb,#fff 18%,transparent),0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}
.search-bar input{flex:1;font:inherit;font-size:1.05rem;font-weight:500;padding:.85rem 0;border:0;background:transparent;color:#fff;min-width:0;outline:none}
.search-bar input::placeholder{color:rgba(255,255,255,.7)}
.search-bar button{font:inherit;font-size:1.25rem;width:3rem;height:3rem;padding:0;border:0;background:var(--surface);color:var(--ink);border-radius:50%;cursor:pointer;display:grid;place-items:center;flex-shrink:0;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast)}
.search-bar button:hover{color:var(--accent);box-shadow:var(--neu-elev-sm)}
.search-bar button:active{box-shadow:var(--neu-inset-xs)}
.search-icon{display:block;width:1em;height:1em;transform:translateY(-1px)}
.search-kind{display:inline-block;min-width:54px;padding:.1rem .45rem;border-radius:4px;background:color-mix(in srgb,var(--accent) 10%,var(--bg));color:var(--accent);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;text-align:center;margin-right:.6rem;vertical-align:middle}
.search-empty{padding:2rem 1rem;text-align:center;color:var(--ink-soft)}
.letter-nav{display:flex;flex-wrap:wrap;gap:.3rem;margin:0 0 1.5rem;font-size:.9rem}
.letter-nav a{padding:.25rem .55rem;border:1px solid var(--line);border-radius:6px;text-decoration:none;color:var(--ink-soft)}
.letter-nav a:hover{border-color:var(--accent);color:var(--accent)}
.city-group{padding:.75rem 1rem;border-bottom:1px solid transparent;border-image:var(--hl) 1}
.city-group:last-child{border-bottom:0}
.city-group h3{margin:0 0 .4rem;font-size:.95rem;color:var(--accent)}
.city-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.25rem .8rem;font-size:.88rem}
.city-list a{text-decoration:none;color:var(--ink)}
.city-list a:hover{color:var(--accent);text-decoration:underline}
.city-list small{color:var(--ink-soft);font-size:.78rem}
.home-cities{margin:1.5rem 0 0;text-align:center}
.home-cities h2{font-size:.92rem;font-weight:600;color:var(--ink-soft);margin:0 0 .6rem}
.home-cities a{color:var(--ink);text-decoration:none;font-size:.85rem;margin:0 .3rem}
.home-cities a:hover{color:var(--accent);text-decoration:underline}
.compact-search{margin:0 0 1.5rem}
.compact-search form{position:relative;display:flex;align-items:center;background:var(--accent);border-radius:999px;padding:.25rem .25rem .25rem 1.05rem;box-shadow:inset 2px 2px 4px color-mix(in srgb,#000 35%,transparent),inset -2px -2px 4px color-mix(in srgb,#fff 18%,transparent);transition:box-shadow var(--t-fast);gap:.4rem}
.compact-search form:focus-within{box-shadow:inset 2px 2px 4px color-mix(in srgb,#000 35%,transparent),inset -2px -2px 4px color-mix(in srgb,#fff 18%,transparent),0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}
.compact-search .cs-input{flex:1;background:transparent;border:0;padding:.45rem 0;font:inherit;font-size:.9rem;color:#fff;min-width:0;outline:none}
.compact-search .cs-input::placeholder{color:rgba(255,255,255,.7)}
.compact-search button{flex-shrink:0;width:2.2rem;height:2.2rem;padding:0;border:0;background:var(--surface);color:var(--ink);border-radius:50%;font:inherit;font-size:1rem;cursor:pointer;display:grid;place-items:center;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast)}
.compact-search button:hover{color:var(--accent);box-shadow:var(--neu-elev-sm)}
.compact-search button:active{box-shadow:var(--neu-inset-xs)}
.search-icon{display:block;width:1em;height:1em;transform:translateY(-1px)}
.cs-results{position:absolute;top:calc(100% + .55rem);left:0;right:0;margin:0;padding:.3rem;list-style:none;background:var(--accent);border-radius:14px;box-shadow:var(--neu-elev);z-index:40}
.cs-results li{margin:0;padding:0}
.cs-results li a{display:block;padding:.55rem .75rem;border-radius:10px;color:#fff;text-decoration:none;transition:background var(--t-fast)}
.cs-results li a:hover,.cs-results li a:focus-visible{background:color-mix(in srgb,#fff 14%,transparent);outline:none}
.cs-results strong{display:block;font-weight:600;font-size:.92rem}
.cs-results small{display:block;color:rgba(255,255,255,.7);font-size:.78rem;margin-top:.1rem}
footer{margin-top:3rem;text-align:center;color:var(--ink-soft);font-size:.82rem}
footer a,.crumb a,.type-tabs a{color:inherit;text-decoration:none}
footer a:hover,footer a:focus-visible,.crumb a:hover,.crumb a:focus-visible{color:var(--accent);text-decoration:underline;text-underline-offset:.2em;text-decoration-thickness:1px}
.footer-disclaimer{max-width:46rem;margin:0 auto 1rem;padding:.7rem 1rem;border-radius:12px;background:var(--surface);box-shadow:var(--neu-inset-xs);font-size:.78rem;color:var(--ink-soft);text-align:left;line-height:1.45}
.footer-disclaimer span{color:var(--accent);font-weight:600;margin-right:.15rem}
.inferred-mark{color:var(--accent);text-decoration:none;font-weight:600;margin-left:.12rem;font-size:.85em;vertical-align:.25em}
.inferred-mark:hover,.inferred-mark:focus-visible{text-decoration:underline;text-underline-offset:2px}
.lede a,.qa-answer a,.ai-summary a,.tariff-note a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-skip-ink:auto;transition:text-underline-offset var(--t-fast) var(--ease)}
.lede a:hover,.qa-answer a:hover,.ai-summary a:hover,.tariff-note a:hover{text-underline-offset:4px}
:where(a,.tag,.fac-row,button):focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
body.home-page{background:var(--bg);color:var(--ink);font:16px/1.5 system-ui,-apple-system,Segoe UI,sans-serif;min-height:100vh;display:grid;place-items:center;padding:1rem}
body.home-page main{width:100%;max-width:32rem;text-align:center}
body.home-page .brand{display:flex;align-items:center;justify-content:center;gap:.55rem;margin:0 0 1.6rem;color:var(--ink-soft);font-size:.95rem;font-weight:500}
body.home-page .brand svg{width:24px;height:24px}
body.home-page h1{font-size:clamp(1.85rem,1.45rem + 1.6vw,2.45rem);font-weight:800;margin:0 0 1.5rem;letter-spacing:-.02em}
body.home-page .hero-search{position:relative;display:flex;align-items:center;background:var(--accent);border-radius:999px;padding:.45rem .45rem .45rem 1.5rem;box-shadow:inset 4px 4px 8px color-mix(in srgb,#000 35%,transparent),inset -4px -4px 8px color-mix(in srgb,#fff 18%,transparent);gap:.55rem;transition:box-shadow var(--t-fast)}
body.home-page .hero-search:focus-within{box-shadow:inset 4px 4px 8px color-mix(in srgb,#000 35%,transparent),inset -4px -4px 8px color-mix(in srgb,#fff 18%,transparent),0 0 0 2px color-mix(in srgb,var(--accent) 35%,transparent)}
body.home-page .q-input{flex:1;font:inherit;font-size:1.1rem;font-weight:500;padding:.95rem 0;border:0;background:transparent;color:#fff;min-width:0;letter-spacing:.005em;outline:none}
body.home-page .q-input::placeholder{color:rgba(255,255,255,.7)}
body.home-page .cs-results{position:absolute;top:calc(100% + .8rem);left:0;right:0;margin:0;padding:.4rem;list-style:none;background:var(--accent);border-radius:14px;box-shadow:var(--neu-elev);z-index:40;text-align:left}
body.home-page .cs-results li{margin:0;padding:0}
body.home-page .cs-results li a{display:block;padding:.6rem .85rem;border-radius:10px;color:#fff;text-decoration:none;transition:background var(--t-fast)}
body.home-page .cs-results li a:hover,body.home-page .cs-results li a:focus-visible{background:color-mix(in srgb,#fff 14%,transparent);outline:none}
body.home-page .cs-results strong{display:block;font-weight:600;font-size:1rem}
body.home-page .cs-results small{display:block;color:rgba(255,255,255,.7);font-size:.82rem;margin-top:.1rem}
body.home-page .hero-search button{font:inherit;font-size:1.35rem;width:3.2rem;height:3.2rem;padding:0;border:0;background:var(--surface);color:var(--ink);border-radius:50%;cursor:pointer;display:grid;place-items:center;flex-shrink:0;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast)}
body.home-page .hero-search button:hover{color:var(--accent);box-shadow:var(--neu-elev-sm)}
body.home-page .hero-search button:active{box-shadow:var(--neu-inset-xs)}
body.home-page footer{margin-top:2rem;text-align:center;color:var(--ink-soft);font-size:.78rem;padding:0 1rem}


.theme-switch{position:fixed;top:.9rem;right:.95rem;display:inline-block;background:none;border:0;padding:0;cursor:pointer;z-index:50;-webkit-tap-highlight-color:transparent}
.theme-switch:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:999px}
.theme-switch-track{position:relative;display:block;width:56px;height:30px;border-radius:999px;background:var(--surface);box-shadow:var(--neu-inset-xs)}
.theme-switch-thumb{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:var(--surface);box-shadow:var(--neu-elev-xs);transform:translateX(0);transition:transform 280ms var(--ease),box-shadow 280ms;display:grid;place-items:center}
:root[data-theme="dark"] .theme-switch-thumb{transform:translateX(26px)}
.theme-switch:active .theme-switch-thumb{box-shadow:var(--neu-elev-sm)}
.theme-switch .theme-icon{position:absolute;line-height:1;color:var(--ink-soft);transition:transform 280ms var(--ease),opacity 280ms ease}
.theme-switch .theme-icon .icon-svg{width:14px;height:14px}
:root:not([data-theme="dark"]) .theme-icon-sun{opacity:1;transform:rotate(0) scale(1)}
:root:not([data-theme="dark"]) .theme-icon-moon{opacity:0;transform:rotate(90deg) scale(.4)}
:root[data-theme="dark"] .theme-icon-sun{opacity:0;transform:rotate(-90deg) scale(.4)}
:root[data-theme="dark"] .theme-icon-moon{opacity:1;transform:rotate(0) scale(1)}
@media(prefers-reduced-motion:reduce){.theme-switch-thumb,.theme-switch .theme-icon{transition:none}}
.location-button{position:fixed;top:.9rem;right:4.65rem;width:28px;height:28px;border:0;border-radius:50%;background:var(--surface);color:var(--live-full);cursor:pointer;display:grid;place-items:center;line-height:1;padding:0;box-shadow:var(--neu-elev-xs);transition:box-shadow var(--t-fast),color var(--t-fast);z-index:50;-webkit-tap-highlight-color:transparent}
.location-button .icon-svg{width:17px;height:17px}
.location-button:hover{color:color-mix(in srgb,var(--live-full) 80%,#000);box-shadow:var(--neu-elev-sm)}
.location-button:active{box-shadow:var(--neu-inset-xs)}
.location-button[data-state="active"]{color:var(--live-full)}
.location-button:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(max-width:380px){.location-button{right:4.4rem}}
.share-button{position:fixed;top:.9rem;right:7.4rem;width:28px;height:28px;border:0;border-radius:50%;background:#1e56c4;color:#fff;cursor:pointer;display:grid;place-items:center;line-height:1;padding:0;box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);z-index:50;-webkit-tap-highlight-color:transparent}
.share-button .icon-svg{width:15px;height:15px}
.share-button:hover{background:#1849a8;transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.22)}
.share-button:active{transform:translateY(0);box-shadow:0 1px 3px rgba(0,0,0,.2) inset}
.share-button:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(max-width:380px){.share-button{right:7.15rem}}
.share-toast{position:fixed;top:3.6rem;right:.95rem;background:var(--ink);color:var(--bg);padding:.5rem .9rem;border-radius:10px;font-size:.85rem;box-shadow:0 6px 18px rgba(0,0,0,.25);opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity 180ms var(--ease),transform 180ms var(--ease);z-index:60}
.share-toast[data-visible="true"]{opacity:1;transform:translateY(0)}
