/* ============================================================
   FlixPro - Apple CMS Premium Movie Template
   Netflix + Apple TV Style | Blue-Gold Dark Theme
   SEO Optimized | Mobile First | Module Based
   ============================================================ */

/* --- CSS Variables --- */
:root {
  --bg:          #0f1115;
  --card:        #181b22;
  --border:      #262b36;
  --text:        #e8eaed;
  --sub:         #9aa4b2;
  --muted:       #5c6472;
  --primary:     #5b8cff;
  --primary-hov: #7aa2ff;
  --gold:        #d8b46a;
  --gold-hov:    #e8c87a;
  --shadow:      0 8px 32px rgba(0,0,0,.5);
  --radius:      12px;
  --radius-sm:   8px;
  --radius-xs:   4px;
  --transition:  .25s cubic-bezier(.4,0,.2,1);
  --font:        Inter,-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei","Helvetica Neue",sans-serif;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--text);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--primary)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
::selection{background:var(--primary);color:#fff}

/* --- Container --- */
.container{max-width:1360px;margin:0 auto;padding:0 24px}

/* =============================================
   HEADER
   ============================================= */
.header{position:sticky;top:0;z-index:1000;background:rgba(15,17,21,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;height:64px;gap:24px}
.logo{flex-shrink:0}
.logo a{font-size:22px;font-weight:800;color:var(--primary);letter-spacing:-.5px}
.logo a span{color:var(--gold)}
.nav{display:flex;flex:1;gap:0;flex-wrap:wrap}
.nav > a,.nav .nav-item > a{display:block;padding:6px 14px;border-radius:var(--radius-xs);font-size:15px;font-weight:500;color:var(--text);transition:var(--transition)}
.nav > a:hover,.nav > a.active,.nav .nav-item > a:hover,.nav .nav-item > a.active{color:#fff;background:var(--primary)}
/* 有子分类的导航加三角指示 */
.nav .nav-item > a::after{content:" ▾";font-size:10px;opacity:.5;margin-left:4px;display:inline-block;transition:var(--transition)}
.nav .nav-item:hover > a::after{opacity:1}
/* Dropdown */
.nav .nav-item{position:relative}
.nav .nav-drop{display:none;position:absolute;top:100%;left:0;min-width:140px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px;z-index:100;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.nav .nav-drop a{display:block;padding:7px 14px;border-radius:var(--radius-xs);font-size:13px;color:var(--sub);transition:var(--transition);white-space:nowrap}
.nav .nav-drop a:hover{color:#fff;background:var(--primary)}
.nav .nav-item:hover .nav-drop{display:block}
.search-bar{display:flex;align-items:center;flex-shrink:0}
.search-bar input{width:200px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-xs) 0 0 var(--radius-xs);background:var(--card);color:var(--text);font-size:13px;outline:none;transition:var(--transition)}
.search-bar input:focus{border-color:var(--primary);width:240px}
.search-bar input::placeholder{color:var(--muted)}
.search-bar button{padding:8px 16px;border:none;border-radius:0 var(--radius-xs) var(--radius-xs) 0;background:var(--primary);color:#fff;font-size:13px;cursor:pointer;transition:var(--transition)}
.search-bar button:hover{background:var(--primary-hov)}
.hamburger{display:none;font-size:22px;cursor:pointer;color:var(--text);flex-shrink:0}

/* =============================================
   FOOTER
   ============================================= */
.footer{margin-top:60px;padding:40px 0 30px;border-top:1px solid var(--border);text-align:center}
.footer p{font-size:13px;color:var(--muted);margin:4px 0}
.footer a{color:var(--sub)}
.footer a:hover{color:var(--primary)}

/* =============================================
   BREADCRUMB
   ============================================= */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding:16px 0;font-size:13px;color:var(--muted)}
.breadcrumb a{color:var(--sub)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb .sep{color:var(--muted);margin:0 6px}

/* =============================================
   SECTION
   ============================================= */
.section{padding:32px 0}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-title{font-size:20px;font-weight:700;color:var(--text);position:relative;padding-left:16px}
.section-title::before{content:'';position:absolute;left:0;top:3px;bottom:3px;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--primary),var(--gold))}
.section-more{font-size:13px;color:var(--sub);transition:var(--transition)}
.section-more:hover{color:var(--gold)}

/* =============================================
   VOD CARD
   ============================================= */
.vod-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.vod-card{background:var(--card);border-radius:var(--radius);overflow:hidden;transition:var(--transition);border:1px solid var(--border)}
.vod-card:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:0 12px 40px rgba(91,140,255,.12)}
.vod-card .pic{position:relative;aspect-ratio:2/3;overflow:hidden;background:var(--card)}
.vod-card .pic img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.vod-card:hover .pic img{transform:scale(1.06)}
.vod-card .badge{position:absolute;top:8px;right:8px;padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;font-weight:700;z-index:2}
.badge.blue{background:var(--primary);color:#fff}
.badge.gold{background:var(--gold);color:#0f1115}
.vod-card .year-tag{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.7);padding:2px 8px;border-radius:var(--radius-xs);font-size:11px;color:#fff;z-index:2}
.vod-card .info{padding:10px 12px 14px}
.vod-card .info h3{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}
.vod-card .info h3 a{color:var(--text)}
.vod-card .info h3 a:hover{color:var(--primary)}
.vod-card .meta{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--sub)}
.vod-card .meta .score{color:var(--gold);font-weight:700}

/* =============================================
   HERO
   ============================================= */
.hero{position:relative;overflow:hidden}
.hero-track{display:grid;grid-template-columns:repeat(5,1fr);height:480px}
.hero-item{position:relative;overflow:hidden;cursor:pointer}
.hero-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.hero-item:hover img{transform:scale(1.08)}
.hero-item .overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,17,21,.95) 0%,transparent 50%,transparent 100%);z-index:1}
.hero-item .hero-info{position:absolute;bottom:0;left:0;right:0;padding:30px 20px 20px;z-index:2}
.hero-item .hero-info .tag{display:inline-block;padding:2px 10px;border-radius:var(--radius-xs);font-size:11px;font-weight:600;background:var(--gold);color:#0f1115;margin-bottom:6px}
.hero-item .hero-info h2{font-size:15px;font-weight:700;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hero-item .hero-info p{font-size:12px;color:rgba(255,255,255,.5);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* =============================================
   FILTER
   ============================================= */
.cate-header h1{font-size:26px;font-weight:800;margin-bottom:16px}
.cate-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.cate-tabs a{padding:5px 14px;border-radius:var(--radius-xs);font-size:13px;color:var(--sub);background:var(--card);border:1px solid var(--border);transition:var(--transition)}
.cate-tabs a:hover,.cate-tabs a.active{border-color:var(--primary);color:var(--primary);background:rgba(91,140,255,.08)}
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:12px 16px;background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:16px}
.filter-bar .label{font-size:13px;color:var(--sub);flex-shrink:0;min-width:40px}
.filter-bar .group{display:flex;flex-wrap:wrap;gap:4px}
.filter-bar .group a{padding:3px 10px;border-radius:var(--radius-xs);font-size:12px;color:var(--sub);transition:var(--transition)}
.filter-bar .group a:hover,.filter-bar .group a.active{color:var(--primary);background:rgba(91,140,255,.1)}

/* =============================================
   PAGINATION
   ============================================= */
.pagination{display:flex;justify-content:center;gap:6px;padding:40px 0}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 14px;border-radius:var(--radius-xs);font-size:13px;background:var(--card);border:1px solid var(--border);color:var(--sub);transition:var(--transition)}
.pagination a:hover{border-color:var(--primary);color:var(--primary)}
.pagination .active,.pagination .current{background:var(--primary);border-color:var(--primary);color:#fff}

/* =============================================
   DETAIL
   ============================================= */
.detail-hero{padding:40px 0;border-bottom:1px solid var(--border)}
.detail-wrap{display:flex;gap:40px}
.detail-poster{flex:0 0 280px}
.detail-poster img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.detail-info{flex:1;min-width:0}
.detail-info h1{font-size:28px;font-weight:800;margin-bottom:10px}
.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.detail-tags span{padding:3px 12px;border-radius:var(--radius-xs);font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--sub)}
.detail-tags .hl{background:var(--primary);color:#fff;font-weight:600}
.detail-meta{margin-bottom:16px}
.detail-meta .meta-line{font-size:14px;line-height:1.8;color:var(--sub);display:flex;flex-wrap:wrap;align-items:baseline;gap:0 4px}
.detail-meta .lbl{color:var(--muted);flex-shrink:0;white-space:nowrap}
.detail-meta .val{color:var(--text)}
.detail-meta .val a,.detail-meta .val a:visited{color:var(--primary);text-decoration:none;border-bottom:1px solid transparent;transition:var(--transition)}
.detail-meta .val a:hover{color:var(--primary-hov);border-bottom-color:var(--primary)}
.detail-meta .val a+a{margin-left:4px}
.detail-meta .val a+a::before{content:" / ";color:var(--muted);margin-right:4px}
.detail-meta .meta-div{display:inline-block;width:1px;height:12px;background:var(--border);margin:0 10px;vertical-align:middle}

.actor-links{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.actor-links a{padding:4px 14px;border-radius:20px;font-size:13px;background:var(--card);border:1px solid var(--border);color:var(--sub);transition:var(--transition)}
.actor-links a:hover{border-color:var(--primary);color:var(--primary)}

.play-btn-row{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}
.play-btn{display:inline-flex;align-items:center;padding:10px 28px;border-radius:var(--radius-xs);font-size:14px;font-weight:600;transition:var(--transition)}
.play-btn.primary{background:var(--primary);color:#fff}
.play-btn.primary:hover{background:var(--primary-hov);color:#fff}
.play-btn.gold{background:var(--gold);color:#0f1115}


.detail-body{max-width:860px;margin-bottom:30px}
.detail-body h3{font-size:18px;font-weight:700;margin-bottom:14px;padding-left:16px}
.detail-body h3::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:2px;background:linear-gradient(180deg,var(--primary),var(--gold))}
.detail-body h3{position:relative}
.detail-body .content{padding:20px 24px;background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:14px;line-height:1.8;color:var(--sub)}
.detail-body .content img{max-width:100%;margin:8px 0;border-radius:var(--radius-sm)}

/* =============================================
   PLAYER
   ============================================= */
.player-wrap{padding:30px 0}
.player-box{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.player-box iframe,.player-box video,.player-box embed,.player-box object{position:absolute;top:0;left:0;width:100%;height:100%}
.player-title{font-size:20px;font-weight:700;margin-bottom:6px}
.player-title small{font-size:14px;color:var(--sub);font-weight:400}
.player-info h2{font-size:18px;font-weight:700;margin-bottom:4px}
.player-meta{font-size:13px;color:var(--sub);margin-bottom:12px;display:flex;gap:8px;flex-wrap:wrap}
.player-meta .tag{padding:2px 10px;border-radius:var(--radius-xs);background:var(--card);border:1px solid var(--border);font-size:12px}
.player-meta .tag.gold{color:var(--gold);border-color:var(--gold)}
.player-meta a{color:var(--primary)}
.player-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.player-actions .btn{padding:6px 16px;border-radius:var(--radius-xs);font-size:13px;background:var(--card);border:1px solid var(--border);color:var(--text);transition:var(--transition);text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.player-actions .btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.player-actions .arrow{font-size:16px;font-weight:700}
.source-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}
.source-tabs a{padding:6px 18px;border-radius:var(--radius-xs);font-size:13px;background:var(--card);border:1px solid var(--border);color:var(--sub);transition:var(--transition);cursor:pointer;text-decoration:none}
.source-tabs a:hover,.source-tabs a.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.episode-wrap{margin-bottom:30px}
.episode-box{display:none}
.episode-list{display:flex;flex-wrap:wrap;gap:4px}
.episode-list a{padding:5px 14px;border-radius:var(--radius-xs);font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--sub);transition:var(--transition);text-decoration:none}
.episode-list a:hover,.episode-list a.active{border-color:var(--primary);color:var(--primary);background:rgba(91,140,255,.08)}
.episode-list::-webkit-scrollbar{width:4px;height:4px}
.episode-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
/* Play icon on detail poster */
.play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:rgba(91,140,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition);z-index:2}
.play-icon::after{content:"▶";color:#fff;font-size:22px;margin-left:3px}
.detail-poster:hover .play-icon{opacity:1}
/* Description toggle */
.desc-sketch{font-size:14px;line-height:1.8;color:var(--sub)}
.desc-full{font-size:14px;line-height:1.8;color:var(--sub)}
.desc-toggle{font-size:13px;color:var(--primary);text-decoration:none;cursor:pointer;display:inline-block;margin-top:4px}
.desc-toggle:hover{text-decoration:underline}

/* =============================================
   ACTOR
   ============================================= */
.actor-page{padding:30px 0}
.actor-page h1{font-size:26px;font-weight:800;margin-bottom:20px}
.actor-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;padding-bottom:30px}
.actor-card{text-align:center;background:var(--card);border-radius:var(--radius);padding:20px 16px;border:1px solid var(--border);transition:var(--transition);display:block}
.actor-card:hover{transform:translateY(-4px);border-color:var(--primary)}
.actor-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:50%;margin-bottom:10px}
.actor-card strong{font-size:14px;display:block}
.actor-card .count{font-size:12px;color:var(--muted);margin-top:4px}

/* =============================================
   SEARCH
   ============================================= */
.search-page{padding:20px 0}
.search-form{max-width:600px;margin:0 auto 30px;display:flex}
.search-form input{flex:1;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm) 0 0 var(--radius-sm);background:var(--card);color:var(--text);font-size:15px;outline:none;transition:var(--transition)}
.search-form input:focus{border-color:var(--primary)}
.search-form button{padding:12px 28px;border:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--primary);color:#fff;font-size:15px;font-weight:600;cursor:pointer}
.search-form button:hover{background:var(--primary-hov)}

/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:1200px){
  .vod-grid{grid-template-columns:repeat(5,1fr)}
  .hero-track{height:400px}
  .actor-grid{grid-template-columns:repeat(5,1fr)}
}
@media(max-width:992px){
  .vod-grid{grid-template-columns:repeat(4,1fr)}
  .hero-track{height:360px}
  .actor-grid{grid-template-columns:repeat(4,1fr)}
  .detail-wrap{flex-direction:column}
  .detail-poster{flex:0 0 auto;max-width:220px;margin:0 auto}
}
@media(max-width:768px){
  html{font-size:14px}
  .vod-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .hero-track{height:auto;grid-template-columns:repeat(2,1fr);grid-template-rows:200px 200px}
  .hero-item:nth-child(n+3){display:none}
  .actor-grid{grid-template-columns:repeat(3,1fr)}
  .nav{display:none;position:absolute;top:64px;left:0;right:0;background:rgba(15,17,21,.98);flex-direction:column;padding:12px;z-index:999}
  .nav.active{display:flex}
  .nav .nav-item .nav-drop{display:none;position:static;background:transparent;border:none;box-shadow:none;padding:0 0 0 16px}
  .nav .nav-item:hover .nav-drop{display:none}
  .nav .nav-item.open .nav-drop{display:block}
  .nav .nav-drop a{color:var(--sub);padding:5px 14px}
  .search-bar input{width:130px}
  .hamburger{display:block}
  .filter-bar{flex-direction:column;align-items:flex-start}
  .container{padding:0 16px}
}
@media(max-width:480px){
  .vod-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .actor-grid{grid-template-columns:repeat(3,1fr)}
  .detail-poster{max-width:160px}
  .search-bar input{width:110px;font-size:12px;padding:6px 10px}
  .search-bar button{padding:6px 10px;font-size:12px}
}