/* ============================================================
   hub.css — UnveilChina city-hub template (gay-search structure)
   Loaded only by generated city-hub pages. Brand-extended:
   Newsreader serif headings, cream/magenta, swipe carousels,
   gay-venue cards, honest-note blocks. Map uses style.css.
   ============================================================ */
/* ===== Direction C: editorial serif + gaypassport-style vibrancy, our brand ===== */
.chero{position:relative;height:60vh;min-height:440px;overflow:hidden;background:var(--ink)}
.chero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;z-index:0}
.chero .slide.on{opacity:1}
.chero .slide img{width:100%;height:100%;object-fit:cover}
.chero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,20,26,.12) 30%,rgba(20,20,26,.86))}
.chero .inner{position:absolute;z-index:2;left:0;right:0;bottom:0;max-width:var(--maxw);margin:0 auto;padding:0 28px 54px;color:#fff}
.chero .crumb{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;opacity:.92;font-weight:600;margin-bottom:.7rem}
.chero h1{font-family:var(--serif);font-weight:700;font-size:clamp(2rem,4.4vw,3.1rem);line-height:1.02;margin:0;background:var(--rainbow);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 2px 12px rgba(0,0,0,.55))}
.chero h1 .cn{-webkit-text-fill-color:#fff;color:#fff}
.chero .lede{font-family:var(--serif);font-size:clamp(.96rem,1.3vw,1.08rem);line-height:1.6;max-width:62ch;margin-top:1rem;opacity:.97}
.chero .dots{position:absolute;z-index:3;right:28px;bottom:30px;display:flex;gap:8px}
.chero .dots button{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.45);cursor:pointer}
.chero .dots button.on{background:var(--accent);width:26px;border-radius:6px}
.jump{position:sticky;top:0;z-index:30;background:rgba(246,243,238,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.jump .wrap{display:flex;overflow-x:auto;max-width:var(--maxw);margin:0 auto;padding:0 16px}
.jump a{font-family:var(--sans);font-size:.86rem;font-weight:600;color:var(--ink-2);padding:15px 15px;white-space:nowrap;border-bottom:2px solid transparent;text-decoration:none}
.jump a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.hub{background:var(--sand)}
.hub section{max-width:var(--maxw);margin:0 auto;padding:34px 28px;scroll-margin-top:58px}
.eyebrow{font-family:var(--sans);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:.4rem}
.hub h2{font-family:var(--serif);font-weight:700;font-size:clamp(1.4rem,2.4vw,1.85rem);line-height:1.08;margin:.1rem 0 .4rem}
.hub .sub{font-family:var(--serif);font-size:.95rem;color:var(--ink-2);max-width:64ch;margin:0 0 1.5rem}
/* swipe carousel (no heavy JS) */
.rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail>*{scroll-snap-align:start;flex:0 0 clamp(260px,32%,340px)}
/* neighbourhood cards (gay-led) */
.ncard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.ncard .ph{aspect-ratio:4/3;background:var(--sand-2)}.ncard .ph img{width:100%;height:100%;object-fit:cover}
.ncard .b{padding:15px 17px 18px}
.ncard h3{font-family:var(--serif);font-size:1.32rem;font-weight:700;margin:0}
.ncard .area{font-family:var(--sans);font-size:.74rem;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);font-weight:700;margin:.25rem 0 .55rem}
.ncard p{font-size:.96rem;line-height:1.6;color:var(--ink-2);margin:0}
/* hotel cards — gaypassport-style: badges + why-we-love bullets + buttons */
.hcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}
.hcard .ph{aspect-ratio:16/10;position:relative;background:var(--sand-2)}.hcard .ph img{width:100%;height:100%;object-fit:cover}
.hcard .badges{position:absolute;top:10px;left:10px;display:flex;gap:6px;flex-wrap:wrap}
.hcard .badge{background:var(--accent);color:#fff;font-family:var(--sans);font-size:.66rem;font-weight:800;letter-spacing:.04em;padding:4px 9px;border-radius:99px}
.hcard .badge.alt{background:var(--ink)}
.hcard .b{padding:15px 18px 16px;flex:1;display:flex;flex-direction:column}
.hcard h3{font-family:var(--serif);font-size:1.1rem;font-weight:700;margin:0 0 .15rem}
.hcard .meta{font-family:var(--sans);font-size:.82rem;color:var(--muted);display:flex;gap:.6rem;margin-bottom:.6rem}
.hcard .price{color:var(--gold);font-weight:800}
.hcard ul{margin:0 0 .8rem;padding-left:1.1rem}.hcard li{font-size:.92rem;line-height:1.5;color:var(--ink-2);margin-bottom:.2rem}
.hcard .btns{margin-top:auto;display:flex;gap:8px}
.hcard .btns a{flex:1;text-align:center;font-family:var(--sans);font-weight:700;font-size:.82rem;padding:9px 10px;border-radius:8px;text-decoration:none}
.hcard .rev{background:var(--sand-2);color:var(--ink)}.hcard .book{background:var(--accent);color:#fff}
.viewall{display:inline-block;margin-top:22px;font-family:var(--sans);font-weight:700;color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:2px;text-decoration:none}
/* nightlife band (ink + magenta, NOT black/green) */
.band-dark{background:var(--ink);max-width:none;color:#fff}
.band-dark .in{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.band-dark h2{color:#fff}.band-dark .sub{color:#cfc9c0}
.band-dark .vcard{background:#1c1c25;border:1px solid #2c2c38;border-radius:var(--radius-lg);overflow:hidden}
.band-dark .vcard .ph{aspect-ratio:16/10;background:#15151c}.band-dark .vcard .ph img{width:100%;height:100%;object-fit:cover}
.band-dark .vcard .b{padding:14px 16px 16px}
.band-dark .vcard h3{font-family:var(--serif);font-size:1.3rem;margin:0 0 .15rem}
.band-dark .vcard .best{font-family:var(--sans);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#ff9ec0;font-weight:700}
.band-dark .vcard p{font-size:.93rem;line-height:1.55;color:#cfc9c0;margin:.4rem 0 0}

.tcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.tcard .ph{aspect-ratio:16/10;background:var(--sand-2)}.tcard .ph img{width:100%;height:100%;object-fit:cover}
.tcard .b{padding:14px 16px 16px}.tcard h3{font-family:var(--serif);font-size:1.22rem;margin:0 0 .2rem}
.tcard .dur{font-family:var(--sans);font-size:.74rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}
.tcard p{font-size:.92rem;line-height:1.55;color:var(--ink-2);margin:.35rem 0 0}
.acc details{border-bottom:1px solid var(--line)}
.acc summary{font-family:var(--serif);font-size:1.05rem;font-weight:600;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between}
.acc summary::after{content:"+";color:var(--accent);font-family:var(--sans);font-size:1.5rem}
.acc details[open] summary::after{content:"\2013"}
.acc .body{padding:0 0 20px;font-size:1.02rem;line-height:1.7;color:var(--ink-2);max-width:72ch}
.faqd{border-bottom:1px solid var(--line);padding:17px 0}.faqd summary{font-family:var(--serif);font-size:1.02rem;font-weight:600;cursor:pointer}
.faqd .a{margin-top:.6rem;line-height:1.7;color:var(--ink-2);max-width:72ch}
.rel{display:flex;flex-wrap:wrap;gap:13px}
.rel a{background:var(--paper);border:1px solid var(--line);border-radius:99px;padding:10px 18px;font-family:var(--sans);font-weight:600;font-size:.9rem;color:var(--ink);text-decoration:none}
.rel a:hover{border-color:var(--accent);color:var(--accent)}

.note{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:var(--radius-lg);padding:18px 22px;font-size:1.02rem;line-height:1.65;color:var(--ink-2);max-width:80ch}
.note strong{color:var(--ink)}
.hub section.tight{padding-top:34px}

.overview{max-width:var(--maxw);margin:0 auto;padding:40px 28px 0}
.overview p{font-family:var(--serif);font-size:1rem;line-height:1.65;color:var(--ink-2);max-width:74ch}
.overview p+p{margin-top:1rem}
.prose{max-width:74ch}
.prose p{font-size:.94rem;line-height:1.65;color:var(--ink-2);margin:.2rem 0 1.1rem}
.tips{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:.5rem}
.tip{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius-lg);padding:12px 15px;font-size:.9rem;line-height:1.6;color:var(--ink-2)}
.tip strong{color:var(--ink)}

/* ---- magazine additions: pull-quote band, itinerary, stories ---- */
.pull{background:var(--sand-2);border-block:1px solid var(--line);margin:12px 0;padding:42px 24px;text-align:center;font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2.6vw,1.7rem);line-height:1.32;color:var(--ink)}
.pull::before{content:"\201C";color:var(--accent);font-weight:600}
.itin{margin-top:.4rem}
.itin-day{display:grid;grid-template-columns:130px 1fr;gap:26px;padding:22px 0;border-top:1px solid var(--line)}
.itin-day:last-child{border-bottom:1px solid var(--line)}
.itin-when{font-family:var(--sans);font-weight:800;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);padding-top:.35rem}
.itin-body h3{font-family:var(--serif);font-size:1.12rem;font-weight:700;margin:0 0 .45rem}
.itin-body p{font-size:.93rem;line-height:1.6;color:var(--ink-2);margin:0;max-width:72ch}
.srail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.srail::-webkit-scrollbar{display:none}
.scard{scroll-snap-align:start;flex:0 0 clamp(260px,40%,360px);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:var(--ink);transition:.16s}
.scard:hover{box-shadow:var(--shadow-2);transform:translateY(-3px)}
.scard .ph{aspect-ratio:16/10;background:var(--sand-2)}
.scard .ph img{width:100%;height:100%;object-fit:cover}
.scard .b{padding:14px 16px 16px}
.scard h3{font-family:var(--serif);font-size:1.02rem;font-weight:700;margin:0;line-height:1.28}
@media(max-width:680px){.itin-day{grid-template-columns:1fr;gap:6px}}

/* ---- venue cards (clubs/bars/tours): rich light card in a grid ---- */
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.vcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:.16s}
.vcard:hover{box-shadow:var(--shadow-2);transform:translateY(-3px);border-color:var(--line-2)}
.vcard .ph{aspect-ratio:16/10;position:relative;background:var(--sand-2)}
.vcard .ph img{width:100%;height:100%;object-fit:cover}
.vcard .vbadge{position:absolute;top:10px;left:10px;background:rgba(20,20,26,.8);color:#fff;font-family:var(--sans);font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 11px;border-radius:99px;backdrop-filter:blur(4px)}
.vcard .b{padding:11px 13px 12px;flex:1;display:flex;flex-direction:column}
.vcard h3{font-family:var(--serif);font-size:1.05rem;font-weight:700;margin:0 0 .25rem;line-height:1.18}
.vcard .vmeta{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .7rem;margin-bottom:.55rem}
.vcard .vloc{font-family:var(--sans);font-size:.78rem;color:var(--muted)}
.vcard .vprice{font-family:var(--sans);font-size:.78rem;font-weight:800;color:var(--gold);letter-spacing:.02em}
.vcard .vbest{align-self:flex-start;font-family:var(--sans);font-size:.68rem;font-weight:700;color:var(--accent);background:rgba(204,31,74,.08);padding:4px 11px;border-radius:99px;margin-bottom:.6rem}
.vcard p{font-size:.85rem;line-height:1.5;color:var(--ink-2);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* hotels share the grid */
.hcard{background:var(--paper)}
@media(max-width:640px){.vgrid{grid-template-columns:1fr}}

/* clickable venue card + succinct "More" affordance */
.vcard{text-decoration:none;color:inherit}
.vcard .vmore{display:inline-block;margin-top:.5rem;font-family:var(--sans);font-size:.78rem;font-weight:700;color:var(--accent)}
.vcard:hover .vmore{text-decoration:underline}

/* ============================================================
   FASHION PASS — make the hub glossy, vibrant & image-led
   (less "survival guide", more premium gay lifestyle mag)
   ============================================================ */
/* vibrant hero: a gay sunset/magenta wash blended into the dark base */
.chero::after{background:linear-gradient(165deg,rgba(115,41,130,.28) 0%,rgba(204,31,74,.14) 38%,rgba(20,20,26,.55) 72%,rgba(20,20,26,.9) 100%)}
.chero .crumb{color:#ffd9e6}
.chero .lede{max-width:56ch}
/* colourful section eyebrows + a gradient tick under each heading */
.eyebrow{background:var(--rainbow);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;font-weight:800}
.hub h2{position:relative;display:inline-block;padding-bottom:.28rem}
.hub h2::after{content:"";position:absolute;left:0;bottom:0;width:48px;height:4px;border-radius:3px;background:var(--rainbow)}
/* glossy, image-led venue cards */
.vgrid{gap:22px}
.vcard{border-radius:18px;border:1px solid var(--line);box-shadow:0 6px 22px rgba(20,20,26,.07);overflow:hidden}
.vcard:hover{box-shadow:0 18px 48px rgba(20,20,26,.18);transform:translateY(-5px);border-color:transparent}
.vcard .ph{aspect-ratio:4/3;overflow:hidden}
.vcard .ph img{transition:transform .5s ease}
.vcard:hover .ph img{transform:scale(1.07)}
.vcard .vbadge{background:linear-gradient(90deg,var(--accent),#ff7a3d);box-shadow:0 2px 8px rgba(204,31,74,.35);text-transform:uppercase}
.vcard h3{font-size:1.12rem}
.vcard .vbest{background:linear-gradient(90deg,rgba(204,31,74,.12),rgba(255,140,0,.12));color:var(--accent)}
/* glossy hotel cards + gradient flash tags */
.hcard{border-radius:18px;box-shadow:0 6px 22px rgba(20,20,26,.07);overflow:hidden;border:1px solid var(--line)}
.hcard:hover{box-shadow:0 18px 48px rgba(20,20,26,.18);transform:translateY(-5px)}
.hcard .ph{overflow:hidden}.hcard .ph img{transition:transform .5s}.hcard:hover .ph img{transform:scale(1.07)}
.hcard .badge{background:linear-gradient(90deg,var(--accent),#ff5fa2);box-shadow:0 2px 8px rgba(204,31,74,.3)}
.hcard .badge.alt{background:linear-gradient(90deg,#732982,#1f5fbf)}
.hcard .book{background:linear-gradient(90deg,var(--accent),#ff5fa2);box-shadow:0 3px 12px rgba(204,31,74,.35)}
/* gradient pill buttons */
.viewall{background:linear-gradient(90deg,var(--accent),#ff5fa2);color:#fff;border:0;border-radius:99px;padding:12px 24px;box-shadow:0 6px 18px rgba(204,31,74,.3);transition:.16s}
.viewall:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(204,31,74,.42);color:#fff}
/* softer, prettier note + tip cards */
.note{border-radius:16px;box-shadow:0 4px 16px rgba(20,20,26,.05)}
.tip{border-radius:14px;box-shadow:0 4px 14px rgba(20,20,26,.05)}
.scard{border-radius:18px;box-shadow:0 6px 22px rgba(20,20,26,.07)}
.scard .ph{overflow:hidden}.scard .ph img{transition:transform .5s}.scard:hover .ph img{transform:scale(1.07)}
/* gallery: rounder, glossier */
.gallery a{border-radius:16px}
/* pull-quote: a vibrant gradient band */
.pull{background:linear-gradient(120deg,#fff5f8,#fdf2ec);border-block:1px solid var(--line);color:var(--ink)}
.pull::before{background:var(--rainbow);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* HOT LIST buttons (hotels) — gaypassport-style */
.hotlists{display:flex;flex-wrap:wrap;gap:14px;margin-top:22px}
.hotlist{display:flex;align-items:center;gap:12px;background:var(--ink);color:#fff;border-radius:14px;padding:13px 20px;text-decoration:none;font-family:var(--sans);font-weight:700;font-size:.92rem;box-shadow:0 6px 18px rgba(20,20,26,.15);transition:.16s}
.hotlist:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(20,20,26,.25);color:#fff}
.hl-tag{background:var(--rainbow);color:#fff;font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:99px;white-space:nowrap}
.hl-go{margin-left:auto;color:#ff9ec0;font-size:.84rem;white-space:nowrap}

/* ---- charming gradient art-tiles (so empty placeholders look DESIGNED) ---- */
.ph[class*="cat-"]{position:relative;display:flex;align-items:center;justify-content:center}
.ph .ph-name{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 18px;color:#fff;font-family:var(--serif);font-weight:600;font-size:1.18rem;line-height:1.2;letter-spacing:.01em;text-shadow:0 1px 10px rgba(0,0,0,.28);z-index:0}
.ph img{position:relative;z-index:1}
.cat-bars{background:linear-gradient(135deg,#732982 0%,#cc1f4a 65%,#ff8c00 100%)}
.cat-saunas{background:linear-gradient(135deg,#1f5fbf,#16a6c4)}
.cat-massage{background:linear-gradient(135deg,#0a8a3d,#15a0a0)}
.cat-gym{background:linear-gradient(135deg,#ff8c00,#e40303)}
.cat-tours{background:linear-gradient(135deg,#1f5fbf,#0a8a3d)}
.cat-hotels{background:linear-gradient(135deg,#b8862f,#732982)}
/* delicacy pass: airier, more refined */
.hub section{padding-top:40px;padding-bottom:40px}
.hub .sub{color:var(--muted);max-width:60ch;margin-bottom:1.7rem}
.eyebrow{letter-spacing:.18em;font-size:.72rem;margin-bottom:.55rem}
.vcard h3{letter-spacing:-.005em}
.vcard .b{padding:13px 15px 15px}
.overview p{font-size:1.05rem;color:var(--ink-2)}

/* ---- designer touches: hero facts, city strip, back-to-top, reveal ---- */
html{scroll-behavior:smooth}
.herofacts{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.1rem}
.herofacts span{font-family:var(--sans);font-size:.76rem;font-weight:600;color:#fff;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);padding:6px 13px;border-radius:99px}
.cityrail{display:flex;flex-wrap:wrap;gap:12px;margin-top:.4rem}
.citychip{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 22px;min-width:104px;transition:.16s;box-shadow:0 4px 14px rgba(20,20,26,.05)}
.citychip:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(20,20,26,.16);border-color:transparent}
.cc-en{font-family:var(--sans);font-weight:800;color:var(--ink);font-size:.98rem}
.cc-cn{font-family:var(--serif);color:var(--accent);font-size:.85rem}
#toTop{position:fixed;right:20px;bottom:20px;width:46px;height:46px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--accent),#ff5fa2);color:#fff;font-size:1.3rem;cursor:pointer;box-shadow:0 8px 22px rgba(204,31,74,.4);opacity:0;transform:translateY(14px);pointer-events:none;transition:.22s;z-index:60}
#toTop.show{opacity:1;transform:none;pointer-events:auto}
#toTop:hover{transform:translateY(-3px)}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* full-width explore map (list removed) */
#explore .map-full{margin-top:14px}
#explore #map{height:460px;width:100%;border-radius:18px;box-shadow:0 6px 22px rgba(20,20,26,.08);z-index:0}
#explore .venue-list[hidden]{display:none}
#explore .venue-count{font-family:var(--sans);color:var(--muted);font-weight:600;font-size:.84rem;margin-top:.4rem}
#explore .toolbar{padding:0;margin-top:.2rem;background:none}
@media(max-width:640px){#explore #map{height:360px}}

/* ============ individual merchant (venue) detail pages ============ */
.m-hero{position:relative;color:#fff}
.m-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,26,.12),rgba(20,20,26,.45));z-index:0}
.m-hero-in{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:54px 28px 42px}
.m-hero .crumb{font-family:var(--sans);font-size:.78rem;opacity:.95;margin-bottom:1rem}
.m-hero .crumb a{color:#fff;text-decoration:underline}
.m-badge{display:inline-block;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);color:#fff;font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:99px;backdrop-filter:blur(6px)}
.m-hero h1{font-family:var(--serif);font-weight:700;font-size:clamp(2rem,4.5vw,3rem);margin:.7rem 0 .3rem;line-height:1.05;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.m-hero .m-meta{font-family:var(--sans);font-size:.92rem;opacity:.96}
.m-body{max-width:760px;margin:0 auto;padding:34px 28px 70px}
.m-photo{aspect-ratio:16/9;border-radius:18px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:26px;box-shadow:0 10px 30px rgba(20,20,26,.12)}
.m-photo .ph-name{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 22px;color:#fff;font-family:var(--serif);font-weight:600;font-size:1.6rem;text-shadow:0 1px 10px rgba(0,0,0,.3);z-index:0}
.m-photo img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover}
.m-best{font-family:var(--sans);font-weight:700;color:var(--accent);margin:0 0 .8rem}
.m-lead{font-family:var(--serif);font-size:1.2rem;line-height:1.6;color:var(--ink);margin:0 0 1rem}
.m-long{font-size:1.02rem;line-height:1.75;color:var(--ink-2);margin-bottom:1.6rem}
.m-todo-block{color:var(--muted);font-style:italic}
.m-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:1.8rem}
.m-fact{background:var(--paper);padding:13px 16px}
.m-k{display:block;font-family:var(--sans);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:3px}
.m-v{font-family:var(--sans);font-size:.94rem;color:var(--ink)}
.m-todo{color:var(--gold);font-style:italic}
.m-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.m-cta .book{background:linear-gradient(90deg,var(--accent),#ff5fa2);color:#fff;font-family:var(--sans);font-weight:700;padding:12px 24px;border-radius:99px;text-decoration:none;box-shadow:0 6px 18px rgba(204,31,74,.3)}
.m-cta .m-back{font-family:var(--sans);font-weight:700;color:var(--accent);text-decoration:none}

/* merchant page photo gallery (multiple shots) */
.m-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:0 0 26px}
.m-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px}

/* "Queer favourite" badge (top-right, gold) */
.vcard .ph .vbadge.fav{left:auto;right:10px;background:linear-gradient(90deg,#b8862f,#ffd400);color:#14141a;box-shadow:0 2px 8px rgba(184,134,47,.45)}
