/* ═══════════════════════════════════════
   VividTV — StreamVid Red Theme
   ═══════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
    --sv-bg: #0b0c10;
    --sv-card: #141620;
    --sv-raised: #1a1c2a;
    --sv-input: #0e1018;
    --sv-glass: rgba(11,12,16,0.85);
    --sv-border: rgba(229,9,20,0.1);
    --sv-border-hover: rgba(229,9,20,0.45);
    --sv-text: #e8e8ec;
    --sv-text2: #8b8d9e;
    --sv-text3: #4a4c5e;
    --sv-red: #e50914;
    --sv-red2: #ff1a25;
    --sv-glow: rgba(229,9,20,0.25);
    --sv-soft: rgba(229,9,20,0.08);
    --sv-grad: linear-gradient(135deg, #e50914, #ff4444);
    --sv-r: 8px;
    --sv-r2: 12px;
}

body { font-family:'Poppins',sans-serif !important; background:var(--sv-bg) !important; }

/* ── Hero ── */
.sv-hero { position:relative; height:480px; overflow:hidden; }
.sv-hero-bg { position:absolute; inset:0; }
.sv-hero-bg img { width:100%; height:100%; object-fit:cover; opacity:0.35; }
.sv-hero-grad { position:absolute; inset:0; background:linear-gradient(to right, rgba(11,12,16,0.97) 0%, rgba(11,12,16,0.6) 50%, rgba(11,12,16,0.2) 100%); }
.sv-hero-grad2 { position:absolute; bottom:0; left:0; right:0; height:200px; background:linear-gradient(transparent, var(--sv-bg)); }
.sv-hero-content { position:absolute; bottom:80px; left:40px; max-width:500px; z-index:2; }
.sv-hero-tags { display:flex; gap:8px; margin-bottom:12px; }
.sv-tag-live { padding:4px 10px; border-radius:4px; font-size:10px; font-weight:700; letter-spacing:0.8px; background:var(--sv-red); color:#fff; text-transform:uppercase; }
.sv-tag-hd { padding:4px 10px; border-radius:4px; font-size:10px; font-weight:700; letter-spacing:0.8px; background:rgba(255,255,255,0.1); color:#fff; border:1px solid rgba(255,255,255,0.15); }
.sv-hero-title { font-size:42px; font-weight:800; line-height:1.08; letter-spacing:-1.5px; margin-bottom:8px; }
.sv-hero-meta { display:flex; gap:10px; align-items:center; font-size:13px; color:var(--sv-text2); margin-bottom:14px; }
.sv-dot { width:3px; height:3px; border-radius:50%; background:var(--sv-text3); }
.sv-hero-desc { font-size:14px; color:var(--sv-text2); line-height:1.6; margin-bottom:22px; }
.sv-hero-btns { display:flex; gap:10px; }
.sv-btn-play { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; border-radius:8px; font-size:14px; font-weight:600; background:var(--sv-red); color:#fff; transition:all .25s; text-decoration:none; }
.sv-btn-play:hover { background:var(--sv-red2); box-shadow:0 4px 20px var(--sv-glow); transform:translateY(-1px); }
.sv-btn-outline { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; border-radius:8px; font-size:14px; font-weight:600; background:rgba(255,255,255,0.06); color:#fff; border:1px solid rgba(255,255,255,0.1); transition:all .25s; text-decoration:none; }
.sv-btn-outline:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.2); }

/* ── Trending Overlay ── */
.sv-trending { padding:0 40px; margin-top:-44px; position:relative; z-index:3; margin-bottom:28px; }
.sv-trending-label { font-size:12px; font-weight:600; color:var(--sv-text2); text-transform:uppercase; letter-spacing:1px; margin-bottom:10px; }
.sv-trending-scroll { display:flex; gap:10px; overflow-x:auto; scrollbar-width:none; padding-bottom:6px; -webkit-overflow-scrolling:touch; }
.sv-trending-scroll::-webkit-scrollbar { display:none; }
.sv-trend { flex-shrink:0; width:200px; height:112px; border-radius:var(--sv-r); overflow:hidden; position:relative; border:2px solid transparent; transition:all .3s; display:block; }
.sv-trend:hover { border-color:var(--sv-red); transform:scale(1.05); box-shadow:0 8px 24px var(--sv-glow); }
.sv-trend-bg { width:100%; height:100%; background:linear-gradient(135deg,#1a0808,#0e1018); display:grid; place-items:center; }
.sv-trend-bg img { width:100%; height:100%; object-fit:cover; }
.sv-trend-bg span { font-size:16px; font-weight:800; color:#333; }
.sv-trend-overlay { position:absolute; inset:0; background:linear-gradient(transparent 40%,rgba(0,0,0,0.8)); display:flex; align-items:flex-end; padding:10px; }
.sv-trend-name { font-size:11px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ── Section ── */
.sv-sec { padding:24px 0; }
.sv-sec-inner { max-width:1400px; margin:0 auto; padding:0 40px; }
.sv-sec-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.sv-sec-title { font-size:18px; font-weight:700; letter-spacing:-0.3px; }
.sv-count { font-size:13px; color:var(--sv-text3); font-weight:400; }
.sv-more { font-size:12px; color:var(--sv-red); font-weight:500; text-decoration:none; }
.sv-more:hover { color:var(--sv-red2); }
.sv-live-badge { display:inline-flex; align-items:center; gap:4px; background:var(--sv-red); color:#fff; padding:3px 10px; border-radius:4px; font-size:10px; font-weight:700; letter-spacing:0.8px; margin-right:6px; animation:sv-pulse 2s infinite; }
.sv-live-badge::before { content:''; width:5px; height:5px; background:#fff; border-radius:50%; }
@keyframes sv-pulse { 0%,100%{box-shadow:0 0 8px var(--sv-glow)} 50%{box-shadow:0 0 18px rgba(229,9,20,0.5)} }
.sv-ipl { background:linear-gradient(135deg, var(--sv-soft) 0%, transparent 50%); border-radius:var(--sv-r2); margin:0 40px; padding:20px; }

/* ── Carousel ── */
.sv-carousel { display:flex; gap:12px; overflow-x:auto; scrollbar-width:none; padding:4px 0 10px; -webkit-overflow-scrolling:touch; }
.sv-carousel::-webkit-scrollbar { display:none; }

/* ── Poster Card ── */
.sv-poster { flex-shrink:0; width:155px; display:block; text-decoration:none; color:var(--sv-text); transition:transform .3s; }
.sv-poster:hover { transform:translateY(-6px); }
.sv-poster-img { aspect-ratio:2/3; border-radius:var(--sv-r); overflow:hidden; position:relative; background:linear-gradient(135deg,var(--sv-card),var(--sv-raised)); border:2px solid transparent; transition:all .3s; display:grid; place-items:center; }
.sv-poster:hover .sv-poster-img { border-color:var(--sv-red); box-shadow:0 12px 32px var(--sv-glow); }
.sv-poster-logo { width:70%; height:70%; object-fit:contain; transition:transform .3s; }
.sv-poster:hover .sv-poster-logo { transform:scale(1.08); }
.sv-poster-ph { font-size:20px; font-weight:800; color:var(--sv-text3); }
.sv-poster-play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,0.5); opacity:0; transition:opacity .2s; }
.sv-poster:hover .sv-poster-play { opacity:1; }
.sv-poster-play svg { width:18px; height:18px; }
.sv-poster-play::before { content:''; position:absolute; width:44px; height:44px; border-radius:50%; background:var(--sv-red); box-shadow:0 4px 16px var(--sv-glow); z-index:-1; }
.sv-poster-info { padding:8px 2px; }
.sv-poster-name { font-size:12px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ── Stats ── */
.sv-stats { display:flex; justify-content:center; gap:48px; padding:36px 40px; border-top:1px solid var(--sv-border); border-bottom:1px solid var(--sv-border); margin:8px 40px; }
.sv-stat { text-align:center; }
.sv-stat-val { font-size:28px; font-weight:800; background:var(--sv-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.sv-stat-label { font-size:10px; color:var(--sv-text3); text-transform:uppercase; letter-spacing:1.2px; margin-top:4px; font-weight:600; }

/* ── Category Grid ── */
.sv-cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:10px; }
.sv-cat-item { background:var(--sv-card); border:1px solid var(--sv-border); border-radius:var(--sv-r); padding:20px 14px; text-align:center; transition:all .25s; display:block; text-decoration:none; color:var(--sv-text); position:relative; overflow:hidden; }
.sv-cat-item::before { content:''; position:absolute; inset:0; background:var(--sv-grad); opacity:0; transition:opacity .3s; }
.sv-cat-item:hover { border-color:var(--sv-red); transform:translateY(-3px); box-shadow:0 6px 20px var(--sv-glow); }
.sv-cat-item:hover::before { opacity:0.05; }
.sv-cat-item * { position:relative; z-index:1; }
.sv-cat-num { font-size:24px; font-weight:800; background:var(--sv-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.sv-cat-name { font-size:11px; color:var(--sv-text2); margin-top:4px; font-weight:500; }

/* ── SEO ── */
.sv-seo { background:rgba(229,9,20,0.02); border-radius:var(--sv-r2); margin:16px 40px; }
.sv-seo-text p { color:var(--sv-text2); font-size:14px; line-height:1.7; margin-bottom:12px; }
.sv-seo-links { display:flex; flex-wrap:wrap; gap:8px; }
.sv-seo-links a { padding:6px 14px; border-radius:6px; font-size:12px; font-weight:500; background:var(--sv-card); border:1px solid var(--sv-border); color:var(--sv-text2); transition:all .2s; text-decoration:none; }
.sv-seo-links a:hover { border-color:var(--sv-red); color:var(--sv-red); }

/* ── CTA ── */
.sv-cta { text-align:center; padding:72px 40px; position:relative; }
.sv-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(229,9,20,0.05),transparent); pointer-events:none; }
.sv-cta h2 { font-size:28px; font-weight:800; letter-spacing:-0.5px; margin-bottom:10px; position:relative; }
.sv-cta p { color:var(--sv-text2); margin-bottom:24px; font-size:15px; position:relative; }

/* ── FAQ ── */
.sv-faq-list { max-width:800px; }
.sv-faq-item { margin-bottom:6px; }
.sv-faq-q { width:100%; display:flex; justify-content:space-between; align-items:center; padding:14px 18px; background:var(--sv-card); border:1px solid var(--sv-border); border-radius:var(--sv-r); font-size:14px; font-weight:500; color:var(--sv-text); text-align:left; transition:all .2s; cursor:pointer; }
.sv-faq-q:hover { border-color:var(--sv-red); }
.sv-faq-icon { font-size:18px; color:var(--sv-text3); transition:transform .2s; }
.sv-faq-item.open .sv-faq-icon { transform:rotate(45deg); color:var(--sv-red); }
.sv-faq-a { max-height:0; overflow:hidden; transition:max-height .3s; }
.sv-faq-item.open .sv-faq-a { max-height:300px; }
.sv-faq-a p { padding:12px 18px; font-size:13px; color:var(--sv-text2); line-height:1.6; }

/* ── Loading ── */
.loading-placeholder { padding:40px; text-align:center; color:var(--sv-text3); font-size:13px; }

/* ── Header override ── */
.site-header { background:var(--sv-glass) !important; backdrop-filter:blur(24px) saturate(180%) !important; border-bottom:1px solid rgba(255,255,255,0.04) !important; }
.nav-link { font-size:13px !important; font-weight:500 !important; border-radius:6px !important; }
.nav-link:hover,.nav-link.active { background:var(--sv-soft) !important; }

/* ── Footer override ── */
.site-footer { background:#060810 !important; border-top:1px solid var(--sv-border) !important; }

/* ── Responsive ── */
@media(max-width:1024px) {
    .sv-hero { height:380px; }
    .sv-hero-title { font-size:32px; }
    .sv-hero-content { left:20px; }
    .sv-sec-inner,.sv-trending,.sv-ipl,.sv-seo { padding-left:20px !important; padding-right:20px !important; margin-left:20px; margin-right:20px; }
    .sv-stats { margin:8px 20px; gap:32px; }
}
@media(max-width:768px) {
    .sv-hero { height:300px; }
    .sv-hero-content { bottom:50px; max-width:85%; }
    .sv-hero-title { font-size:24px; }
    .sv-hero-desc { display:none; }
    .sv-poster { width:125px; }
    .sv-trend { width:160px; height:90px; }
    .sv-cat-grid { grid-template-columns:repeat(2,1fr); }
    .sv-stats { flex-wrap:wrap; gap:20px; padding:24px 20px; }
    .sv-sec-inner { padding:0 16px !important; }
}
@media(max-width:480px) {
    .sv-hero { height:240px; }
    .sv-hero-title { font-size:20px; }
    .sv-hero-btns .sv-btn-outline { display:none; }
    .sv-poster { width:105px; }
    .sv-stat-val { font-size:22px; }
    .sv-trending { padding:0 16px; }
}

/* ═══════════════════════════════════════
   Premium Home Override
   ═══════════════════════════════════════ */
:root {
    --sv-bg: #070707;
    --sv-card: #111111;
    --sv-raised: #171717;
    --sv-input: #121212;
    --sv-border: rgba(255,255,255,0.06);
    --sv-border-hover: rgba(229,9,20,0.28);
    --sv-text: #f3f3f3;
    --sv-text2: #a0a0a0;
    --sv-text3: #6d6d6d;
    --sv-glow: rgba(229,9,20,0.18);
    --sv-soft: rgba(229,9,20,0.08);
    --sv-r: 14px;
    --sv-r2: 22px;
}

.sv-hero {
    height: 560px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.sv-hero-bg img {
    opacity: 0.24;
    filter: saturate(0.82) contrast(1.02);
}

.sv-hero-grad {
    background: linear-gradient(to right, rgba(8, 8, 8, 0.94) 0%, rgba(8, 8, 8, 0.68) 48%, rgba(8, 8, 8, 0.34) 100%);
}

.sv-hero-content {
    left: 50%;
    width: min(1380px, calc(100% - 48px));
    transform: translateX(-50%);
    bottom: 84px;
    max-width: 640px;
}

.sv-hero-title {
    font-size: clamp(40px, 6vw, 68px);
    line-height: 0.96;
    letter-spacing: -0.05em;
    margin-bottom: 12px;
}

.sv-hero-meta,
.sv-hero-desc {
    font-size: 15px;
}

.sv-btn-play,
.sv-btn-outline {
    min-height: 48px;
    padding: 0 22px;
    border-radius: 999px;
}

.sv-btn-outline {
    background: rgba(255, 255, 255, 0.04);
}

.sv-trending {
    padding: 0 24px;
    margin-top: -34px;
}

.sv-trending-scroll,
.sv-carousel {
    gap: 14px;
}

.sv-trend {
    width: 220px;
    height: 124px;
    border: 1px solid var(--sv-border);
    border-radius: 16px;
}

.sv-trend:hover {
    transform: translateY(-2px);
}

.sv-sec {
    padding: 26px 0;
}

.sv-sec-inner {
    max-width: 1460px;
    padding: 0 24px;
}

.sv-sec-head {
    margin-bottom: 16px;
}

.sv-sec-title {
    font-size: 22px;
    letter-spacing: -0.03em;
}

.sv-poster {
    width: 170px;
}

.sv-poster-img,
.sv-cat-item,
.sv-faq-q,
.sv-seo,
.sv-ipl {
    border: 1px solid var(--sv-border);
}

.sv-poster-img {
    border-radius: 16px;
    background: linear-gradient(180deg, #181818, #111111);
}

.sv-poster:hover .sv-poster-img {
    border-color: var(--sv-border-hover);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
}

.sv-poster-name {
    font-size: 13px;
    line-height: 1.45;
}

.sv-stats {
    gap: 22px;
    margin: 6px 24px 14px;
    padding: 26px 24px;
    border: 1px solid var(--sv-border);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.02);
}

.sv-stat {
    min-width: 120px;
}

.sv-cat-grid {
    gap: 12px;
}

.sv-cat-item {
    border-radius: 16px;
    padding: 18px 14px;
    background: #121212;
}

.sv-cat-item:hover {
    border-color: var(--sv-border-hover);
    box-shadow: none;
}

.sv-seo {
    margin: 12px 24px;
    padding: 10px 0;
    border-radius: 20px;
    background: rgba(255,255,255,0.02);
}

.sv-seo-links a {
    border-radius: 999px;
    background: #121212;
}

.sv-cta {
    padding: 64px 24px;
}

.sv-faq-list {
    max-width: 920px;
}

.sv-faq-q {
    border-radius: 16px;
    background: #121212;
}

@media (max-width: 1024px) {
    .sv-hero {
        height: 460px;
    }

    .sv-hero-content {
        width: calc(100% - 32px);
        bottom: 58px;
    }

    .sv-stats,
    .sv-seo,
    .sv-ipl {
        margin-left: 16px;
        margin-right: 16px;
    }

    .sv-sec-inner,
    .sv-trending {
        padding-left: 16px;
        padding-right: 16px;
    }
}

@media (max-width: 768px) {
    .sv-hero {
        height: 360px;
    }

    .sv-hero-title {
        font-size: 30px;
    }

    .sv-hero-desc {
        display: block;
        font-size: 13px;
    }

    .sv-poster {
        width: 132px;
    }

    .sv-trend {
        width: 176px;
        height: 100px;
    }

    .sv-stats {
        gap: 18px;
    }
}
