.vod-faq-section {
  margin-top:10px
}
.vod-faq-content {
  padding:15px 12px;
  line-height:1.9;
  font-size:14px;
  color:#555;
  background:#fafafa;
  border:1px solid #eee;
  border-top:none
}
.vod-faq-content dl {
  margin:0 0 12px;
  padding:0
}
.vod-faq-content dt {
  font-size:15px;
  font-weight:700;
  color:#333;
  margin:0 0 4px;
  padding-left:4px
}
.vod-faq-content dd {
  margin:0 0 0 18px;
  color:#666;
  font-size:13px
}
.vod-text-list {
  clear:both;
  padding:10px 12px;
  border-top:1px solid #f0f0f0;
  margin-top:8px;
  background:#fafafa;
  border-radius:0 0 4px 4px
}
.vod-text-list ol {
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  counter-reset:vtl
}
.vod-text-list ol li {
  width:50%;
  box-sizing:border-box;
  padding:4px 8px;
  font-size:13px;
  line-height:1.7;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  display:flex;
  align-items:center;
  gap:4px;
  border-bottom:1px dashed #eee
}
.vod-text-list ol li:before {
  counter-increment:vtl;
  content:counter(vtl);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  height:18px;
  border-radius:3px;
  font-size:11px;
  font-weight:700;
  color:#999;
  background:#f0f0f0;
  flex-shrink:0
}
.vod-text-list ol li:nth-child(1):before,.vod-text-list ol li:nth-child(2):before,.vod-text-list ol li:nth-child(3):before {
  color:#fff;
  background:#ff6600
}
.vod-text-list ol li a {
  color:#444;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  flex:1
}
.vod-text-list ol li a:hover {
  color:#ff6600;
  text-decoration:none
}
.vod-text-list ol li span {
  color:#aaa;
  font-size:11px;
  flex-shrink:0;
  margin-left:auto
}
.vod-rec-grid {
  display:flex;
  flex-wrap:wrap;
  gap:0;
  overflow:hidden
}
.vod-rec-grid .qcontainer {
  float:none;
  width:calc(100% / 6);
  margin:0;
  box-sizing:border-box;
  padding:0 8px 12px
}
@media(max-width:767px) {
  .vod-text-list ol li {
    width:100%;
    padding:5px 6px;
    font-size:12px;
  }
  .vod-faq-content {
    padding:10px 8px;
    font-size:13px;
  }
  .vod-faq-content dt {
    font-size:14px;
  }
  .vod-faq-content dd {
    font-size:12px;
    margin-left:12px;
  }
  .vod-rec-grid .qcontainer {
    width:calc(100% / 3);
  }
}
.idx-topic-list {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  padding:8px 0
}
.idx-topic-item {
  display:block;
  width:calc((100% - 60px) / 6);
  text-decoration:none;
  color:#333;
  transition:transform .2s
}
.idx-topic-item:hover {
  transform:translateY(-3px);
  text-decoration:none;
  color:#333
}
.idx-topic-pic {
  position:relative;
  width:100%;
  padding-top:140%;
  overflow:hidden;
  border-radius:6px;
  background:#eee
}
.idx-topic-pic img {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .3s
}
.idx-topic-item:hover .idx-topic-pic img {
  transform:scale(1.05)
}
.idx-topic-cnt {
  position:absolute;
  bottom:6px;
  right:6px;
  background:rgba(0,0,0,.6);
  color:#fff;
  font-size:11px;
  padding:2px 6px;
  border-radius:3px
}
.idx-topic-item p {
  text-align:center;
  font-size:13px;
  margin:6px 0 0;
  line-height:1.4;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap
}
@media(max-width:767px) {
  .idx-topic-list {
    gap:8px;
  }
  .idx-topic-item {
    width:calc(50% - 4px);
  }
  .idx-topic-item p {
    font-size:12px;
  }
}
.tp-list {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
  padding:5px 0
}
.tp-card {
  display:block;
  background:#fff;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 1px 4px rgba(0,0,0,.08);
  transition:all .25s;
  text-decoration:none;
  color:#333
}
.tp-card:hover {
  box-shadow:0 4px 15px rgba(0,0,0,.12);
  transform:translateY(-2px);
  text-decoration:none;
  color:#333
}
.tp-card-pic {
  position:relative;
  padding-top:56%;
  overflow:hidden;
  background:#eee
}
.tp-card-pic img {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .3s
}
.tp-card:hover .tp-card-pic img {
  transform:scale(1.05)
}
.tp-card-overlay {
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:20px 10px 8px;
  background:linear-gradient(transparent,rgba(0,0,0,.6))
}
.tp-card-count {
  color:#fff;
  font-size:12px;
  font-weight:500
}
.tp-card-body {
  padding:10px 12px
}
.tp-card-body h3 {
  font-size:14px;
  margin:0 0 5px;
  line-height:1.4;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:600
}
.tp-card-body p {
  font-size:12px;
  color:#888;
  margin:0 0 6px;
  line-height:1.5;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:36px
}
.tp-card-meta {
  font-size:11px;
  color:#bbb
}
.tp-hero {
  position:relative;
  border-radius:8px;
  overflow:hidden;
  margin:0 -10px;
  min-height:160px
}
.tp-hero-bg {
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background-size:cover;
  background-position:center;
  filter:blur(20px) brightness(.6);
  transform:scale(1.2)
}
.tp-hero-mask {
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:linear-gradient(135deg,rgba(0,0,0,.5),rgba(0,0,0,.3))
}
.tp-hero-body {
  position:relative;
  z-index:1;
  display:flex;
  gap:15px;
  padding:20px;
  align-items:center
}
.tp-hero-pic {
  flex:0 0 120px;
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 4px 15px rgba(0,0,0,.3)
}
.tp-hero-pic img {
  width:100%;
  height:auto;
  display:block
}
.tp-hero-info {
  flex:1;
  color:#fff
}
.tp-hero-info h1 {
  font-size:18px;
  margin:0 0 8px;
  line-height:1.3;
  text-shadow:0 1px 3px rgba(0,0,0,.3)
}
.tp-hero-desc {
  font-size:13px;
  color:rgba(255,255,255,.85);
  line-height:1.6;
  margin:0 0 10px;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden
}
.tp-hero-stat {
  display:flex;
  gap:15px
}
.tp-hero-stat span {
  font-size:12px;
  color:rgba(255,255,255,.7)
}
.tp-hero-stat span i {
  margin-right:3px;
  font-style:normal
}
.tp-content {
  padding:10px 0;
  line-height:1.8;
  font-size:14px;
  color:#444
}
.tp-content p {
  margin-bottom:12px;
  text-indent:2em
}
.tp-content h2 {
  font-size:16px;
  color:#333;
  margin:15px 0 8px;
  padding-left:10px;
  border-left:3px solid #4db2ff
}
.tp-content h3 {
  font-size:15px;
  color:#555;
  margin:12px 0 6px
}
.tp-vod-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  padding:5px 0
}
.tp-vod-card a {
  display:block;
  text-decoration:none;
  color:#333;
  transition:transform .2s
}
.tp-vod-card a:hover {
  transform:translateY(-3px)
}
.tp-vod-poster {
  position:relative;
  border-radius:6px;
  overflow:hidden;
  padding-top:140%;
  background:#f0f0f0
}
.tp-vod-poster img {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover
}
.tp-vod-badge {
  position:absolute;
  top:5px;
  right:5px;
  background:rgba(0,0,0,.6);
  color:#fff;
  padding:1px 6px;
  border-radius:3px;
  font-size:11px
}
.tp-vod-info {
  padding:6px 2px
}
.tp-vod-info h5 {
  font-size:13px;
  margin:0 0 2px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:500
}
.tp-vod-info p {
  font-size:11px;
  color:#999;
  margin:0
}
.tp-more-list {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  padding:5px 0
}
.tp-more-item {
  display:block;
  text-decoration:none;
  color:#333;
  min-width:0;
  overflow:hidden
}
.tp-more-item:hover {
  text-decoration:none;
  color:#ff6600
}
.tp-more-pic {
  position:relative;
  border-radius:6px;
  overflow:hidden;
  padding-top:56%;
  background:#f0f0f0;
  min-width:0
}
.tp-more-pic img {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:cover
}
.tp-more-count {
  position:absolute;
  bottom:5px;
  right:5px;
  background:rgba(0,0,0,.6);
  color:#fff;
  padding:1px 8px;
  border-radius:3px;
  font-size:11px
}
.tp-more-item p {
  font-size:12px;
  margin:5px 0 0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap
}
@media(min-width:769px) {
  .tp-more-list {
    grid-template-columns:repeat(3,1fr);
    gap:10px;
  }
  .tp-more-item p {
    font-size:13px;
  }
}
@media(max-width:768px) {
  .tp-list {
    grid-template-columns:1fr;
    gap:10px;
  }
  .tp-hero-body {
    padding:12px;
  }
  .tp-hero-pic {
    flex:0 0 90px;
  }
  .tp-hero-info h1 {
    font-size:15px;
  }
  .tp-vod-grid {
    grid-template-columns:repeat(3,1fr);
    gap:8px;
  }
}
