:root{--bg:#0a0a0a;--surface:#141414;--card:#1c1c1c;--border:#2a2a2a;--text:#f5f5f5;--text2:#999;--accent:#e50914;--accent-hover:#f6121d;--gold:#ffc107;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--safe-bottom:env(safe-area-inset-bottom,16px);--safe-top:env(safe-area-inset-top,0px);--tab-h:56px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
button{border:none;background:none;color:inherit;cursor:pointer;font:inherit}
input{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:0;height:0}
::selection{background:var(--accent);color:#fff}
.hidden{display:none!important}

/* Tab Bar */
#tab-bar{position:fixed;bottom:0;left:0;right:0;height:var(--tab-h);background:rgba(10,10,10,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;z-index:100;padding-bottom:var(--safe-bottom)}
#tab-bar .tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text2);transition:color .2s;min-height:44px;padding:4px 0}
#tab-bar .tab.active{color:var(--accent)}
#tab-bar .tab .tab-icon{font-size:22px;line-height:1}
#tab-bar .tab .tab-label{font-size:10px;font-weight:500;letter-spacing:.3px}

/* App */
#app{position:fixed;top:0;left:0;right:0;bottom:var(--tab-h);overflow:hidden;padding-top:var(--safe-top)}
.page{position:absolute;top:0;left:0;right:0;bottom:0;overflow-y:auto;overflow-x:hidden;background:var(--bg);-webkit-overflow-scrolling:touch;transform:translateX(0);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;will-change:transform,opacity}
.page.exit-left{transform:translateX(-30%);opacity:0}
.page.enter-right{transform:translateX(100%);opacity:1}
.page.enter-left{transform:translateX(-100%);opacity:1}
.page.exit-right{transform:translateX(30%);opacity:0}
.page.active{z-index:1;transform:translateX(0);opacity:1}
.page::-webkit-scrollbar{display:none}

/* Skeleton Shimmer */
.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--surface) 50%,var(--card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-banner{height:200px;width:100%;border-radius:0}
.skel-card{height:200px;width:140px;flex-shrink:0}
.skel-card-wide{height:100px;width:100%;border-radius:var(--radius-md)}
.skel-text{height:14px;width:60%;margin:8px 0;border-radius:4px}
.skel-text-short{height:14px;width:40%;margin:4px 0;border-radius:4px}
.skel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px}
.skel-grid .skel-card{width:100%;height:160px}

/* Error State */
.err-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 32px;text-align:center}
.err-state .err-icon{font-size:48px;margin-bottom:16px;opacity:.5}
.err-state .err-msg{color:var(--text2);font-size:15px;margin-bottom:20px;line-height:1.5}
.err-state .err-btn{background:var(--accent);color:#fff;padding:12px 32px;border-radius:24px;font-size:15px;font-weight:600;min-height:44px;display:flex;align-items:center;gap:6px}
.err-state .err-btn:active{transform:scale(.96)}

/* Page Header */
.page-header{position:sticky;top:0;z-index:10;background:rgba(10,10,10,.92);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:12px 16px;display:flex;align-items:center;gap:12px;min-height:52px}
.page-header .back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:50%;flex-shrink:0}
.page-header .back-btn:active{background:var(--card)}
.page-header .page-title{font-size:17px;font-weight:600}

/* Banner Carousel */
.banner-wrap{position:relative;width:100%;height:0;padding-bottom:50%;overflow:hidden;background:var(--card)}
.banner-track{display:flex;position:absolute;top:0;left:0;height:100%;transition:transform .4s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.banner-slide{flex:0 0 100%;height:100%;position:relative;cursor:pointer}
.banner-slide .banner-img{width:100%;height:100%;object-fit:cover}
.banner-slide .banner-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.85));padding:40px 20px 20px}
.banner-slide .banner-overlay h2{font-size:20px;font-weight:700;margin-bottom:4px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.banner-slide .banner-overlay p{font-size:13px;color:var(--text2);text-shadow:0 1px 3px rgba(0,0,0,.5)}
.banner-dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:2}
.banner-dots .dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);transition:all .3s}
.banner-dots .dot.active{width:20px;border-radius:3px;background:var(--accent)}
.banner-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.banner-wrap:hover .banner-arrow{opacity:1}
.banner-arrow.prev{left:8px}
.banner-arrow.next{right:8px}

