/* bdfilm — 百度优化清新明亮影视SEO模板
   Design: 白底蓝调、卡片式布局、响应式、最小JS依赖
   Primary: #1a56db (百度友好蓝) */

:root {
  --bg: #f5f7fa;
  --bg-soft: #eef2f7;
  --panel: #ffffff;
  --panel-2: #f8fafc;
  --text: #1e293b;
  --muted: #64748b;
  --primary: #1a56db;
  --primary-hover: #1544b0;
  --primary-light: #dbeafe;
  --accent: #2563eb;
  --border: #e2e8f0;
  --border-hover: #cbd5e1;
  --shadow: 0 1px 3px rgba(30,41,59,.05), 0 1px 2px rgba(30,41,59,.03);
  --shadow-md: 0 4px 12px rgba(30,41,59,.08), 0 2px 4px rgba(30,41,59,.04);
  --shadow-lg: 0 12px 32px rgba(30,41,59,.10), 0 4px 8px rgba(30,41,59,.06);
  --success: #16a34a;
  --warning: #d97706;
  --radius: .75rem;
  --radius-lg: 1rem;
  --radius-full: 9999px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
a{color:var(--primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--primary-hover)}
img{display:block;max-width:100%;height:auto}
ul,ol{list-style:none}
button,input,select,textarea{font:inherit}
::selection{background:var(--primary-light);color:var(--primary-hover)}

/* Container */
.container{width:min(1200px,calc(100% - 1.5rem));margin:0 auto}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);box-shadow:0 1px 8px rgba(30,41,59,.04)}
.header-inner{display:flex;flex-direction:column;gap:.75rem;padding:.75rem 0}
.brand{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{font-size:1.35rem;font-weight:800;color:var(--primary);letter-spacing:.01em}
.site-subtitle{font-size:.82rem;color:var(--muted)}
.topbar{display:flex;flex-wrap:wrap;gap:.4rem .6rem;align-items:center}
.topbar a{padding:.35rem .65rem;border-radius:var(--radius-full);font-size:.85rem;color:var(--muted);border:1px solid transparent}
.topbar a:hover{color:var(--primary);background:var(--primary-light);border-color:var(--primary-light)}
.site-nav{display:flex;flex-wrap:wrap;gap:.4rem .5rem;align-items:center}
.site-nav a{padding:.4rem .75rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;color:var(--text);border:1px solid var(--border);background:var(--panel)}
.site-nav a:hover,.site-nav a.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.search-form{display:flex;gap:.5rem}
.search-form input{flex:1;min-width:0;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);color:var(--text);font-size:.9rem}
.search-form input::placeholder{color:var(--muted)}
.search-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
.search-form button{padding:.6rem 1.1rem;border:0;border-radius:var(--radius);background:var(--primary);color:#fff;font-weight:700;cursor:pointer;font-size:.9rem;white-space:nowrap}
.search-form button:hover{background:var(--primary-hover)}

/* Main */
.main{padding:1.5rem 0 2.5rem}

/* Breadcrumb */
.breadcrumb{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center;font-size:.86rem;color:var(--muted);margin:0 0 1.15rem;padding:.65rem 1rem;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.breadcrumb .sep{margin:0 .1rem;opacity:.35}
.breadcrumb a{color:var(--muted);transition:color .15s}
.breadcrumb a:hover{color:var(--primary)}

/* Hero / Page Header */
.hero{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}
.hero h1,.page-title{font-size:1.5rem;line-height:1.3;margin-bottom:.35rem;color:var(--text)}
.hero p,.hero .meta{color:var(--muted);font-size:.92rem}

/* Sections */
.section{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.35rem;margin-bottom:1.15rem;box-shadow:var(--shadow-md);transition:box-shadow .25s}
.section:hover{box-shadow:var(--shadow-lg)}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.section-head h2{font-size:1.1rem;font-weight:700;padding-left:.75rem;border-left:3px solid var(--primary);line-height:1.3}
.section-head .more{font-size:.85rem;color:var(--muted);transition:color .15s}
.section-head .more:hover{color:var(--primary)}
.section-subtitle{color:var(--muted);font-size:.86rem}

/* Movie Grid */
.movie-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem}
.movie-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;height:100%}
.movie-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}
.movie-card a{display:flex;flex-direction:column;height:100%;color:inherit}
.movie-card .poster{aspect-ratio:2/3;background:var(--bg-soft);overflow:hidden;position:relative}
.movie-card .poster img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.movie-card:hover .poster img{transform:scale(1.05)}
.movie-card .poster::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(transparent,rgba(0,0,0,.35));pointer-events:none;opacity:0;transition:opacity .25s}
.movie-card:hover .poster::after{opacity:1}
.movie-card .poster .remarks{position:absolute;bottom:.5rem;left:.5rem;padding:.2rem .55rem;border-radius:var(--radius-full);background:rgba(26,86,219,.9);color:#fff;font-size:.72rem;font-weight:600;backdrop-filter:blur(4px)}
.movie-card .poster .score{position:absolute;top:.5rem;right:.5rem;padding:.2rem .5rem;border-radius:var(--radius-full);background:rgba(234,179,8,.92);color:#1e293b;font-size:.72rem;font-weight:700}
.movie-card .info{display:flex;flex-direction:column;gap:.3rem;padding:.75rem .8rem}
.movie-card h3{font-size:.92rem;font-weight:600;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .15s}
.movie-card:hover h3{color:var(--primary)}
.movie-card .meta{font-size:.78rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:.25rem .5rem}

/* Movie List (horizontal items) */
.movie-list{display:grid;gap:.65rem}
.movie-item{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.movie-item:hover{border-color:var(--primary-light)}
.movie-item a{display:grid;grid-template-columns:80px 1fr;gap:.7rem;align-items:center;padding:.65rem;color:inherit}
.movie-item img{width:80px;height:112px;object-fit:cover;border-radius:calc(var(--radius) - 2px);background:var(--bg-soft)}
.movie-item .mi-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}
.movie-item .mi-title{font-size:.92rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.movie-item .mi-meta{font-size:.8rem;color:var(--muted)}
.movie-item .mi-desc{font-size:.82rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Rank List */
.rank-list{counter-reset:rank-num}
.rank-list .mo-list,.rank-list ul.tb-list{display:grid;gap:.5rem;list-style:none;padding:0;margin:0}
.rank-list .movie-item,.rank-list .tb-film{counter-increment:rank-num;position:relative;padding-left:2.5rem;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.rank-list .movie-item:hover,.rank-list .tb-film:hover{border-color:var(--primary-light)}
.rank-list .movie-item::before,.rank-list .tb-film::before{content:counter(rank-num);position:absolute;left:0;top:0;bottom:0;width:2.2rem;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700;color:var(--muted);background:var(--bg-soft);border-right:1px solid var(--border)}
.rank-list .movie-item:nth-child(-n+3)::before,.rank-list .tb-film:nth-child(-n+3)::before{color:#fff;background:var(--primary)}
.rank-list .movie-item a,.rank-list .tb-film a{display:grid;grid-template-columns:56px 1fr;gap:.6rem;align-items:center;padding:.5rem .6rem .5rem 0;color:inherit}
.rank-list .movie-item img,.rank-list .tb-film img{width:56px;height:78px;object-fit:cover;border-radius:calc(var(--radius) - 2px);background:var(--bg-soft)}
.rank-list .movie-item span,.rank-list .tb-film .tb-title{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem;font-weight:600}
.rank-list .movie-item span+span,.rank-list .tb-film .tb-note{font-size:.78rem;color:var(--muted);font-weight:400}

/* Detail page */
.detail-layout{display:grid;gap:1rem}
.detail-panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.15rem}
.detail-header{display:grid;grid-template-columns:140px 1fr;gap:1rem;align-items:start}
.detail-header .poster{width:140px;aspect-ratio:2/3;border-radius:var(--radius);overflow:hidden;background:var(--bg-soft)}
.detail-header .poster img{width:100%;height:100%;object-fit:cover}
.detail-header .di{display:flex;flex-direction:column;gap:.45rem}
.detail-header h1{font-size:1.3rem;line-height:1.35}
.detail-meta{display:flex;flex-wrap:wrap;gap:.4rem .6rem;font-size:.85rem;color:var(--muted)}
.detail-meta span{padding:.25rem .6rem;border-radius:var(--radius-full);background:var(--bg-soft);border:1px solid var(--border);transition:border-color .15s}
.detail-meta span:hover{border-color:var(--primary-light)}
.detail-meta a{color:var(--primary)}
.detail-intro{margin-top:.8rem;padding:.85rem;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);font-size:.88rem;line-height:1.7;color:#475569}

/* Play page */
.player-wrap{position:relative;width:100%;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:1rem}
.player-aspect{position:relative;width:100%;padding-top:56.25%}
#playerContainer{position:absolute;top:0;left:0;width:100%;height:100%}
#playerContainer iframe,#playerContainer video{width:100%;height:100%;border:0;display:block;background:#000}
.source-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.source-tab{padding:.4rem .8rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}
.source-tab:hover{border-color:var(--primary);color:var(--primary)}
.source-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:.4rem;margin-bottom:1rem}
.ep-btn{display:flex;align-items:center;justify-content:center;padding:.45rem .25rem;border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);background:var(--panel-2);color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ep-btn:hover{border-color:var(--primary);color:var(--primary)}
.ep-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Tag cloud */
.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem}
.tag-cloud a{padding:.4rem .85rem;border-radius:var(--radius-full);background:var(--panel-2);border:1px solid var(--border);font-size:.86rem;color:var(--text);transition:all .15s}
.tag-cloud a:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}

/* Pagination */
.pagination,.pages{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}
.pagination a,.pagination span,.pages a,.pages span{display:inline-flex;align-items:center;justify-content:center;min-width:2.4rem;padding:.45rem .7rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--panel);color:var(--text);font-size:.88rem}
.pagination a:hover,.pages a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination .current{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Play items (episode links) */
.play-list{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.85rem}
.play-item{padding:.55rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel-2);font-weight:600;font-size:.88rem;color:var(--text)}
.play-item:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Person links */
.person-list{display:flex;flex-wrap:wrap;gap:.55rem}
.person-list a{padding:.4rem .7rem;border-radius:var(--radius-full);background:var(--bg-soft);border:1px solid var(--border);font-size:.85rem}
.person-list a:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}

