*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}button,a,select,[role=button]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}button:active:not(:disabled){opacity:.8;transform:scale(.97)}:root{--bg-primary: #f5f4f1;--bg-surface: #ffffff;--bg-elevated: #fafaf8;--bg-muted: #edecea;--text-primary: #1a1918;--text-secondary: #6d6c6a;--text-tertiary: #9c9b99;--border-subtle: #e5e4e1;--border-strong: #d1d0cd;--accent-primary: #3d8a5a;--accent-light: #c8f0d8;--accent-warm: #d89575;--status-negative: #d08068;--shadow-card: 0 2px 12px #1a191808;--shadow-elevated: 0 2px 8px #1a191808;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 100px;--font-primary: "Outfit", sans-serif}html,body{height:100%;font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);overflow:hidden;overscroll-behavior:none}#app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;min-height:56px;padding:0 24px;padding-top:env(safe-area-inset-top,0px);padding-left:max(24px,env(safe-area-inset-left,0px));padding-right:max(24px,env(safe-area-inset-right,0px));background:var(--bg-surface);box-shadow:var(--shadow-elevated);z-index:100;flex-shrink:0}.header__title{font-size:20px;font-weight:600;letter-spacing:-.5px;color:var(--text-primary)}.header__right{display:flex;align-items:center;gap:8px;flex-shrink:1;min-width:0}.header__status{display:flex;align-items:center;gap:10px}.header__last-update{font-size:13px;color:var(--text-tertiary);white-space:nowrap}.header__cache-status{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.share-banner{display:flex;align-items:center;gap:10px;padding:8px 24px;background:var(--accent-light);border-bottom:1px solid var(--accent-primary);flex-shrink:0;z-index:99}.share-banner__icon{flex-shrink:0;color:var(--accent-primary)}.share-banner__text{flex:1;font-size:13px;font-weight:500;color:var(--accent-primary)}.share-banner__save{height:28px;padding:0 12px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:12px;font-weight:600;cursor:pointer}.share-banner__save:hover{opacity:.9}.share-banner__dismiss{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:16px;border-radius:4px}.share-banner__dismiss:hover{background:#3d8a5a1a}@media(max-width:768px){.share-banner{padding:6px 12px;gap:8px}.share-banner__text{font-size:12px}}.progress-strip{position:relative;width:100%;height:24px;background:var(--bg-muted);display:flex;align-items:center;justify-content:center;z-index:900;flex-shrink:0}.progress-strip[hidden]{display:none}.progress-strip__fill{position:absolute;left:0;top:0;height:100%;background:var(--accent-primary);opacity:.2;width:0%;transition:width .3s ease}.progress-strip__label{position:relative;font-size:.75rem;font-weight:500;color:var(--text-primary);z-index:1}.header__install-btn,.header__refresh-btn{display:flex;align-items:center;gap:6px;height:36px;padding:0 16px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .1s}.header__install-btn{background:var(--accent-warm)}.header__install-btn--hidden{display:none}.header__install-btn:hover,.header__refresh-btn:hover{opacity:.9}.header__settings-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .1s}.header__settings-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.header__share-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .1s}.header__share-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.share-overlay{display:none;position:fixed;inset:0;z-index:1000;background:#1a191866;justify-content:center;align-items:center}.share-overlay--visible{display:flex}.share-card{background:var(--bg-surface);border-radius:var(--radius-lg);padding:28px 32px;max-width:360px;width:90%;box-shadow:0 8px 32px #1a191826;display:flex;flex-direction:column;align-items:center;gap:12px}.share-card__title{font-size:18px;font-weight:700;color:var(--text-primary)}.share-card__qr{display:flex;align-items:center;justify-content:center;padding:16px;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.share-card__qr svg{width:200px;height:200px}.share-card__hint{font-size:12px;color:var(--text-tertiary)}.share-card__actions{display:flex;gap:8px;width:100%}.share-card__action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;height:40px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);font-family:var(--font-primary);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .1s}.share-card__action-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.share-card__action-btn--copied{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-light)}.share-card__close{align-self:flex-end;height:36px;padding:0 20px;border:none;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-family:var(--font-primary);font-size:13px;font-weight:600;cursor:pointer;margin-top:4px}.share-card__close:hover{opacity:.9}.header__save-offline-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .1s}.header__save-offline-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.header__offline-badge{display:none;align-items:center;height:24px;padding:0 10px;background:var(--status-negative);color:#fff;border-radius:var(--radius-full);font-size:11px;font-weight:600}.header__offline-badge--visible{display:inline-flex}.main-body{display:flex;flex:1;overflow:hidden}.sidebar{display:flex;flex-direction:column;width:360px;min-width:360px;background:var(--bg-surface);padding:20px;gap:16px;box-shadow:2px 0 12px #1a191808;z-index:50;overflow:hidden}.sidebar__controls{display:flex;gap:8px;align-items:center}.prefecture-select,.sort-select{flex:1;height:34px;padding:0 28px 0 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-primary);font-family:var(--font-primary);font-size:12px;color:var(--text-secondary);cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239c9b99' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.prefecture-select:focus,.sort-select:focus{border-color:var(--accent-primary)}.route-toggle{display:flex;align-items:center;gap:4px;height:34px;padding:0 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-primary);font-family:var(--font-primary);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .1s;white-space:nowrap}.route-toggle:hover{border-color:var(--border-strong)}.route-toggle--active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.route-panel{display:none;flex-direction:column;gap:8px}.route-panel--visible{display:flex}.route-panel__header{display:flex;justify-content:space-between;align-items:center}.route-panel__title{font-size:13px;font-weight:600;color:var(--text-primary)}.route-panel__clear{font-size:11px;font-weight:500;color:var(--status-negative);background:none;border:none;cursor:pointer;font-family:var(--font-primary)}.route-panel__clear:hover{text-decoration:underline}.route-list{display:flex;flex-direction:column;gap:4px;max-height:150px;overflow-y:auto}.route-empty{font-size:12px;color:var(--text-tertiary);padding:8px 0}.route-stop{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);background:var(--bg-primary)}.route-stop__number{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--accent-primary);color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.route-stop__name{flex:1;font-size:12px;font-weight:500;color:var(--text-primary);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-stop__name:hover{color:var(--accent-primary)}.route-stop__remove{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-radius:4px;flex-shrink:0}.route-stop__remove:hover{color:var(--status-negative);background:var(--bg-muted)}.route-number-icon{background:none!important;border:none!important}.route-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--accent-primary);color:#fff;font-family:var(--font-primary);font-size:12px;font-weight:700;box-shadow:0 2px 6px #0000004d}.search-box{display:flex;align-items:center;height:44px;padding:0 14px;gap:10px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.search-box__icon{flex-shrink:0;color:var(--text-tertiary)}.search-box__input{flex:1;border:none;background:transparent;font-family:var(--font-primary);font-size:14px;color:var(--text-primary);outline:none}.search-box__input::placeholder{color:var(--text-tertiary)}.filter-section{display:flex;flex-direction:column;gap:10px}.filter-section__label{font-size:14px;font-weight:600;color:var(--text-primary);-webkit-user-select:none;user-select:none}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:4px;height:32px;padding:0 14px;border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--bg-primary);font-family:var(--font-primary);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .1s}.filter-chip--active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.filter-chip:hover:not(.filter-chip--active){border-color:var(--border-strong)}.filter-chip--fav svg{flex-shrink:0}.divider{height:1px;background:var(--border-subtle)}.list-header{display:flex;justify-content:space-between;align-items:center}.list-header__title{font-size:14px;font-weight:600;color:var(--text-primary);-webkit-user-select:none;user-select:none}.list-header__count{display:inline-flex;align-items:center;height:24px;padding:0 10px;background:var(--accent-light);border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--accent-primary)}.spot-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;-webkit-overflow-scrolling:touch;will-change:scroll-position}.spot-list__spacer-top,.spot-list__spacer-bottom{flex-shrink:0}.spot-item{display:flex;align-items:center;height:58px;box-sizing:border-box;padding:10px 12px;gap:8px;border-radius:var(--radius-md);cursor:pointer;transition:background .1s}.spot-item:hover{background:var(--bg-primary)}.spot-item--error{opacity:.5}.spot-item__icon{flex-shrink:0}.spot-item__info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.spot-item__name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none}.spot-item__address{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none}.spot-item__category{flex-shrink:0;display:inline-flex;align-items:center;height:22px;padding:0 8px;background:var(--accent-light);border-radius:var(--radius-full);font-size:10px;font-weight:600;color:var(--accent-primary)}.spot-item__fav{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;border-radius:4px;flex-shrink:0;transition:all .1s}.spot-item__fav:hover,.spot-item__fav--active{color:var(--accent-warm)}.spot-item__distance{flex-shrink:0;font-size:11px;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.spot-item__retry{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-subtle);background:var(--bg-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:all .1s}.spot-item__retry:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.spot-item__retry--loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spot-item__route-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-subtle);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0;transition:all .1s}.spot-item__route-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.spot-item__route-btn--in{background:var(--accent-light);border-color:var(--accent-primary);color:var(--accent-primary)}.map-area{flex:1;position:relative;z-index:0}.custom-pin{background:none!important;border:none!important}@keyframes pulse-ring{0%{stroke-opacity:.8;stroke-width:3;r:8}to{stroke-opacity:0;stroke-width:1;r:30}}.pulse-indicator{animation:pulse-ring 1s ease-out 2}.custom-popup .leaflet-popup-content-wrapper{border-radius:var(--radius-md);box-shadow:0 4px 16px #1a191820;padding:0}.custom-popup .leaflet-popup-content{margin:0}.custom-popup .leaflet-popup-tip{box-shadow:none}.popup-content{padding:14px;font-family:var(--font-primary);display:flex;flex-direction:column;gap:4px}.popup-name{font-size:14px;font-weight:600;color:var(--text-primary)}.popup-address{font-size:11px;color:var(--text-tertiary)}.popup-category{display:inline-flex;align-items:center;align-self:flex-start;height:20px;padding:0 8px;margin-top:4px;background:var(--accent-light);border-radius:var(--radius-full);font-size:10px;font-weight:600;color:var(--accent-primary)}.popup-memo{font-size:12px;color:var(--text-secondary);margin-top:4px}.popup-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle)}.popup-action-btn{display:inline-flex;align-items:center;gap:4px;height:28px;padding:0 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-primary);font-family:var(--font-primary);font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:all .1s}.popup-action-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.popup-fav-btn.popup-fav--active{background:var(--accent-light);border-color:var(--accent-primary);color:var(--accent-primary)}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background-color:var(--accent-light)!important}.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background-color:var(--accent-primary)!important;color:#fff!important;font-family:var(--font-primary);font-weight:600}.locate-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg-surface);cursor:pointer;color:var(--text-secondary);transition:color .1s}.locate-btn:hover{color:var(--accent-primary)}.locate-marker{fill:#4285f4;fill-opacity:1;stroke:#fff;stroke-width:3}.locate-accuracy{fill:#4285f4;fill-opacity:.1;stroke:#4285f4;stroke-opacity:.3;stroke-width:1}.tile-switcher{position:relative}.tile-switcher__btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg-surface);cursor:pointer;color:var(--text-secondary);transition:color .1s}.tile-switcher__btn:hover{color:var(--accent-primary)}.tile-switcher__dropdown{position:absolute;top:38px;right:0;background:var(--bg-surface);border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001f;min-width:140px;overflow:hidden;z-index:1000}.tile-switcher__item{padding:10px 14px;font-family:var(--font-primary);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:background .1s}.tile-switcher__item:hover{background:var(--bg-primary)}.tile-switcher__item--active{color:var(--accent-primary);font-weight:600;background:var(--accent-light)}.info-overlay{display:none;position:fixed;inset:0;z-index:1000;background:#1a191866;justify-content:center;align-items:center}.info-overlay--visible{display:flex}.info-card{background:var(--bg-surface);border-radius:var(--radius-lg);padding:28px 32px;max-width:520px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #1a191826;display:flex;flex-direction:column;gap:12px}.info-card__title{font-size:18px;font-weight:700;color:var(--text-primary)}.info-section__heading{font-size:14px;font-weight:600;color:var(--accent-primary);margin-bottom:6px}.info-section__list{list-style:none;display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-secondary);line-height:1.5}.info-section__list li:before{content:"•";color:var(--border-strong);margin-right:8px}.info-card__close{align-self:flex-end;height:36px;padding:0 20px;border:none;border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;font-family:var(--font-primary);font-size:13px;font-weight:600;cursor:pointer;margin-top:4px}.info-card__close:hover{opacity:.9}.header__info-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:border-color .2s}.header__info-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.settings-overlay{display:none;position:fixed;inset:0;z-index:1000;background:#1a191866;justify-content:center;align-items:center}.settings-overlay--visible{display:flex}.settings-card{background:var(--bg-surface);border-radius:var(--radius-lg);padding:32px;max-width:540px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #1a191826;display:flex;flex-direction:column;gap:16px}.settings-card__title{font-size:18px;font-weight:600;letter-spacing:-.2px}.settings-card__desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.settings-card__input{width:100%;height:44px;padding:0 14px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:13px;color:var(--text-primary);outline:none;transition:border-color .1s}.settings-card__input:focus{border-color:var(--accent-primary)}.settings-card__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.settings-card__add{height:40px;padding:0 20px;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .1s}.settings-card__add:hover{border-color:var(--border-strong);color:var(--text-primary)}.settings-card__save{height:40px;padding:0 24px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .1s}.settings-card__save:hover{opacity:.9}.sheet-list{display:flex;flex-direction:column;gap:12px}.sheet-item{display:flex;flex-direction:column;gap:8px;padding:14px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);transition:border-color .1s}.sheet-item--active{border-color:var(--accent-primary);background:var(--accent-light)}.sheet-item__name{width:100%;height:34px;padding:0 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:13px;font-weight:600;color:var(--text-primary);background:var(--bg-surface);outline:none}.sheet-item__url{width:100%;height:34px;padding:0 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:12px;color:var(--text-secondary);background:var(--bg-surface);outline:none}.sheet-item__name:focus,.sheet-item__url:focus{border-color:var(--accent-primary)}.sheet-item__actions{display:flex;gap:8px}.sheet-item__select{height:30px;padding:0 14px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-primary);font-size:12px;font-weight:600;cursor:pointer}.sheet-item--active .sheet-item__select{background:var(--text-tertiary);cursor:default}.sheet-item__delete{height:30px;width:30px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:16px;color:var(--text-tertiary);cursor:pointer;transition:all .1s}.sheet-item__delete:hover{border-color:var(--status-negative);color:var(--status-negative)}.sidebar__handle{display:none}@media(max-width:768px){.main-body{position:relative;flex-direction:column}.map-area{flex:1;height:100%}.sidebar{position:fixed;bottom:0;left:0;right:0;width:100%;min-width:100%;height:80vh;height:80dvh;z-index:500;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 24px #1a19181f;transform:translateY(calc(100% - 130px));transition:transform .25s ease-out;padding-top:0;padding-bottom:env(safe-area-inset-bottom,0px);will-change:transform}.sidebar--expanded{transform:translateY(0)}.sidebar--dragging{transition:none}.sidebar__handle{display:flex;justify-content:center;padding:12px 0 8px;cursor:grab;touch-action:none;flex-shrink:0}.sidebar__handle-bar{width:36px;height:4px;border-radius:2px;background:var(--border-strong)}.header{padding:0 10px;padding-top:env(safe-area-inset-top,0px);gap:4px}.header__title{font-size:16px}.header__right{gap:4px}.header__status{display:none}.header__refresh-btn{width:32px;height:32px;padding:0;border-radius:var(--radius-full);font-size:0;gap:0;justify-content:center}.header__install-btn{padding:0 10px;font-size:12px}.header__share-btn,.header__save-offline-btn,.header__info-btn,.header__settings-btn{width:32px;height:32px}.header__share-btn svg,.header__save-offline-btn svg,.header__info-btn svg,.header__settings-btn svg{width:15px;height:15px}.sidebar__controls{gap:6px}.prefecture-select,.sort-select{font-size:11px;height:30px}.route-toggle{height:30px;padding:0 8px;font-size:11px}input[type=text],input[type=url],input[type=search],textarea,select{font-size:16px!important}}.spot-label-tooltip{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:0 2px 8px #1a19181f;padding:4px 10px;font-family:var(--font-primary);font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap}.spot-label-tooltip:before{border-top-color:var(--bg-surface)}.detail-sheet{display:none}@media(max-width:768px){.detail-sheet{display:block;position:fixed;bottom:0;left:0;right:0;z-index:600;background:var(--bg-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 24px #1a191826;transform:translateY(100%);transition:transform .25s ease-out;padding-bottom:env(safe-area-inset-bottom,0px);will-change:transform;pointer-events:none}.detail-sheet--visible{transform:translateY(0);pointer-events:auto}.detail-sheet__handle{display:flex;justify-content:center;padding:12px 0 8px;cursor:pointer}.detail-sheet__handle-bar{width:36px;height:4px;border-radius:2px;background:var(--border-strong)}.detail-sheet__body{padding:0 20px 20px}.detail-sheet__header{display:flex;align-items:flex-start;gap:12px}.detail-sheet__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.detail-sheet__name{font-size:18px;font-weight:600;color:var(--text-primary)}.detail-sheet__address{font-size:13px;color:var(--text-tertiary)}.detail-sheet__category{display:inline-flex;align-items:center;align-self:flex-start;height:22px;padding:0 10px;margin-top:2px;background:var(--accent-light);border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--accent-primary)}.detail-sheet__memo{font-size:13px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.detail-sheet__fav{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--border-subtle);background:var(--bg-primary);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-md);flex-shrink:0;transition:all .1s}.detail-sheet__fav:hover{color:var(--accent-warm);border-color:var(--accent-warm)}.detail-sheet__fav--active{color:var(--accent-warm);background:#fdf0e9;border-color:var(--accent-warm)}.detail-sheet__actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px;margin-top:16px}.detail-sheet__action{display:flex;align-items:center;justify-content:center;gap:6px;height:44px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-primary);font-family:var(--font-primary);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:all .1s}.detail-sheet__action:hover{border-color:var(--accent-primary);color:var(--accent-primary)}}.spot-list::-webkit-scrollbar{width:6px}.spot-list::-webkit-scrollbar-track{background:transparent}.spot-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}.spot-list::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.route-list::-webkit-scrollbar{width:4px}.route-list::-webkit-scrollbar-track{background:transparent}.route-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}