/* Section */
.section{padding:20px 16px 8px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-header h3{font-size:17px;font-weight:700}
.section-header .section-link{font-size:13px;color:var(--text2);display:flex;align-items:center;gap:4px}
.scroll-row{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;padding:0 16px 4px;scrollbar-width:none}
.scroll-row::-webkit-scrollbar{display:none}

/* Quick Actions */
.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px}
.quick-actions .qa-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 0;border-radius:var(--radius-md);background:var(--card);min-height:60px;font-size:12px;font-weight:500;color:var(--text);transition:transform .15s,background .2s}
.quick-actions .qa-btn:active{transform:scale(.93);background:var(--border)}
.quick-actions .qa-btn .qa-icon{font-size:24px}

/* Poster Card */
.poster-card{flex:0 0 auto;width:140px;cursor:pointer;position:relative}
.poster-card .poster-img-wrap{position:relative;width:100%;padding-bottom:140%;border-radius:var(--radius-sm);overflow:hidden;background:var(--card)}
.poster-card .poster-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s}
.poster-card:active .poster-img{transform:scale(1.05)}
.poster-card .poster-badge{position:absolute;top:6px;right:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px}
.poster-card .poster-title{font-size:13px;font-weight:500;margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.poster-card .poster-sub{font-size:11px;color:var(--text2);margin-top:2px}

/* Grid row */
.grid-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px}
.grid-row .poster-card{width:100%}
.grid-row .poster-card .poster-img-wrap{padding-bottom:140%}