/* News */
.news-list{display:grid;gap:.75rem}
.news-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}
.news-card:hover{border-color:var(--primary-light)}
.news-card a{display:grid;grid-template-columns:140px 1fr;gap:.75rem;align-items:start;padding:.75rem;color:inherit}
.news-card .news-pic img{width:140px;height:95px;object-fit:cover;border-radius:calc(var(--radius) - 2px);display:block}
.news-card .news-info{display:flex;flex-direction:column;gap:.35rem;min-width:0}
.news-card .news-title{font-size:.92rem;font-weight:600;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-card .news-meta{display:flex;gap:.6rem;font-size:.78rem;color:var(--muted)}
.news-card .news-category{background:var(--primary-light);color:var(--primary);padding:.1rem .4rem;border-radius:var(--radius-full);font-size:.72rem}
.news-item{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;transition:border-color .2s}
.news-item:hover{border-color:var(--primary-light)}
.news-item h3{font-size:.95rem;font-weight:600;margin-bottom:.35rem}
.news-item h3 a{color:var(--text)}
.news-item h3 a:hover{color:var(--primary)}
.news-item .ni-meta{font-size:.82rem;color:var(--muted)}
.news-item .ni-summary{font-size:.86rem;color:#475569;margin-top:.4rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-article{line-height:1.8;color:#334155}
.news-article p{margin-bottom:1rem}

/* Sidebar */
.content-grid{display:grid;gap:1rem}
.sidebar .section{padding:.85rem}

/* Footer */
.site-footer{padding:1.5rem 0 2rem;margin-top:1.5rem;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%)}
.footer-panel{display:grid;gap:.85rem;padding:1.35rem 1.25rem;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.footer-links{display:flex;flex-wrap:wrap;gap:.35rem .55rem;align-items:center}
.footer-links a{padding:.3rem .55rem;font-size:.85rem;color:var(--muted);border-radius:var(--radius-full);transition:all .15s}
.footer-links a:hover{color:var(--primary);background:var(--primary-light)}
.footer-meta{display:flex;flex-wrap:wrap;gap:.4rem .85rem;font-size:.82rem;color:var(--muted)}
.footer-meta a{color:var(--muted)}
.footer-meta a:hover{color:var(--primary)}
.site-footer small{font-size:.8rem;color:var(--muted)}

/* KPI row */
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.85rem}
.kpi{padding:.85rem;border-radius:var(--radius);background:var(--panel-2);border:1px solid var(--border);text-align:center}
.kpi strong{display:block;font-size:1.25rem;color:var(--primary)}
.kpi span{font-size:.82rem;color:var(--muted)}

/* Notice / Alert */
.notice{padding:.75rem 1rem;border-radius:var(--radius);background:var(--primary-light);border:1px solid var(--primary);color:var(--primary-hover);font-size:.9rem}
.notice.success{background:#f0fdf4;border-color:#86efac;color:#166534}

/* Form */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.9rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);color:var(--text);font-size:.9rem}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.3rem;border:0;border-radius:var(--radius);font-weight:700;font-size:.9rem;cursor:pointer;transition:background .15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover)}
.btn-outline{background:var(--panel);color:var(--primary);border:1px solid var(--primary)}
.btn-outline:hover{background:var(--primary-light)}

