
:root {
  --bg: #070b16;
  --panel: rgba(15, 23, 42, 0.76);
  --panel-strong: rgba(15, 23, 42, 0.94);
  --line: rgba(255,255,255,0.10);
  --text: #e5eefc;
  --muted: #9fb0cf;
  --accent: #7c3aed;
  --accent-2: #22d3ee;
  --shadow: 0 24px 80px rgba(0,0,0,0.35);
  --radius: 24px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: radial-gradient(circle at top, #15213f 0, #070b16 46%, #05070e 100%); color: var(--text); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.container { width: min(1320px, calc(100% - 32px)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 40; backdrop-filter: blur(18px); background: rgba(5,10,20,0.72); border-bottom: 1px solid var(--line); }
.navbar { display:flex; align-items:center; justify-content:space-between; padding: 16px 0; gap: 16px; }
.brand { display:flex; align-items:center; gap: 12px; font-weight: 800; letter-spacing: .04em; }
.brand-mark { width: 42px; height: 42px; border-radius: 14px; background: linear-gradient(135deg, #22d3ee, #7c3aed 50%, #f59e0b); box-shadow: 0 12px 34px rgba(124,58,237,.4); position: relative; overflow:hidden; }
.brand-mark::after { content:''; position:absolute; inset: 7px; border-radius: 10px; border: 1px solid rgba(255,255,255,.36); }
.brand span { font-size: 1.02rem; }
.nav-links { display:flex; align-items:center; gap: 20px; flex-wrap: wrap; }
.nav-links a { color: var(--muted); font-size: .96rem; padding: 8px 10px; border-radius: 999px; transition: .2s; }
.nav-links a:hover, .nav-links a.active { color: white; background: rgba(255,255,255,0.08); }
.nav-toggle { display:none; border:1px solid var(--line); background:rgba(255,255,255,.04); color:var(--text); border-radius:12px; width:44px; height:44px; font-size:20px; }
.hero { padding: 26px 0 20px; }
.hero-shell { border-radius: 34px; overflow:hidden; background: linear-gradient(135deg, rgba(15,23,42,.88), rgba(39, 23, 82, .75)); box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.10); position: relative; }
.hero-shell::before { content:''; position:absolute; inset:0; background: radial-gradient(circle at 20% 20%, rgba(34,211,238,.24), transparent 30%), radial-gradient(circle at 80% 10%, rgba(124,58,237,.24), transparent 28%), radial-gradient(circle at 50% 90%, rgba(245,158,11,.16), transparent 32%); pointer-events:none; }
.hero-grid { display:grid; grid-template-columns: 1.35fr .85fr; gap: 18px; padding: 22px; position: relative; z-index: 1; }
.hero-main { min-height: 540px; border-radius: 28px; overflow:hidden; position: relative; border: 1px solid rgba(255,255,255,.08); background: #0f172a; }
.hero-slide { position:absolute; inset:0; opacity:0; transform: scale(1.02); transition: opacity .45s ease, transform .45s ease; background-size: cover; background-position: center; }
.hero-slide.active { opacity:1; transform: scale(1); }
.hero-overlay { position:absolute; inset:0; background: linear-gradient(90deg, rgba(7,11,22,.92) 0%, rgba(7,11,22,.64) 38%, rgba(7,11,22,.16) 100%), linear-gradient(0deg, rgba(7,11,22,.78), rgba(7,11,22,.06)); }
.hero-content { position:absolute; left: 0; right: 0; bottom: 0; padding: 28px; display:flex; flex-direction:column; gap: 14px; max-width: 760px; }
.kicker { display:inline-flex; align-items:center; gap: 8px; padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.08); color: #d6e6ff; width: fit-content; font-size: .88rem; border: 1px solid rgba(255,255,255,.10); }
.hero h1 { margin: 0; font-size: clamp(2rem, 4vw, 4.25rem); line-height: 1.06; letter-spacing: -.03em; text-wrap: balance; }
.hero p { margin: 0; color: var(--muted); font-size: 1rem; line-height: 1.8; max-width: 62ch; }
.hero-actions { display:flex; gap: 12px; flex-wrap: wrap; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap: 8px; border-radius: 999px; padding: 12px 18px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.06); color: white; transition: .2s; }
.btn.primary { background: linear-gradient(135deg, #22d3ee, #7c3aed); border: 0; box-shadow: 0 14px 30px rgba(124,58,237,.34); }
.btn:hover { transform: translateY(-1px); filter: brightness(1.05); }
.hero-meta { display:flex; flex-wrap: wrap; gap: 10px; }
.chip { padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); color: #d8e6ff; font-size: .88rem; }
.hero-side { display:grid; grid-template-rows: auto 1fr; gap: 14px; }
.panel { background: var(--panel); border: 1px solid var(--line); border-radius: 28px; box-shadow: var(--shadow); overflow:hidden; }
.panel-header { display:flex; align-items:center; justify-content:space-between; gap: 12px; padding: 18px 18px 0; }
.panel-title { font-size: 1.05rem; font-weight: 700; }
.panel-sub { color: var(--muted); font-size: .9rem; }
.hero-list { padding: 18px; display:grid; gap: 12px; }
.hero-mini { display:grid; grid-template-columns: 80px 1fr; gap: 12px; align-items: center; padding: 10px; border-radius: 18px; background: rgba(255,255,255,.05); border:1px solid transparent; transition: .2s; }
.hero-mini:hover { border-color: rgba(255,255,255,.10); background: rgba(255,255,255,.08); transform: translateY(-1px); }
.hero-mini img { width: 80px; height: 110px; object-fit: cover; border-radius: 14px; }
.hero-mini h3 { margin:0 0 6px; font-size: 1rem; line-height: 1.3; }
.hero-mini p { margin:0; color: var(--muted); font-size: .88rem; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.section { padding: 14px 0 32px; }
.section-head { display:flex; align-items:end; justify-content:space-between; gap: 18px; margin-bottom: 16px; }
.section-head h2 { margin:0; font-size: 1.4rem; }
.section-head p { margin:6px 0 0; color: var(--muted); }
.grid { display:grid; gap: 14px; }
.grid.cards { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.movie-card { background: rgba(255,255,255,.04); border: 1px solid var(--line); border-radius: 22px; overflow:hidden; box-shadow: var(--shadow); transition: .2s; min-height: 100%; }
.movie-card:hover { transform: translateY(-2px); border-color: rgba(255,255,255,.16); }
.movie-poster { aspect-ratio: 2 / 3; position: relative; overflow:hidden; background: #111827; }
.movie-poster img { width:100%; height:100%; object-fit:cover; transition: .25s; }
.movie-card:hover img { transform: scale(1.04); }
.movie-badge { position:absolute; top: 12px; left: 12px; padding: 6px 10px; border-radius: 999px; background: rgba(0,0,0,.55); border:1px solid rgba(255,255,255,.10); backdrop-filter: blur(10px); font-size: .78rem; }
.movie-body { padding: 12px 12px 14px; display:grid; gap: 8px; }
.movie-body h3 { margin:0; font-size: 1rem; line-height: 1.35; min-height: 2.7em; }
.meta-line { color: var(--muted); font-size: .85rem; display:flex; flex-wrap: wrap; gap: 6px; }
.meta-line span { padding: 4px 8px; border-radius: 999px; background: rgba(255,255,255,.06); }
.movie-body p { margin:0; color: #c4d3ee; font-size: .9rem; line-height: 1.65; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; min-height: 4.8em; }
.link-row { display:flex; justify-content:space-between; align-items:center; gap: 10px; }
.link-row a { color: #d8f3ff; font-size: .9rem; }
.link-row a:hover { text-decoration: underline; }
.toolbar { display:flex; align-items:center; gap: 12px; flex-wrap: wrap; }
.input, select { border:1px solid var(--line); background: rgba(255,255,255,.04); color: var(--text); border-radius: 16px; padding: 12px 14px; outline:none; }
.input::placeholder { color: #93a3c1; }
.footer { padding: 28px 0 44px; color: var(--muted); border-top: 1px solid var(--line); margin-top: 24px; }
.breadcrumb { display:flex; gap: 8px; flex-wrap: wrap; color: #a7b7d7; font-size: .92rem; margin-bottom: 14px; }
.breadcrumb a { color: #d8e6ff; }
.detail-grid { display:grid; grid-template-columns: 320px 1fr; gap: 18px; }
.detail-poster { border-radius: 26px; overflow:hidden; border:1px solid var(--line); background: #0f172a; box-shadow: var(--shadow); position: relative; }
.detail-poster img { width:100%; height:auto; display:block; }
.detail-main { display:grid; gap: 18px; }
.detail-hero { padding: 18px; border-radius: 26px; background: var(--panel); border:1px solid var(--line); box-shadow: var(--shadow); }
.detail-hero h1 { margin:0 0 10px; font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1.08; }
.detail-hero .summary { color: #d8e6ff; line-height: 1.9; }
.detail-stats { display:flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.stat { padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); color: #dbe7ff; font-size: .88rem; }
.player-card { padding: 18px; border-radius: 26px; background: var(--panel); border:1px solid var(--line); box-shadow: var(--shadow); }
.player-frame { position:relative; aspect-ratio: 16 / 9; border-radius: 22px; overflow:hidden; background: #020617; border:1px solid rgba(255,255,255,.10); }
.player-frame video { width:100%; height:100%; background: #020617; }
.player-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background: linear-gradient(180deg, rgba(7,11,22,.14), rgba(7,11,22,.5)); pointer-events:none; }
.play-btn { pointer-events:auto; border:0; width:78px; height:78px; border-radius:50%; background: linear-gradient(135deg, #22d3ee, #7c3aed); color:white; font-size: 1.5rem; box-shadow: 0 18px 34px rgba(124,58,237,.35); cursor:pointer; }
.article { padding: 18px; border-radius: 26px; background: var(--panel); border:1px solid var(--line); box-shadow: var(--shadow); }
.article h2 { margin:0 0 12px; font-size: 1.2rem; }
.article p { margin: 0; color: #d6e4ff; line-height: 1.9; }
.related-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.category-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.category-tile { padding: 20px; border-radius: 22px; border:1px solid var(--line); background: rgba(255,255,255,.05); box-shadow: var(--shadow); }
.category-tile h3 { margin:0 0 6px; }
.category-tile p { margin:0; color: var(--muted); line-height:1.7; }
.rank-table { width:100%; border-collapse: collapse; overflow:hidden; border-radius: 20px; }
.rank-table th, .rank-table td { padding: 12px 14px; border-bottom: 1px solid var(--line); text-align:left; }
.rank-table th { color: #dce8ff; background: rgba(255,255,255,.05); }
.rank-table td { color: #d9e6ff; }
.rank-index { font-weight:700; color:#67e8f9; }
.muted { color: var(--muted); }
.hero-side .mini-more { display:flex; gap: 10px; flex-wrap: wrap; padding: 0 18px 18px; }
.mini-pill { padding: 8px 12px; border-radius:999px; background: rgba(255,255,255,.06); color: #dbe8ff; font-size: .88rem; border: 1px solid rgba(255,255,255,.08); }
.mobile-only { display:none; }
.hidden { display:none !important; }
@media (max-width: 1200px) {
  .grid.cards { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .related-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .category-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .hero-grid, .detail-grid { grid-template-columns: 1fr; }
  .hero-main { min-height: 480px; }
  .grid.cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .nav-toggle { display:inline-flex; align-items:center; justify-content:center; }
  .nav-links { display:none; width: 100%; padding-bottom: 16px; }
  .nav-links.open { display:flex; }
  .navbar { flex-wrap: wrap; }
}
@media (max-width: 640px) {
  .container { width: min(100% - 20px, 1320px); }
  .hero, .section { padding-left: 0; padding-right: 0; }
  .hero-shell { border-radius: 26px; }
  .hero-content { padding: 18px; }
  .hero-main { min-height: 420px; }
  .grid.cards { grid-template-columns: 1fr; }
  .category-grid { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
  .detail-poster { max-width: 360px; margin: 0 auto; }
  .panel, .detail-hero, .player-card, .article, .category-tile { border-radius: 20px; }
  .mobile-only { display:block; }
}
.search-note { font-size: .9rem; color: var(--muted); margin-top: 8px; }
