:root {
  --bg: #f7f6f3; --card: #fff; --ink: #1c1b19; --muted: #6b7280; --line: #e3e0d8;
  --accent: #1f5c3d; --open: #1a7f37; --closed: #b42318; --seasonal: #b54708; --unknown: #6b7280;
}
* { box-sizing: border-box; }
body {
  margin: 0; font: 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  color: var(--ink); background: var(--bg);
}
a { color: var(--accent); }
main { max-width: 880px; margin: 0 auto; padding: 1rem; }

.site-header {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  padding: .75rem 1rem; background: var(--accent); color: #fff;
}
.site-header a { color: #fff; text-decoration: none; }
.brand { font-weight: 700; font-size: 1.15rem; margin-right: auto; }
.site-header nav a { margin-left: 1rem; }

.filters {
  display: grid; gap: .6rem; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  align-items: end; background: var(--card); padding: 1rem; border: 1px solid var(--line);
  border-radius: 10px;
}
.filters .field { display: flex; flex-direction: column; }
.filters label { font-size: .75rem; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.filters input, .filters select { padding: .45rem; border: 1px solid var(--line); border-radius: 6px; font-size: 1rem; }
.filters button { padding: .55rem 1rem; background: var(--accent); color: #fff; border: 0; border-radius: 6px; cursor: pointer; }
.filters .clear { align-self: center; font-size: .85rem; }
.result-count { color: var(--muted); margin: 1rem 0 .5rem; }

.pass-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .5rem; }
.pass-card {
  display: grid; grid-template-columns: 1fr auto; gap: .15rem 1rem; align-items: center;
  background: var(--card); border: 1px solid var(--line); border-radius: 10px;
  padding: .8rem 1rem; text-decoration: none; color: var(--ink);
}
.pass-card:hover { border-color: var(--accent); }
.pass-name { font-weight: 600; }
.pass-meta { grid-column: 1; color: var(--muted); font-size: .9rem; }
.pass-card .badge { grid-column: 2; grid-row: 1 / span 2; }
.empty, .muted, .note { color: var(--muted); }

.badge { display: inline-flex; align-items: center; gap: .3rem; padding: .2rem .55rem; border-radius: 999px;
  font-size: .85rem; font-weight: 600; white-space: nowrap; border: 1px solid transparent; }
.badge-open { background: #e7f5ec; color: var(--open); border-color: #b7e0c4; }
.badge-closed { background: #fbeae8; color: var(--closed); border-color: #f0c2bc; }
.badge-seasonal { background: #fdf0e6; color: var(--seasonal); border-color: #f3d2b3; }
.badge-unknown { background: #f1f1ef; color: var(--unknown); border-color: var(--line); }
.badge-stale { opacity: .6; }

.back { display: inline-block; margin-bottom: .5rem; }
.facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: .5rem; padding: 0; }
.facts div { background: var(--card); border: 1px solid var(--line); border-radius: 8px; padding: .6rem .8rem; }
.facts dt { font-size: .72rem; text-transform: uppercase; color: var(--muted); letter-spacing: .03em; }
.facts dd { margin: .15rem 0 0; font-weight: 600; }
section { margin-top: 1.5rem; }
section h2 { font-size: 1.05rem; border-bottom: 2px solid var(--line); padding-bottom: .25rem; }
.status-list, .roads, .forecast, .sources { list-style: none; padding: 0; }
.status-list li, .roads li { padding: .4rem 0; border-bottom: 1px solid var(--line); }
.forecast { display: grid; gap: .3rem; }
.forecast li { display: grid; grid-template-columns: 1fr auto 2fr; gap: .5rem; padding: .3rem 0; border-bottom: 1px solid var(--line); }
.ftemp { font-weight: 600; text-align: right; }
.ref { background: var(--line); border-radius: 4px; padding: 0 .35rem; font-size: .8rem; }

.map-snippet { height: 280px; border-radius: 10px; }
.map-full { height: 70vh; min-height: 360px; border-radius: 10px; }
.map-legend { display: flex; gap: 1rem; align-items: center; color: var(--muted); font-size: .9rem; flex-wrap: wrap; }
.dot { display: inline-block; width: .8rem; height: .8rem; border-radius: 50%; margin-right: .25rem; vertical-align: middle; }
.dot-open { background: var(--open); } .dot-closed { background: var(--closed); }
.dot-seasonal { background: var(--seasonal); } .dot-unknown { background: var(--unknown); }
.pass-marker { width: 14px; height: 14px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 1px rgba(0,0,0,.3); cursor: pointer; }

.site-footer { max-width: 880px; margin: 2rem auto 0; padding: 1rem; border-top: 1px solid var(--line); color: var(--muted); font-size: .85rem; }
.disclaimer { font-weight: 600; }

@media (max-width: 520px) {
  .pass-card { grid-template-columns: 1fr; }
  .pass-card .badge { grid-column: 1; grid-row: auto; justify-self: start; }
}