/* Legal page */
.legal-content{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;line-height:1.8;color:#475569}
.legal-content h2{font-size:1.15rem;margin:1.2rem 0 .6rem;color:var(--text)}
.legal-content p{margin-bottom:.8rem}
.legal-content ul{margin:.5rem 0 .8rem 1.5rem;list-style:disc}
.legal-content li{margin-bottom:.35rem}

/* Simple page center */
.simple-page{display:flex;align-items:center;justify-content:center;min-height:50vh}
.simple-box{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;max-width:420px;width:100%;box-shadow:var(--shadow)}
.simple-box h1{font-size:1.35rem;margin-bottom:1rem;text-align:center}
.simple-box .form-group:last-of-type{margin-bottom:1.25rem}
.simple-box .btn{width:100%}
.simple-box .alt-link{text-align:center;margin-top:1rem;font-size:.88rem;color:var(--muted)}
.simple-box .alt-link a{color:var(--primary);font-weight:600}

/* 404 */
.not-found{text-align:center;padding:3rem 1rem}
.not-found h1{font-size:4rem;font-weight:800;color:var(--primary);line-height:1}
.not-found p{color:var(--muted);margin:.75rem 0 1.5rem;font-size:1rem}

/* Sitemap page */
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}
.sitemap-col h3{font-size:.95rem;font-weight:700;margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:2px solid var(--primary)}
.sitemap-col ul{display:flex;flex-direction:column;gap:.3rem}
.sitemap-col a{font-size:.88rem;color:var(--text);padding:.15rem 0}
.sitemap-col a:hover{color:var(--primary)}

