:root{--panel-bg:#ffffff;--panel-border:#e8e4dd;--surface:#f7f5f2;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#aaa;--accent:#2d6a00;--accent-light:rgba(45, 106, 0, 0.1);--accent-ring:rgba(45, 106, 0, 0.18);--radius:16px;--panel-width:340px;--shadow:0 4px 24px rgba(0, 0, 0, 0.1),0 1px 4px rgba(0, 0, 0, 0.06);--font:"Plus Jakarta Sans",sans-serif}*,::after,::before{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;overflow:hidden;font-family:var(--font);font-size:14px;line-height:1.5;color:var(--text-primary)}a{color:var(--accent)}#map{position:fixed;inset:0;z-index:1}#map-legend{position:fixed;bottom:24px;right:24px;z-index:900;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;box-shadow:var(--shadow);padding:10px 12px;display:flex;flex-direction:column;gap:5px}@media (max-width:768px){#map-legend{bottom:auto;top:16px;right:16px}}#panel{position:fixed;top:16px;right:16px;width:var(--panel-width);max-height:calc(100vh - 32px);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);z-index:1000;box-shadow:var(--shadow);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--panel-border) transparent;touch-action:pan-y}#panel::-webkit-scrollbar{width:4px}#panel::-webkit-scrollbar-track{background:0 0}#panel::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:2px}#panel-header{padding:8px 18px 0;display:flex;align-items:center;justify-content:flex-end;position:sticky;top:0;background:var(--panel-bg);z-index:10}h1{font-family:var(--font);font-weight:800;font-size:24px;letter-spacing:-.03em;color:var(--text-primary)}.subtitle{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-weight:500}@keyframes pulse-amber{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(245,158,11,.3)}50%{opacity:.7;box-shadow:0 0 0 5px rgba(245,158,11,0)}}@keyframes pulse-green{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(45,106,0,.3)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(45,106,0,0)}}.section-label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;margin-bottom:6px}#search-section{padding:12px 18px 12px;display:flex;align-items:center;gap:8px}#search-wrap{position:relative;flex:1}#info-btn{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1px solid var(--panel-border);background:var(--surface);color:var(--text-muted);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}#info-btn:hover{color:var(--accent);border-color:var(--accent)}#search-icon-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:0 0;border:none;color:var(--text-muted);font-size:20px;line-height:1;padding:2px 5px;cursor:pointer;transition:color .15s}#search-icon-btn:hover{color:var(--text-primary)}#search-input{width:100%;background:var(--surface);border:1px solid var(--panel-border);border-radius:10px;color:var(--text-primary);font-family:var(--font);font-size:13px;padding:9px 36px 9px 12px;outline:0;transition:border-color .15s,box-shadow .15s}#search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}#search-input::placeholder{color:var(--text-muted)}#search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;box-shadow:var(--shadow);z-index:100;display:none;max-height:200px;overflow-y:auto}.search-result-item{padding:9px 14px;font-family:var(--font);font-size:12px;color:var(--text-secondary);cursor:pointer;border-bottom:1px solid var(--panel-border);transition:background .12s;line-height:1.4}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--surface);color:var(--text-primary)}.search-result-item strong{color:var(--text-primary);display:block;font-size:13px;font-weight:700}#day-legend-section{border-bottom:1px solid var(--panel-border)}#day-section{padding:10px 18px 12px}#day-selector{display:flex;flex-direction:row;gap:6px;margin-top:6px}.day-btn{flex:1;background:var(--surface);border:1px solid var(--panel-border);border-radius:8px;color:var(--text-secondary);font-family:var(--font);font-size:12px;font-weight:600;padding:7px 4px;cursor:pointer;transition:all .12s;letter-spacing:-.01em}.day-btn:hover{border-color:var(--accent);color:var(--accent)}.day-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}#legend-section{flex:1;padding:10px 18px 12px 12px}#legend{display:flex;flex-direction:column;gap:5px;margin-top:6px}.legend-row{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-secondary)}.legend-swatch{width:20px;height:5px;border-radius:3px;flex-shrink:0}.train-swatch{background:#111;height:7px;border-radius:4px;border:1.5px solid #555}#radius-section{padding:10px 18px 12px;border-bottom:1px solid var(--panel-border)}#radius-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}#radius-display{font-family:var(--font);font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-.04em;line-height:1}#radius-display #radius-value{font-size:26px}#radius-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:#ddd;border-radius:2px;outline:0;cursor:pointer}#radius-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 0 0 3px var(--accent-ring);transition:box-shadow .15s}#radius-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 6px var(--accent-ring)}#radius-slider::-moz-range-thumb{width:18px;height:18px;background:var(--accent);border-radius:50%;border:none;cursor:pointer}.slider-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:10px;color:var(--text-muted)}#poi-section{padding:10px 18px 12px;border-bottom:1px solid var(--panel-border)}#poi-toggles{display:flex;flex-wrap:wrap;gap:5px}.poi-btn{font-family:var(--font);font-size:11px;font-weight:600;padding:4px 9px;border-radius:20px;border:1px solid var(--panel-border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all .12s;white-space:nowrap}.poi-btn:hover{border-color:var(--accent);color:var(--accent)}.poi-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}#routes-section{padding:10px 18px 12px}#routes-section .section-label{margin-bottom:8px}#route-list{display:flex;flex-direction:column;gap:3px}.route-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;border:1px solid transparent;cursor:pointer;touch-action:manipulation;transition:all .12s;background:0 0}.route-item:hover{background:var(--surface);border-color:var(--panel-border)}.route-item.active{background:var(--accent-light);border-color:var(--accent)}.route-badge{font-family:var(--font);font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;min-width:38px;text-align:center;flex-shrink:0;letter-spacing:-.01em;border:1px solid transparent}.route-name{font-family:var(--font);font-size:12px;font-weight:500;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-hw{font-family:var(--font);font-size:10px;font-weight:600;color:var(--text-muted);flex-shrink:0;white-space:nowrap}.route-item.active .route-name{color:var(--text-primary)}.route-item.active .route-hw{color:var(--text-secondary)}#panel-footer{display:block;padding:8px 18px;background:var(--surface);border-top:1px solid var(--panel-border);font-size:10px;color:var(--text-muted);text-align:center}#panel-footer a{color:var(--accent);text-decoration:none;font-weight:600}#panel-footer a:hover{text-decoration:underline}#route-info{display:none;align-items:center;justify-content:space-between;gap:10px;padding:10px 18px;border-bottom:1px solid var(--panel-border);border-left:3px solid transparent;background:var(--surface);animation:fadeIn .15s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}#route-info-inner{display:flex;align-items:center;gap:10px;flex:1;min-width:0;overflow:hidden}#route-info-badge{font-family:var(--font);font-size:12px;font-weight:800;padding:3px 10px;border-radius:6px;flex-shrink:0;border:1px solid transparent}#route-info-name{font-family:var(--font);font-weight:700;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#route-info-hw{font-size:11px;color:var(--text-secondary);margin-top:1px}#route-info-close{background:0 0;border:none;color:var(--text-muted);width:24px;height:24px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .12s}#route-info-close:hover{color:var(--text-primary)}#intro-overlay{position:fixed;inset:0;z-index:2000;background:rgba(20,30,15,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px}#intro-box{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 26px 24px;max-width:400px;width:100%}#intro-box h2{font-size:18px;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:2px}.intro-sub{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;margin-bottom:14px}#intro-box>p:not(.intro-sub):not(.intro-credit){font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:18px}.intro-steps{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.intro-step{display:flex;gap:12px;align-items:flex-start}.intro-icon{font-size:15px;color:var(--accent);flex-shrink:0;margin-top:1px;line-height:1;width:22px;text-align:center;display:inline-block}.intro-step span:last-child{font-size:13px;color:var(--text-secondary);line-height:1.6}.intro-step strong{color:var(--text-primary);font-weight:600}.intro-credit{font-size:10px;color:var(--text-muted);margin-bottom:18px;padding-top:14px;border-top:1px solid var(--panel-border);text-align:center;line-height:1.7}.intro-credit a{color:var(--accent);text-decoration:none;font-weight:600}.intro-credit a:hover{text-decoration:underline}#intro-close{width:100%;padding:11px;background:var(--accent);color:#fff;border:1.5px solid var(--accent);border-radius:10px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;letter-spacing:-.01em;transition:background .15s,opacity .15s}#intro-close:hover:not(:disabled){background:#1f4d00;border-color:#1f4d00}#intro-close:disabled{font-variant-numeric:tabular-nums;letter-spacing:.01em;opacity:.5;cursor:not-allowed}.footer-feedback{display:inline-block;margin-top:5px;color:var(--accent);font-weight:600;text-decoration:none}.footer-feedback:hover{text-decoration:underline}.leaflet-popup-content-wrapper{border-radius:10px!important;box-shadow:var(--shadow)!important;border:1px solid var(--panel-border)!important}.leaflet-popup-content{font-family:var(--font)!important;font-size:13px!important;color:var(--text-primary)!important;margin:12px 14px!important;min-width:150px}.popup-stop-name{font-weight:800;margin-bottom:3px;font-size:14px}.popup-stop-route{font-size:11px;color:var(--text-secondary)}.popup-poi-name{font-weight:700;margin-bottom:3px}.popup-poi-cat{font-size:10px;color:var(--accent);text-transform:uppercase;letter-spacing:.07em;font-weight:700}.popup-poi-addr{font-size:11px;color:var(--text-secondary);margin-top:3px}.leaflet-control-zoom a{font-family:var(--font)!important;font-weight:700!important}.geo-marker-outer{width:40px;height:40px;display:flex;align-items:center;justify-content:center;position:relative}.geo-marker-outer::before{content:"";position:absolute;width:40px;height:40px;border-radius:50%;background:rgba(66,133,244,.2);animation:geo-pulse 2s ease-out infinite}.geo-marker-dot{width:22px;height:22px;border-radius:50%;background:#4285f4;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.45);position:relative;z-index:1}@keyframes geo-pulse{0%{transform:scale(.6);opacity:.8}70%{transform:scale(1.4);opacity:0}100%{transform:scale(1.4);opacity:0}}.home-marker-icon{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:0 0 0 3px var(--accent-ring),0 2px 8px rgba(0,0,0,.2);animation:homebeat 2s ease-in-out infinite}@keyframes homebeat{0%,100%{box-shadow:0 0 0 3px var(--accent-ring),0 2px 8px rgba(0,0,0,.2)}50%{box-shadow:0 0 0 7px rgba(45,106,0,.06),0 2px 8px rgba(0,0,0,.2)}}@media (max-width:768px){#panel{top:auto;bottom:0;left:0;right:0;width:100%!important;border-radius:var(--radius) var(--radius) 0 0;max-height:70vh;overflow-y:auto;-webkit-overflow-scrolling:touch;transition:max-height .3s cubic-bezier(.4, 0, .2, 1),box-shadow .3s ease}#panel.panel--collapsed{overflow:hidden;box-shadow:0 -2px 12px rgba(0,0,0,.08);border-radius:var(--radius) var(--radius) 0 0}#panel-drag-handle{display:block;width:36px;height:4px;background:var(--panel-border);border-radius:2px;margin:0 auto 6px;cursor:pointer;flex-shrink:0}#panel{display:block}#panel-header{flex-direction:row;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;padding-top:6px}}#panel-tabs{display:flex;gap:6px;padding:12px 18px 12px}.panel-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 10px;border-radius:10px;border:1px solid var(--panel-border);background:var(--surface);color:var(--text-muted);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;min-height:34px;min-width:34px}#info-btn.panel-tab{flex:0 0 auto;padding:7px 10px}.panel-tab:hover{border-color:var(--accent);color:var(--accent)}.panel-tab.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.panel-tab svg{flex-shrink:0}.panel-drawer{border-top:1px solid var(--panel-border);overflow:hidden}#panel-drag-handle{display:none}.collapsible-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 18px;background:0 0;border:none;border-top:1px solid var(--panel-border);border-bottom:1px solid var(--panel-border);font-family:var(--font);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s}.collapsible-header:hover{background:var(--surface);color:var(--text-secondary)}.collapsible-icon{font-size:16px;font-weight:400;line-height:1;transition:transform .2s ease;color:var(--text-muted)}.collapsible-icon.open{transform:rotate(90deg)}.collapsible-body{overflow:hidden;transition:max-height .3s cubic-bezier(.4, 0, .2, 1)}.collapsible-body.collapsed{max-height:0}.route-inactive-label{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700;padding:10px 10px 4px;border-top:1px solid var(--panel-border);margin-top:4px}.route-item--inactive{opacity:.5;pointer-events:none}.popup-gmaps{display:inline-block;margin-top:6px;font-size:11px;font-weight:600;color:#1d6030;text-decoration:none;letter-spacing:.01em}.popup-gmaps:hover{text-decoration:underline}.section-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.poi-bulk-btns{display:flex;gap:4px}.poi-bulk-btns button{font-family:inherit;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:4px;border:1px solid #d1cdc6;background:#f5f2ed;color:#6b6560;cursor:pointer;transition:background .15s,color .15s}.poi-bulk-btns button:hover{background:#2d6a00;color:#fff;border-color:#2d6a00}.route-line{cursor:pointer}.route-line path{stroke-linecap:round;stroke-linejoin:round}.leaflet-overlay-pane svg .route-line{pointer-events:stroke}#poi-loading-toast{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:999;background:var(--accent);border:none;border-radius:20px;padding:9px 16px 9px 12px;font-size:13px;font-family:var(--font);font-weight:600;color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.25);display:flex;align-items:center;gap:8px;white-space:nowrap;transition:opacity .4s ease,transform .4s ease}#poi-loading-toast.hidden{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(-6px)}.poi-toast-spinner{width:13px;height:13px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}#location-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1100;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:10px 30px 30px;max-width:320px;width:calc(100% - 48px);text-align:center;opacity:1;transition:opacity .4s ease,transform .4s ease}#location-popup img{display:block;margin:0 auto;border-radius:8px}#location-popup p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}#location-popup strong{color:var(--text-primary);font-weight:700}#location-popup .popup-tab-btn{display:inline-flex;align-items:center;gap:4px;background:var(--accent-light);color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:2px 8px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;vertical-align:middle;margin:0 1px}#location-popup.hiding{opacity:0;transform:translate(-50%,-50%) scale(.97);pointer-events:none}@media (max-width:768px){#location-popup{bottom:130px}}