:root{
  --bg:#f2f3f5; --card:#ffffff; --line:#ececef;
  --txt:#1a1a1a; --sub:#9a9aa2; --muted:#bfbfc6;
  --green:#19b566; --green-d:#13a85d;
  --orange:#ff7a30; --purple:#8b5cf6; --red:#ff4d4f; --gold:#ff9a1a;
  --tabh:54px;
  --safe-t:env(safe-area-inset-top); --safe-b:env(safe-area-inset-bottom);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;height:100%;}
body{
  background:var(--bg); color:var(--txt); overflow-x:hidden;
  font-family:-apple-system,"PingFang SC","Hiragino Sans GB",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; overscroll-behavior-y:none;
}
button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer;padding:0;}
img{display:block;}
.loading{padding:40vh 0;text-align:center;color:var(--sub);}

#view{padding-bottom:calc(var(--tabh) + var(--safe-b) + 6px);}

/* ---------- 顶部标题栏 ---------- */
.appbar{
  position:sticky;top:0;z-index:20;
  padding:calc(var(--safe-t) + 10px) 16px 10px;
  background:rgba(242,243,245,.92);backdrop-filter:blur(14px);
  display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);
}
.appbar .logo{font-size:21px;font-weight:800;letter-spacing:.5px;
  background:linear-gradient(90deg,#7c5cff,#00b3ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.appbar .spacer{flex:1;}
.appbar .search{flex:1;height:34px;border-radius:18px;background:#e9eaee;color:var(--sub);
  display:flex;align-items:center;gap:6px;padding:0 14px;font-size:13px;}
.appbar .iconbtn{width:34px;height:34px;border-radius:50%;background:#e9eaee;
  display:grid;place-items:center;font-size:16px;color:#6a6a72;}

/* ---------- 模块通用 ---------- */
.module{margin:14px 0 4px;}
.mod-head{display:flex;align-items:center;padding:0 14px 10px;}
.mod-head .bar{width:4px;height:17px;border-radius:2px;background:var(--green);margin-right:8px;}
.mod-head h3{font-size:17px;font-weight:800;margin:0;color:#1d1d1f;}
.mod-head .more{margin-left:auto;font-size:13px;color:var(--sub);display:flex;align-items:center;gap:2px;}

/* ---------- 标准卡片 ---------- */
.cgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:11px;padding:0 14px;}
.card{display:flex;flex-direction:column;min-width:0;text-decoration:none;color:inherit;}
.card .cv{position:relative;width:100%;aspect-ratio:3/4;flex-shrink:0;border-radius:9px;overflow:hidden;
  background:#e7e8ec;border:1px solid var(--line);}
.card .cv>img,.card .cv>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;}
.card .tt{font-size:13px;font-weight:600;color:#222;margin:7px 1px 2px;line-height:1.3;min-height:1.3em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.card .meta{display:flex;align-items:center;font-size:12px;color:var(--green);margin:0 1px;min-height:18px;}
.card .meta .hot{display:flex;align-items:center;gap:2px;font-weight:700;}
.card .meta .ch{margin-left:auto;color:var(--green-d);}
.card .meta .flame{width:13px;height:13px;}

/* 左下角 连载/完结 斜角标 */
.ribbon{position:absolute;left:0;bottom:8px;z-index:3;font-size:11px;line-height:1;color:#fff;
  font-weight:700;padding:4px 14px 4px 8px;
  clip-path:polygon(0 0,100% 0,calc(100% - 7px) 50%,100% 100%,0 100%);}
.ribbon.lz{background:var(--orange);}     /* 连载 */
.ribbon.wj{background:var(--green);}        /* 完结 */
/* 右上角 独家/精品/火热 */
.corner{position:absolute;right:6px;top:6px;z-index:3;font-size:11px;font-weight:700;color:#fff;
  padding:3px 8px;border-radius:8px;}
.corner.dj{background:var(--purple);}      /* 独家 */
.corner.jp{background:var(--gold);}         /* 精品 */
.corner.rh{background:var(--red);}          /* 火热 */

/* ---------- 大 Banner ---------- */
.banner-card{padding:0 14px;}
.banner-card .bc{position:relative;width:100%;aspect-ratio:2/1;max-height:200px;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);display:block;}
.banner-card .bc::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 80% at 25% 15%,rgba(255,255,255,.32),rgba(255,255,255,0) 60%);}
.banner-card .bc::after{content:"";position:absolute;right:-30px;bottom:-50px;width:180px;height:180px;z-index:1;pointer-events:none;
  border-radius:50%;background:rgba(0,0,0,.10);}
.banner-card .bc.has-cover::before{background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.38));}
.banner-card .bc.has-cover::after{display:none;}
.banner-card .bhero{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:900;color:#fff;letter-spacing:2px;text-align:center;padding:0 18px;
  text-shadow:0 2px 14px rgba(0,0,0,.28);}