/* Responsive */
@media(min-width:768px){
  .header-inner{flex-direction:row;justify-content:space-between;align-items:center}
  .header-main{flex:1;display:flex;flex-direction:column;gap:.5rem}
  .movie-grid{grid-template-columns:repeat(4,1fr)}
  .content-grid{grid-template-columns:1fr 300px}
  .detail-layout{grid-template-columns:1fr 320px}
  .detail-header{grid-template-columns:180px 1fr}
  .detail-header .poster{width:180px}
  .section{padding:1.35rem 1.25rem}
}
@media(min-width:1024px){
  .movie-grid{grid-template-columns:repeat(6,1fr)}
  .hero{padding:1.5rem}
  .section{padding:1.5rem 1.35rem}
}

/* Player page */
.player-wrap{position:relative;width:100%;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:1rem}
.player-aspect{position:relative;width:100%;padding-top:56.25%}
#playerContainer{position:absolute;top:0;left:0;width:100%;height:100%}
#playerContainer iframe,#playerContainer video{width:100%;height:100%;border:0;display:block;background:#000}
.source-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.source-tab{padding:.4rem .8rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}
.source-tab:hover{border-color:var(--primary);color:var(--primary)}
.source-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:.4rem;margin-bottom:1rem}
.ep-btn{display:flex;align-items:center;justify-content:center;padding:.45rem .25rem;border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);background:var(--panel-2);color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ep-btn:hover{border-color:var(--primary);color:var(--primary)}
.ep-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.playing-bar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;padding:.6rem .8rem;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.6rem}
.playing-bar .now-playing{font-weight:700;font-size:.95rem}
.playing-bar .now-source{color:var(--muted);font-size:.82rem}
.auto-next-btn{margin-left:auto;padding:.35rem .7rem;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--panel-2);color:var(--muted);font-size:.82rem;cursor:pointer;transition:all .15s;user-select:none}
.auto-next-btn.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}
@media(min-width:768px){.ep-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}
@media(min-width:1024px){.ep-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}}

