:root{--rm-gold:#C8952E;--rm-gold-border:rgba(200,149,46,0.12);--rm-bg:hsl(var(--background));--rm-card:hsl(var(--card));--rm-text:hsl(var(--foreground));--rm-text-muted:hsl(var(--muted-foreground))}.route-map-widget{border:1px solid var(--rm-gold-border);border-radius:20px;overflow:hidden;height:480px;position:relative;z-index:0}.route-map-sidebar,.route-map-widget{background:hsl(var(--card));display:flex}.route-map-sidebar{width:280px;min-width:280px;flex-direction:column;border-right:1px solid var(--rm-gold-border)}.route-map-sidebar-header{padding:20px;border-bottom:1px solid var(--rm-gold-border)}.route-map-sidebar-header h3{font-size:18px;font-weight:600;margin:0 0 2px;color:var(--rm-text)}.route-map-sidebar-header span{font-size:12px;color:var(--rm-text-muted)}.route-map-timeline-scroll{flex:1;overflow-y:auto;padding:12px 0 12px 20px;scrollbar-width:none}.route-map-timeline-scroll::-webkit-scrollbar{width:0}.route-map-timeline{position:relative;padding-left:20px}.route-map-timeline:before{content:"";position:absolute;left:6px;top:14px;bottom:14px;width:2px;background:var(--rm-gold-border)}.route-map-day{position:relative;padding:10px 14px;margin-bottom:4px;margin-right:12px;border-radius:10px;cursor:pointer;transition:all .3s ease;border-left:3px solid transparent}.route-map-day:hover{background:rgba(200,149,46,.04)}.route-map-day.is-active{background:rgba(200,149,46,.06);border-left-color:#C8952E}.route-map-day-dot{position:absolute;left:-20px;top:16px;width:14px;height:14px;border-radius:50%;background:hsl(var(--card));border:2px solid rgba(200,149,46,.25);transition:all .3s ease;z-index:2}.route-map-day.is-active .route-map-day-dot,.route-map-day.is-visited .route-map-day-dot{background:#C8952E;border-color:#C8952E}.route-map-day.is-active .route-map-day-dot{box-shadow:0 0 10px rgba(200,149,46,.4)}.route-map-day-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--rm-gold);font-weight:600;margin-bottom:3px}.route-map-day-name{font-weight:600;font-size:14px;color:var(--rm-text);transition:color .2s}.route-map-day.is-active .route-map-day-name{color:#C8952E}.route-map-sidebar-footer{padding:14px 20px;border-top:1px solid var(--rm-gold-border);display:flex;align-items:center;gap:12px}.route-map-play-btn{flex:1;padding:10px;background:rgba(200,149,46,.1);border:1px solid rgba(200,149,46,.25);border-radius:8px;color:var(--rm-gold);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .25s ease;display:flex;align-items:center;justify-content:center;gap:6px}.route-map-play-btn:hover{background:rgba(200,149,46,.18)}.route-map-play-btn.is-playing{background:rgba(200,149,46,.2);color:var(--rm-text)}.route-map-area{flex:1;position:relative}.route-map-area .leaflet-container{width:100%;height:100%;background:var(--rm-bg)!important}.route-map-current-label{position:absolute;bottom:16px;left:16px;z-index:500;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:hsl(var(--card)/.85);border:1px solid var(--rm-gold-border);border-radius:10px;padding:10px 14px;font-size:12px;color:var(--rm-text-muted);display:flex;align-items:center;gap:8px;pointer-events:none}.route-map-current-label .mcl-dot{width:7px;height:7px;border-radius:50%;background:#C8952E;flex-shrink:0}.route-map-current-label b{color:var(--rm-text);font-weight:600}.route-map-area .leaflet-control-attribution{display:none!important}.route-map-area .leaflet-control-zoom{border:none!important}.route-map-area .leaflet-control-zoom a{background:hsl(var(--card))!important;color:#C8952E!important;border:1px solid var(--rm-gold-border)!important;width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;transition:background .2s!important}.route-map-area .leaflet-control-zoom a:hover{background:rgba(200,149,46,.15)!important}.route-map-area .leaflet-control-zoom-in{border-radius:10px 10px 0 0!important}.route-map-area .leaflet-control-zoom-out{border-radius:0 0 10px 10px!important}.route-tl-marker{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:hsl(var(--card));border:2px solid rgba(200,149,46,.3);color:var(--rm-gold);font-size:12px;font-weight:700;transition:all .4s ease;opacity:0;transform:scale(0)}.route-tl-marker.is-visible{opacity:1;transform:scale(1)}.route-tl-marker.is-active{background:var(--rm-gold);color:hsl(var(--background));border-color:var(--rm-gold);box-shadow:0 0 16px rgba(200,149,46,.4);transform:scale(1.2)}.route-tl-marker.is-visited{opacity:1;transform:scale(1);background:rgba(200,149,46,.15);border-color:#C8952E}.route-map-pin{position:relative;width:32px;height:40px}.route-map-pin:after{content:"";position:absolute;top:0;left:50%;width:30px;height:30px;background:#C8952E;border-radius:50% 50% 50% 0;transform:translateX(-50%) rotate(-45deg);box-shadow:0 2px 8px rgba(200,149,46,.4)}.route-map-pin-num{position:absolute;top:3px;left:50%;transform:translateX(-50%);z-index:1;font-size:12px;font-weight:700;color:#fff;font-family:system-ui,sans-serif}.route-map-popup .leaflet-popup-content-wrapper{background:#fff;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.2);padding:0}.route-map-popup .leaflet-popup-content{margin:8px 12px}.route-map-popup .leaflet-popup-tip{background:#fff}.route-map-mobile-wrap{height:60vh;min-height:360px;max-height:600px;border-radius:16px;overflow:hidden;border:1px solid var(--rm-gold-border);position:relative;z-index:0}.route-map-mobile-wrap .leaflet-container{width:100%;height:100%;background:var(--rm-bg)!important}.route-map-mobile-wrap .leaflet-control-attribution{display:none!important}.route-map-mobile-wrap .leaflet-control-zoom{border:none!important}.route-map-mobile-wrap .leaflet-control-zoom a{background:hsl(var(--card))!important;color:#C8952E!important;border:1px solid var(--rm-gold-border)!important;width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important}.route-map-mobile-wrap .leaflet-control-zoom a:hover{background:rgba(200,149,46,.15)!important}.route-map-mobile-wrap .leaflet-control-zoom-in{border-radius:10px 10px 0 0!important}.route-map-mobile-wrap .leaflet-control-zoom-out{border-radius:0 0 10px 10px!important}@media (max-width:768px){.route-map-widget{flex-direction:column;height:auto}.route-map-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid var(--rm-gold-border);max-height:220px}.route-map-area{height:340px}.route-map-sidebar-footer{flex-wrap:wrap}}.route-map-placeholder{display:flex;align-items:center;justify-content:center;height:200px;color:var(--rm-text-muted);font-size:14px}