
:root{
  --bg:#070b16;
  --bg-soft:#0b1020;
  --panel:rgba(17,24,39,.72);
  --panel-strong:rgba(15,23,42,.92);
  --panel-soft:rgba(255,255,255,.04);
  --line:rgba(255,255,255,.09);
  --text:#e5e7eb;
  --muted:#9ca3af;
  --muted-2:#cbd5e1;
  --primary:#60a5fa;
  --primary-2:#7c3aed;
  --accent:#22c55e;
  --shadow:0 24px 80px rgba(0,0,0,.45);
  --radius:24px;
  --radius-sm:16px;
  --container:1280px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  background:
    radial-gradient(circle at 20% 20%, rgba(124,58,237,.20), transparent 26%),
    radial-gradient(circle at 80% 10%, rgba(96,165,250,.16), transparent 20%),
    radial-gradient(circle at 50% 80%, rgba(34,197,94,.10), transparent 18%),
    linear-gradient(180deg, #050816 0%, #091021 40%, #050816 100%);
  color:var(--text);
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{
  width:min(var(--container), calc(100% - 32px));
  margin-inline:auto;
}
.site-bg{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.25;
  background-image:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,.12) 0, transparent 20%),
    radial-gradient(circle at 85% 15%, rgba(255,255,255,.08) 0, transparent 18%),
    radial-gradient(circle at 50% 80%, rgba(255,255,255,.06) 0, transparent 22%);
  filter:blur(24px);
  z-index:-1;
}
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(18px);
  background:linear-gradient(180deg, rgba(7,11,22,.90), rgba(7,11,22,.68));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  min-height:78px;
  display:flex;
  align-items:center;
  gap:16px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
  min-width:0;
}
.brand-mark{
  width:44px;height:44px;
  border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(96,165,250,.95), rgba(124,58,237,.95));
  color:white;
  box-shadow:0 12px 30px rgba(96,165,250,.28);
  flex:0 0 auto;
}
.brand-body{display:flex;flex-direction:column;min-width:0}
.brand-body strong{
  font-size:1.05rem;
  letter-spacing:.03em;
  white-space:nowrap;
}
.brand-body small{
  color:var(--muted);
  font-size:.78rem;
  white-space:nowrap;
}
.nav{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:auto;
}
.nav-link{
  padding:.58rem .92rem;
  border-radius:999px;
  color:var(--muted-2);
  border:1px solid transparent;
  transition:.2s ease;
}
.nav-link:hover,.nav-link.active{
  color:white;
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.08);
}
.search-form{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:8px;
  flex:0 0 auto;
}
.search-input{
  width:min(300px, 26vw);
  padding:.8rem 1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:white;
  outline:none;
  transition:.2s ease;
}
.search-input::placeholder{color:#94a3b8}
.search-input:focus{
  border-color:rgba(96,165,250,.55);
  box-shadow:0 0 0 4px rgba(96,165,250,.14);
}
.search-button, .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:.8rem 1.12rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  color:white;
  cursor:pointer;
  transition:.22s ease;
  white-space:nowrap;
}
.search-button:hover, .btn:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.18)}
.btn-primary{
  background:linear-gradient(135deg, rgba(96,165,250,.98), rgba(124,58,237,.98));
  border-color:transparent;
  box-shadow:0 18px 35px rgba(124,58,237,.20);
}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{
  background:rgba(255,255,255,.05);
}
.nav-toggle{
  display:none;
  margin-left:auto;
  background:rgba(255,255,255,.05);
  color:white;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  width:46px;height:46px;
}