/* Detail page */
.detail-top{display:grid;grid-template-columns:140px 1fr;gap:1rem;align-items:start}
.detail-top .poster{width:140px;aspect-ratio:2/3;border-radius:var(--radius);overflow:hidden;background:var(--bg-soft)}
.detail-top .poster img{width:100%;height:100%;object-fit:cover}
.detail-top .di{display:flex;flex-direction:column;gap:.45rem}
.summary{margin-top:.8rem}
.summary h2{font-size:1rem;margin-bottom:.4rem}
.summary p{font-size:.88rem;line-height:1.7;color:#475569}
@media(min-width:768px){.detail-top{grid-template-columns:180px 1fr}.detail-top .poster{width:180px}}

/* Mobile menu toggle */
.menu-toggle{display:none;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);cursor:pointer;font-size:1.1rem;color:var(--text)}
.menu-toggle span{display:block;width:1.1rem;height:2px;background:var(--text);border-radius:1px;transition:all .2s;position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:'';position:absolute;left:0;width:100%;height:2px;background:var(--text);border-radius:1px;transition:all .2s}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
@media(max-width:767px){
  .menu-toggle{display:flex}
  .site-nav{display:none;flex-direction:column;gap:.3rem}
  .site-nav.open{display:flex}
}

/* ===== Back to Top ===== */
.back-to-top{position:fixed;bottom:30px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;opacity:0;visibility:hidden;transition:all .3s ease;z-index:999;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.15);font-size:1.2rem}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{transform:translateY(-3px);box-shadow:0 4px 16px rgba(0,0,0,.25)}

