:root{--bg: #fafaf7;--surface: #ffffff;--fg: #1c1c1c;--muted: #6b7280;--accent-h: 167;--accent-s: 39%;--accent-l: 30%;--accent: hsl(var(--accent-h) var(--accent-s) var(--accent-l));--accent-hover: hsl(var(--accent-h) var(--accent-s) 22%);--active-glow: hsl(calc(var(--accent-h) + 35) 78% 55%);--border: #e6e3dc;--pill-bg: #efece5;--radius: 6px;--maxw: 980px;--tap-min: 44px;--header-h: 61px}@media(min-width:640px){:root{--header-h: 69px}}html{scroll-padding-top:calc(var(--header-h) + 6px)}@media(max-width:899px){html{scroll-padding-top:calc(var(--header-h) + 37px + 38svh + 1rem)}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.55;font-weight:400;-webkit-text-size-adjust:100%;overflow-x:clip}html,body{min-height:100vh}body{display:flex;flex-direction:column}header.site,footer.site{flex:0 0 auto}main{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}html:has(.locator),body:has(.locator){height:100svh;min-height:0}body:has(.locator){overflow:hidden}h1,h2,h3{font-weight:600;letter-spacing:-.01em}h1{font-size:1.5rem;margin:0 0 .5rem}h2{font-size:1.2rem;margin:1.5rem 0 .75rem}h3{font-size:1rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}header.site{background:var(--surface);border-bottom:1px solid var(--border);padding:.5rem 1rem;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;position:sticky;top:0;z-index:20;view-transition-name:site-header}header.site h1{margin:0;font-size:.9rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg)}header.site h1 a{color:inherit}header.site h1 a:hover{text-decoration:none;color:var(--accent)}header.site nav{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}header.site nav a{color:var(--fg);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;padding:.35rem;min-height:var(--tap-min);display:inline-flex;align-items:center}header.site nav a:hover{color:var(--accent);text-decoration:none}main{max-width:var(--maxw);margin:0 auto;padding:1rem 1rem 2rem}main:has(.locator){padding-top:0;padding-bottom:0}main:has(.locator){max-width:1400px;width:100%}footer.site{border-top:1px solid var(--border);padding:1.5rem 1rem;text-align:center;color:var(--muted);font-size:.85rem;margin-top:3rem}body:has(.locator) footer.site{margin-top:0;padding:.5rem 1rem}@media(max-width:899px){body:has(.locator) footer.site{padding:2px 1rem;font-size:.7rem;line-height:1.3}body:has(.locator) footer.site p{margin:0}}.btn,.cafe-page .actions a{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-min);padding:.55rem 1.1rem;background:var(--surface);color:var(--fg);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.btn:hover,.cafe-page .actions a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.map-wrap{height:min(38svh,calc(100svh - var(--header-h) - 37px - var(--expanded-card-h, 260px) - 48px - 1rem));min-height:200px;max-height:340px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-bottom:1rem;background:#f0ede6;touch-action:pan-x pan-y;transition:opacity .25s ease-out}.map-wrap--loading{position:relative}.map-wrap--loading>:not(.map-wrap__pending){visibility:hidden}.map-wrap__pending{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;color:var(--muted);font-size:.85rem;letter-spacing:.04em;pointer-events:none}.map-wrap__denied{position:absolute;left:10px;bottom:10px;width:28px;height:28px;border-radius:50%;border:0;background:#1c1c1cd9;color:#fff;cursor:help;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #00000040;z-index:3}.map-wrap__denied:hover{background:#1c1c1c}.map-wrap__denied[hidden]{display:none}.map-wrap__pending svg{width:36px;height:36px;animation:map-pending-pulse 1.4s ease-in-out infinite}@keyframes map-pending-pulse{0%,to{transform:translateY(0);opacity:.55}50%{transform:translateY(-4px);opacity:1}}.cafe-list{list-style:none;padding:0;margin:0;display:grid;gap:.75rem;grid-template-columns:1fr}.cafe-card{position:relative;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .12s,box-shadow .12s,transform .12s}.cafe-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000a}.cafe-card__featured-badge{position:absolute;top:.35rem;right:.45rem;color:#d4a017;font-size:.95rem;line-height:1;pointer-events:none;z-index:2}.featured-star{color:#d4a017;font-size:.95em;margin-right:.25rem;vertical-align:baseline}.cafe-card__trigger{display:block;width:100%;padding:.65rem .9rem;background:transparent;border:0;text-align:left;font:inherit;color:inherit;cursor:pointer;border-radius:var(--radius)}.cafe-card__trigger:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.cafe-card.is-expanded{box-shadow:0 2px 14px #0000000f;border-color:#2f6b5e59}.cafe-card.is-expanded[data-cat=coffeeshop]{background:linear-gradient(180deg,rgba(93,64,55,.1),transparent 55%)}.cafe-card.is-expanded[data-cat=cafe]{background:linear-gradient(180deg,rgba(201,117,81,.12),transparent 55%)}.cafe-card.is-expanded[data-cat=other]{background:linear-gradient(180deg,rgba(74,124,89,.1),transparent 55%)}.cafe-card__expando{padding:0 1rem .6rem;position:relative}.cafe-card__mission{margin:0 0 .5rem;font-size:.85rem;line-height:1.45;color:var(--fg);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.cafe-card__actions{display:flex;flex-wrap:wrap;gap:.35rem}.cafe-card__action{font-size:.78rem;padding:.3rem .55rem;border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);background:var(--surface);white-space:nowrap}.cafe-card__action--icon{padding:.3rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.cafe-card__action--icon:hover{border-color:var(--accent);color:var(--accent)}.cafe-card__action:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.cafe-card__action--primary{background:var(--fg);color:#fff;border-color:var(--fg)}.cafe-card__action--primary:hover{background:var(--accent);border-color:var(--accent);color:#fff}.cafe-card__head{display:flex;align-items:center;gap:.5rem;min-width:0}.cafe-card__head .cafe-card__dist{margin-left:auto;padding-right:1rem}.cafe-card h3{margin:0;font-size:1rem;line-height:1.2;min-width:0;word-wrap:break-word;overflow-wrap:break-word;flex:1 1 auto}.cafe-card .city{color:var(--muted);font-size:.85rem;margin-bottom:.35rem}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}::view-transition-old(selected-card),::view-transition-new(selected-card){animation-duration:.42s;animation-timing-function:cubic-bezier(.22,.61,.36,1)}.cafe-card__meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:0 .35rem;margin-top:.2rem;font-size:.78rem;color:var(--muted);line-height:1.3}.cafe-card__tag{text-transform:uppercase;font-size:.68rem;letter-spacing:.06em;color:var(--fg)}.cafe-card__meta-sep{color:var(--border)}.cafe-card__full-addr{display:none}.cafe-card.is-expanded .cafe-card__full-addr{display:block}.cafe-card.is-expanded .cafe-card__meta{display:none}.empty-state{padding:1.5rem 1rem;border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);text-align:center}.empty-state h3{margin:0 0 .5rem;font-size:1.05rem}.empty-state p{margin:0 0 1rem;color:var(--muted);font-size:.9rem}.empty-state--filter{padding:1rem}.empty-state--filter p{margin:0}.pill{display:inline-block;padding:2px 10px;background:var(--pill-bg);color:var(--fg);border-radius:999px;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;margin-right:4px;margin-top:4px}.cafe-page{max-width:700px}.cafe-page .back-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.85rem;color:var(--muted);margin-bottom:1rem;min-height:32px}.cafe-page .back-link:hover{color:var(--accent);text-decoration:none}.cafe-page .actions{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.25rem 0}.cafe-page .meta{color:var(--muted);margin-bottom:1rem;font-size:.95rem}.cafe-page img{max-width:100%;border-radius:var(--radius);margin-bottom:1rem}.cafe-page .mission{font-size:1.15rem;line-height:1.45;margin:1.25rem 0}.cafe-page .cafe-photo{display:block;width:100%;max-height:360px;object-fit:cover;border-radius:var(--radius);margin-bottom:1rem}.cafe-page .edit-cta{margin-top:2.5rem;padding-top:1.25rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--muted)}.cafe-page .closed-banner{background:#fff4e5;border:1px solid #f0c48a;padding:.85rem 1.1rem;border-radius:var(--radius);margin-bottom:1.25rem}@media(min-width:640px){h1{font-size:2rem}h2{font-size:1.4rem}header.site{padding:.75rem 1.5rem}header.site h1{font-size:1rem}header.site nav a{font-size:.8rem;padding:.4rem .5rem}main{padding:1.5rem}.cafe-list{gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.cafe-card.is-expanded{grid-row:span 2}}@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}html{scroll-behavior:auto!important}}
