*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;text-size-adjust:100%;color:#1a1a1a;background:#f5f5f5}body{height:100dvh}body:has(.app-scroll){overflow:hidden}#app{height:100dvh}#app:has(>.app-scroll){display:flex;flex-direction:column;overflow-y:hidden}.app-scroll{flex:1;overflow-y:auto;min-height:0}.app-header{position:sticky;top:0;z-index:10;background:#1a73e8;color:#fff;padding:16px;padding-top:max(16px,env(safe-area-inset-top))}.app-header h1{font-size:1.25rem;font-weight:600}.app-header p{font-size:.85rem;opacity:.85;margin-top:2px}.app-header-row{display:flex;justify-content:space-between;align-items:center}.header-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}@media not (min-width:360px){.header-controls{gap:4px}}.header-lang-select{position:relative}.lang-trigger{background:#ffffff26;border:1px solid rgb(255 255 255 / 40%);border-radius:6px;padding:4px 8px;font-size:.8rem;color:#fff;cursor:pointer;font-weight:500}.lang-trigger:hover{background:#ffffff40}.lang-listbox{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;list-style:none;padding:4px 0;min-width:160px;max-height:280px;overflow-y:auto;z-index:20}.lang-listbox li{padding:8px 12px;font-size:.85rem;color:#1a1a1a;cursor:pointer;white-space:nowrap}.lang-listbox li:hover,.lang-listbox li:focus{background:#f0f0f0;outline:none}.lang-listbox .lang-option-active{color:#1a73e8;font-weight:500}.header-icon-btn{background:none;border:none;color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;padding:4px 8px;border-radius:6px;opacity:.9}.header-icon-btn:hover{background:#ffffff26}.header-icon-btn:focus-visible{outline:2px solid #fff;outline-offset:2px}.header-icon-btn:active{background:#ffffff40}.mode-toggle{display:flex;gap:0;background:#ffffff1a;border-radius:8px;padding:2px}.mode-toggle .header-icon-btn{border-radius:6px;padding:4px 8px}.mode-toggle .mode-active{background:#ffffff40;opacity:1}.mode-toggle .mode-inactive{opacity:.4;cursor:pointer}.mode-toggle .mode-inactive:hover{opacity:.7;background:#ffffff1a}.gps-signal-lost{animation:gps-blink 1.5s ease-in-out infinite}@keyframes gps-blink{0%,to{opacity:1}50%{opacity:.2}}.scroll-pause-blink{animation:scroll-pause-blink 1.5s ease-in-out 3}@keyframes scroll-pause-blink{0%,to{opacity:1}50%{opacity:.3}}.nearby-list{list-style:none;padding:8px;display:flex;flex-direction:column;gap:4px}.nearby-list.virtual-scroll{display:block;position:relative;overflow:visible;padding:0}.nearby-list.virtual-scroll>li{padding:2px 8px;box-sizing:border-box}.virtual-scroll-container{position:relative;padding:6px 0}.nearby-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:8px;text-decoration:none;color:inherit;cursor:pointer;transition:background .15s}.nearby-item:active{background:#e8e8e8}.nearby-info{display:flex;flex-direction:column;gap:2px;min-width:0}.nearby-name{font-weight:500;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nearby-thumb{width:0;height:40px;overflow:hidden;border-radius:4px;flex-shrink:0;transition:width .2s ease}.nearby-thumb-loaded{width:40px}.virtual-scroll .nearby-thumb{transition:none}.virtual-scroll .nearby-thumb-loaded{width:40px}.nearby-thumb img{width:40px;height:40px;object-fit:cover;display:block}.nearby-desc{font-size:.8rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nearby-distance{font-size:.85rem;font-weight:500;color:#1a73e8;white-space:nowrap}.status-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:16px}.loading-dot{width:12px;height:12px;border-radius:50%;background:#1a73e8;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.progress-track{width:100%;max-width:240px;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:#1a73e8;border-radius:3px;transition:width .15s ease-out}.status-message{font-size:.95rem;color:#666;max-width:28ch;text-align:center;line-height:1.4}.status-action{background:#1a73e8;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:500;cursor:pointer;margin-top:8px}.status-action:active{background:#1557b0}.lang-select{background:#fff;border:1px solid #ccc;border-radius:8px;padding:8px 12px;font-size:.9rem;color:#1a1a1a;cursor:pointer}.welcome-choices{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px;margin-top:8px}.welcome-choice{background:#fff;border:1.5px solid #1a73e8;border-radius:8px;padding:12px 20px;font-size:.9rem;font-weight:500;color:#1a73e8;cursor:pointer;text-align:center}.welcome-choice:active{background:#e8f0fe}.welcome-choice:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}.welcome-choice-icon{font-size:1.5rem;vertical-align:middle}.welcome-about{background:none;border:none;color:#888;font-family:inherit;font-size:.8rem;cursor:pointer;margin-top:8px}.welcome-about:hover{color:#1a73e8;text-decoration:underline}.welcome-about:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}.detail-header{display:flex;align-items:center;gap:12px}.detail-back{background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:4px 8px;border-radius:8px;flex-shrink:0}.detail-back:active{background:#ffffff26}.detail-header-text{min-width:0}.detail-header-text h1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-content{padding:16px;display:flex;flex-direction:column;gap:12px}.detail-thumbnail{max-width:100%;height:auto;border-radius:8px}.detail-description{font-size:.9rem;color:#666;font-style:italic;line-height:1.4}.detail-extract{font-size:.95rem;line-height:1.5;color:#1a1a1a}.detail-wiki-link{display:inline-block;background:#1a73e8;color:#fff;text-decoration:none;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:500;text-align:center;margin-top:4px}.detail-wiki-link:active{background:#1557b0}.detail-directions-link{display:inline-block;background:#fff;color:#1a73e8;text-decoration:none;border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:500;text-align:center;margin-top:4px;border:1.5px solid #1a73e8}.detail-directions-link:active{background:#e8f0fe}.detail-actions{display:flex;gap:10px;margin-top:4px}.detail-actions .detail-wiki-link,.detail-actions .detail-directions-link{flex:1;margin-top:0}.update-banner{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#323232;color:#fff;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;animation:update-banner-slide-up .25s ease-out}@keyframes update-banner-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.update-banner-text{font-size:.9rem;flex:1 1 auto;min-width:0}.update-banner-actions{display:flex;gap:8px;flex-shrink:0}.update-banner-btn{background:none;border:none;color:#8ab4f8;font-size:.9rem;font-weight:500;cursor:pointer;padding:6px 12px;border-radius:4px;text-transform:uppercase;letter-spacing:.02em}.update-banner-btn:active{background:#ffffff1a}#app:has(.map-picker-container){display:flex;flex-direction:column;height:100dvh;overflow:hidden}.map-picker-instructions{text-align:center;padding:12px 16px;color:#666;font-size:.9rem}.map-picker-container{position:relative;flex:1;display:flex;flex-direction:column;min-height:0}.map-picker-map{flex:1;min-height:0}.map-picker-confirm{display:block;position:absolute;bottom:16px;left:16px;right:16px;z-index:1000;background:#1a73e8;color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:.95rem;font-weight:500;cursor:pointer}.map-picker-confirm:active{background:#1557b0}@media(min-width:768px){.app-header{padding-left:max(16px,calc((100% - 720px)/2));padding-right:max(16px,calc((100% - 720px)/2))}.nearby-list,.status-screen,.detail-content{max-width:720px;margin:0 auto}.update-banner{padding-left:max(16px,calc((100% - 720px)/2));padding-right:max(16px,calc((100% - 720px)/2))}}.browse-map{width:100%;height:100%}@media(min-width:1024px){.nearby-item:hover{background:#f0f0f0}}@media(min-width:1024px){body:has(.map-drawer:not([hidden])) #app{transition:margin-right .3s ease}body:has(.map-drawer.open:not([hidden])) #app{margin-right:50%}}.map-drawer{position:fixed;top:0;right:0;bottom:0;width:100%;transform:translate(100%);transition:transform .3s ease;will-change:transform;z-index:50;display:flex}.map-drawer[hidden]{display:none}.map-drawer.open{transform:translate(0)}.map-drawer.dragging{transition:none}.map-drawer-handle{position:absolute;left:0;top:50%;transform:translate(-85%,-50%);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#fff;border:1px solid #ddd;box-shadow:0 1px 4px #00000026;touch-action:none;-webkit-user-select:none;user-select:none;padding:0;color:#666;z-index:1}.map-drawer-handle:hover{background:#f5f5f5;color:#333}.map-drawer.open .map-drawer-handle{transform:translateY(-50%)}.map-drawer-chevron{display:block;transition:transform .3s ease}.map-drawer.open .map-drawer-chevron{transform:rotate(180deg)}.map-drawer-content{flex:1;min-width:0;background:#fff;position:relative;z-index:0}@media(min-width:1024px){.map-drawer{width:50%}}.about-btn{font-size:1.1rem;padding:4px;flex-shrink:0}dialog.about-dialog{border:none;border-radius:12px;padding:24px;max-width:400px;max-height:calc(100dvh - 48px);width:calc(100% - 48px);margin:auto;overflow-y:auto;box-shadow:0 8px 32px #0003}dialog.about-dialog::backdrop{background:#0000007f}.about-close{position:absolute;top:12px;right:12px;background:none;border:none;font-family:inherit;font-size:1.5rem;line-height:1;cursor:pointer;color:#666;padding:4px 8px;border-radius:4px}.about-close:hover{background:#f0f0f0}.about-close:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}.about-dialog h2{font-size:1.25rem;font-weight:600;margin-bottom:4px}.about-tagline{font-size:.85rem;color:#666;line-height:1.4;margin-bottom:16px}.about-section h3{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#999;margin-bottom:8px}.about-section p{font-size:.85rem;line-height:1.5;color:#333;margin-bottom:8px}.about-section a{color:#1a73e8;text-decoration:none}.about-section a:hover{text-decoration:underline}.about-section a:focus-visible{outline:2px solid #1a73e8;outline-offset:2px}