/* Live Preview */
.live-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 16px}
.live-preview .live-card{position:relative;aspect-ratio:16/9;border-radius:var(--radius-sm);overflow:hidden;background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px}
.live-preview .live-card:active{transform:scale(.95)}
.live-preview .live-card .play-icon{width:32px;height:32px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:14px;opacity:.9}
.live-preview .live-card .ch-name{font-size:11px;font-weight:500;text-align:center;padding:0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.live-preview .live-card .live-tag{font-size:8px;color:var(--accent);font-weight:700}

/* Rank Page - legacy poster styles kept for compatibility */
.rank-poster{width:50px;height:70px;border-radius:var(--radius-sm);object-fit:cover;background:var(--card);flex-shrink:0}

/* Category Page */
.cat-tabs{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;scrollbar-width:none;flex-shrink:0}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tabs .cat-tab{padding:8px 18px;border-radius:20px;font-size:14px;font-weight:500;white-space:nowrap;background:var(--card);color:var(--text2);transition:all .2s;min-height:36px}
.cat-tabs .cat-tab.active{background:var(--accent);color:#fff}
.cat-content{padding:12px 0;flex:1;overflow-y:auto}

/* Search Page */
.search-bar-wrap{display:flex;gap:10px;padding:12px 16px;align-items:center}
.search-bar-wrap .search-input-wrap{flex:1;display:flex;align-items:center;background:var(--card);border-radius:24px;padding:0 16px;gap:8px;min-height:40px}
.search-bar-wrap .search-input-wrap .search-icon{font-size:16px;color:var(--text2)}
.search-bar-wrap .search-input-wrap input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:15px;padding:8px 0}
.search-bar-wrap .search-input-wrap input::placeholder{color:var(--text2)}
.search-bar-wrap .search-cancel{font-size:15px;color:var(--text2);min-height:44px;display:flex;align-items:center}
.search-history{padding:8px 16px}
.search-history .sh-title{font-size:15px;font-weight:600;color:var(--text2);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}
.search-history .sh-tags{display:flex;flex-wrap:wrap;gap:8px}
.search-history .sh-tags .sh-tag{padding:6px 14px;background:var(--card);border-radius:16px;font-size:13px;color:var(--text2)}
.search-history .sh-tags .sh-tag:active{background:var(--border)}

/* Detail Page */
.detail-header{position:relative;width:100%;height:0;padding-bottom:56%;overflow:hidden;background:var(--card)}
.detail-header .detail-poster{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.detail-header .detail-gradient{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(transparent,var(--bg))}
.detail-header .detail-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 20px rgba(229,9,20,.4)}
.detail-header .detail-play-btn:active{transform:translate(-50%,-50%) scale(.9)}
.detail-body{padding:16px}
.detail-body .detail-title{font-size:22px;font-weight:700;margin-bottom:6px}
.detail-body .detail-meta{display:flex;gap:12px;font-size:13px;color:var(--text2);margin-bottom:12px;flex-wrap:wrap}
.detail-body .detail-meta span{padding:2px 8px;background:var(--card);border-radius:4px}
.detail-body .detail-desc{font-size:14px;line-height:1.6;color:var(--text2);margin-bottom:16px}
.detail-body .detail-section-title{font-size:16px;font-weight:600;margin-bottom:10px;margin-top:16px}
.episode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:8px;margin-bottom:16px}
.episode-grid .ep-btn{padding:8px 4px;text-align:center;background:var(--card);border-radius:var(--radius-sm);font-size:13px;font-weight:500;min-height:44px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.episode-grid .ep-btn:active{background:var(--accent)}
.episode-grid .ep-btn.playing{background:var(--accent);color:#fff}

/* Live TV Page */
.live-page{display:flex;flex-direction:column;height:100%}
.live-tabs{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;scrollbar-width:none;flex-shrink:0;background:var(--bg);border-bottom:1px solid var(--border)}
.live-tabs::-webkit-scrollbar{display:none}
.live-tabs .live-tab{padding:8px 20px;border-radius:20px;font-size:14px;font-weight:500;white-space:nowrap;background:var(--card);color:var(--text2);transition:all .2s;min-height:36px}
.live-tabs .live-tab.active{background:var(--accent);color:#fff}
.live-channels{flex:1;overflow-y:auto;padding:12px 16px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px;align-content:start}
.live-channel-card{background:var(--card);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:6px;cursor:pointer;position:relative;overflow:hidden;transition:all .2s;min-height:72px}
.live-channel-card:active{transform:scale(.96)}
.live-channel-card.playing{border:2px solid var(--accent);animation:pulse-border 1.5s infinite}
@keyframes pulse-border{0%,100%{border-color:var(--accent)}50%{border-color:rgba(229,9,20,.4)}}
.live-channel-card .ch-name{font-size:15px;font-weight:600}
.live-channel-card .ch-group{font-size:11px;color:var(--text2)}
.live-channel-card .ch-badge{position:absolute;top:8px;right:8px;background:var(--border);color:var(--text2);font-size:10px;padding:2px 6px;border-radius:4px}
.live-channel-card .ch-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:var(--accent);display:none;align-items:center;justify-content:center;font-size:14px}
.live-channel-card.playing .ch-play{display:flex}

/* Player Overlay */
#player-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:#000;display:flex;flex-direction:column}
#player-overlay.hidden{display:none}
#player-overlay video{flex:1;width:100%;height:100%;object-fit:contain;background:#000}
.player-top{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;padding-top:calc(8px + var(--safe-top));background:linear-gradient(rgba(0,0,0,.7),transparent)}
.player-top .player-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;border-radius:50%}
.player-top .player-back:active{background:rgba(255,255,255,.2)}
.player-top .player-source-badge{background:rgba(0,0,0,.6);color:var(--text2);font-size:11px;padding:4px 10px;border-radius:12px}
.player-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;text-align:center;color:#fff}
.player-center .player-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
.player-center .player-err-msg{font-size:14px;color:var(--text2);margin-bottom:12px}
.player-center .player-retry-btn{background:var(--accent);color:#fff;padding:10px 28px;border-radius:20px;font-size:14px;font-weight:600;min-height:44px}
#player-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;z-index:4;background:#000}

/* Mine Page */
.mine-profile{padding:40px 16px 24px;text-align:center}
.mine-profile .mine-avatar{width:80px;height:80px;border-radius:50%;background:var(--card);margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:36px}
.mine-profile .mine-name{font-size:20px;font-weight:700;margin-bottom:4px}
.mine-profile .mine-sub{font-size:13px;color:var(--text2)}
.mine-menu{padding:0 16px}
.mine-menu .mine-item{display:flex;align-items:center;gap:12px;padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;min-height:52px}
.mine-menu .mine-item:active{opacity:.6}
.mine-menu .mine-item .mi-icon{font-size:20px;width:28px;text-align:center}
.mine-menu .mine-item .mi-label{font-size:15px;font-weight:500;flex:1}
.mine-menu .mine-item .mi-arrow{color:var(--text2);font-size:14px}

/* Toast */
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:300;pointer-events:none;opacity:0;transition:opacity .3s}
.toast.show{opacity:1}

/* Loading More */
.load-more{text-align:center;padding:16px;color:var(--text2);font-size:13px}
.load-more .lm-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:8px;vertical-align:middle}

