:root{--color-primary: #0077cc;--color-bg: #ffffff;--color-surface: #f8fafc;--color-text: #111111;--color-text-muted: #888888;--color-border: #e8e8e8;--color-note: #e8f4fd;--color-note-text: #0077cc;--radius-card: 20px;--radius-pill: 20px;--radius-sm: 8px;--radius-photo: 10px;--pin-size: 38px;--shadow-card: 0 -4px 24px rgba(0, 0, 0, .1);--shadow-pin: 0 3px 10px rgba(0, 0, 0, .3);--transition: .3s cubic-bezier(.4, 0, .2, 1);--safe-top: env(safe-area-inset-top, 12px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--color-bg);color:var(--color-text)}#app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}#map{position:absolute;top:0;right:0;bottom:0;left:0}#filter-bar{position:absolute;top:calc(var(--safe-top) + 8px);left:12px;right:12px;z-index:100;display:flex;flex-direction:column;gap:6px;pointer-events:none}.filter-row{display:flex;gap:6px;flex-wrap:nowrap;pointer-events:auto}.filter-row.sub-row{flex-wrap:wrap}.pill{padding:7px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;border:1.5px solid rgba(0,0,0,.08);background:#ffffffe0;color:#333;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);cursor:pointer;white-space:nowrap;transition:all .15s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.pill:active{transform:scale(.96)}.pill.active{color:#fff;border-color:transparent;box-shadow:0 2px 8px #0003}.pill.dim{opacity:.45}.sub-row{animation:slide-in .2s ease}@keyframes slide-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.map-pin{width:var(--pin-size);height:var(--pin-size);border-radius:50%;border:2.5px solid white;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--shadow-pin);cursor:pointer;transition:transform .15s ease;line-height:1}.map-pin:active{transform:scale(.9)}.map-pin.pulsing{animation:pulse .4s ease}@keyframes pulse{0%{box-shadow:var(--shadow-pin)}50%{box-shadow:0 0 0 8px #0077cc40,var(--shadow-pin)}to{box-shadow:var(--shadow-pin)}}#card-container{position:absolute;bottom:0;left:0;right:0;z-index:200;pointer-events:none}.card{background:var(--color-bg);border-radius:var(--radius-card) var(--radius-card) 0 0;box-shadow:var(--shadow-card);transform:translateY(100%);transition:transform var(--transition);pointer-events:auto;padding-bottom:calc(var(--safe-bottom) + 16px)}.card.peek{transform:translateY(calc(100% - 110px))}.card.full{transform:translateY(0);max-height:60vh;overflow-y:auto}.drag-handle{width:36px;height:4px;background:var(--color-border);border-radius:2px;margin:12px auto 0;cursor:grab}.card-peek-content{display:flex;align-items:center;gap:12px;padding:10px 16px 14px}.card-thumb{width:52px;height:52px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--color-surface)}.card-peek-info{flex:1;min-width:0}.card-peek-name{font-size:15px;font-weight:800;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-peek-meta{font-size:12px;color:var(--color-text-muted);margin-top:2px}.btn-go{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.btn-go:active{opacity:.85}.card-full-content{padding:0 16px 8px}.card-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:10px}.card-main-photo{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:var(--color-surface);cursor:pointer}.card-title{font-size:18px;font-weight:800;color:var(--color-text)}.card-meta{font-size:12px;color:var(--color-text-muted);margin-top:4px;line-height:1.6}.card-blurb{font-size:13px;color:#555;margin-top:8px;line-height:1.5}.photo-strip{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin:10px 0;padding-bottom:2px}.photo-strip::-webkit-scrollbar{display:none}.photo-strip img{width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;cursor:pointer}.card-actions{display:flex;gap:8px;margin-top:10px}.btn-directions{flex:1;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px;font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-directions:active{opacity:.85}.btn-maps{flex:1;background:var(--color-surface);color:#444;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);padding:12px;font-size:14px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}#gallery-container{position:absolute;top:0;right:0;bottom:0;left:0;z-index:300;background:#fff;overflow-y:auto;transform:translate(100%);transition:transform var(--transition)}#gallery-container.open{transform:translate(0)}#gallery-container.hidden{display:none}.gallery-header{display:flex;align-items:center;gap:12px;padding:calc(var(--safe-top) + 10px) 16px 12px;background:#fff;position:sticky;top:0;z-index:10;border-bottom:1px solid var(--color-border)}.btn-back{width:34px;height:34px;border-radius:50%;background:var(--color-surface);border:1.5px solid var(--color-border);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gallery-place-name{font-size:16px;font-weight:800}.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;padding:3px}.photo-grid img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.photo-grid img.hero{grid-column:1 / -1;aspect-ratio:16/9}.gallery-details{padding:16px}.gallery-title{font-size:20px;font-weight:800;color:var(--color-text)}.gallery-meta{font-size:13px;color:var(--color-text-muted);margin-top:5px;line-height:1.7}.gallery-blurb{font-size:14px;color:#555;margin-top:10px;line-height:1.6}.personal-note{background:var(--color-note);color:var(--color-note-text);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;line-height:1.5;margin-top:12px}.personal-note:before{content:"💬 "}.btn-open-maps{display:block;width:100%;margin-top:16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px;font-size:15px;font-weight:700;cursor:pointer;text-align:center;margin-bottom:24px}.hidden{display:none!important}
