:root {
  --bg1-dfeb95c3: #0b0814;
  --bg2-dfeb95c3: #160a26;
  --acc-dfeb95c3: #ff3ea5;
  --acc2-dfeb95c3: #7a5cff;
  --tx-dfeb95c3: #f5f1ff;
  --mu-dfeb95c3: #b3a8d1;
}
* { box-sizing: border-box; margin:0; padding:0; }
html,body { background: radial-gradient(1200px 600px at 10% -10%, #ff3ea522, transparent 60%), radial-gradient(900px 500px at 100% 0%, #7a5cff22, transparent 60%), linear-gradient(180deg, var(--bg1-dfeb95c3), var(--bg2-dfeb95c3)); color: var(--tx-dfeb95c3); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif; -webkit-font-smoothing: antialiased; min-height:100%; }
img { display:block; max-width:100%; }
a { color: inherit; text-decoration:none; }
.body-dfeb95c3 { padding-top: 76px; }

/* Header */
.hd-dfeb95c3 { position:fixed; top:0; left:0; right:0; z-index:50; backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%); background: rgba(8,6,16,0.55); border-bottom: 1px solid rgba(255,255,255,0.08); }
.hd-dfeb95c3__inner { max-width: 1280px; margin:0 auto; padding: 12px 24px; display:grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items:center; }
.brand-dfeb95c3 { display:flex; align-items:center; gap:10px; }
.brand-dfeb95c3__name { font-size: 17px; font-weight: 700; letter-spacing: 0.5px; background: linear-gradient(135deg, #ff3ea5 0%, #7a5cff 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.nav-dfeb95c3 { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; }
.nav-dfeb95c3__item { padding: 8px 14px; border-radius: 999px; font-size: 13px; color: var(--mu-dfeb95c3); transition: all .25s ease; border:1px solid transparent; }
.nav-dfeb95c3__item:hover { color: var(--tx-dfeb95c3); background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); transform: translateY(-1px); }
.search-dfeb95c3 { display:flex; align-items:center; gap:6px; background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius: 999px; padding: 6px 6px 6px 14px; transition: box-shadow .25s; }
.search-dfeb95c3:focus-within { box-shadow: 0 0 0 3px #ff3ea533; border-color: #ff3ea5; }
.search-dfeb95c3__input { background: transparent; border:0; outline:0; color: var(--tx-dfeb95c3); width: 200px; font-size: 13px; }
.search-dfeb95c3__input::placeholder { color: var(--mu-dfeb95c3); }
.search-dfeb95c3__btn { background: linear-gradient(135deg, #ff3ea5 0%, #7a5cff 100%); border:0; color:#fff; width:32px; height:32px; border-radius: 999px; display:grid; place-items:center; cursor:pointer; }

/* Breadcrumb */
.crumb-dfeb95c3 { max-width:1280px; margin: 18px auto 0; padding: 0 24px; color: var(--mu-dfeb95c3); font-size: 13px; }
.crumb-dfeb95c3 ol { list-style:none; display:flex; gap:8px; }
.crumb-dfeb95c3 li + li::before { content:"›"; margin-right:8px; opacity:.6; }

/* Hero */
.hero-dfeb95c3 { position:relative; max-width:1280px; margin: 18px auto 0; padding: 0 24px; }
.hero-dfeb95c3__bg { position:absolute; inset: 0 24px; background-size: cover; background-position: center; border-radius: 20px; filter: blur(2px) brightness(.5); transform: scale(1.02); }
.hero-dfeb95c3__glass { position:relative; padding: 38px; border-radius: 20px; background: rgba(10,8,20,0.45); backdrop-filter: blur(14px) saturate(160%); -webkit-backdrop-filter: blur(14px) saturate(160%); border:1px solid rgba(255,255,255,0.1); }
.hero-dfeb95c3__h2 { font-size: clamp(20px, 3vw, 30px); font-weight: 800; line-height:1.3; }
.hero-dfeb95c3__desc { margin-top: 10px; color: var(--mu-dfeb95c3); max-width: 820px; line-height:1.7; }
.hero-dfeb95c3__meta { margin-top: 14px; display:flex; gap:18px; font-size: 12px; color: var(--mu-dfeb95c3); }

/* Grid */
.grid-wrap-dfeb95c3 { max-width:1280px; margin: 30px auto; padding: 0 24px; }
.grid-h3-dfeb95c3 { font-size: 18px; font-weight:700; margin-bottom: 16px; padding-left: 12px; border-left: 4px solid; border-image: linear-gradient(135deg, #ff3ea5 0%, #7a5cff 100%) 1; }
.grid-dfeb95c3 { display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 22px; }
.card-dfeb95c3 { background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius: 20px; overflow:hidden; transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.card-dfeb95c3:hover { transform: translateY(-6px); border-color: #ff3ea577; box-shadow: 0 20px 40px -20px #ff3ea555; }
.card-dfeb95c3__cover { position:relative; aspect-ratio: 16/10; overflow:hidden; }
.card-dfeb95c3__cover img { width:100%; height:100%; object-fit:cover; transition: transform .6s ease; }
.card-dfeb95c3:hover .card-dfeb95c3__cover img { transform: scale(1.06); }
.card-dfeb95c3__play { position:absolute; inset:0; display:grid; place-items:center; color: #fff; opacity:0; transition: opacity .3s; background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.55)); }
.card-dfeb95c3:hover .card-dfeb95c3__play { opacity:1; }
.card-dfeb95c3__score { position:absolute; top:10px; right:10px; background: linear-gradient(135deg, #ff3ea5 0%, #7a5cff 100%); color:#fff; padding: 2px 8px; border-radius: 999px; font-size: 12px; font-weight:700; }
.card-dfeb95c3__chip { position:absolute; top:10px; left:10px; background: rgba(0,0,0,0.55); color:#fff; padding: 2px 8px; border-radius: 999px; font-size: 11px; }
.card-dfeb95c3__body { padding: 14px 16px 16px; }
.card-dfeb95c3__title { font-size: 15px; font-weight: 700; line-height: 1.4; }
.card-dfeb95c3__desc { margin-top: 6px; font-size: 13px; color: var(--mu-dfeb95c3); line-height: 1.6; min-height: 42px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-dfeb95c3__foot { margin-top: 10px; display:flex; justify-content:space-between; font-size: 12px; color: var(--mu-dfeb95c3); }

/* Testimonials */
.testi-dfeb95c3 { max-width:1280px; margin: 40px auto; padding: 0 24px; }
.testi-dfeb95c3 h3 { font-size:18px; font-weight:700; margin-bottom:16px; }
.testi-dfeb95c3__grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.testi-dfeb95c3__item { padding: 18px; border-radius: 20px; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); }
.testi-dfeb95c3__item p { line-height: 1.7; color: var(--tx-dfeb95c3); }
.testi-dfeb95c3__item cite { display:block; margin-top: 10px; font-style: normal; font-size: 12px; color: var(--mu-dfeb95c3); }

/* Contact */
.contact-dfeb95c3 { max-width:1280px; margin: 40px auto; padding: 0 24px; }
.contact-dfeb95c3 h3 { font-size:18px; font-weight:700; margin-bottom:16px; }
.contact-dfeb95c3__grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 16px; }
.contact-dfeb95c3__card { padding: 20px; border-radius: 20px; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); line-height:1.8; }
.contact-dfeb95c3__card h4 { margin-bottom:8px; font-size:15px; }
.contact-dfeb95c3__card a { color: #ff3ea5; }
.contact-dfeb95c3__json { margin-top:12px; padding:10px; background: rgba(0,0,0,0.35); border-radius: 10px; font-size:11px; line-height:1.5; color: var(--mu-dfeb95c3); overflow:auto; max-height: 220px; }
.share-dfeb95c3 { display:flex; flex-wrap:wrap; gap:10px; }
.share-dfeb95c3__btn { padding: 10px 16px; border-radius: 999px; font-size: 13px; color:#fff; background: rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.14); transition: all .25s; }
.share-dfeb95c3__btn:hover { background: linear-gradient(135deg, #ff3ea5 0%, #7a5cff 100%); transform: translateY(-2px); }

/* FAQ */
.faq-dfeb95c3 { max-width:980px; margin: 40px auto 60px; padding: 0 24px; }
.faq-dfeb95c3 h3 { font-size:18px; font-weight:700; margin-bottom:16px; }
.faq-dfeb95c3__item { padding: 14px 18px; border-radius: 14px; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); margin-bottom: 10px; transition: background .3s; }
.faq-dfeb95c3__item[open] { background: rgba(255,255,255,0.07); }
.faq-dfeb95c3__item summary { cursor:pointer; font-weight:600; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq-dfeb95c3__item summary::after { content:"+"; color: #ff3ea5; font-size: 22px; transition: transform .3s; }
.faq-dfeb95c3__item[open] summary::after { transform: rotate(45deg); }
.faq-dfeb95c3__item p { margin-top: 10px; color: var(--mu-dfeb95c3); line-height: 1.8; animation: fadein-dfeb95c3 .3s ease; }
@keyframes fadein-dfeb95c3 { from {opacity:0; transform:translateY(-4px);} to {opacity:1; transform:translateY(0);} }

/* Footer */
.ft-dfeb95c3 { border-top: 1px solid rgba(255,255,255,0.08); padding: 30px 24px; background: rgba(0,0,0,0.25); }
.ft-dfeb95c3__cols { max-width:1280px; margin:0 auto; display:grid; grid-template-columns: 2fr 1fr 1.5fr; gap: 30px; }
.ft-dfeb95c3__cols h5 { font-size:14px; margin-bottom:10px; color: var(--tx-dfeb95c3); }
.ft-dfeb95c3__cols p, .ft-dfeb95c3__cols li { font-size:12px; color: var(--mu-dfeb95c3); line-height:1.8; }
.ft-dfeb95c3__cols ul { list-style:none; }
.ft-dfeb95c3__copy { max-width:1280px; margin: 18px auto 0; padding-top: 14px; border-top: 1px dashed rgba(255,255,255,0.1); font-size: 12px; color: var(--mu-dfeb95c3); text-align:center; }

@media (max-width: 900px) {
  .hd-dfeb95c3__inner { grid-template-columns: 1fr auto; }
  .nav-dfeb95c3 { order: 3; grid-column: 1 / -1; justify-content: flex-start; overflow-x:auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .nav-dfeb95c3__item { flex:0 0 auto; }
  .search-dfeb95c3__input { width: 140px; }
  .ft-dfeb95c3__cols { grid-template-columns: 1fr; }
  .body-dfeb95c3 { padding-top: 120px; }
}
