:root{--rm-gold:#c8952e;--rm-gold-border:#c8952e1f;--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{background:hsl(var(--card));border:1px solid var(--rm-gold-border);z-index:0;border-radius:20px;height:480px;display:flex;position:relative;overflow:hidden}.route-map-sidebar{border-right:1px solid var(--rm-gold-border);background:hsl(var(--card));flex-direction:column;width:280px;min-width:280px;display:flex}.route-map-sidebar-header{border-bottom:1px solid var(--rm-gold-border);padding:20px}.route-map-sidebar-header h3{color:var(--rm-text);margin:0 0 2px;font-size:18px;font-weight:600}.route-map-sidebar-header span{color:var(--rm-text-muted);font-size:12px}.route-map-timeline-scroll{scrollbar-width:none;flex:1;padding:12px 0 12px 20px;overflow-y:auto}.route-map-timeline-scroll::-webkit-scrollbar{width:0}.route-map-timeline{padding-left:20px;position:relative}.route-map-timeline:before{content:"";background:var(--rm-gold-border);width:2px;position:absolute;top:14px;bottom:14px;left:6px}.route-map-day{cursor:pointer;border-left:3px solid #0000;border-radius:10px;margin-bottom:4px;margin-right:12px;padding:10px 14px;transition:all .3s;position:relative}.route-map-day:hover{background:#c8952e0a}.route-map-day.is-active{background:#c8952e0f;border-left-color:#c8952e}.route-map-day-dot{background:hsl(var(--card));z-index:2;border:2px solid #c8952e40;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;top:16px;left:-20px}.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 #c8952e66}.route-map-day-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--rm-gold);margin-bottom:3px;font-size:10px;font-weight:600}.route-map-day-name{color:var(--rm-text);font-size:14px;font-weight:600;transition:color .2s}.route-map-day.is-active .route-map-day-name{color:#c8952e}.route-map-sidebar-footer{border-top:1px solid var(--rm-gold-border);align-items:center;gap:12px;padding:14px 20px;display:flex}.route-map-play-btn{color:var(--rm-gold);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;background:#c8952e1a;border:1px solid #c8952e40;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:12px;font-weight:600;transition:all .25s;display:flex}.route-map-play-btn:hover{background:#c8952e2e}.route-map-play-btn.is-playing{color:var(--rm-text);background:#c8952e33}.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{z-index:500;-webkit-backdrop-filter:blur(16px);background:hsl(var(--card) / .85);border:1px solid var(--rm-gold-border);color:var(--rm-text-muted);pointer-events:none;border-radius:10px;align-items:center;gap:8px;padding:10px 14px;font-size:12px;display:flex;position:absolute;bottom:16px;left:16px}.route-map-current-label .mcl-dot{background:#c8952e;border-radius:50%;flex-shrink:0;width:7px;height:7px}.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;font-size:18px!important;line-height:36px!important;transition:background .2s!important}.route-map-area .leaflet-control-zoom a:hover{background:#c8952e26!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{background:hsl(var(--card));width:30px;height:30px;color:var(--rm-gold);opacity:0;border:2px solid #c8952e4d;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .4s;display:flex;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);transform:scale(1.2);box-shadow:0 0 16px #c8952e66}.route-tl-marker.is-visited{opacity:1;background:#c8952e26;border-color:#c8952e;transform:scale(1)}.route-map-pin{width:32px;height:40px;position:relative}.route-map-pin:after{content:"";background:#c8952e;border-radius:50% 50% 50% 0;width:30px;height:30px;position:absolute;top:0;left:50%;transform:translate(-50%)rotate(-45deg);box-shadow:0 2px 8px #c8952e66}.route-map-pin-num{z-index:1;color:#fff;font-family:system-ui,sans-serif;font-size:12px;font-weight:700;position:absolute;top:3px;left:50%;transform:translate(-50%)}.route-map-popup .leaflet-popup-content-wrapper{background:#fff;border-radius:8px;padding:0;box-shadow:0 4px 16px #0003}.route-map-popup .leaflet-popup-content{margin:8px 12px}.route-map-popup .leaflet-popup-tip{background:#fff}.route-map-mobile-wrap{border:1px solid var(--rm-gold-border);z-index:0;border-radius:16px;height:60vh;min-height:360px;max-height:600px;position:relative;overflow:hidden}.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;font-size:18px!important;line-height:36px!important}.route-map-mobile-wrap .leaflet-control-zoom a:hover{background:#c8952e26!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{border-right:none;border-bottom:1px solid var(--rm-gold-border);width:100%;min-width:100%;max-height:220px}.route-map-area{height:340px}.route-map-sidebar-footer{flex-wrap:wrap}}.route-map-placeholder{height:200px;color:var(--rm-text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}
