@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--color-text: #111;--color-bg: #f8f8f8;--color-muted: #2b2b2b;--color-border: #111;--color-cta-bg: #111;--color-cta-text: #fff;--color-panel-bg: rgba(255, 255, 255, .96);--color-surface: #fff;--color-progress-track: #e0e0e0;--color-progress-fill: #111;--color-map-bg: #f8f8f8;--tile-filter: grayscale(1) contrast(1.05);--route-color-1: #f36c21;--route-color-2: #2563eb;--route-color-3: #1f8f4e;--route-color-4: #2563eb;--map-radius-color: #111;--map-radius-weight: 1;--map-radius-fill-opacity: .05;--map-poi-radius: 14;--map-poi-weight: 1;--map-poi-fill-opacity: .7;--map-location-radius: 6;--map-location-color: #1e88e5;--map-location-weight: 2;--map-location-fill-opacity: .9;--map-route-outline-color: #f8f8f8;--map-route-outline-weight: 8;--map-route-outline-weight-selected: 9;--map-route-outline-opacity: 1;--map-route-line-weight: 5;--map-route-line-weight-selected: 6;--map-route-line-opacity: .8;--map-route-line-opacity-selected: .95;--map-route-stop-radius: 6;--map-route-stop-color: #111;--map-route-stop-weight: 2;--map-route-stop-fill-color: #fff;--map-route-stop-fill-opacity: 1;--poi-color-historic: #C8922A;--poi-color-temple: #C0392B;--poi-color-pond: #1A7A8A;--poi-color-other: #7D8471;--poi-color-aircraft: #2E86DE;--poi-color-archaeological_site:#7B3F00;--poi-color-building: #8B7355;--poi-color-castle: #D4730A;--poi-color-city_gate: #1B4D3E;--poi-color-garden: #4A7C59;--poi-color-house: #E8B84B;--poi-color-lake: #0E6B80;--poi-color-manor: #7E3D8F;--poi-color-memorial: #A0445A;--poi-color-monument: #C1121F;--poi-color-park: #5A8A3C;--poi-color-ruins: #A67C52;--poi-color-tomb: #3D5A99}:root[data-theme=dark]{--color-text: #f5f6f7;--color-bg: #0f1114;--color-muted: #c0c6cf;--color-border: #3a4048;--color-cta-bg: #f5f6f7;--color-cta-text: #0f1114;--color-panel-bg: rgba(20, 23, 28, .96);--color-surface: #171b20;--color-progress-track: #2b3138;--color-progress-fill: #f5f6f7;--color-map-bg: #f8f8f8;--tile-filter: grayscale(1) contrast(1.05)}:root{font-family:Space Grotesk,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;color-scheme:light dark}*{box-sizing:border-box}body{margin:0;min-height:100vh;min-height:100svh;min-height:100dvh;background:var(--color-bg)}a{color:inherit;text-decoration:none}button{font-family:inherit}#root{min-height:100vh;min-height:100svh;min-height:100dvh}.page{min-height:100vh;min-height:100svh;min-height:100dvh;padding:4rem 6vw 5rem;background:var(--color-bg);color:var(--color-text);display:flex;flex-direction:column;gap:3rem}.page>*{max-width:600px;width:100%;margin-left:auto;margin-right:auto}.hero{display:grid;gap:1rem}.hero h1{font-size:clamp(2.4rem,4vw,3.6rem);margin:0}.subhead{font-size:1.05rem;margin:0;line-height:1.6;color:var(--color-muted);text-align:justify}.doc-section{display:grid;gap:1rem}.doc-section h2{margin:0;font-size:1.4rem;text-align:center}.doc-section h3{margin:0;font-size:1.05rem}.doc-section p{margin:0;line-height:1.7;text-align:justify}.doc-section a{color:inherit;text-decoration:underline}.disclaimer{margin:0;font-size:.85rem;color:var(--color-muted);line-height:1.5;word-break:break-word;text-align:center}.disclaimer a{text-decoration:underline}.site-footer{margin-top:auto;padding-top:.75rem;font-size:.8rem;color:var(--color-muted);text-align:center}.site-footer a+a:before{content:"|";margin:0 .6rem;color:var(--color-muted)}.cta{width:100%;border:1px solid var(--color-border);background:var(--color-cta-bg);color:var(--color-cta-text);padding:.8rem 1.6rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.2em;cursor:pointer}.cta.secondary{background:transparent;color:var(--color-text)}.cta.transparent{border-color:var(--color-border)}.cta+.disclaimer{margin-top:.65rem}.cta:disabled{opacity:.4;cursor:not-allowed}.map-screen{position:relative;width:100vw;height:100vh;height:100svh;height:100dvh;background:var(--color-map-bg);color:var(--color-text);overflow:hidden}.map{position:absolute;inset:0;height:100%;width:100%}.leaflet-tile{filter:var(--tile-filter)}.route-panel{position:absolute;right:6vw;bottom:2rem;width:min(360px,90vw);border:1px solid var(--color-border);background:var(--color-panel-bg);padding:1.5rem;display:grid;gap:1.1rem;z-index:1000}.route-panel--compact{padding:1rem 1.1rem;gap:.8rem}.route-panel--compact .route-item{padding:.6rem .8rem;font-size:.9rem}.route-panel--compact .route-actions{gap:.6rem}.route-panel h2{margin:0;font-size:1.3rem}.route-panel__header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.route-panel-toggle{border:1px solid var(--color-border);background:transparent;color:var(--color-text);padding:0;font-size:.9rem;letter-spacing:.08em;cursor:pointer}.route-panel-toggle--outside{position:absolute;top:1px;right:-1px;width:1.6rem;height:1.6rem;display:grid;place-items:center;background:var(--color-panel-bg);border-bottom:0;transform:translateY(-100%)}.route-panel--hidden{background:transparent;border:none;padding:0;width:auto;left:auto}.panel-copy{margin:0;color:var(--color-muted);line-height:1.5}.progress{height:4px;background:var(--color-progress-track);overflow:hidden}.progress-bar{height:100%;background:var(--color-progress-fill);transition:width .16s ease}.route-list{display:grid;gap:.75rem}.route-item{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--color-border);background:var(--color-surface);padding:.7rem .9rem;font-size:.95rem;cursor:pointer}.route-meta{display:inline-flex;align-items:center;gap:.5rem}.route-swatch{width:.55rem;height:.55rem;border-radius:2px;background:currentColor;flex-shrink:0}.route-item.active{background:var(--color-cta-bg);color:var(--color-cta-text)}.distance{font-variant-numeric:tabular-nums}.route-actions{padding:0;display:grid;gap:.8rem;align-content:start}.route-actions .cta{width:100%}.route-arrow{background:transparent;border:none;display:flex;align-items:center;justify-content:center}.route-arrow__shape{width:18px;height:18px;background:var(--arrow-color, var(--color-text));clip-path:polygon(50% 0,0 100%,100% 100%);transform-origin:center}@media(max-width:900px){.route-panel{left:6vw;right:6vw;bottom:1.5rem;width:auto;padding:1.2rem;gap:.9rem}.route-panel--hidden{left:auto;right:6vw}.route-panel h2{font-size:1.15rem}.panel-copy{font-size:.9rem}.cta{width:100%;text-align:center}}@media(max-width:700px){.page{padding:2.5rem 6vw 4rem}.route-panel{left:4vw;right:4vw}}
