﻿/* ========================================================================
   HOME PAGE STYLES
   Extracted from Index.cshtml inline <style> for browser caching
   ======================================================================== */
/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       DESIGN TOKENS
       HCI: Single source of truth - consistency across all UI
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    :root {
        --cf-red: #E50914;
        --cf-red-dim: rgba(229,9,20,.18);
        --cf-red-glow: rgba(229,9,20,.45);
        --cf-dark: #0A0A0A;
        --cf-dark-2: #141414;
        --cf-dark-3: #1C1C1C;
        --cf-dark-4: #252525;
        --cf-border: rgba(255,255,255,.09);
        --cf-border-h: rgba(255,255,255,.22);
        --cf-gold: #F5C518;
        --cf-text-hi: #FFFFFF;
        --cf-text-md: #D4D4D4;
        --cf-text-lo: #888;
        /* Spacing 4pt grid */
        --sp-1: 4px;
        --sp-2: 8px;
        --sp-3: 12px;
        --sp-4: 16px;
        --sp-5: 20px;
        --sp-6: 24px;
        --sp-8: 32px;
        --sp-10: 40px;
        /* Radii */
        --r-xs: 4px;
        --r-sm: 8px;
        --r-md: 12px;
        --r-lg: 16px;
        --r-xl: 20px;
        /* Shadows */
        --sh-card: 0 4px 16px rgba(0,0,0,.5);
        --sh-hover: 0 12px 36px rgba(0,0,0,.75), 0 0 24px var(--cf-red-dim);
        --sh-glow: 0 0 32px var(--cf-red-glow);
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       RESET & BASE
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    *, *::before, *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }

    html {
        scroll-behavior: smooth;
    }

    body {
        background: var(--cf-dark);
        color: var(--cf-text-hi);
        font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
        -webkit-font-smoothing: antialiased;
    }

    img {
        display: block;
        max-width: 100%;
    }

    a {
        color: inherit;
        text-decoration: none;
    }

    button {
        cursor: pointer;
        font-family: inherit;
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       UTILITY
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .container {
        max-width: 1440px;
        margin: 0 auto;
        padding: 0 var(--sp-8);
    }
    @media (max-width: 768px) {
        .container

    {
        padding: 0 var(--sp-4);
    }

    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       BADGES
       HCI: Consistent visual language for status labels
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .badge-vip-card {
        position: absolute;
        top: var(--sp-2);
        right: var(--sp-2);
        background: linear-gradient(135deg, #FFD700, #FF8C00);
        color: #000;
        font-size: .68rem;
        font-weight: 900;
        padding: 3px 8px;
        border-radius: var(--r-xs);
        z-index: 10;
        letter-spacing: .4px;
        box-shadow: 0 2px 8px rgba(255,200,0,.4);
        pointer-events: none;
    }

    .badge-type-card {
        position: absolute;
        top: var(--sp-2);
        left: var(--sp-2);
        background: var(--cf-red);
        color: #fff;
        font-size: .68rem;
        font-weight: 700;
        padding: 3px 8px;
        border-radius: var(--r-xs);
        z-index: 10;
        letter-spacing: .3px;
        pointer-events: none;
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       SECTION HEADERS
       HCI: Clear hierarchy - accent line = primary identifier
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .sec-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: var(--sp-5);
        padding-bottom: var(--sp-4);
        border-bottom: 1px solid var(--cf-border);
        position: relative;
    }

        .sec-head::after {
            content: '';
            position: absolute;
            bottom: -1px;
            left: 0;
            width: 48px;
            height: 3px;
            background: var(--cf-red);
            border-radius: 3px;
        }

    .sec-head-left {
        display: flex;
        align-items: center;
        gap: var(--sp-3);
    }

        .sec-head-left i {
            font-size: 1.25rem;
            color: var(--cf-red);
            width: 32px;
            text-align: center;
        }

        .sec-head-left h2 {
            font-size: 1.35rem;
            font-weight: 800;
            letter-spacing: -.3px;
            color: var(--cf-text-hi);
        }

    .sec-head-right a {
        font-size: .82rem;
        font-weight: 600;
        color: var(--cf-text-lo);
        padding: 6px 12px;
        border-radius: var(--r-sm);
        border: 1px solid var(--cf-border);
        transition: color .15s, border-color .15s;
        display: inline-flex;
        align-items: center;
        gap: 5px;
    }

        .sec-head-right a:hover {
            color: var(--cf-text-hi);
            border-color: var(--cf-border-h);
        }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       â–ˆâ–ˆ HERO SLIDER
       HCI FIX: áº¢nh nÃ©t tuyá»‡t Ä‘á»‘i
       Root causes of blur fixed:
         1. Removed will-change:transform on idle state
         2. Removed translateX (subpixel offset = guaranteed blur)
         3. Removed backface-visibility hack (triggers GPU raster at wrong DPI)
         4. Ken-burns: ONLY scale, no translate - keeps image pixel-perfect
         5. image-rendering: high-quality applied
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .hero-wrap {
        position: relative;
        margin-bottom: var(--sp-10);
    }

    .hero-container {
        position: relative;
        width: 100%;
        height: clamp(620px, calc(100dvh - 72px), 860px);
        min-height: 620px;
        overflow: hidden;
        background: var(--cf-dark);
    }

    /* â”€â”€ Slide â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
    .hero-slide {
        position: absolute;
        inset: 0;
        display: flex;
        align-items: center;
        opacity: 0;
        visibility: hidden;
        transition: opacity .9s cubic-bezier(.4,0,.2,1), visibility .9s;
        z-index: 1;
    }

        .hero-slide.active {
            opacity: 1;
            visibility: visible;
            z-index: 2;
        }

    /* â”€â”€ Background image â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
    .hero-bg-wrap {
        position: absolute;
        inset: 0;
        z-index: 1;
        overflow: hidden;
    }

    /*
     * SHARP HERO IMAGE - Technical explanation:
     * - object-fit: cover + object-position: center 18% preserves faces
     * - transform: scale(1) as baseline â†’ NO compositing layer created yet
     * - active state: only scale(1.04), ZERO translate â†’ no subpixel offset
     * - NO will-change on idle â†’ prevents premature rasterization
     * - NO backface-visibility â†’ avoids DPI downscale on some browsers
     * - image-rendering: -webkit-optimize-contrast = sharpest on WebKit
     * - transition only on transform, 10s easing = smooth, barely perceptible
     */
    .hero-bg-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
        display: block;
        /* NO filter â€” filter forces a GPU compositing layer which
           rasterizes at wrong resolution and causes blur */
        image-rendering: auto;
        /* Static transform â€” no animation, no subpixel offset, no blur */
        transform: none;
        transform-origin: center center;
    }

    /* No Ken Burns on the hero â€” pure sharpness */
    .hero-slide.active .hero-bg-img {
        transform: none;
    }

    /* Gradient overlays - lighter on the right to show full image */
    .hero-bg-overlay {
        position: absolute;
        inset: 0;
        pointer-events: none;
        background:
            /* left side dark for text readability */
            linear-gradient(95deg,
                rgba(10,10,10,.90) 0%,
                rgba(10,10,10,.60) 28%,
                rgba(10,10,10,.18) 55%,
                rgba(10,10,10,.00) 80%
            ),
            /* bottom vignette */
            linear-gradient(0deg,
                rgba(10,10,10,.65) 0%,
                rgba(10,10,10,.08) 22%,
                transparent 50%
            );
    }

    /* â”€â”€ Hero content â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
    .hero-body {
        position: relative;
        z-index: 5;
        width: 100%;
        max-width: 1440px;
        margin: 0 auto;
        padding: 0 var(--sp-8);
    }

    .hero-text {
        max-width: 600px;
    }

        /* Stagger reveal - HCI: progressive disclosure */
        .hero-text > * {
            opacity: 0;
            transform: translateY(22px);
            transition: opacity .65s cubic-bezier(.22,.61,.36,1), transform .65s cubic-bezier(.22,.61,.36,1);
        }

    .hero-slide.active .hero-eyebrow {
        transition-delay: .15s;
        opacity: 1;
        transform: translateY(0);
    }

    .hero-slide.active .hero-title {
        transition-delay: .28s;
        opacity: 1;
        transform: translateY(0);
    }

    .hero-slide.active .hero-badges {
        transition-delay: .40s;
        opacity: 1;
        transform: translateY(0);
    }

    .hero-slide.active .hero-desc {
        transition-delay: .52s;
        opacity: 1;
        transform: translateY(0);
    }

    .hero-slide.active .hero-actions {
        transition-delay: .64s;
        opacity: 1;
        transform: translateY(0);
    }

    .hero-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        background: rgba(229,9,20,.18);
        border: 1px solid rgba(229,9,20,.35);
        border-radius: 100px;
        padding: 5px 14px;
        margin-bottom: var(--sp-4);
        font-size: .73rem;
        font-weight: 700;
        letter-spacing: .6px;
        text-transform: uppercase;
        color: #FF6B6B;
    }

        .hero-eyebrow .dot {
            width: 6px;
            height: 6px;
            background: #FF6B6B;
            border-radius: 50%;
            animation: cf-blink 1.4s ease infinite;
        }
    @keyframes cf-blink {
        0%,100%

    {
        opacity: 1
    }

    50% {
        opacity: .2
    }

    }

    .hero-title {
        font-size: clamp(2rem,4.8vw,3.8rem);
        font-weight: 900;
        line-height: 1.08;
        letter-spacing: -1.5px;
        margin-bottom: var(--sp-4);
        text-shadow: 0 2px 20px rgba(0,0,0,.7);
    }

    .hero-badges {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--sp-2);
        margin-bottom: var(--sp-5);
    }

    .hbadge {
        border: 1.5px solid rgba(255,255,255,.4);
        padding: 4px 11px;
        border-radius: var(--r-xs);
        font-size: .74rem;
        font-weight: 700;
        letter-spacing: .5px;
        text-transform: uppercase;
        background: rgba(0,0,0,.3);
        backdrop-filter: blur(8px);
    }

    .hbadge-vip {
        border-color: var(--cf-gold);
        color: var(--cf-gold);
    }

    .hero-desc {
        font-size: .97rem;
        color: var(--cf-text-md);
        line-height: 1.8;
        margin-bottom: var(--sp-8);
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-shadow: 0 1px 6px rgba(0,0,0,.9);
    }

    /* Hero action buttons - HCI: min 48px touch target */
    .hero-actions {
        display: flex;
        align-items: center;
        gap: var(--sp-4);
        flex-wrap: wrap;
    }

    @keyframes cf-pulse {
        0%

    {
        box-shadow: 0 0 0 0 var(--cf-red-glow);
    }

    70% {
        box-shadow: 0 0 0 18px rgba(229,9,20,0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(229,9,20,0);
    }

    }

    .btn-hero-play {
        display: flex;
        align-items: center;
        gap: var(--sp-3);
        height: 52px;
        padding: 0 var(--sp-8);
        background: var(--cf-red);
        color: #fff;
        border: none;
        border-radius: 100px;
        font-size: 1rem;
        font-weight: 800;
        letter-spacing: -.2px;
        animation: cf-pulse 2.5s ease infinite;
        transition: transform .2s, background .2s, animation .2s;
    }

        .btn-hero-play:hover {
            transform: scale(1.05);
            background: #f40612;
            animation: none;
            box-shadow: var(--sh-glow);
            color: #fff;
        }

        .btn-hero-play:focus-visible {
            outline: 3px solid var(--cf-red);
            outline-offset: 3px;
        }

    .btn-hero-info {
        display: flex;
        align-items: center;
        gap: var(--sp-2);
        height: 52px;
        padding: 0 var(--sp-6);
        background: rgba(255,255,255,.12);
        border: 1.5px solid rgba(255,255,255,.3);
        backdrop-filter: blur(8px);
        color: #fff;
        border-radius: 100px;
        font-size: .9rem;
        font-weight: 700;
        transition: background .2s, border-color .2s, transform .2s;
    }

        .btn-hero-info:hover {
            background: rgba(255,255,255,.22);
            border-color: rgba(255,255,255,.65);
            transform: scale(1.03);
            color: #fff;
        }

        .btn-hero-info:focus-visible {
            outline: 3px solid rgba(255,255,255,.6);
            outline-offset: 3px;
        }

    /* â”€â”€ Thumbnail strip â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
    .hero-thumbs {
        position: absolute;
        bottom: var(--sp-6);
        right: var(--sp-8);
        display: flex;
        gap: var(--sp-2);
        z-index: 20;
        padding: var(--sp-2) var(--sp-3);
        background: rgba(0,0,0,.6);
        backdrop-filter: blur(16px);
        border-radius: var(--r-md);
        border: 1px solid var(--cf-border);
        max-width: 340px;
        overflow-x: auto;
        scrollbar-width: none;
        align-items: center;
    }

        .hero-thumbs::-webkit-scrollbar {
            display: none;
        }

    .thumb-item {
        flex: 0 0 auto;
        width: 48px;
        height: 72px;
        border-radius: var(--r-xs);
        overflow: hidden;
        cursor: pointer;
        border: 2px solid transparent;
        background: none;
        padding: 0;
        opacity: .45;
        transition: opacity .25s, transform .25s, border-color .25s;
        position: relative;
    }

        .thumb-item:hover {
            opacity: .85;
            transform: translateY(-3px);
        }

        .thumb-item.active {
            border-color: #fff;
            opacity: 1;
            transform: scale(1.1);
            box-shadow: 0 4px 16px rgba(0,0,0,.7);
        }

        .thumb-item:focus-visible {
            outline: 2px solid var(--cf-red);
            outline-offset: 2px;
        }

        /* Thumb images: sharp, no GPU blur */
        .thumb-item img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center top;
            display: block;
            transform: none; /* no GPU layer on thumbnails */
            image-rendering: -webkit-optimize-contrast;
        }

    .thumb-num {
        position: absolute;
        bottom: 2px;
        right: 2px;
        width: 15px;
        height: 15px;
        border-radius: 50%;
        background: var(--cf-red);
        color: #fff;
        font-size: .58rem;
        font-weight: 800;
        display: flex;
        align-items: center;
        justify-content: center;
        pointer-events: none;
    }

    /* â”€â”€ Progress dots â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
    .hero-dots {
        position: absolute;
        bottom: 14px;
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        gap: 6px;
        z-index: 20;
    }

    .cf-dot {
        width: 6px;
        height: 6px;
        border-radius: 100px;
        background: rgba(255,255,255,.3);
        border: none;
        padding: 0;
        cursor: pointer;
        transition: background .25s, width .25s;
        min-width: 6px;
    }

        .cf-dot.active {
            background: #fff;
            width: 22px;
        }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       MOVIE ROW (horizontal scroller)
       HCI: Peek next card â†’ affordance for scrolling
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .row-section {
        margin-bottom: var(--sp-10);
    }

    .row-wrap {
        position: relative;
    }

    .movies-row {
        display: flex;
        overflow-x: auto;
        overflow-y: visible;
        padding: var(--sp-4) var(--sp-2);
        gap: var(--sp-3);
        scrollbar-width: none;
        scroll-behavior: smooth;
        /* Show 'peek' of next card = affordance */
        padding-right: var(--sp-10);
    }

        .movies-row::-webkit-scrollbar {
            display: none;
        }

    /* Scroll arrows - appear on hover of parent */
    .scroll-btn {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 44px;
        height: 44px;
        border-radius: 50%;
        background: rgba(20,20,20,.85);
        border: 1px solid var(--cf-border);
        color: #fff;
        font-size: 1rem;
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 10;
        opacity: 0;
        backdrop-filter: blur(6px);
        transition: opacity .2s, background .2s, transform .2s, border-color .2s;
    }

    .scroll-btn-l {
        left: -14px;
    }

    .scroll-btn-r {
        right: -14px;
    }

    .row-wrap:hover .scroll-btn {
        opacity: 1;
    }

    .scroll-btn:hover {
        background: var(--cf-red);
        border-color: var(--cf-red);
        transform: translateY(-50%) scale(1.1);
    }

    .scroll-btn:focus-visible {
        opacity: 1;
        outline: 2px solid var(--cf-red);
        outline-offset: 2px;
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       MOVIE CARD
       HCI: Lift + subtle red glow on hover = delight without distraction
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .movie-card {
        flex: 0 0 auto;
        width: 200px;
        position: relative;
        border-radius: var(--r-sm);
        transition: transform .35s cubic-bezier(.25,.46,.45,.94);
        cursor: pointer;
    }

        .movie-card:hover {
            transform: translateY(-10px);
            z-index: 20;
        }

    .movie-poster {
        position: relative;
        aspect-ratio: 2/3;
        overflow: hidden;
        background: var(--cf-dark-3);
        border-radius: var(--r-sm);
        box-shadow: var(--sh-card);
        transition: box-shadow .35s;
        isolation: isolate;
    }

    .movie-card:hover .movie-poster {
        box-shadow: var(--sh-hover);
    }

    .movie-poster img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
        display: block;
        filter: contrast(1.04) saturate(1.04) brightness(1.02);
        image-rendering: auto;
        transition: transform .45s cubic-bezier(.25,.46,.45,.94), filter .35s ease;
    }

    .movie-card:hover .movie-poster img {
        transform: scale(1.025);
        filter: contrast(1.08) saturate(1.08) brightness(1.03);
    }

    /* Overlay with play button */
    .movie-overlay {
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.96) 100%);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        align-items: center;
        padding-bottom: var(--sp-4);
        opacity: 0;
        transition: opacity .25s;
    }

    .movie-card:hover .movie-overlay {
        opacity: 1;
    }

    .play-circle {
        width: 52px;
        height: 52px;
        border-radius: 50%;
        background: rgba(229,9,20,.9);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 1.5rem;
        color: #fff;
        border: 2px solid #fff;
        padding-left: 3px;
        transform: scale(.8);
        transition: transform .25s cubic-bezier(.25,.46,.45,.94), box-shadow .25s;
        position: absolute;
        top: 50%;
        left: 50%;
        margin: -26px 0 0 -26px;
    }

    .movie-card:hover .play-circle {
        transform: scale(1);
        box-shadow: 0 6px 24px rgba(229,9,20,.55);
    }

    /* View count badge */
    .view-tag {
        position: absolute;
        top: var(--sp-2);
        left: var(--sp-2);
        background: rgba(0,0,0,.72);
        border: 1px solid var(--cf-border);
        backdrop-filter: blur(4px);
        padding: 3px 8px;
        border-radius: var(--r-xs);
        font-size: .7rem;
        font-weight: 600;
        z-index: 3;
        display: flex;
        align-items: center;
        gap: 5px;
        color: #fff;
    }

        .view-tag i {
            color: var(--cf-red);
            font-size: .65rem;
        }

    /* Card info below poster */
    .movie-info {
        padding: var(--sp-3) var(--sp-1) var(--sp-2);
    }

    .movie-title {
        font-size: .9rem;
        font-weight: 700;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        margin-bottom: var(--sp-1);
        transition: color .2s;
    }

    .movie-card:hover .movie-title {
        color: var(--cf-red);
    }

    .movie-title a {
        color: inherit;
    }

    .movie-meta {
        display: flex;
        align-items: center;
        gap: var(--sp-3);
        font-size: .78rem;
        color: var(--cf-text-lo);
    }

        .movie-meta i {
            color: var(--cf-red);
            font-size: .7rem;
        }

    /* Continue watching progress bar */
    .progress-bar-wrap {
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 3px;
        background: rgba(255,255,255,.2);
        z-index: 5;
    }

    .progress-bar-fill {
        height: 100%;
        background: var(--cf-red);
    }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       FILTER SECTION
       HCI: Progressive disclosure - collapsed by default,
            auto-submit on select change, clear result count feedback
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .filter-toggle-btn {
        display: inline-flex;
        align-items: center;
        gap: var(--sp-2);
        height: 40px;
        padding: 0 var(--sp-4);
        background: var(--cf-dark-3);
        border: 1px solid var(--cf-border);
        border-radius: var(--r-sm);
        color: var(--cf-text-md);
        font-size: .88rem;
        font-weight: 600;
        transition: background .15s, border-color .15s, color .15s;
    }

        .filter-toggle-btn:hover,
        .filter-toggle-btn.active {
            background: var(--cf-red-dim);
            border-color: var(--cf-red);
            color: #fff;
        }

        .filter-toggle-btn:focus-visible {
            outline: 2px solid var(--cf-red);
            outline-offset: 2px;
        }

    .filter-panel {
        background: var(--cf-dark-2);
        border: 1px solid var(--cf-border);
        border-radius: var(--r-lg);
        padding: var(--sp-6);
        margin-bottom: var(--sp-6);
    }

    .filter-row {
        display: flex;
        flex-wrap: wrap;
        gap: var(--sp-4);
        align-items: flex-end;
    }

    .filter-group {
        display: flex;
        flex-direction: column;
        gap: var(--sp-1);
        flex: 1;
        min-width: 140px;
    }

        .filter-group label {
            font-size: .73rem;
            font-weight: 700;
            letter-spacing: .6px;
            text-transform: uppercase;
            color: var(--cf-text-lo);
        }

    .filter-select {
        height: 40px;
        padding: 0 var(--sp-4);
        background: var(--cf-dark-3);
        border: 1px solid var(--cf-border);
        color: var(--cf-text-hi);
        border-radius: var(--r-sm);
        font-size: .88rem;
        cursor: pointer;
        transition: border-color .15s;
        appearance: none;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 12px center;
        padding-right: 32px;
    }

        .filter-select:focus {
            outline: none;
            border-color: var(--cf-red);
        }

        .filter-select option {
            background: var(--cf-dark-3);
        }

    .search-wrap {
        display: flex;
        align-items: center;
        background: var(--cf-dark-3);
        border: 1px solid var(--cf-border);
        border-radius: var(--r-sm);
        overflow: hidden;
        transition: border-color .15s;
        height: 40px;
    }

        .search-wrap:focus-within {
            border-color: var(--cf-red);
        }

        .search-wrap input {
            flex: 1;
            background: transparent;
            border: none;
            color: var(--cf-text-hi);
            font-size: .88rem;
            padding: 0 var(--sp-4);
            outline: none;
            height: 100%;
        }

            .search-wrap input::placeholder {
                color: var(--cf-text-lo);
            }

        .search-wrap button {
            height: 100%;
            padding: 0 var(--sp-4);
            background: var(--cf-red);
            border: none;
            color: #fff;
            font-size: .82rem;
            transition: background .15s;
        }

            .search-wrap button:hover {
                background: #f40612;
            }

    .btn-reset-filter {
        height: 40px;
        padding: 0 var(--sp-4);
        background: transparent;
        color: var(--cf-text-lo);
        border: 1px solid var(--cf-border);
        border-radius: var(--r-sm);
        font-size: .85rem;
        display: inline-flex;
        align-items: center;
        gap: 6px;
        transition: color .15s, border-color .15s;
        text-decoration: none;
    }

        .btn-reset-filter:hover {
            color: var(--cf-red);
            border-color: var(--cf-red);
        }

    .filter-count {
        margin-top: var(--sp-4);
        font-size: .85rem;
        color: var(--cf-text-lo);
    }

        .filter-count strong {
            color: var(--cf-red);
        }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       GRID (all movies)
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .movies-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
        gap: var(--sp-4);
        margin-bottom: var(--sp-8);
    }

    .grid-card {
        position: relative;
        border-radius: var(--r-sm);
        cursor: pointer;
        transition: transform .3s cubic-bezier(.25,.46,.45,.94);
    }

        .grid-card:hover {
            transform: translateY(-8px);
            z-index: 10;
        }

    .grid-poster {
        position: relative;
        aspect-ratio: 2/3;
        overflow: hidden;
        background: var(--cf-dark-3);
        border-radius: var(--r-sm);
        box-shadow: var(--sh-card);
        transition: box-shadow .3s;
        isolation: isolate;
    }

    .grid-card:hover .grid-poster {
        box-shadow: var(--sh-hover);
    }

    .grid-poster img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
        display: block;
        filter: contrast(1.04) saturate(1.04) brightness(1.02);
        image-rendering: auto;
        transition: transform .45s cubic-bezier(.25,.46,.45,.94), filter .35s ease;
    }

    .grid-card:hover .grid-poster img {
        transform: scale(1.025);
        filter: contrast(1.08) saturate(1.08) brightness(1.03);
    }

    .grid-overlay {
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.95) 100%);
        opacity: 0;
        transition: opacity .25s;
        display: flex;
        align-items: flex-end;
        padding: var(--sp-3);
    }

    .grid-card:hover .grid-overlay {
        opacity: 1;
    }

    .btn-play-card {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        width: 100%;
        height: 38px;
        background: var(--cf-red);
        color: #fff;
        border-radius: var(--r-sm);
        font-size: .82rem;
        font-weight: 700;
        transition: background .15s;
        text-decoration: none;
    }

        .btn-play-card:hover {
            background: #f40612;
            color: #fff;
        }

    .grid-info {
        padding: var(--sp-3) var(--sp-1) var(--sp-2);
    }

    .grid-title {
        font-size: .88rem;
        font-weight: 700;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        margin-bottom: 3px;
        transition: color .2s;
    }

    .grid-card:hover .grid-title {
        color: var(--cf-red);
    }

    .grid-title a {
        color: inherit;
    }

    .grid-meta {
        font-size: .75rem;
        color: var(--cf-text-lo);
        display: flex;
        gap: var(--sp-2);
        align-items: center;
    }

        .grid-meta i {
            color: var(--cf-red);
            font-size: .68rem;
        }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       PAGINATION
       HCI: Clear active state, adequate touch targets
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    .pagination {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: var(--sp-2);
        margin: var(--sp-8) 0;
        flex-wrap: wrap;
    }

    .page-btn {
        min-width: 40px;
        height: 40px;
        padding: 0 var(--sp-3);
        border-radius: var(--r-sm);
        background: var(--cf-dark-3);
        border: 1px solid var(--cf-border);
        color: var(--cf-text-md);
        font-size: .88rem;
        font-weight: 600;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        transition: background .15s, border-color .15s, color .15s;
    }

        .page-btn:hover {
            background: var(--cf-dark-4);
            border-color: var(--cf-border-h);
            color: #fff;
        }

        .page-btn.active {
            background: var(--cf-red);
            border-color: var(--cf-red);
            color: #fff;
        }

        .page-btn.disabled {
            opacity: .3;
            pointer-events: none;
        }

        .page-btn:focus-visible {
            outline: 2px solid var(--cf-red);
            outline-offset: 2px;
        }

    /* Empty state */
    .empty-state {
        background: var(--cf-dark-2);
        border: 1px solid var(--cf-border);
        border-radius: var(--r-lg);
        padding: var(--sp-10) var(--sp-8);
        text-align: center;
        margin: var(--sp-6) 0;
    }

        .empty-state i {
            font-size: 2.5rem;
            color: var(--cf-red);
            margin-bottom: var(--sp-4);
            display: block;
        }

        .empty-state h3 {
            font-size: 1.1rem;
            font-weight: 700;
            margin-bottom: var(--sp-2);
        }

        .empty-state p {
            font-size: .9rem;
            color: var(--cf-text-lo);
        }

        .empty-state a {
            color: var(--cf-red);
        }

    /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
       RESPONSIVE
    â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
    @media (max-width: 992px) {
        .hero-container {
            height: 72vh;
            min-height: 560px;
        }

        .hero-title {
            font-size: 2.4rem;
        }

        .hero-thumbs {
            max-width: 260px;
            right: var(--sp-4);
        }
    }

    @media (max-width: 768px) {
        .hero-container {
            height: 100svh;
            min-height: 540px;
        }

        .hero-title {
            font-size: 1.9rem;
            letter-spacing: -.5px;
        }

        .hero-body {
            padding: 0 var(--sp-4);
        }

        .hero-text {
            max-width: 100%;
        }

        .hero-bg-img {
            object-position: center top;
        }

        .hero-desc {
            -webkit-line-clamp: 2;
            font-size: .9rem;
        }

        .btn-hero-play {
            height: 46px;
            font-size: .9rem;
        }

        .btn-hero-info {
            height: 46px;
            font-size: .85rem;
        }

        .hero-thumbs {
            bottom: 52px;
            right: var(--sp-3);
            max-width: 220px;
        }

        .thumb-item {
            width: 38px;
            height: 58px;
        }

        .movies-grid {
            grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
        }

        .movie-card {
            width: 155px;
        }
    }
