@keyframes pulse{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5);opacity:0}}@keyframes loadBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}:root{--coral:#FF6B6B;--teal:#4ECDC4;--gold:#FFD93D;--purple:#A06CD5;--dark:#2C3E50;--light:#FAFAFA;--white:#FFFFFF;--muted:#7F8C8D;--radius:12px;--shadow:0 2px 12px rgba(0,0,0,0.1);--shadow-lg:0 8px 32px rgba(0,0,0,0.15);--font:'Avenir Next', 'Segoe UI', system-ui, -apple-system, sans-serif;--panel-width:360px}*,::after,::before{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;overflow:hidden}body{font-family:var(--font);color:var(--dark);background:var(--light);-webkit-font-smoothing:antialiased}a{color:var(--coral);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}.header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:52px;background:var(--white);box-shadow:var(--shadow)}.header-brand{display:flex;align-items:baseline;gap:8px}.logo{font-size:1.6rem;font-weight:800;letter-spacing:.08em;color:var(--coral)}.logo-sub{font-size:.8rem;color:var(--muted);font-weight:500}.header-nav{display:flex;gap:8px}.about-btn,.legend-btn,.settings-btn{background:0 0;border:2px solid var(--dark);border-radius:20px;padding:4px 14px;font-size:.78rem;font-weight:600;color:var(--dark);transition:all .2s}.about-btn:hover,.legend-btn:hover,.settings-btn:hover{background:var(--dark);color:var(--white)}.main{position:fixed;top:52px;left:0;right:0;bottom:0;display:flex}.map-container{flex:1;height:100%}.leaflet-control-zoom{border:0!important;box-shadow:var(--shadow)!important;border-radius:8px!important;overflow:hidden}.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;color:var(--dark)!important}.leaflet-control-zoom a:hover{background:var(--coral)!important;color:#fff!important}.marker span{display:block;width:100%;height:100%;border-radius:50%;border:2.5px solid var(--white);box-shadow:0 1px 4px rgba(0,0,0,.3);transition:transform .2s,box-shadow .2s}.marker-highlighted span,.marker:hover span{transform:scale(1.3);box-shadow:0 2px 10px rgba(0,0,0,.3)}.marker-diamond span{border-radius:3px;transform:rotate(45deg)}.marker-diamond.marker-highlighted span,.marker-diamond:hover span{transform:rotate(45deg) scale(1.3)}.venue-label{width:150px!important}.venue-label span{display:block;font-family:var(--font);font-size:.68rem;font-weight:700;color:var(--dark);text-align:center;background:rgba(255,255,255,.9);padding:2px 6px;border-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.15);pointer-events:none;max-width:140px;margin:0 auto;line-height:1.2}.user-pin,.venue-label{background:0 0!important;border:0!important}.pin-dot,.pin-pulse{position:absolute;top:50%;left:50%;border-radius:50%}.pin-dot{width:14px;height:14px;margin:-7px 0 0-7px;background:var(--dark);border:3px solid var(--white);box-shadow:0 1px 6px rgba(0,0,0,.4);z-index:2}.pin-pulse{width:40px;height:40px;margin:-20px 0 0-20px;background:rgba(44,62,80,.2);animation:pulse 2s ease-out infinite;z-index:1}@media (prefers-reduced-motion:reduce){.pin-pulse{animation:none;opacity:.3;transform:scale(1)}}.venue-popup .leaflet-popup-content-wrapper{border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;padding:0!important}.venue-popup .leaflet-popup-content{margin:0!important}.venue-popup .leaflet-popup-tip{box-shadow:none!important}.popup-content{padding:16px}.popup-type{display:inline-block;padding:2px 10px;border-radius:10px;font-size:.7rem;font-weight:700;color:var(--dark);margin-bottom:6px}.popup-content h3{font-size:1rem;margin:4px 0}.popup-artist{font-style:italic;color:var(--muted);font-size:.85rem;margin:2px 0 6px}.popup-addr{font-size:.8rem;color:var(--muted);margin:2px 0}.popup-maps-link{font-size:.75rem;margin:2px 0}.popup-desc{font-size:.82rem;line-height:1.4;margin:8px 0}.popup-contact{font-size:.8rem;margin:3px 0}.panel{width:var(--panel-width);background:var(--white);box-shadow:-2px 0 12px rgba(0,0,0,.08);overflow-y:auto;display:flex;flex-direction:column;z-index:500}.panel .sheet-handle{display:none}.panel-inner{padding:16px;flex:1}.panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:var(--muted)}.panel-empty-icon{font-size:2.5rem;margin-bottom:12px}.panel-empty p{font-size:.9rem;line-height:1.5}.routing-notice{text-align:center;padding:8px 12px;margin-bottom:10px;color:var(--muted)}.mode-toggle{display:flex;background:var(--light);border-radius:25px;padding:3px;margin-bottom:14px}.mode-btn{flex:1;padding:8px 12px;border:0;border-radius:22px;background:0 0;font-size:.8rem;font-weight:600;color:var(--muted);transition:all .25s}.mode-btn.active{background:var(--coral);color:var(--white);box-shadow:0 2px 8px rgba(255,107,107,.3)}.loading-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;margin-bottom:12px;font-size:.82rem;color:var(--muted);font-weight:500}.loading-dot{width:6px;height:6px;border-radius:50%;background:var(--coral);animation:loadBounce 1.2s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}.walk-time-loading{color:var(--muted)!important;font-weight:500!important;font-style:italic}@media (prefers-reduced-motion:reduce){.loading-dot{animation:none;opacity:.6}}.loop-summary{text-align:center;padding:10px;margin-bottom:12px;background:linear-gradient(135deg,var(--coral),#ff8e8e);color:var(--white);border-radius:var(--radius);font-size:.9rem}.loop-distance{margin-left:8px;opacity:.85;font-size:.8rem}.venue-list{display:flex;flex-direction:column;gap:10px}.venue-card{background:var(--white);border:1.5px solid #eee;border-radius:var(--radius);padding:14px;cursor:pointer;transition:box-shadow .2s,transform .15s}.venue-card:focus-visible,.venue-card:hover{box-shadow:var(--shadow);transform:translateY(-1px);outline:0}.venue-card:focus-visible{border-color:var(--coral)}.venue-card-header{display:flex;align-items:flex-start;gap:10px}.venue-dot{flex-shrink:0;width:12px;height:12px;border-radius:50%;margin-top:4px;box-shadow:0 0 6px rgba(0,0,0,.15)}.venue-card-title{flex:1}.venue-card-title h3{font-size:.92rem;font-weight:700;line-height:1.2}.venue-order{color:var(--coral);font-weight:800}.venue-meta{display:flex;gap:10px;margin-top:3px}.walk-time{font-size:.78rem;font-weight:700;color:var(--coral)}.walk-dist{font-size:.78rem;color:var(--muted)}.venue-card-body{margin-top:10px;padding-top:10px;border-top:1px solid #f0f0f0}.venue-addr,.venue-artist{font-size:.8rem;color:var(--muted)}.venue-artist{font-style:italic;margin-bottom:4px}.venue-addr{margin-bottom:2px}.venue-maps-link{font-size:.75rem;margin-bottom:6px}.venue-desc{font-size:.82rem;line-height:1.4;margin-bottom:8px}.venue-link{display:inline-block;font-size:.78rem;margin-right:12px;font-weight:600}.overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px);transition:opacity .2s}.overlay.hidden{opacity:0;pointer-events:none}.overlay-card{background:var(--white);border-radius:var(--radius);padding:28px;max-width:380px;width:90%;box-shadow:var(--shadow-lg);position:relative}.overlay-close{position:absolute;top:12px;right:14px;background:0 0;border:0;font-size:1.5rem;color:var(--muted);line-height:1}.overlay-close:hover{color:var(--dark)}.overlay-card h2{font-size:1.1rem;margin-bottom:14px;color:var(--coral)}.overlay-card p{font-size:.85rem;line-height:1.5;margin-bottom:10px}.about-credits{font-size:.75rem!important;color:var(--muted);margin-top:16px;padding-top:12px;border-top:1px solid #eee}.setting-row{margin:8px 0}.setting-label{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer}.setting-text{flex:1}.setting-text strong{display:block;font-size:.88rem}.setting-text small{display:block;font-size:.75rem;color:var(--muted);margin-top:2px}.setting-toggle{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:relative;width:44px;height:24px;background:#ddd;border-radius:12px;flex-shrink:0;transition:background .2s}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--white);border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s}.setting-toggle:checked+.toggle-track{background:var(--coral)}.setting-toggle:checked+.toggle-track .toggle-thumb{transform:translateX(20px)}.setting-toggle:focus-visible+.toggle-track{outline:2px solid var(--coral);outline-offset:2px}.legend-list{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:.85rem}.legend-list li{display:flex;align-items:center;gap:10px}.legend-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--white);box-shadow:0 1px 3px rgba(0,0,0,.2);flex-shrink:0}.legend-dot-dashed{border:2px dashed var(--dark)}.legend-dot-diamond{border-radius:3px;transform:rotate(45deg)}.legend-dot-pin{background:var(--dark)!important;border:2px solid var(--white);width:14px;height:14px;border-radius:50%}.onboarding-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:1500;background:var(--dark);color:var(--white);padding:14px 20px;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;max-width:480px;width:90%;opacity:0;transition:opacity .3s,transform .3s}.onboarding-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}.onboarding-toast p{font-size:.85rem;line-height:1.4;flex:1}.toast-dismiss{background:var(--coral);border:0;color:#fff;padding:6px 16px;border-radius:20px;font-size:.78rem;font-weight:700;white-space:nowrap}@media (max-width:767px){.header{height:46px;padding:0 12px}.logo{font-size:1.3rem}.logo-sub{display:none}.about-btn,.legend-btn,.settings-btn{padding:3px 10px;font-size:.72rem}.main{flex-direction:column}.map-container{flex:1}.panel{position:fixed;left:0;right:0;bottom:0;width:100%;max-height:85vh;border-radius:16px 16px 0 0;box-shadow:0-4px 20px rgba(0,0,0,.12);transition:transform .3s ease;overflow:hidden}.panel .sheet-handle{display:flex;justify-content:center;padding:16px 0 8px;cursor:grab;touch-action:none}.panel .sheet-handle span{width:40px;height:5px;border-radius:3px;background:#ccc}.panel-inner{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.panel:not(.has-results){transform:translateY(100%)}.panel.collapsed{transform:translateY(calc(100% - 50px))}.panel.half{transform:translateY(50%)}.panel.full{transform:translateY(0)}.onboarding-toast{bottom:70px}.marker span{width:100%;height:100%}}.coords-display{position:fixed;top:60px;left:50%;transform:translateX(-50%) translateY(-10px);background:var(--dark);color:var(--white);font-family:monospace;font-size:.82rem;padding:6px 14px;border-radius:20px;z-index:2000;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}.coords-display.visible{opacity:1;transform:translateX(-50%) translateY(0)}.marker-circle.editing,.marker-diamond.editing,.marker.editing{cursor:grab!important}.leaflet-dragging .marker-circle.editing,.leaflet-dragging .marker-diamond.editing,.leaflet-dragging .marker.editing{cursor:grabbing!important}.edit-panel{padding:16px}.edit-title{font-size:1.1rem;font-weight:800;color:var(--coral);margin-bottom:4px}.edit-hint,.edit-subtitle{font-size:.85rem;color:var(--muted);margin-bottom:16px}.edit-hint{font-style:italic}.edit-item,.edit-list{display:flex;flex-direction:column}.edit-list{gap:8px;margin-bottom:16px}.edit-item{padding:8px 12px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow)}.edit-item strong{font-size:.85rem;color:var(--dark)}.edit-coords{font-size:.75rem;color:var(--muted);font-family:"SF Mono","Fira Code",monospace}.export-btn{border:0}.clear-btn,.export-btn{display:block;width:100%;padding:10px;border-radius:var(--radius);font-size:.85rem;font-weight:600;cursor:pointer;margin-bottom:8px}.export-btn{background:var(--coral);color:var(--white)}.export-btn:hover{opacity:.9}.clear-btn{background:0 0;color:var(--muted);border:1px solid #ddd}.clear-btn:hover{background:#f5f5f5}.edit-json-label{display:block;font-size:.75rem;font-weight:600;color:var(--muted);margin-top:16px;margin-bottom:4px}.edit-json{width:100%;height:200px;font-family:"SF Mono","Fira Code",monospace;font-size:.7rem;line-height:1.4;padding:8px;border:1px solid #ddd;border-radius:var(--radius);background:var(--white);color:var(--dark);resize:vertical}.panel::-webkit-scrollbar{width:6px}.panel::-webkit-scrollbar-track{background:0 0}.panel::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.panel::-webkit-scrollbar-thumb:hover{background:#bbb}