/* ===== Star Rating ===== */
.star-rating{display:inline-flex;gap:2px;font-size:1.05rem;color:#f59e0b}
.star-rating .star{display:inline-block;width:1.1em;height:1.1em}
.star-rating .star.full{color:#f59e0b}
.star-rating .star.half{background:linear-gradient(90deg,#f59e0b 50%,#d1d5db 50%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.star-rating .star.empty{color:#d1d5db}
.star-rating .score{font-size:.88rem;font-weight:700;color:var(--primary);margin-left:.35rem}

/* ===== Share Bar ===== */
.share-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.65rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:.8rem 0}
.share-bar .share-label{font-size:.85rem;color:var(--muted);margin-right:.25rem}
.share-bar a{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border-radius:var(--radius-full);font-size:.8rem;color:#fff;text-decoration:none;transition:opacity .2s}
.share-bar a:hover{opacity:.85}
.share-weibo{background:#e6162d}
.share-qq{background:#12b7f5}
.share-qzone{background:#f6c94e;color:#333!important}
.share-wechat{background:#07c160}
.share-copy{background:#6b7280;cursor:pointer}
.share-copied{background:#10b981}

/* ===== Favorite Button ===== */
.btn-fav{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem 1rem;border:2px solid var(--primary);border-radius:var(--radius-full);background:transparent;color:var(--primary);font-size:.88rem;cursor:pointer;transition:all .2s}
.btn-fav:hover,.btn-fav.active{background:var(--primary);color:#fff}
.btn-fav.active{background:var(--primary);color:#fff}

/* ===== Carousel / Featured ===== */
.carousel{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--panel-2);margin-bottom:1rem}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-slide{min-width:100%;position:relative}
.carousel-slide img{width:100%;height:280px;object-fit:cover;display:block}
.carousel-caption{position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1.2rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.75));color:#fff}
.carousel-caption h2{font-size:1.2rem;margin-bottom:.3rem;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.carousel-caption p{font-size:.85rem;opacity:.9;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.carousel-dots{position:absolute;bottom:.75rem;right:1rem;display:flex;gap:.4rem}
.carousel-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:all .2s}
.carousel-dots span.active{background:#fff;width:20px;border-radius:4px}
@media(min-width:768px){.carousel-slide img{height:360px}.carousel-caption h2{font-size:1.5rem}}

/* ===== Filter Bar ===== */
.filter-bar{display:flex;flex-wrap:wrap;gap:.45rem;padding:.65rem 0;border-bottom:1px solid var(--border);margin-bottom:.75rem}
.filter-bar .filter-label{font-size:.85rem;font-weight:600;color:var(--text);min-width:4rem;line-height:2rem}
.filter-bar a{display:inline-block;padding:.25rem .65rem;border-radius:var(--radius-full);font-size:.82rem;color:var(--text);background:var(--bg-soft);border:1px solid transparent;transition:all .2s}
.filter-bar a:hover,.filter-bar a.active{color:var(--primary);border-color:var(--primary);background:var(--primary-light)}

/* ===== Sort Tabs ===== */
.sort-tabs{display:flex;gap:.35rem;padding:.5rem 0;margin-bottom:.65rem;border-bottom:1px solid var(--border)}
.sort-tabs a{padding:.35rem .85rem;border-radius:var(--radius-full);font-size:.82rem;color:var(--muted);background:transparent;border:1px solid transparent;transition:all .2s}
.sort-tabs a:hover{color:var(--text)}
.sort-tabs a.active{color:var(--primary);background:var(--primary-light);border-color:var(--primary)}

/* ===== Tag Cloud (sized) ===== */
.tag-cloud-sized{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}
.tag-cloud-sized a{display:inline-block;padding:.2rem .6rem;border-radius:var(--radius-full);color:var(--text);background:var(--bg-soft);transition:all .2s;line-height:1.4}
.tag-cloud-sized a:hover{color:var(--primary);background:var(--primary-light)}
.tag-cloud-sized a[data-size="xl"]{font-size:1.15rem;font-weight:700;padding:.3rem .85rem}
.tag-cloud-sized a[data-size="lg"]{font-size:1rem;font-weight:600}
.tag-cloud-sized a[data-size="md"]{font-size:.9rem}
.tag-cloud-sized a[data-size="sm"]{font-size:.82rem;color:var(--muted)}

/* ===== Episode Nav ===== */
.ep-nav{display:flex;gap:.5rem;margin:.65rem 0}
.ep-nav a{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .9rem;border-radius:var(--radius);font-size:.85rem;color:var(--primary);background:var(--primary-light);text-decoration:none;transition:all .2s}
.ep-nav a:hover{background:var(--primary);color:#fff}
.ep-nav a:only-child{margin-right:auto}

/* ===== Batch Actions ===== */
.batch-bar{display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.65rem}
.batch-bar label{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text);cursor:pointer}
.batch-bar button{padding:.35rem .75rem;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--panel);font-size:.82rem;color:var(--text);cursor:pointer;transition:all .2s}
.batch-bar button:hover{border-color:var(--primary);color:var(--primary)}
.batch-bar button.danger:hover{border-color:#ef4444;color:#ef4444}
.batch-bar .batch-count{font-size:.82rem;color:var(--muted);margin-left:auto}

/* ===== Skeleton Loading ===== */
.skeleton{background:linear-gradient(90deg,var(--bg-soft) 25%,var(--panel-2) 50%,var(--bg-soft) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius)}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{height:240px;border-radius:var(--radius)}
.skeleton-text{height:1rem;margin-bottom:.5rem;border-radius:4px}
.skeleton-text.short{width:60%}

/* ===== Search Form Enhancement ===== */
.search-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}

/* ===== Tag Links (detail page) ===== */
.tag-links{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.45rem}
.tag-links a{display:inline-block;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.78rem;color:var(--primary);background:var(--primary-light);text-decoration:none;transition:all .2s}
.tag-links a:hover{background:var(--primary);color:#fff}

/* ===== Related Section ===== */
.related-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}
.related-section h3{font-size:1rem;font-weight:700;margin-bottom:.65rem}

/* ===== 404 Enhancement ===== */
.error-page{text-align:center;padding:3rem 1rem}
.error-page h1{font-size:4rem;font-weight:800;color:var(--primary);margin-bottom:.5rem}
.error-page p{font-size:1rem;color:var(--muted);margin-bottom:1.5rem}
.error-page .error-search{max-width:400px;margin:0 auto 1.5rem}
.error-page .error-search input{width:100%;padding:.65rem 1rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem}
.error-page .error-recommend{text-align:left;max-width:800px;margin:1.5rem auto 0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.record-table{width:100%;border-collapse:collapse;margin:1rem 0}
.record-table th,.record-table td{padding:.5rem .75rem;border:1px solid var(--border);text-align:left;font-size:.9rem}
.record-table th{background:var(--panel);font-weight:600}
.record-table tr:nth-child(even){background:var(--bg-soft)}
.simple-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:40px 16px}
.simple-box{width:100%;max-width:420px;background:#fff;border-radius:12px;box-shadow:0 2px 16px rgba(0,0,0,.08);padding:36px 32px}
.simple-box h1{text-align:center;font-size:22px;margin:0 0 8px;color:#1a202c}
.simple-box .subtitle{text-align:center;color:#718096;margin:0 0 28px;font-size:14px}
.simple-box .alt-link{text-align:center;margin-top:20px;font-size:14px;color:#718096}
.simple-box .alt-link a{color:#1a56db;text-decoration:none}
.simple-box .alt-link a:hover{text-decoration:underline}
.simple-box .back-home{text-align:center;margin-top:12px;font-size:13px}
.simple-box .back-home a{color:#a0aec0;text-decoration:none}
.page-empty{text-align:center;padding:3rem 1rem;color:var(--muted)}
.page-empty p{font-size:1.1rem;margin-bottom:.5rem}
.page-empty a{color:var(--primary)}
.full-width-sections{margin-top:1.5rem}
.full-width-sections .section{background:var(--panel);border-radius:var(--radius-lg);padding:1.25rem 1.35rem;margin-bottom:1rem;box-shadow:var(--shadow-md)}
.text-list{display:flex;flex-direction:column;gap:.45rem}
.text-list a{display:flex;align-items:center;gap:.65rem;padding:.55rem .85rem;border-radius:var(--radius);color:var(--text);font-size:.9rem;transition:all .15s;border:1px solid transparent}
.text-list a:hover{background:var(--bg-soft);border-color:var(--border);transform:translateX(3px)}
.text-list a .text-rank{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:4px;font-size:.75rem;font-weight:700;background:var(--bg-soft);color:var(--muted);flex-shrink:0}
.text-list a:nth-child(-n+3) .text-rank{background:var(--primary);color:#fff}
.faq-list{display:flex;flex-direction:column;gap:.6rem}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-item summary{padding:.65rem .85rem;font-weight:600;font-size:.92rem;cursor:pointer;list-style:none;display:flex;align-items:center;gap:.4rem}
.faq-item summary::before{content:'Q';display:inline-flex;align-items:center;justify-content:center;width:1.3rem;height:1.3rem;border-radius:3px;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;flex-shrink:0}
.faq-item[open] summary::before{content:'A';background:var(--success)}
.faq-item p{padding:0 .85rem .65rem 2.2rem;font-size:.88rem;color:var(--muted);line-height:1.55}
.virtual-links{display:flex;flex-wrap:wrap;gap:.4rem .8rem;padding:.5rem 0;font-size:.78rem}
.virtual-links a{color:var(--muted);text-decoration:none;opacity:.7}
.virtual-links a:hover{opacity:1;color:var(--primary)}