/* Pull to refresh hint */
.ptr-hint{text-align:center;padding:10px;color:var(--text2);font-size:13px;display:none}

/* Empty State */
.empty-state{padding:60px 32px;text-align:center;color:var(--text2);font-size:15px}
.empty-state .empty-icon{font-size:48px;margin-bottom:12px;opacity:.4}

/* Responsive fine-tune */
@media(min-width:500px){
.banner-wrap{padding-bottom:40%;max-height:350px}
.grid-row{grid-template-columns:repeat(4,1fr)}
.poster-card{width:160px}
.live-channels{grid-template-columns:repeat(3,1fr)}
}
/* Player Controls Bar */
#player-controls{position:absolute;bottom:0;left:0;right:0;z-index:20;opacity:1;transition:opacity .4s;padding-bottom:var(--safe-bottom)}
#player-controls.hidden{opacity:0;pointer-events:none}
.pc-gradient{position:absolute;bottom:0;left:0;right:0;height:140px;background:linear-gradient(transparent,rgba(0,0,0,.75) 60%,rgba(0,0,0,.9));pointer-events:none}
.pc-progress-wrap{position:relative;height:44px;display:flex;align-items:center;padding:0 16px;cursor:pointer;touch-action:none;z-index:1}
.pc-progress-bar{position:relative;width:100%;height:6px;background:rgba(255,255,255,.2);border-radius:2px;transition:height .15s}
.pc-progress-wrap:hover .pc-progress-bar,.pc-progress-wrap.active .pc-progress-bar{height:8px}
.pc-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--accent);border-radius:2px;width:0%}
.pc-progress-buffered{position:absolute;top:0;left:0;height:100%;background:rgba(255,255,255,.35);border-radius:2px;width:0%;pointer-events:none}
.pc-progress-thumb{position:absolute;top:50%;left:0;width:20px;height:20px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .15s;pointer-events:none;box-shadow:0 0 4px rgba(0,0,0,.5)}
.pc-progress-wrap:hover .pc-progress-thumb,.pc-progress-wrap.active .pc-progress-thumb{opacity:1}
.pc-bottom{position:relative;z-index:1;display:flex;align-items:center;gap:2px;padding:6px 16px 16px}
.pc-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;border-radius:50%;flex-shrink:0;transition:background .15s;min-width:36px}
.pc-btn:active{background:rgba(255,255,255,.15)}
.pc-time{font-size:12px;color:rgba(255,255,255,.85);font-variant-numeric:tabular-nums;min-width:36px;text-align:center;white-space:nowrap}
.pc-time-sep{font-size:12px;color:rgba(255,255,255,.35);margin:0 1px}
.pc-episode{font-size:12px;color:rgba(255,255,255,.6);margin:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.pc-spacer{flex:1}
.pc-speed-wrap{position:relative}
.pc-speed-btn{font-size:12px;font-weight:700;border-radius:6px;min-width:34px;width:auto;padding:0 6px}
.pc-speed-menu{position:absolute;bottom:100%;right:0;margin-bottom:6px;background:rgba(20,20,20,.96);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;overflow:hidden;min-width:72px;border:1px solid rgba(255,255,255,.1)}
.pc-speed-opt{padding:10px 20px;font-size:13px;color:#ccc;cursor:pointer;text-align:center;white-space:nowrap;transition:background .15s,color .15s}
.pc-speed-opt:active,.pc-speed-opt.active{background:var(--accent);color:#fff}
.pc-volume-btn{font-size:16px}
.pc-volume-slider-wrap{display:flex;align-items:center}
.pc-volume-slider{width:64px;height:4px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,.2);border-radius:2px;outline:none;cursor:pointer}
.pc-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#fff;border-radius:50%}
.pc-volume-slider::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%;border:none}
#player-center-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(1);z-index:15;width:68px;height:68px;border-radius:50%;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;opacity:1;transition:opacity .3s,transform .2s;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
#player-center-btn:active{transform:translate(-50%,-50%) scale(.85)}
.pc-fullscreen-btn{font-size:20px}
@media(max-width:480px){
.pc-volume-slider{width:48px}
.pc-time{font-size:11px;min-width:32px}
.pc-btn{width:32px;height:32px;min-width:32px;font-size:16px}
.pc-episode{max-width:80px}
.pc-speed-btn{font-size:11px;min-width:28px;padding:0 4px}
}/* Rank Page - New Design */
.rank-tabs {
  display: flex;
  gap: 6px;
  padding: 0 16px 12px;
  overflow-x: auto;
  scrollbar-width: none;
  border-bottom: 1px solid var(--border);
}
.rank-tabs::-webkit-scrollbar { display: none; }
.rank-tabs .rank-tab {
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  background: var(--card);
  color: var(--text2);
  transition: all .2s;
  min-height: 36px;
}
.rank-tabs .rank-tab.active {
  background: var(--accent);
  color: #fff;
}

/* Rank Sub-tabs (category sub-tabs) */
.rank-subtabs {
  display: flex;
  gap: 6px;
  padding: 10px 16px;
  overflow-x: auto;
  scrollbar-width: none;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.rank-subtabs::-webkit-scrollbar { display: none; }
.rank-subtabs .rank-subtab {
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  background: var(--card);
  color: var(--text2);
  transition: all .2s;
  min-height: 30px;
}
.rank-subtabs .rank-subtab.active {
  background: var(--gold);
  color: #000;
  font-weight: 600;
}

.rank-content {
  flex: 1;
  overflow-y: auto;
}

/* Rank List - Enhanced */
.rank-list {
  padding: 4px 16px;
}
.rank-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 8px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  min-height: 64px;
  transition: background .15s;
  position: relative;
}
.rank-item:active {
  background: var(--card);
}

/* Top 3 Special Styling */
.rank-item-gold {
  background: linear-gradient(135deg, rgba(255,193,7,.08) 0%, rgba(255,152,0,.05) 100%);
  border: 1px solid rgba(255,193,7,.15);
}
.rank-item-silver {
  background: linear-gradient(135deg, rgba(158,158,158,.08) 0%, rgba(189,189,189,.05) 100%);
  border: 1px solid rgba(158,158,158,.12);
}
.rank-item-bronze {
  background: linear-gradient(135deg, rgba(205,127,50,.08) 0%, rgba(139,90,43,.05) 100%);
  border: 1px solid rgba(205,127,50,.12);
}

/* Rank Number Container */
.rank-num-wrap {
  width: 32px;
  text-align: center;
  font-size: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rank-num-val {
  font-size: 16px;
  font-weight: 700;
  color: var(--text2);
}

/* Rank Poster */
.rank-poster-wrap {
  width: 50px;
  height: 70px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--card);
  flex-shrink: 0;
  position: relative;
}
.rank-poster-wrap .rank-poster {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.rank-item-gold .rank-poster-wrap { box-shadow: 0 2px 8px rgba(255,193,7,.3); }
.rank-item-silver .rank-poster-wrap { box-shadow: 0 2px 8px rgba(158,158,158,.3); }
.rank-item-bronze .rank-poster-wrap { box-shadow: 0 2px 8px rgba(205,127,50,.3); }

/* Rank Poster Fallback */
.rank-poster-fallback {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 700;
  color: rgba(255,255,255,.25);
}

/* Rank Info */
.rank-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rank-info .rank-name {
  font-size: 15px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rank-item-gold .rank-name { font-weight: 700; }
.rank-item-silver .rank-name { font-weight: 600; }
.rank-item-bronze .rank-name { font-weight: 600; }

.rank-meta {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.rank-score-badge {
  font-size: 11px;
  color: var(--gold);
  font-weight: 600;
  padding: 0 2px;
}
.rank-cate-badge {
  font-size: 10px;
  background: var(--card);
  color: var(--text2);
  padding: 1px 6px;
  border-radius: 4px;
  font-weight: 500;
}
.rank-remark-text {
  font-size: 11px;
  color: var(--text2);
}

/* Rank Separator */
.rank-list .rank-item + .rank-item {
  border-top: 1px solid var(--border);
}
.rank-item-gold + .rank-item,
.rank-item-silver + .rank-item,
.rank-item-bronze + .rank-item {
  border-top-color: transparent;
}

/* Category Load More Button */
.cat-loadmore {
  padding: 12px 16px 24px;
}
.lm-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 12px;
  background: var(--card);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  min-height: 44px;
  cursor: pointer;
  transition: background .15s;
}
.lm-btn:active {
  background: var(--border);
}
.cat-retry-btn {
  color: var(--accent);
}