.page{
  padding:24px 0 56px;
}
.section{
  padding:28px 0;
}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}
.section-title{
  margin:0;
  font-size:clamp(1.3rem, 2vw, 2.05rem);
  line-height:1.2;
}
.section-subtitle{
  margin:6px 0 0;
  color:var(--muted);
  font-size:.95rem;
}
.section-action{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.hero{
  padding:22px 0 6px;
}
.hero-grid{
  display:grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(300px, .8fr);
  gap:18px;
}
.hero-main,.hero-aside,.panel{
  background:linear-gradient(180deg, rgba(16,24,40,.82), rgba(9,14,25,.85));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-main{
  overflow:hidden;
  min-height:620px;
}
.hero-slider{
  position:relative;
  min-height:620px;
  overflow:hidden;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  transform:scale(1.02);
  transition:opacity .55s ease, transform .55s ease;
  background:
    linear-gradient(90deg, rgba(6,10,20,.94) 0%, rgba(6,10,20,.74) 32%, rgba(6,10,20,.24) 58%, rgba(6,10,20,.08) 100%),
    var(--slide-image) center/cover no-repeat;
}
.hero-slide.active{
  opacity:1;
  transform:scale(1);
}
.hero-slide-inner{
  min-height:620px;
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(240px,.7fr);
  align-items:end;
  gap:24px;
  padding:42px;
}
.hero-copy{
  max-width:720px;
  padding-bottom:20px;
}
.hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:.45rem .85rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:#dbeafe;
  font-size:.86rem;
  letter-spacing:.02em;
}
.hero-title{
  margin:16px 0 12px;
  font-size:clamp(2.2rem, 4.5vw, 4.7rem);
  line-height:1.02;
  letter-spacing:-.03em;
  text-wrap:balance;
}
.hero-desc{
  color:#d6d8e0;
  font-size:1.02rem;
  max-width:58ch;
}
.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:18px 0 24px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:.46rem .82rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#e5eefc;
  border:1px solid rgba(255,255,255,.10);
  font-size:.88rem;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.hero-poster-wrap{
  align-self:center;
  justify-self:end;
  width:min(100%, 320px);
  aspect-ratio:2/3;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 26px 60px rgba(0,0,0,.45);
  background:rgba(255,255,255,.05);
}
.hero-poster-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-controls{
  position:absolute;
  left:42px;
  right:42px;
  bottom:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.hero-dots{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.hero-dot{
  width:10px;height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
  border:none;
  transition:.2s ease;
}
.hero-dot.active{
  width:26px;
  background:linear-gradient(135deg, var(--primary), var(--primary-2));
}
.hero-arrows{
  display:flex;
  gap:10px;
}
.hero-arrow{
  width:42px;height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  color:white;
  cursor:pointer;
}

.hero-aside{
  padding:18px;
}
.aside-block{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
  padding:16px;
  margin-bottom:14px;
}
.aside-title{
  margin:0 0 10px;
  font-size:1rem;
}
.aside-list{
  display:grid;
  gap:10px;
}
.mini-item{
  display:grid;
  grid-template-columns:56px minmax(0,1fr);
  gap:12px;
  align-items:center;
  padding:8px;
  border-radius:16px;
  transition:.2s ease;
}
.mini-item:hover{background:rgba(255,255,255,.05)}
.mini-thumb{
  width:56px;height:78px;
  border-radius:14px;
  overflow:hidden;
  flex:0 0 auto;
}
.mini-thumb img{width:100%;height:100%;object-fit:cover}
.mini-title{
  margin:0;
  font-size:.95rem;
  line-height:1.35;
}
.mini-meta{
  color:var(--muted);
  font-size:.78rem;
  margin-top:2px;
}
.stat-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
}
.stat{
  padding:14px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
}
.stat strong{
  display:block;
  font-size:1.2rem;
}
.stat span{
  color:var(--muted);
  font-size:.82rem;
}

.panel{
  padding:18px;
}
.filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.filter-input{
  flex:1 1 250px;
  min-width:220px;
}
.input{
  width:100%;
  padding:.9rem 1rem;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:white;
  outline:none;
}
.input:focus{
  border-color:rgba(96,165,250,.55);
  box-shadow:0 0 0 4px rgba(96,165,250,.12);
}
.chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.chip{
  padding:.5rem .82rem;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
  color:var(--muted-2);
  cursor:pointer;
  transition:.2s ease;
}
.chip.active,.chip:hover{
  background:linear-gradient(135deg, rgba(96,165,250,.20), rgba(124,58,237,.20));
  color:white;
  border-color:rgba(255,255,255,.14);
}
.movie-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0,1fr));
  gap:16px;
}
.movie-card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
  transition:.22s ease;
  min-width:0;
}
.movie-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.16);
  box-shadow:0 18px 40px rgba(0,0,0,.32);
}
.movie-poster{
  position:relative;
  aspect-ratio:2/3;
  overflow:hidden;
  background:rgba(255,255,255,.04);
}
.movie-poster img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.35s ease;
}
.movie-card:hover .movie-poster img{transform:scale(1.05)}
.movie-badge{
  position:absolute;
  left:12px;
  top:12px;
  padding:.34rem .62rem;
  border-radius:999px;
  background:rgba(7,11,22,.78);
  backdrop-filter:blur(8px);
  font-size:.75rem;
  border:1px solid rgba(255,255,255,.10);
}
.movie-body{
  padding:14px 14px 16px;
}
.movie-title{
  margin:0 0 6px;
  font-size:1rem;
  line-height:1.35;
  min-height:2.7em;
}
.movie-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  color:var(--muted);
  font-size:.82rem;
}
.movie-meta span{
  padding:.18rem .5rem;
  border-radius:999px;
  background:rgba(255,255,255,.05);
}
.movie-desc{
  color:#cbd5e1;
  font-size:.86rem;
  margin-top:10px;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:4.15em;
}
.link-row{
  display:flex;
  gap:10px;
  margin-top:12px;
  flex-wrap:wrap;
}
.link-row a{
  color:#dbeafe;
  font-size:.84rem;
}
.link-row a:hover{text-decoration:underline}

.category-grid{
  display:grid;
  grid-template-columns:repeat(5, minmax(0,1fr));
  gap:14px;
}
.category-card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  padding:18px;
  transition:.22s ease;
}
.category-card:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.16);
}
.category-card h3{margin:0 0 8px;font-size:1.02rem}
.category-card p{margin:0;color:var(--muted);font-size:.88rem}
.category-card .count{
  display:inline-flex;
  margin-top:12px;
  padding:.35rem .7rem;
  border-radius:999px;
  background:rgba(255,255,255,.07);
}

