*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--esp:#2C1A0E;--car:#C8853A;--lat:#D4A96A;--foam:#FAF6F0;--bark:#5C3D2E;--mist:#E8DDD1;--cream:#F5EFE6;--green:#3A6B4A;--sb:260px}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',sans-serif;background:var(--foam);color:var(--esp);display:flex;flex-direction:column}

/* HEADER */
header{background:var(--esp);padding:6px 20px 2px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:100}
.logo{font-family:'Playfair Display',serif;font-size:1.42rem;color:var(--lat)}.logo em{font-family:'DM Sans',sans-serif;font-size:0.72rem;font-style:normal;color:rgba(212,169,106,0.55);letter-spacing:0.06em}
.hright{display:flex;align-items:center;gap:8px}
.hbtn-fb{background:transparent;border:1px solid rgba(212,169,106,0.35);color:var(--lat);padding:4px 12px;border-radius:5px;font-size:0.7rem;cursor:pointer;font-family:'DM Sans',sans-serif;letter-spacing:0.02em;transition:border-color 0.15s,color 0.15s,opacity 0.15s}
.hbtn-fb:hover{border-color:var(--lat);color:var(--lat);opacity:0.88}

/* ABOUT STRIP */
.about-strip{background:var(--esp);border-bottom:1px solid rgba(200,133,58,0.15);padding:2px 20px 7px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px}
.about-text{font-size:0.72rem;color:#D4A96A;line-height:1.3;flex:1;opacity:0.92}
.about-dismiss{font-size:0.85rem;color:rgba(212,169,106,0.45);background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;flex-shrink:0;padding:2px 4px;line-height:1}
.about-dismiss:hover{color:#D4A96A}
.about-strip.hid{display:none}

/* MAIN LAYOUT */
.main{display:flex;flex:1;overflow:hidden}

/* SIDEBAR */
.sb{width:var(--sb);flex-shrink:0;background:var(--cream);border-right:1px solid var(--mist);display:flex;flex-direction:column;overflow:hidden}
.sw{padding:8px 10px;border-bottom:1px solid #E8DDD1;flex-shrink:0}
.sbar{width:100%;background:white;border:1px solid var(--mist);border-radius:7px;padding:7px 10px;font-family:'DM Sans',sans-serif;font-size:0.78rem;color:var(--esp);outline:none}
.sbar:focus{border-color:var(--car)}.sbar::placeholder{color:#bbb}
.fp{overflow-y:auto;flex:1}
.fp::-webkit-scrollbar{width:3px}.fp::-webkit-scrollbar-thumb{background:var(--mist)}
.fsec{border-bottom:1px solid var(--mist);padding-bottom:8px}
.fsh{display:flex;align-items:center;justify-content:space-between;padding:15px 10px 7px;cursor:pointer;user-select:none}
.fsh:hover{background:rgba(200,133,58,0.05)}
.fst{font-size:0.61rem;text-transform:none;letter-spacing:0.02em;color:var(--bark);font-weight:500;display:flex;align-items:center;gap:4px}
.arr{font-size:0.56rem;color:var(--car);transition:transform 0.18s}
.fsec.col .arr{transform:rotate(-90deg)}
.fsb{padding:4px 10px 9px;display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start;align-content:flex-start;width:100%;box-sizing:border-box}
.fsec.col .fsb{display:none}
.fsb.cl{flex-direction:column;gap:5px;align-items:stretch}
.fsb .chip{flex:0 0 auto;width:auto;max-width:100%;min-width:0}
.hsel{width:100%;background:white;border:1px solid var(--mist);border-radius:6px;padding:5px 8px;font-family:'DM Sans',sans-serif;font-size:0.74rem;color:var(--esp);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath fill='%235C3D2E' d='M5 7L1 3h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.rrow{display:flex;align-items:center;gap:6px}
.rrow label{font-size:0.66rem;color:var(--bark);white-space:nowrap}
.rrow input[type=range]{flex:1;accent-color:var(--car);cursor:pointer}
.rv{font-size:0.66rem;font-weight:500;color:var(--car);min-width:28px;text-align:right}
.chip{padding:3px 12px;border-radius:10px;border:1px solid transparent;font-size:0.64rem;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;font-weight:500;transition:box-shadow 0.1s,opacity 0.1s}
.chip:hover{opacity:0.92}.chip.on{box-shadow:inset 0 0 0 2px #2C1A0E}
.bdg{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;background:var(--car);border-radius:50%;font-size:0.52rem;color:white;font-weight:600;margin-left:2px}
.rb{padding:5px 10px;font-size:0.62rem;color:#aaa;text-transform:uppercase;letter-spacing:0.07em;border-bottom:1px solid var(--mist);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:white}
.clrbtn{font-size:0.63rem;color:var(--car);background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;text-decoration:underline}

/* CONTENT */
.content{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.content::-webkit-scrollbar{width:5px}.content::-webkit-scrollbar-thumb{background:var(--mist);border-radius:3px}
.cards-wrap{padding:16px 20px;flex:1}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px;align-items:stretch}
@media(max-width:1100px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards-grid{grid-template-columns:1fr}}

/* ALPHA HEADER */
.alpha-hdr{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:#bbb;font-weight:500;padding:8px 0 4px;margin-bottom:6px;border-bottom:1px solid var(--mist);position:sticky;top:0;background:var(--foam);z-index:10}

/* A-Z LETTER NAV */
.letter-nav{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--mist);align-items:baseline}
.ltr-btn{font-size:0.7rem;font-weight:400;color:#ccc;cursor:pointer;letter-spacing:0.05em;padding:3px 8px;border-radius:10px;transition:background 0.15s,color 0.15s;line-height:1}
.ltr-btn.on{font-size:0.8rem;font-weight:600;color:#fff;background:#C8853A}
.ltr-btn-all{font-weight:600}
@media(hover:hover){
  .ltr-btn:not(.on):hover{background:#D4A96A;color:#fff}
}

/* SHOP CARD */
.scard{background:white;border-radius:12px;overflow:hidden;border:1px solid var(--mist);margin-bottom:0;transition:box-shadow 0.2s;will-change:transform;display:flex;flex-direction:column}
.scard:has(.scard-known){box-shadow:0 2px 12px rgba(44,26,14,0.08)}
.scard:hover{box-shadow:0 4px 20px rgba(44,26,14,0.08)}
.scard:has(.scard-known):hover{box-shadow:0 4px 20px rgba(44,26,14,0.08)}
.scard-photo{width:100%;height:160px;flex-shrink:0;position:relative;overflow:hidden;background:var(--mist)}
.scard-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease}
.scard:hover .scard-photo img{transform:scale(1.03)}
.scard-badges{position:absolute;top:10px;left:10px;display:flex;flex-wrap:wrap;gap:4px}
.ib{font-size:0.58rem;font-weight:600;padding:3px 8px;border-radius:6px;white-space:nowrap;letter-spacing:0.01em}
.scard-badges .ib,.dp-identity-badges .ib{backdrop-filter:blur(6px)}
.ib-new{background:rgba(200,133,58,0.95);color:#FFFFFF}
.ib-tr{background:rgba(255,237,160,0.92);color:#7A4500}
.ib-sp{background:rgba(58,107,74,0.88);color:#D0EED8}
.ib-lm{background:rgba(28,60,110,0.88);color:#C5DCFF}
.ib-wait{background:#2D5A3D;color:#FFFFFF}
.chip.chip-idn{background:#FFF3E0;color:#8B4513;border:none;font-weight:500}
.chip.chip-idn.on{box-shadow:inset 0 0 0 2px #8B4513}
.scard-rat{position:absolute;top:10px;right:10px;background:rgba(255,255,255,0.92);border-radius:6px;padding:4px 9px;font-size:0.75rem;font-weight:600;color:var(--esp);backdrop-filter:blur(4px)}
.scard-vid-play{position:absolute;bottom:10px;left:10px;width:44px;height:44px;border-radius:50%;background:rgba(44,26,14,0.75);border:1.5px solid rgba(255,255,255,0.6);cursor:pointer;z-index:20;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 2px 10px rgba(0,0,0,0.28);pointer-events:auto}
.scard-vid-play:hover{background:rgba(44,26,14,0.88);border-color:rgba(255,255,255,0.75)}
.scard-vid-tri{width:0;height:0;border-style:solid;border-width:8px 0 8px 14px;border-color:transparent transparent transparent #fff;margin-left:4px;pointer-events:none}
.vid-overlay{position:fixed;inset:0;background:rgba(26,15,7,0.88);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.vid-modal{background:#2C1A0E;border-radius:12px;width:100%;max-width:600px;max-height:92vh;overflow:auto;padding:20px 22px 24px;position:relative;box-shadow:0 12px 40px rgba(0,0,0,0.5);border:1px solid rgba(212,169,106,0.2)}
.vid-close{position:absolute;top:12px;right:14px;background:transparent;border:none;color:#D4A96A;font-size:1.5rem;cursor:pointer;line-height:1;padding:4px;z-index:2}
.vid-close:hover{color:#FAF6F0}
.vid-modal-name{font-family:'Playfair Display',serif;font-size:1.35rem;color:#D4A96A;margin:0 36px 14px 0;padding-right:8px;line-height:1.25}
.vid-player-wrap{display:flex;align-items:center;gap:8px}
.vid-player-area{flex:1;min-width:0}
.vid-nav{flex-shrink:0;width:42px;height:42px;border-radius:50%;background:rgba(212,169,106,0.12);border:1px solid rgba(212,169,106,0.45);color:#D4A96A;font-size:1.5rem;line-height:1;cursor:pointer;font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;padding:0;transition:background 0.15s,border-color 0.15s,color 0.15s}
.vid-nav:hover{background:rgba(212,169,106,0.28);border-color:#D4A96A;color:#FAF6F0}
.vid-pos{text-align:center;font-size:0.72rem;color:rgba(212,169,106,0.8);margin-top:12px;letter-spacing:0.03em}
.vid-embed-wrap{position:relative;width:100%;padding-top:56.25%;border-radius:8px;overflow:hidden;background:#1a1008}
.vid-embed-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.vid-via{margin-top:7px;text-align:right}
.vid-via-link{display:inline-flex;align-items:center;gap:4px;font-size:0.65rem;color:rgba(212,169,106,0.52);text-decoration:none;font-family:'DM Sans',sans-serif;letter-spacing:0.02em}
.vid-via-link:hover{color:rgba(212,169,106,0.82)}
.vid-via-icon{font-size:0.58rem;line-height:1;opacity:0.75}
.vid-external{display:flex;align-items:center;justify-content:center;min-height:220px;padding:28px 16px;background:#1a1008;border-radius:8px}
.vid-pill{display:inline-block;padding:12px 22px;border-radius:999px;background:rgba(200,133,58,0.2);color:#D4A96A;font-size:0.88rem;text-decoration:none;border:1px solid rgba(212,169,106,0.45);font-family:'DM Sans',sans-serif}
.vid-pill:hover{background:rgba(200,133,58,0.35);color:#FAF6F0}
.scard-body{padding:12px 14px 10px;flex:1;display:flex;flex-direction:column;align-items:stretch;min-height:0}
.scard-name{font-family:'Playfair Display',serif;font-size:1.08rem;color:#2C1A0E;line-height:1.35;flex:0 0 2.9rem;height:2.9rem;margin-bottom:2px;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis}
.scard-meta{font-size:0.66rem;color:#bbb;line-height:1.35;flex:0 0 0.9rem;height:0.9rem;margin-bottom:8px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.scard-known-wrap{margin-bottom:8px}
.scard-known-label{font-size:0.58rem;text-transform:uppercase;letter-spacing:0.09em;color:#bbb;font-weight:500;margin-bottom:3px;font-style:normal}
.scard-known-slot{flex:0 0 72px;height:72px;margin-bottom:8px;overflow:hidden;flex-shrink:0}
.scard-known{font-size:0.82rem;color:var(--esp);font-style:italic;border-left:3px solid var(--mist);padding-left:10px;line-height:1.55;margin-bottom:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;text-overflow:ellipsis}
.scard-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px;align-content:flex-start;max-height:64px;overflow:hidden;width:100%}
.scard-tags:has(.tag:nth-child(4)){gap:6px}
.scard-tags .tag{flex:1 1 calc(33.333% - 3px);box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;text-align:center;min-width:0}
.scard-tags:has(.tag:nth-child(4)) .tag{flex:1 1 calc(33.333% - 4px)}
.scard-tags:has(.tag:nth-child(4):last-child) .tag,
.scard-tags:has(.tag:nth-child(2):last-child) .tag{flex:1 1 calc(50% - 2px)}
.tag,.chip{font-weight:500;white-space:nowrap;border:1px solid transparent}
.tag{font-size:0.62rem;padding:2px 7px;border-radius:7px}
.tag.t-id,.chip.t-id{background:#F5E6C8;color:#2C1A0E}
.tag.t-cof,.chip.t-cof{background:#F2EAE0;color:#6B4A2A}
.tag.t-drk,.chip.t-drk{background:#E8F0E8;color:#2D4A2D}
.tag.t-vib,.chip.t-vib{background:#E8EEF5;color:#1A3A5C}
.tag.t-cold,.chip.t-cold{background:#E0F0F0;color:#1A4040}
.tag.t-prc,.chip.t-prc{background:#EEE8F5;color:#3D2060}
.tag.t-fod,.chip.t-fod{background:#F5E8EC;color:#6B2A3A}
.tag.t-xp,.chip.t-xp{background:#EDEFDF;color:#3D4A10}
.scard-map-strip{border-top:1px solid var(--mist);height:72px;flex-shrink:0;margin-top:auto;position:relative;overflow:hidden;background:var(--cream)}
.scard-map-strip img{width:100%;height:100%;object-fit:cover;display:block}
.scard-map-label{position:absolute;top:6px;left:8px;font-size:0.58rem;color:var(--bark);background:rgba(255,255,255,0.85);border-radius:4px;padding:2px 6px}
.scard-map-btn{position:absolute;bottom:7px;right:8px;background:white;border:1px solid var(--mist);border-radius:5px;padding:4px 10px;font-size:0.63rem;font-weight:500;color:var(--esp);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.15s}
.scard-map-btn:hover{background:var(--esp);color:var(--lat)}

/* SKELETON CARDS (Google Places fetch) */
.fetch-status{text-align:center;padding:12px 16px 4px;color:var(--bark);font-size:0.82rem}
.fetch-status .ld{display:inline-flex;gap:4px;margin-bottom:6px}
.scard--skeleton{pointer-events:none;box-shadow:none}
.scard--skeleton:hover{box-shadow:none}
.scard--skeleton .scard-photo{background:var(--mist)}
.skel-shimmer{background:linear-gradient(90deg,var(--mist) 0%,#ece4da 45%,var(--mist) 90%);background-size:200% 100%;animation:skel-shimmer 1.25s ease-in-out infinite}
.skel-line{border-radius:6px;background:var(--mist)}
.skel-line--title{flex:0 0 2.9rem;height:2.9rem;margin-bottom:2px;width:88%}
.skel-line--meta{flex:0 0 0.9rem;height:0.9rem;margin-bottom:8px;width:42%}
.skel-known{flex:1;height:100%;border-radius:6px;background:var(--mist)}
.scard--skeleton .scard-known-slot{display:flex}
.skel-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px;max-height:64px;overflow:hidden;width:100%}
.skel-pill{flex:1 1 calc(33.333% - 3px);height:22px;border-radius:7px;background:var(--mist);box-sizing:border-box;min-width:0}
.scard--skeleton .scard-map-strip{background:var(--mist)}
@keyframes skel-shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
@media (prefers-reduced-motion:reduce){
  .skel-shimmer{animation:none;background:var(--mist)}
}

/* COMMUNITY FOOTER */
.community-footer{background:var(--esp);border-top:1px solid rgba(200,133,58,0.15);padding:14px 20px;flex-shrink:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}
.cf-btn{display:inline-flex;align-items:center;gap:5px;font-size:0.7rem;color:#D4A96A;background:transparent;border:1px solid rgba(212,169,106,0.5);border-radius:5px;padding:5px 11px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:color 0.15s,border-color 0.15s}
.cf-btn:hover{color:#FAF6F0;border-color:#D4A96A}
.cf-div{width:1px;height:12px;background:rgba(200,133,58,0.12);flex-shrink:0}

/* LOADING */
.ld-wrap{text-align:center;padding:60px 20px;color:var(--bark);font-size:0.82rem}
.ld{display:inline-flex;gap:4px;margin-bottom:8px}
.ld span{width:7px;height:7px;background:var(--car);border-radius:50%;animation:bo 1.2s infinite}
.ld span:nth-child(2){animation-delay:.2s}.ld span:nth-child(3){animation-delay:.4s}
@keyframes bo{0%,80%,100%{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}
.prog-bar{height:2px;background:var(--mist);border-radius:2px;width:180px;margin:8px auto 0}
.prog-fill{height:100%;background:var(--car);border-radius:2px;transition:width 0.3s;width:0%}
.prog-txt{font-size:0.66rem;color:#bbb;margin-top:4px}
.empty-st{text-align:center;padding:60px 24px;max-width:420px;margin:0 auto;color:var(--bark);font-size:0.88rem;line-height:1.5}
.empty-st-msg{margin:0 0 16px}
.empty-st-btn{background:var(--esp);color:var(--lat);border:none;border-radius:7px;padding:8px 16px;font-family:'DM Sans',sans-serif;font-size:0.75rem;cursor:pointer}
.empty-st-btn:hover{opacity:0.9}

/* MAP MODAL */
.mov{position:fixed;inset:0;background:rgba(44,26,14,0.7);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center}
.mov.hid{display:none}
.map-mw{background:white;border-radius:14px;width:660px;max-width:95vw;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
.map-mhdr{padding:13px 17px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--mist)}
.map-mt{font-family:'Playfair Display',serif;font-size:0.95rem;color:var(--esp)}
.map-mc{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--bark)}
#mapModalEl{height:380px}

/* API MODAL */
.mf{margin-bottom:8px}.mf label{display:block;font-size:0.65rem;color:var(--bark);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.06em}
.mf input{width:100%;border:1px solid var(--mist);border-radius:6px;padding:7px 10px;font-family:'DM Sans',sans-serif;font-size:0.8rem;color:var(--esp);outline:none;background:white}
.mf input:focus{border-color:var(--car)}
.mact{display:flex;gap:7px;margin-top:12px}
.bp{flex:1;background:var(--esp);color:var(--lat);border:none;border-radius:7px;padding:9px;font-family:'DM Sans',sans-serif;font-size:0.8rem;cursor:pointer}.bp:hover{background:var(--bark)}
.bs{flex:1;background:white;color:var(--bark);border:1px solid var(--mist);border-radius:7px;padding:9px;font-family:'DM Sans',sans-serif;font-size:0.8rem;cursor:pointer}.bs:hover{border-color:var(--car)}

/* FEEDBACK MODAL */
.fb-m{background:var(--foam);border-radius:13px;padding:24px;width:440px;max-width:92vw;max-height:90vh;overflow-y:auto}
.fb-m h2{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--esp);margin-bottom:5px}
.fb-m p{font-size:0.76rem;color:var(--bark);margin-bottom:14px;line-height:1.6}
.fb-sub{font-size:0.72rem;color:var(--bark);margin-bottom:14px;line-height:1.5}
.mf{margin-bottom:10px}
.mf label{display:block;font-size:0.65rem;color:var(--bark);margin-bottom:3px;text-transform:uppercase;letter-spacing:0.06em}
.mf input,.mf select,.mf textarea{width:100%;border:1px solid var(--mist);border-radius:6px;padding:7px 10px;font-family:'DM Sans',sans-serif;font-size:0.8rem;color:var(--esp);outline:none;background:white;resize:vertical}
.mf input:focus,.mf select:focus,.mf textarea:focus{border-color:var(--car)}
.fb-pick{display:flex;flex-direction:column;gap:10px}
.fb-path{display:block;width:100%;text-align:left;padding:14px 16px;border-radius:10px;border:1px solid var(--mist);background:white;cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color 0.15s,background 0.15s,box-shadow 0.15s}
.fb-path:hover{border-color:rgba(200,133,58,0.45);background:#FFFBF6;box-shadow:0 2px 10px rgba(44,26,14,0.06)}
.fb-path-icon{font-size:1.15rem;display:block;margin-bottom:6px}
.fb-path-title{font-size:0.82rem;font-weight:600;color:var(--esp);line-height:1.35;display:block}
.fb-form{display:none}
.fb-form.on{display:block}
.fb-form h3{font-family:'Playfair Display',serif;font-size:1rem;color:var(--esp);margin-bottom:4px}
.fb-back{font-size:0.68rem;color:var(--car);background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;padding:0;margin-bottom:10px;text-decoration:underline}
.fb-back:hover{color:var(--bark)}
.fb-ok{display:none;text-align:center;padding:12px 8px;font-size:0.76rem;color:var(--green)}
.fb-ok.on{display:block}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--esp);border-radius:8px;padding:10px 16px;font-size:0.75rem;color:var(--lat);z-index:600;transform:translateY(50px);opacity:0;transition:all 0.25s ease;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}

/* MOBILE */
@media(max-width:600px){
  .sb{display:none}
  .main{flex-direction:column}
  .content{flex:1;min-height:0}
  .cards-wrap{padding:10px 12px 80px}
  .filter-fab{display:flex!important;align-items:center;justify-content:center;bottom:calc(58px + env(safe-area-inset-bottom,0px));min-height:44px;padding:10px 22px}
  .scard-photo{height:170px}
  .scard-map-strip{height:70px}
  .scard-body{min-width:0}
  .scard-known-slot,.scard-known{overflow-wrap:break-word;word-wrap:break-word}
  .scard-tags{max-width:100%;overflow-wrap:anywhere}
  .letter-nav{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:12px;scrollbar-width:none}
  .letter-nav::-webkit-scrollbar{display:none}
  .ltr-btn{flex-shrink:0}
  .detail-panel{width:100%;max-width:100vw}
  .dp-known{overflow-wrap:break-word;word-wrap:break-word}
  .dp-tags{max-width:100%}
  .community-footer{padding:12px 14px;gap:8px;flex-shrink:0}
  .cf-btn{min-height:44px;padding:8px 12px;touch-action:manipulation}
}

/* MOBILE FILTER DRAWER */
.filter-fab{display:none;position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--esp);color:var(--lat);border:none;border-radius:22px;padding:10px 20px;font-family:'DM Sans',sans-serif;font-size:0.78rem;font-weight:500;cursor:pointer;z-index:400;box-shadow:0 4px 20px rgba(44,26,14,0.35)}
.drawer-dim{position:fixed;inset:0;background:rgba(44,26,14,0.4);z-index:440;opacity:0;pointer-events:none;transition:opacity 0.3s}
.drawer-dim.on{opacity:1;pointer-events:auto}
.filter-drawer{position:fixed;bottom:0;left:0;right:0;background:var(--foam);border-radius:16px 16px 0 0;z-index:450;transform:translateY(100%);transition:transform 0.3s cubic-bezier(0.16,1,0.3,1);max-height:82vh;display:flex;flex-direction:column}
.filter-drawer.open{transform:translateY(0)}
.fd-handle{width:34px;height:3px;background:var(--mist);border-radius:2px;margin:10px auto 0;flex-shrink:0}
.fd-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 8px;flex-shrink:0;border-bottom:1px solid var(--mist)}
.fd-title{font-size:0.82rem;font-weight:500;color:var(--esp)}
.fd-done{background:var(--esp);color:var(--lat);border:none;border-radius:6px;padding:5px 13px;font-size:0.73rem;cursor:pointer;font-family:'DM Sans',sans-serif}
.fd-clear{font-size:0.7rem;color:var(--car);background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;text-decoration:underline}
.fd-body{overflow-y:auto;flex:1;padding-bottom:20px}
#fdFilters .fsec{border-bottom:1px solid var(--mist)}
#fdFilters .fsh{padding:18px 14px 10px}
#fdFilters .fsb{padding:4px 14px 18px;gap:6px;width:100%}
.fd-search{padding:8px 14px;border-bottom:1px solid var(--mist)}
.fd-search input{width:100%;background:white;border:1px solid var(--mist);border-radius:7px;padding:7px 11px;font-family:'DM Sans',sans-serif;font-size:0.8rem;color:var(--esp);outline:none}

/* PHOTO CAROUSEL */
.scard-photo{position:relative}
.carousel-inner{width:100%;height:100%;position:relative;overflow:hidden}
.carousel-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.3s ease}
.carousel-img.active{opacity:1}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.35);border:none;color:white;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:0.8rem;display:flex;align-items:center;justify-content:center;z-index:5;transition:background 0.15s;backdrop-filter:blur(2px)}
.carousel-btn:hover{background:rgba(0,0,0,0.6)}
.carousel-prev{left:7px}.carousel-next{right:7px}
.carousel-dots{position:absolute;bottom:7px;left:50%;transform:translateX(-50%);display:flex;gap:4px;z-index:5}
.carousel-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.5);cursor:pointer;transition:background 0.15s}
.carousel-dot.on{background:white}

/* DETAIL PANEL */
.detail-overlay{position:fixed;inset:0;background:rgba(44,26,14,0.55);z-index:600;backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity 0.25s}
.detail-overlay.on{opacity:1;pointer-events:auto}
.detail-panel{position:fixed;top:0;right:0;width:420px;max-width:100vw;height:100vh;background:var(--foam);z-index:700;transform:translateX(100%);transition:transform 0.32s cubic-bezier(0.16,1,0.3,1);display:flex;flex-direction:column;overflow:hidden;box-shadow:-8px 0 40px rgba(44,26,14,0.15)}
.detail-panel.open{transform:translateX(0)}
.dp-photos{height:240px;flex-shrink:0;position:relative;overflow:hidden;background:var(--mist)}
.dp-photo-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.3s}
.dp-photo-img.active{opacity:1}
.dp-photo-count{position:absolute;bottom:10px;right:12px;background:rgba(0,0,0,0.45);color:white;font-size:0.65rem;padding:2px 8px;border-radius:10px;backdrop-filter:blur(4px)}
.dp-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.3);border:none;color:white;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:0.9rem;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.dp-carousel-btn:hover{background:rgba(0,0,0,0.55)}
.dp-prev{left:10px}.dp-next{right:10px}
.dp-close{position:absolute;top:10px;left:10px;background:rgba(0,0,0,0.35);border:none;color:white;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;z-index:10;backdrop-filter:blur(3px)}
.dp-body{padding:16px 20px;overflow-y:auto;flex:1}
.dp-body::-webkit-scrollbar{width:3px}.dp-body::-webkit-scrollbar-thumb{background:var(--mist)}
.dp-name{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--esp);margin-bottom:3px;line-height:1.3}
.dp-meta{font-size:0.7rem;color:#aaa;margin-bottom:10px}
.dp-rating{display:inline-flex;align-items:center;gap:5px;background:#FFF3E8;border:1px solid rgba(200,133,58,0.2);border-radius:6px;padding:4px 10px;font-size:0.78rem;font-weight:500;color:var(--car);margin-bottom:12px}
.dp-badges{display:none}
.dp-identity-badges{display:flex;flex-wrap:wrap;gap:5px}
.dp-identity-badges .ib{font-size:0.62rem;padding:4px 10px;border-radius:6px}
.dp-known-wrap{margin-top:20px;margin-bottom:12px;border-bottom:1px solid rgba(92,61,46,0.08);padding-bottom:16px}
.dp-known-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:#bbb;font-weight:500;margin-bottom:5px}
.dp-known{font-size:0.78rem;color:var(--esp);font-style:italic;border-left:3px solid var(--mist);padding-left:9px;line-height:1.55}
.dp-vibe-summary{font-size:0.78rem;color:var(--esp);font-style:italic;line-height:1.55}
.dp-order-rec-empty{color:#B0957A;font-style:normal}
.dp-hours{font-size:0.7rem;color:#8a6b55;line-height:1.45;margin-top:0}
.dp-hours strong{display:block;font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:#bbb;font-weight:500;margin-bottom:4px}
.dp-hours span{display:block;margin-top:1px}
#dpVibeWrap{border-bottom:1px solid rgba(92,61,46,0.08);padding-bottom:16px}
.dp-tags-section{margin-top:20px;margin-bottom:8px}
.dp-tags-title{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:#bbb;font-weight:500;margin-bottom:6px}
.dp-tags{display:flex;flex-direction:column;gap:5px;align-items:flex-start}
.dp-tags-pills{display:flex;flex-wrap:wrap;gap:5px;align-items:flex-start}
.dp-tags-pills .tag,.dp-tags .tag{font-size:0.68rem;padding:3px 9px;border-radius:8px;font-weight:500;white-space:nowrap}
.dp-tags-evidence{display:flex;flex-direction:column;gap:4px;margin-top:2px;width:100%}
.dp-tag-evidence{font-style:italic;font-size:0.70rem;color:#8B6A4A;line-height:1.35}
.dp-actions{display:flex;gap:8px;padding:14px 20px;border-top:1px solid var(--mist);flex-shrink:0;background:white}
.dp-btn{flex:1;padding:10px;border-radius:8px;font-size:0.76rem;font-weight:500;cursor:pointer;text-align:center;font-family:'DM Sans',sans-serif;border:none;transition:all 0.15s;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:5px}
.dp-btn-map{background:var(--esp);color:var(--lat)}.dp-btn-map:hover{background:var(--bark)}
.dp-btn-share{background:var(--cream);color:var(--bark);border:1px solid var(--mist)}.dp-btn-share:hover{border-color:var(--car);color:var(--car)}
.scard-name{cursor:pointer;color:#2C1A0E}
