:root{--brand:#0a5bd8;--text:#222;--muted:#667;--bg:#fafafa;--card:#fff;--tag:#f2f4f7}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,'PingFang SC','Noto Sans SC',sans-serif;color:var(--text);background:var(--bg);line-height:1.65}
.no-scroll{overflow:hidden}
.container{max-width:1120px;margin:0 auto;padding:16px}
a{text-decoration:none;color:var(--brand)}
.btn{display:inline-block;padding:12px 16px;border-radius:12px;background:var(--brand);color:#fff;font-weight:600;border:1px solid var(--brand)}
.btn.outline{background:transparent;color:var(--brand)}
.section-title{font-size:20px;margin:18px 0 10px 0}
/* Banner */
.banner{position:relative;border-radius:16px;overflow:hidden}
.banner img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}
.banner .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.5));display:flex;align-items:end}
.banner .content{padding:18px;color:#fff}
.banner h1{margin:0 0 8px 0;font-size:28px}
.banner p{margin:0 0 12px 0;opacity:.95}
.banner .actions{display:flex;gap:10px;flex-wrap:wrap}
/* 强化“私聊 Telegram”（outline 按钮）：品牌蓝描边 + 蓝文字 */
.banner .actions .btn.outline{background:transparent;color:var(--brand);border:1px solid var(--brand);box-shadow:none}
.banner .actions .btn.outline:hover{transform:translateY(-1px);opacity:.95}
.banner .actions .btn.outline:focus{outline:2px solid rgba(10,91,216,.3);outline-offset:2px}
@media (min-width:780px){
  .banner img{aspect-ratio:16/7}
}
/* Horizontal scroll girls */
.hscroll{display:flex;gap:12px;overflow-x:auto;padding:8px 2px 8px 2px;scroll-snap-type:x mandatory}
.card-square{flex:0 0 180px;background:var(--card);border:1px solid #eee;border-radius:14px;overflow:hidden;scroll-snap-align:start}
.card-square .img{width:100%;aspect-ratio:1/1;display:block;object-fit:cover}
.card-square .meta{padding:8px 10px}
.card-square .name{font-weight:700}
.card-square .city{color:var(--muted);font-size:13px}
/* Vertical list girls */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.girl-vert{grid-column:span 12;background:var(--card);border:1px solid #eee;border-radius:14px;overflow:hidden;display:grid;grid-template-columns:1fr}
.girl-vert .thumb-wrap{position:relative}
.girl-vert img{width:100%;display:block;aspect-ratio:4/5;object-fit:cover}
.tags{position:absolute;top:8px;left:8px;display:flex;gap:6px;flex-wrap:wrap}
.tag{background:var(--tag);color:#333;border-radius:999px;padding:4px 8px;font-size:12px}
.girl-vert .info{padding:10px 12px}
.girl-vert .name{font-weight:700;font-size:18px;margin:0}
.girl-vert .city{color:#667;font-size:13px;margin:4px 0 6px}
.girl-vert .bio{color:#444;margin:0}
@media (min-width:640px){
  .girl-vert{grid-column:span 6}
}
@media (min-width:980px){
  .girl-vert{grid-column:span 4}
}
/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.8);display:none;align-items:center;justify-content:center;z-index:999}
.lightbox img{max-width:92vw;max-height:92vh;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.lightbox.show{display:flex}
.lightbox .close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:999px;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;font-size:20px;color:#111;cursor:pointer}
/* SEO content */
.prose h2{font-size:22px;margin:14px 0 6px}
.prose h3{font-size:18px;margin:12px 0 6px}
.prose p{margin:8px 0}
.prose ul{padding-left:18px;margin:8px 0}
/* Blog cards */
.blog-grid{display:grid;grid-template-columns:1fr;gap:14px}
.blog-card{background:var(--card);border:1px solid #eee;border-radius:14px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:box-shadow .2s ease, transform .2s ease}
.blog-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.08);transform:translateY(-2px)}
.blog-card img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;transition:transform .25s ease}
.blog-card:hover img{transform:scale(1.02)}
.blog-card .meta{padding:12px 14px}
.blog-card .meta h3{margin:0 0 6px 0;font-size:17px}
.blog-card .meta .muted{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.muted{color:#667}
@media (min-width:780px){
  .blog-grid{grid-template-columns:repeat(3,1fr)}
}
footer{padding:24px 0;color:#555}

/* Two-column on mobile for the "all girls" grid */
.grid.girls-two .girl-vert{grid-column:span 6}
@media (min-width:980px){
  .grid.girls-two .girl-vert{grid-column:span 4}
}

/* SEO panel (cities/tags/FAQ) */
.seo-panel{background:var(--card);border:1px solid #eee;border-radius:14px;padding:16px;margin-top:18px}
.seo-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.seo-header h2{margin:0;font-size:18px}
.seo-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:780px){.seo-grid{grid-template-columns:1fr 1fr}}
.seo-block h3{margin:0 0 8px 0;font-size:16px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-block;background:var(--tag);color:#333;border:1px solid #e5e7eb;border-radius:999px;padding:6px 10px;font-size:13px}
.chip:hover{background:#e9eef6}
.faq{margin-top:12px}
details.seo-faq{background:#fff;border:1px solid #eee;border-radius:10px;padding:10px 12px}
details.seo-faq+details.seo-faq{margin-top:8px}
details.seo-faq summary{cursor:pointer;font-weight:600;list-style:none;display:flex;align-items:center;gap:6px}
details.seo-faq summary::-webkit-details-marker{display:none}
details.seo-faq[open]{border-color:#d5def0;box-shadow:0 1px 0 rgba(0,0,0,.02)}

/* Hover polish for girls cards */
.girl-vert{transition:box-shadow .2s ease, transform .2s ease}
.girl-vert:hover{box-shadow:0 6px 18px rgba(0,0,0,.06);transform:translateY(-2px)}

/* Age gate */
.age-gate{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:10000}
.age-card{width:100%;max-width:560px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.18);padding:18px}
.age-title{margin:4px 0 8px 0;font-size:20px}
.age-text{margin:0 0 14px 0;color:#333}
.age-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}

/* Marquee (text ticker) */
.marquee{background:#fff;border:1px solid #eee;border-radius:12px;overflow:hidden;margin:16px 0}
.marquee-track{display:flex;gap:48px;align-items:center;white-space:nowrap;padding:10px 12px;color:#333;animation:marquee-linear 22s linear infinite}
.marquee a{color:var(--brand)}
@keyframes marquee-linear{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* Hide secondary marquee placed after girls grid (legacy block) */
.grid.girls-two + .marquee{display:none}
/* Slim variant used under section title */
.marquee.marquee-slim{margin:8px 0}.marquee.marquee-slim .marquee-track{padding:6px 10px;font-size:14px;animation-duration:12s}
/* Hide the in-section duplicate marquee that sits before the "查看全部女生" link */
.marquee.marquee-slim:has(+ .muted){display:none}
/* Hide the banner-adjacent marquee (we will render inline in title) */
.banner + .marquee{display:none}

/* Inline marquee inside the section title */
.section-title.with-marquee{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}
.section-title.with-marquee .marquee-inline{flex:1;min-width:0;overflow:hidden}
.section-title.with-marquee .marquee-inline .marquee-track{display:flex;gap:40px;animation:marquee-linear 8s linear infinite}
.section-title.with-marquee .marquee-inline a{color:var(--brand)}

/* Place marquee to the right of the title without changing markup */
h2.section-title{display:block;margin-right:0}
.section-title + .marquee.marquee-slim{display:block !important;vertical-align:baseline;background:transparent;border:0;border-radius:0;margin:8px 0}
.section-title + .marquee.marquee-slim .marquee-track{padding:0 8px;font-size:14px;animation-duration:8s}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none !important; transform:none !important}
}

/* Floating contact button and card */
.contact-fab{position:fixed;right:16px;bottom:18px;width:54px;height:54px;border-radius:999px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(0,0,0,.18);cursor:pointer;z-index:1000;border:1px solid rgba(10,91,216,.9)}
.contact-fab:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.22)}
.contact-card{position:fixed;right:16px;bottom:86px;width:280px;max-width:calc(100vw - 32px);background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 14px 36px rgba(0,0,0,.16);padding:12px;z-index:1000;opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .18s ease, transform .18s ease}
.contact-card.show{opacity:1;transform:translateY(0);pointer-events:auto}
.contact-card .close{position:absolute;top:6px;right:8px;width:28px;height:28px;border:0;background:transparent;border-radius:8px;color:#666;font-size:18px;cursor:pointer}
.contact-card .inner{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.contact-card .avatar{width:36px;height:36px;border-radius:999px;background:#f6f8ff;display:flex;align-items:center;justify-content:center;font-size:18px}
.contact-card .headline{font-weight:700;margin:2px 0 8px 0;line-height:1.5}
.contact-card .title{margin:0 0 2px 0;font-weight:700}
.contact-card .muted{margin:0 0 8px 0;color:#667;font-size:13px}
.contact-card .links div+div{margin-top:6px}
.contact-card a{color:var(--brand)}