.ranking-list{
  display:grid;
  gap:12px;
}
.rank-item{
  display:grid;
  grid-template-columns:64px minmax(0,1fr) 120px;
  gap:14px;
  align-items:center;
  padding:14px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
}
.rank-no{
  width:54px;height:54px;
  border-radius:18px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.07);
  font-size:1.15rem;
  font-weight:700;
}
.rank-main h3{
  margin:0 0 4px;
  font-size:1.02rem;
}
.rank-main p{
  margin:0;
  color:var(--muted);
  font-size:.88rem;
}
.rank-bar{
  width:100%;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
  margin-top:8px;
}
.rank-bar > i{
  display:block;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg, var(--primary), var(--primary-2));
}

.detail-grid{
  display:grid;
  grid-template-columns:minmax(280px, 360px) minmax(0, 1fr);
  gap:18px;
  align-items:start;
}
.detail-aside, .detail-content, .search-panel, .player-panel{
  background:linear-gradient(180deg, rgba(16,24,40,.84), rgba(9,14,25,.88));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.detail-aside{
  overflow:hidden;
}
.detail-poster{
  aspect-ratio:2/3;
  background:rgba(255,255,255,.04);
}
.detail-poster img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.detail-body{
  padding:18px;
}
.detail-title{
  margin:0 0 10px;
  font-size:clamp(1.8rem, 3.8vw, 3.2rem);
  line-height:1.08;
}
.detail-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:14px;
}
.detail-meta .badge{font-size:.8rem}
.detail-info{
  display:grid;
  gap:10px;
  color:#dbe2ef;
}
.detail-info .row{
  display:grid;
  grid-template-columns:110px minmax(0,1fr);
  gap:10px;
}
.detail-info .label{color:var(--muted)}
.story, .review{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
  padding:18px;
}
.story h2, .review h2{
  margin:0 0 10px;
  font-size:1.2rem;
}
.story p, .review p{margin:0;color:#d5d9e6}
.player-panel{
  padding:18px;
}
.player-box{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 42px rgba(0,0,0,.35);
}
.player-box video{
  width:100%;
  aspect-ratio:16/9;
  background:#000;
}
.player-overlay{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  pointer-events:none;
}
.play-button{
  width:78px;height:78px;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  color:white;
  font-size:1.4rem;
  backdrop-filter:blur(10px);
  box-shadow:0 16px 40px rgba(0,0,0,.4);
  pointer-events:auto;
  cursor:pointer;
}
.related-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0,1fr));
  gap:14px;
}
.small-card{
  display:block;
}
.small-card .movie-title{
  min-height:auto;
  font-size:.94rem;
}
.small-card .movie-body{
  padding:12px;
}
.site-footer{
  margin-top:40px;
  padding:28px 0 38px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.12);
}
.footer-grid{
  display:flex;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}
.footer-logo{
  font-weight:700;
  font-size:1.05rem;
  margin-bottom:8px;
}
.footer-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:flex-start;
}
.footer-links a{color:var(--muted-2)}
.footer-links a:hover{color:white}

.search-hero{
  display:grid;
  gap:16px;
  padding:18px;
}
.search-result-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.empty-state{
  padding:40px 18px;
  text-align:center;
  color:var(--muted);
}

.hidden{display:none !important}
.muted{color:var(--muted)}
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  border:0;
}

@media (max-width: 1200px){
  .movie-grid{grid-template-columns:repeat(4, minmax(0,1fr))}
  .related-grid{grid-template-columns:repeat(4, minmax(0,1fr))}
}
@media (max-width: 960px){
  .hero-grid,.detail-grid{grid-template-columns:1fr}
  .hero-main,.hero-slider,.hero-slide-inner{min-height:auto}
  .hero-slide-inner{grid-template-columns:1fr; padding:28px 20px 76px}
  .hero-poster-wrap{justify-self:start; width:min(260px, 100%)}
  .hero-controls{left:20px; right:20px}
  .category-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .movie-grid{grid-template-columns:repeat(3, minmax(0,1fr))}
  .rank-item{grid-template-columns:54px minmax(0,1fr)}
  .rank-score{grid-column:2}
}
@media (max-width: 760px){
  .nav-toggle{display:inline-grid;place-items:center}
  .nav{
    position:absolute;
    left:16px;
    right:16px;
    top:86px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding:14px;
    border-radius:20px;
    background:rgba(6,10,20,.96);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:var(--shadow);
  }
  .nav.open{display:flex}
  .search-form{display:none}
  .topbar-inner{position:relative}
  .movie-grid,.related-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .category-grid{grid-template-columns:1fr}
  .rank-item{grid-template-columns:48px minmax(0,1fr)}
  .detail-info .row{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .container{width:min(var(--container), calc(100% - 22px))}
  .movie-grid,.related-grid{grid-template-columns:1fr}
  .hero-title{font-size:2rem}
  .hero-desc{font-size:.96rem}
  .section-head{flex-direction:column; align-items:flex-start}
}