.banner-card .bc>img,.banner-card .bc>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;}
.banner-card .bttl{text-align:center;font-size:15px;font-weight:800;color:#1d1d1f;margin:10px 0 4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.banner-card .bmeta{display:flex;align-items:center;font-size:12px;color:var(--green);padding:0 2px 8px;min-height:18px;}
.banner-card .bmeta .hot{display:flex;align-items:center;gap:2px;font-weight:700;}
.banner-card .bmeta .ch{margin-left:auto;color:var(--green-d);}
.banner-card .bmeta .flame{width:14px;height:14px;}

/* ---------- 横滑 + 圆点 ---------- */
.hscroll{display:flex;gap:11px;overflow-x:auto;padding:0 14px 2px;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;}
.hscroll::-webkit-scrollbar{display:none;}
.hscroll .card{flex:0 0 calc((100% - 22px) / 3);min-width:0;scroll-snap-align:start;}
.dots{display:flex;justify-content:center;gap:6px;padding:10px 0 2px;}
.dots i{width:7px;height:7px;border-radius:50%;background:#d3d4d9;transition:.2s;}
.dots i.on{width:18px;border-radius:4px;background:var(--green);}

/* ---------- 左图右文 列表 ---------- */
.vlist{padding:0 14px;}
.vlist .row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);}
.vlist .row:last-child{border-bottom:none;}
.vlist .row .cv{position:relative;flex:0 0 92px;width:92px;aspect-ratio:3/4;border-radius:9px;
  overflow:hidden;background:#e7e8ec;border:1px solid var(--line);}
.vlist .row .cv>img,.vlist .row .cv>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;}
.vlist .row .info{flex:1;min-width:0;display:flex;flex-direction:column;}
.vlist .row .info .tt{font-size:15px;font-weight:700;color:var(--green-d);margin:2px 0 6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vlist .row .info .ds{font-size:12.5px;color:var(--sub);line-height:1.6;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.vlist .row .info .meta{display:flex;align-items:center;font-size:12px;color:var(--green);margin-top:6px;}
.vlist .row .info .meta .hot{display:flex;align-items:center;gap:2px;font-weight:700;}
.vlist .row .info .meta .ch{margin-left:18px;color:var(--green-d);}
.vlist .row .info .meta .flame{width:13px;height:13px;}

/* ---------- 模块底部 更多/换一换 ---------- */
.mod-foot{display:flex;gap:12px;padding:14px 14px 4px;}
.mod-foot button{flex:1;height:42px;border-radius:21px;background:#e7e8ec;color:#6a6a72;
  font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;}
.mod-foot button:active{background:#dfe0e5;}

/* ============================================================ 详情页 */
.backbtn{position:fixed;top:calc(var(--safe-t) + 10px);left:14px;z-index:50;
  width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);box-shadow:0 2px 10px rgba(0,0,0,.12);
  display:grid;place-items:center;font-size:22px;color:#333;}
.detail .hero{position:relative;padding:calc(var(--safe-t) + 54px) 16px 16px;overflow:hidden;}
.detail .hero .blur{position:absolute;inset:0;z-index:-2;}
.detail .hero .blur>img,.detail .hero .blur>svg{width:100%;height:100%;object-fit:cover;filter:blur(30px) saturate(1.3);transform:scale(1.4);opacity:.45;}
.detail .hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(0deg,var(--bg),rgba(242,243,245,.5));}
.detail .hero .row{display:flex;gap:14px;}
.detail .hero .cv{position:relative;flex:0 0 112px;width:112px;aspect-ratio:3/4;border-radius:11px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.18);}
.detail .hero .cv>img,.detail .hero .cv>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;}
.detail .hero .info{flex:1;min-width:0;}
.detail .hero .info h1{font-size:21px;margin:2px 0 6px;color:#1d1d1f;}
.detail .hero .info .au{font-size:13px;color:var(--sub);margin:0 0 10px;}
.detail .tags{display:flex;flex-wrap:wrap;gap:6px;}
.detail .tags span{font-size:11px;padding:3px 10px;border-radius:20px;background:#e7e8ec;color:#6a6a72;}
.detail .desc{padding:6px 16px 14px;color:#444;font-size:14px;line-height:1.65;}
.detail .cta{display:flex;gap:12px;padding:0 16px 16px;}
.detail .cta button{height:46px;border-radius:23px;font-size:16px;font-weight:700;}
.detail .cta .primary{flex:1;background:linear-gradient(90deg,var(--green),#1fcf78);color:#fff;}
.detail .cta .ghost{flex:0 0 54px;background:#e7e8ec;color:var(--green-d);font-size:20px;}
.chaps{padding:0 14px;}
.chaps h3{font-size:16px;margin:6px 2px 10px;color:#1d1d1f;}
.chaplist{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.chaplist button{height:44px;border-radius:11px;background:var(--card);border:1px solid var(--line);
  font-size:14px;text-align:left;padding:0 14px;display:flex;align-items:center;gap:8px;color:#333;}
.chaplist button .n{color:var(--green);font-weight:700;}

/* ============================================================ 阅读器（黑底） */
.reader{background:#0b0b0d;min-height:100vh;}
.reader .pages img,.reader .pages svg{width:100%;display:block;}
.reader .rtop{position:fixed;top:0;left:0;right:0;z-index:40;padding:calc(var(--safe-t) + 8px) 14px 10px;
  color:#fff;background:linear-gradient(180deg,rgba(0,0,0,.65),transparent);display:flex;align-items:center;gap:12px;transition:.25s;}
.reader .rtop .iconbtn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:20px;}
.reader .rtop .ttl{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.reader .rbottom{position:fixed;bottom:0;left:0;right:0;z-index:40;padding:12px 14px calc(var(--safe-b) + 12px);
  color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.65),transparent);display:flex;gap:10px;transition:.25s;}
.reader .rbottom button{flex:1;height:42px;border-radius:11px;background:rgba(255,255,255,.16);font-size:15px;font-weight:600;}
.reader .rbottom button:disabled{opacity:.35;}
.reader.hideui .rtop{transform:translateY(-120%);}
.reader.hideui .rbottom{transform:translateY(120%);}
.reader .endcard{padding:36px 24px calc(var(--safe-b) + 36px);text-align:center;color:#888;}

/* ============================================================ 我的 */
.me .prof{display:flex;align-items:center;gap:14px;padding:calc(var(--safe-t) + 24px) 18px 22px;
  background:linear-gradient(135deg,#7c5cff,#00b3ff);color:#fff;}
.me .prof .av{width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.25);display:grid;place-items:center;font-size:26px;font-weight:800;}
.me .prof .nm{font-size:19px;font-weight:700;}
.me .prof .id{font-size:13px;opacity:.85;margin-top:3px;}
.me .stats{display:flex;margin:-14px 16px 16px;background:var(--card);border-radius:14px;padding:15px 0;box-shadow:0 4px 16px rgba(0,0,0,.06);position:relative;}
.me .stats div{flex:1;text-align:center;}
.me .stats .num{font-size:20px;font-weight:800;color:#1d1d1f;}
.me .stats .lab{font-size:12px;color:var(--sub);margin-top:3px;}
.me .list{margin:0 16px;background:var(--card);border-radius:14px;overflow:hidden;}
.me .list a{display:flex;align-items:center;gap:12px;padding:15px 14px;border-bottom:1px solid var(--line);font-size:15px;color:#333;text-decoration:none;}
.me .list a:last-child{border-bottom:none;}
.me .list a .ic{color:var(--green);width:22px;text-align:center;}
.me .list a .ar{margin-left:auto;color:var(--muted);}
.me .note{margin:18px 16px;font-size:12px;color:var(--sub);line-height:1.7;background:var(--card);border-radius:12px;padding:14px 16px;}

/* ============================================================ 发现 */
.disc-chips{display:flex;flex-wrap:wrap;gap:8px;padding:4px 14px 8px;}
.disc-chips span{font-size:13px;padding:7px 16px;border-radius:18px;background:var(--card);border:1px solid var(--line);color:#555;}

/* ---------- 底部 Tab ---------- */
#tabbar{position:fixed;bottom:0;left:0;right:0;z-index:30;height:calc(var(--tabh) + var(--safe-b));
  padding-bottom:var(--safe-b);display:flex;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border-top:1px solid var(--line);}
#tabbar.hide{transform:translateY(120%);}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--muted);font-size:11px;}
.tab .ic{height:24px;display:flex;align-items:center;justify-content:center;}
.tab .ic svg{width:24px;height:24px;display:block;}
.tab.active{color:var(--green);}
.soon{padding:60px 28px 80px;text-align:center;color:var(--sub);}
.soon .soon-ic{font-size:54px;margin-bottom:14px;}
.soon h2{font-size:19px;color:#1d1d1f;margin:0 0 8px;}
.soon p{font-size:14px;line-height:1.7;margin:0 auto;max-width:280px;}
.empty{padding:80px 24px;text-align:center;color:var(--sub);}
.empty .big{font-size:40px;margin-bottom:12px;}

/* ---------- 骨架屏 / 加载态 ---------- */
.mod-empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13px;}
.skel{aspect-ratio:3/4;border-radius:9px;background:linear-gradient(100deg,#e9eaee 30%,#f3f4f6 50%,#e9eaee 70%);
  background-size:200% 100%;animation:sk 1.2s ease-in-out infinite;}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ============================================================ 通用绿色顶栏 */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:8px;
  padding:calc(var(--safe-t) + 10px) 8px 10px;background:var(--green);color:#fff;}
.topbar .bk,.topbar .home{flex:0 0 38px;width:38px;height:38px;display:grid;place-items:center;color:#fff;}
.topbar .bk{font-size:26px;line-height:1;}
.topbar .home svg{width:24px;height:24px;}
.topbar .ttl{flex:1;text-align:center;font-size:17px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ============================================================ 详情页 v2 */
.detail2{padding-bottom:24px;}
.detail2>.loading{padding:28vh 0;}
.detail2 .cover{position:relative;width:200px;aspect-ratio:3/4;margin:18px auto 12px;border-radius:12px;
  overflow:hidden;background:#e7e8ec;box-shadow:0 10px 28px rgba(0,0,0,.22);}
.detail2 .cover>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;}
.detail2 .name{text-align:center;font-size:20px;font-weight:800;color:#1d1d1f;margin:0 0 14px;padding:0 24px;}
.detail2 .intro{padding:0 16px;font-size:15px;line-height:1.9;}
.detail2 .intro .lead{font-weight:800;color:#1d1d1f;margin-right:10px;}
.detail2 .intro .tag{color:var(--green);font-weight:700;margin-right:12px;white-space:nowrap;}
.detail2 .note{padding:8px 16px 0;margin:0;color:#555;font-size:14px;line-height:1.7;}
.detail2 .cta{display:flex;gap:14px;padding:16px;}
.detail2 .cta button{flex:1;height:46px;border-radius:8px;font-size:16px;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:6px;}
.detail2 .cta .bic{width:19px;height:19px;}
.detail2 .cta .read{background:var(--green);color:#fff;}
.detail2 .cta .fav{background:#fff;color:var(--green);border:1.5px solid var(--green);}
.detail2 .cta .fav.on .bic{fill:currentColor;}
.chap-div{display:flex;align-items:center;gap:12px;padding:4px 16px 14px;}
.chap-div::before,.chap-div::after{content:"";flex:1;height:1px;background:var(--line);}
.chap-div span{color:var(--orange);font-size:14px;font-weight:600;white-space:nowrap;}
.chaps2{padding:0 16px;}
.chaplist2{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;overflow:hidden;transition:max-height .38s ease;}
.chaplist2.collapsed{max-height:42px;}
.chaplist2 button{position:relative;height:42px;border-radius:8px;background:var(--green);color:#fff;
  font-size:14px;font-weight:600;overflow:hidden;}
.chaplist2 button .vip{position:absolute;top:0;right:0;background:#ffd400;color:#7a4b00;font-style:normal;
  font-size:9px;font-weight:800;line-height:1;padding:2px 4px;border-bottom-left-radius:6px;}
.expand-btn{display:block;margin:14px auto 2px;padding:11px 44px;border:1.5px solid var(--green);
  color:var(--green);background:#fff;border-radius:24px;font-size:14px;font-weight:600;}
.rec{margin-top:20px;}

/* ============================================================ 阅读器 v2 */
.reader{background:#f3f3f4;min-height:100vh;padding-bottom:calc(56px + var(--safe-b));}
.reader.night{background:#0b0b0d;}
.reader .pages img{width:100%;display:block;}
.reader.night .pages img{filter:brightness(.82);}
.reader .pages .loading,.reader .reader-locked{padding:120px 24px;text-align:center;color:var(--muted);}
.reader.night .pages .loading,.reader.night .reader-locked{color:#777;}
.reader .endcard{padding:30px 24px;text-align:center;color:var(--muted);}
.reader.night .endcard{color:#777;}
.reader .side{position:fixed;top:46%;transform:translateY(-50%);z-index:42;width:52px;height:88px;
  background:var(--green);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;opacity:.92;transition:.25s;}
.reader .side.prev{left:0;border-radius:0 50px 50px 0;padding-left:4px;}
.reader .side.next{right:0;border-radius:50px 0 0 50px;padding-right:4px;}
.reader .side .ar{font-size:12px;}
.reader .side .tx{writing-mode:vertical-rl;letter-spacing:3px;font-size:15px;font-weight:700;}
.reader .side[hidden]{display:none;}
.reader .rbar{position:fixed;left:0;right:0;bottom:0;z-index:42;height:calc(54px + var(--safe-b));
  padding-bottom:var(--safe-b);background:var(--green);color:#fff;display:flex;align-items:center;transition:.25s;}
.reader .rbar button{flex:1;height:54px;display:flex;align-items:center;justify-content:center;gap:5px;
  color:#fff;font-size:15px;font-weight:600;}
.reader .rbar button:disabled{opacity:.45;}
.reader.hideui .topbar{transform:translateY(-120%);}
.reader.hideui .rbar{transform:translateY(120%);}
.reader.hideui .side{opacity:0;pointer-events:none;}
/* 页码 + 翻页模式 */
.reader .pageind{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(54px + var(--safe-b) + 12px);
  z-index:42;background:rgba(0,0,0,.55);color:#fff;font-size:12px;padding:3px 12px;border-radius:14px;
  transition:.25s;pointer-events:none;}
.reader .pageind:empty{display:none;}
.reader.hideui .pageind{opacity:0;}
.reader.paged{height:100vh;overflow:hidden;padding-bottom:0;}
.reader.paged .topbar{position:fixed;top:0;left:0;right:0;}
.reader.paged .endcard{display:none;}
.reader.paged .pages{display:flex;overflow-x:auto;overflow-y:hidden;height:100vh;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.reader.paged .pages::-webkit-scrollbar{display:none;}
.reader.paged .pages img{flex:0 0 100%;width:100vw;height:100vh;object-fit:contain;scroll-snap-align:center;}

/* ============ 短视频 竖屏流 ============ */
.vfeed{position:fixed;inset:0;z-index:10;background:#000;overflow-y:scroll;
  scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.vfeed::-webkit-scrollbar{display:none;}
.vfeed .vloading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;}
.vslide{position:relative;width:100%;height:100%;scroll-snap-align:start;scroll-snap-stop:always;overflow:hidden;background:#000;}
.vvid{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;}
.vplaybtn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;
  border:0;border-radius:50%;background:rgba(0,0,0,.32);color:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;pointer-events:none;z-index:3;}
.vplaybtn svg{width:40px;height:40px;margin-left:4px;}
.vplaybtn.show{opacity:1;}
/* 右侧操作栏 */
.vrail{position:absolute;right:10px;bottom:calc(var(--tabh) + var(--safe-b) + 40px);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:18px;}
.vrail .vauthor{position:relative;width:48px;height:48px;margin-bottom:6px;}
.vrail .vauthor img,.vrail .vauthor .vph{width:48px;height:48px;border-radius:50%;object-fit:cover;
  border:2px solid #fff;background:#444;display:block;}
.vrail .vfollow{position:absolute;left:50%;bottom:-9px;transform:translateX(-50%);width:18px;height:18px;
  border-radius:50%;background:#ff3b5c;color:#fff;font-size:14px;line-height:16px;text-align:center;font-weight:700;}
.vact{background:none;border:0;display:flex;flex-direction:column;align-items:center;gap:4px;color:#fff;}
.vact .vicon{width:34px;height:34px;}
.vact .vicon svg{width:34px;height:34px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));}
.vact b{font-size:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5);}
.vact.on .vicon svg{color:#ff3b5c;fill:#ff3b5c;stroke:#ff3b5c;}
/* 左下作者+文案 */
.vmeta{position:absolute;left:14px;right:80px;bottom:calc(var(--tabh) + var(--safe-b) + 20px);z-index:4;color:#fff;}
.vmeta .vname{font-size:17px;font-weight:700;margin-bottom:7px;text-shadow:0 1px 3px rgba(0,0,0,.5);}
.vmeta .vdesc{font-size:14px;line-height:1.4;text-shadow:0 1px 3px rgba(0,0,0,.5);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.vmeta .vtags{color:#fff;font-weight:600;}
/* 底部进度条 */
.vprog{position:absolute;left:0;right:0;bottom:calc(var(--tabh) + var(--safe-b));height:3px;background:rgba(255,255,255,.25);z-index:6;touch-action:none;}
.vprog::before{content:"";position:absolute;left:0;right:0;top:-14px;height:28px;}  /* 扩大触摸热区，便于拖拽 */
.vprog>i{display:block;height:100%;width:0;background:#fff;position:relative;}
.vprog.scrub{height:6px;}
.vprog.scrub>i::after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:#fff;}

/* ============ 小说 顶部分类 tab ============ */
.ntabs{position:sticky;top:0;z-index:20;display:flex;gap:22px;overflow-x:auto;white-space:nowrap;
  background:var(--green);padding:calc(var(--safe-t) + 12px) 16px 10px;scrollbar-width:none;}
.ntabs::-webkit-scrollbar{display:none;}
.ntab{color:rgba(255,255,255,.72);font-size:16px;flex:0 0 auto;position:relative;padding-bottom:5px;line-height:1;}
.ntab.on{color:#fff;font-weight:800;font-size:18px;}
.ntab.on::after{content:"";position:absolute;left:0;right:0;bottom:0;margin:auto;width:18px;height:3px;border-radius:2px;background:#fff;}

/* ============ 小说 文字阅读器 ============ */
.nreader{min-height:100vh;background:#f6f2e9;color:#2a2520;}
.nreader.night{background:#1a1a1a;color:#b8b2a8;}
.ncontent{padding:16px 20px calc(64px + var(--safe-b));max-width:720px;margin:0 auto;}
.ncontent .nctitle{font-size:20px;font-weight:800;margin:10px 0 18px;line-height:1.4;}
.ncontent p{font-size:18px;line-height:1.9;margin:0 0 18px;text-indent:2em;
  font-family:Georgia,"Songti SC","STSong",serif;letter-spacing:.2px;}
.nreader.night .ncontent p{color:#b8b2a8;}
.nrbar{position:fixed;left:0;right:0;bottom:0;z-index:42;height:calc(52px + var(--safe-b));
  padding-bottom:var(--safe-b);display:flex;align-items:center;background:rgba(255,255,255,.96);
  border-top:1px solid #e6e0d4;backdrop-filter:saturate(1.4) blur(6px);}
.nreader.night .nrbar{background:rgba(34,34,34,.96);border-top-color:#333;}
.nrbar button{flex:1;height:100%;background:none;border:0;color:var(--green);font-size:14px;font-weight:600;}
.nreader.night .nrbar button{color:#7bbf93;}
.nrbar button:disabled{color:#bbb;}

/* ============ 长视频 ============ */
.lvmod{padding-bottom:6px;}
.lvgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px 10px;padding:0 12px;}
.lvcard{display:block;}
.lvcv{position:relative;width:100%;aspect-ratio:16/9;border-radius:9px;overflow:hidden;background:#e9eaee;}
.lvcv>img,.lvcv>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.lvtt{font-size:13px;line-height:1.35;margin:6px 1px 0;color:#222;font-weight:600;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.lvbanner{display:block;padding:0 12px 2px;}
.lvbanner .lvcv{aspect-ratio:16/9;border-radius:11px;}
.lvbanner .lvtt.big{font-size:15px;font-weight:700;text-align:center;-webkit-line-clamp:1;margin:8px 4px 4px;}
.lv-vip{position:absolute;top:0;right:0;z-index:2;background:rgba(255,255,255,.82);color:#16a34a;
  font-weight:800;font-size:12px;font-style:italic;padding:2px 7px;border-bottom-left-radius:8px;}
.lv-pc{position:absolute;left:6px;bottom:5px;z-index:2;color:#fff;font-size:12px;text-shadow:0 1px 2px rgba(0,0,0,.7);}
.lv-dur{position:absolute;right:6px;bottom:5px;z-index:2;color:#fff;font-size:12px;text-shadow:0 1px 2px rgba(0,0,0,.7);}
.lvscroll{display:flex;gap:10px;overflow-x:auto;padding:0 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.lvscroll::-webkit-scrollbar{display:none;}
.lvscroll .lvcard{flex:0 0 calc(50% - 16px);scroll-snap-align:start;}
.lvskel{aspect-ratio:16/9;border-radius:9px;}
.lvdetail{padding-bottom:calc(var(--tabh) + var(--safe-b) + 12px);}
.lvplayer{position:relative;width:100%;aspect-ratio:16/9;background:#000;}
.lvplayer .lvposter{position:absolute;inset:0;}
.lvplayer .lvposter>img{width:100%;height:100%;object-fit:contain;background:#000;}
.lvplayer .lvbig{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:72px;height:72px;
  border:0;border-radius:50%;background:rgba(255,255,255,.26);color:#fff;display:flex;align-items:center;justify-content:center;}
.lvplayer .lvbig svg{width:34px;height:34px;margin-left:4px;}
.lvplayer .lvvid{width:100%;height:100%;background:#000;display:block;}
.lvtags{padding:14px 16px 2px;color:var(--green);font-size:14px;font-weight:600;}
.lvtags span{margin-right:10px;}
.lvcollect{display:flex;align-items:center;justify-content:center;gap:6px;margin:12px 16px;width:calc(100% - 32px);
  height:46px;border:0;border-radius:10px;background:var(--green);color:#fff;font-size:16px;font-weight:600;}
.lvcollect svg{width:20px;height:20px;}
.lvcollect.on{background:#13a85d;}

/* ============ 短视频 4 子tab ============ */
.svtabs{position:fixed;top:calc(var(--safe-t) + 4px);left:0;right:0;z-index:15;
  display:flex;justify-content:center;gap:36px;padding:8px 0;}
.svtab{color:rgba(255,255,255,.7);font-size:19px;text-shadow:0 1px 3px rgba(0,0,0,.55);position:relative;
  padding:8px 8px;line-height:1;}              /* 加 padding 扩大点击热区，避免误触到视频暂停/播放 */
.svtab.on{color:#fff;font-weight:800;font-size:22px;}
.svtab.on::after{content:"";position:absolute;left:0;right:0;bottom:2px;margin:auto;width:20px;height:3px;border-radius:2px;background:#fff;}
.svtabs.dark{position:sticky;top:0;background:var(--green);padding:calc(var(--safe-t) + 12px) 0 10px;}
.svtabs.dark .svtab{text-shadow:none;}

/* ============ 专题 3列竖屏视频网格 ============ */
.ztgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px 8px;padding:0 12px;}
.ztcard{display:block;}
.ztcv{position:relative;width:100%;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:#e9eaee;}
.ztcv>img,.ztcv>svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ztt{font-size:12px;line-height:1.3;margin:5px 1px 0;color:#222;font-weight:500;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.ztskel{aspect-ratio:3/4;border-radius:8px;}

/* ============ 我的（收藏/历史 × 子tab）============ */
.metabs{display:flex;justify-content:center;gap:60px;padding:calc(var(--safe-t) + 16px) 16px 0;
  border-bottom:1px solid #eee;background:var(--card);}
.metab{font-size:18px;color:var(--sub);padding-bottom:12px;position:relative;}
.metab.on{color:var(--green);font-weight:800;}
.metab.on::after{content:"";position:absolute;left:50%;bottom:-1px;transform:translateX(-50%);
  width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:7px solid var(--green);}
.mesubs{display:flex;gap:4px;margin:14px 16px;padding:5px;border:1.5px solid var(--green);border-radius:24px;overflow-x:auto;scrollbar-width:none;}
.mesubs::-webkit-scrollbar{display:none;}
.mesub{flex:1 0 auto;text-align:center;padding:8px 16px;border-radius:20px;font-size:15px;color:#333;white-space:nowrap;}
.mesub.on{background:var(--green);color:#fff;font-weight:700;}
.me-empty{text-align:center;color:var(--green);font-size:15px;padding:30px 16px;}
