:root{
    --pv-bg: #0b0f17;
    --pv-card: rgba(255,255,255,.06);
    --pv-border: rgba(255,255,255,.10);
    --pv-text: rgba(255,255,255,.92);
    --pv-muted: rgba(255,255,255,.70);
    --pv-accent: #ff2d95;
}
body{
    font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    background: radial-gradient(1200px 600px at 10% 0%, rgba(255,45,149,.18), transparent 50%),
    radial-gradient(1000px 500px at 90% 10%, rgba(59,130,246,.14), transparent 45%),
    var(--pv-bg);
    color: var(--pv-text);
}
.navbar{
    backdrop-filter: blur(12px);
    background: rgba(11,15,23,.65);
    border-bottom: 1px solid var(--pv-border);
}
.brand-logo{ height: 34px; width:auto; }
.hero{ border-bottom: 1px solid var(--pv-border); }
.hero-slide{
    min-height: 520px;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
}
.hero-slide::before{
    content:"";
    position:absolute; inset:0;
    background:
            linear-gradient(90deg, rgba(11,15,23,.95) 0%, rgba(11,15,23,.70) 35%, rgba(11,15,23,.25) 70%, rgba(11,15,23,.15) 100%),
            radial-gradient(800px 500px at 30% 20%, rgba(255,45,149,.22), transparent 55%);
}
.hero-content{ position:relative; z-index:1; }
.btn-accent{
    background: var(--pv-accent);
    border-color: var(--pv-accent);
    color: #fff;
    font-weight: 700;
}
.btn-accent:hover{ filter: brightness(.95); }
.section-title{
    font-family: "Montserrat", sans-serif;
    font-weight: 800;
    letter-spacing: .2px;
}
.card-glass{
    background: var(--pv-card);
    border: 1px solid var(--pv-border);
    border-radius: 16px;
    overflow: hidden;
}
.poster{
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
    display:block;
    background: rgba(255,255,255,.04);
}
.badge-soft{
    background: rgba(255,45,149,.16);
    border: 1px solid rgba(255,45,149,.40);
    color: #fff;
}
.badge-rental{
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.20);
    color: #fff;
}
.badge-expire{
    background: rgba(220,53,69,.18);
    border: 1px solid rgba(220,53,69,.45);
    color: #fff;
}
.muted{ color: var(--pv-muted); }
/* Horizontal scroller (index rows) */
.grid-scroller{
    display: grid;
    grid-auto-flow: column;

    /* IMPORTANT: match the card width so items never overflow/overlap */
    grid-auto-columns: clamp(240px, 22vw, 300px);

    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
}

.grid-scroller > *{
    width: auto !important; /* prevents inline widths from forcing overflow */
}

/* Poster card (title over thumb + corner pill) */
.pv-cardposter{
    position: relative;
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 18px 55px rgba(0,0,0,.35);
    scroll-snap-align: start;
    transform: translateZ(0);
}

.pv-cardposter:hover{
    border-color: rgba(255,45,149,.35);
}

.pv-cardlink{
    display:block;
    color: inherit;
    text-decoration: none;
}

.pv-cardimg{
    width:100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display:block;
}

.pv-cardfade{
    position:absolute;
    left:0; right:0; bottom:0;
    height:60%;
    background: linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,0));
    pointer-events:none;
}

.pv-cardtitle{
    position:absolute;
    left:12px; right:12px; bottom:12px;
    color:#fff;
    font-weight:800;
    line-height:1.15;
    letter-spacing: .2px;
    text-shadow: 0 10px 30px rgba(0,0,0,.55);

    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow:hidden;
}

.pv-cardpill{
    position:absolute;
    top:10px; left:10px;
    padding: .35rem .6rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .2px;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(0,0,0,.35);
    color: rgba(255,255,255,.92);
}

.pv-cardpill.sub{
    border-color: rgba(255,45,149,.45);
    background: rgba(255,45,149,.14);
}

.pv-cardpill.rental{
    border-color: rgba(255,255,255,.18);
    background: rgba(255,255,255,.10);
}


/* Top bar glass */
.pv-topbar{
    background: rgba(11,15,23,.55) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 14px 40px rgba(0,0,0,.35);
    position: sticky;
}

.pv-topbar::before{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    /* subtle pink/blue sheen */
    background:
            radial-gradient(900px 220px at 20% 0%, rgba(255,45,149,.18), transparent 55%),
            radial-gradient(700px 200px at 90% 0%, rgba(59,130,246,.12), transparent 55%);
    opacity: .9;
}

/* Make navbar content render above the ::before sheen */
.pv-topbar .container{ position: relative; z-index: 1; }

/* Right side group */
.pv-right{
    display:flex;
    align-items:center;
    gap: .55rem; /* tighter than default */
}

/* Search: true “single pill” with perfect button spacing */
.pv-search{ width: 340px; max-width: 42vw; }
@media (max-width: 991.98px){
    .pv-search{ width: 100%; max-width: 100%; margin-top:.6rem; }
    .pv-right{ width: 100%; gap: .5rem; }
}

.pv-search .pv-pill{
    display:flex;
    align-items:center;
    width:100%;
    border-radius: 999px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    overflow:hidden;
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.pv-search .pv-pill:focus-within{
    border-color: rgba(255,45,149,.55);
    box-shadow: 0 0 0 .22rem rgba(255,45,149,.18);
    background: rgba(255,255,255,.075);
}

.pv-search input{
    flex:1;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: rgba(255,255,255,.92);
    padding: .55rem .95rem;
    font-size: .95rem;
}

.pv-search input::placeholder{ color: rgba(255,255,255,.55); }

.pv-search button{
    border: 0;
    background: transparent;
    color: rgba(255,255,255,.85);
    padding: .55rem .75rem; /* no weird right gap */
    line-height: 1;
    display:flex;
    align-items:center;
    justify-content:center;
}

.pv-search button:hover{
    background: rgba(255,45,149,.12);
    color: #fff;
}

/* Optional: tiny separator line inside the pill */
.pv-search .pv-sep{
    width: 1px;
    align-self: stretch;
    background: rgba(255,255,255,.10);
}

/* Account button: match pill look + subtle pink focus */
.pv-account-btn{
    border-radius: 999px !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    background: rgba(255,255,255,.06) !important;
    color: rgba(255,255,255,.92) !important;
    padding: .52rem .9rem !important;
    font-weight: 700;
}
.pv-account-btn:hover{
    background: rgba(255,255,255,.10) !important;
}
.pv-account-btn:focus{
    box-shadow: 0 0 0 .22rem rgba(255,45,149,.18) !important;
    border-color: rgba(255,45,149,.45) !important;
}

/* Page background like index */
.pv-page{
    background: radial-gradient(1200px 420px at 20% 0%, rgba(255,45,149,.10), transparent 60%),
    radial-gradient(900px 360px at 90% 10%, rgba(59,130,246,.08), transparent 55%),
    rgba(7,10,16,1);
    min-height: 100vh;
}

.pv-shell{
    background: rgba(11,15,23,.35);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 18px;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 18px 55px rgba(0,0,0,.45);
}

/* Card grid consistent with your dark theme */
.pv-vod-card{
    border-radius: 16px;
    overflow: hidden;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    transition: transform .15s ease, border-color .15s ease, background .15s ease;
    height: 100%;
}
.pv-vod-card:hover{
    transform: translateY(-2px);
    border-color: rgba(255,45,149,.22);
    background: rgba(255,255,255,.05);
}
.pv-vod-thumb{
    position: relative;
    padding-top: 56.25%;
    background: rgba(255,255,255,.03);
}
.pv-vod-thumb img{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit: cover;
}
.pv-vod-badge{
    position:absolute;
    left:10px; bottom:10px;
    font-size: 12px;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.pv-vod-badge.sub{ background: rgba(255,45,149,.20); color:#fff; }
.pv-vod-badge.rent{ background: rgba(255,255,255,.14); color: rgba(255,255,255,.9); }

.pv-vod-body{ padding: 12px 12px 14px; }
.pv-vod-title{
    color: rgba(255,255,255,.92);
    font-weight: 800;
    font-size: 15px;
    line-height: 1.2;
    margin-bottom: 6px;
}
.pv-vod-desc{
    color: rgba(255,255,255,.62);
    font-size: 13px;
}

/* Sidebar / filters glass */
.pv-panel{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 16px;
}

/* Compact accordion look (if BS4) */
.pv-acc .card{
    background: transparent;
    border: 0;
}
.pv-acc .card-header{
    padding: 0;
    background: transparent;
    border: 0;
}
.pv-acc .btn-link{
    color: rgba(255,255,255,.9);
    text-decoration: none;
    font-weight: 700;
    padding: .45rem 0;
}
.pv-acc .btn-link:hover{ color:#fff; }

/* Load more button */
.pv-btn{
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.92);
    font-weight: 800;
}
.pv-btn:hover{
    background: rgba(255,45,149,.12);
    border-color: rgba(255,45,149,.28);
    color:#fff;
}

:root{
    --pv-pink: rgba(255,45,149,1);
    --pv-bg: rgba(11,15,23,1);
}

body{ background: #070A10; }

/* Page header glass */
.pv-pagehead{
    background: rgba(11,15,23,.55);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 18px;
    box-shadow: 0 18px 55px rgba(0,0,0,.45);
    overflow: hidden;
    position: relative;
}
.pv-pagehead::before{
    content:"";
    position:absolute; inset:0;
    background:
            radial-gradient(900px 220px at 10% 0%, rgba(255,45,149,.18), transparent 55%),
            radial-gradient(700px 200px at 90% 0%, rgba(59,130,246,.10), transparent 55%);
    pointer-events:none;
}
.pv-pagehead > *{ position: relative; z-index: 1; }

/* ===== Pagehead breadcrumb polish (match PV glass theme) ===== */
.pv-pagehead .breadcrumb{
    margin: 0;
    padding: 0;
    background: transparent;
    --bs-breadcrumb-divider: "›";
}

.pv-pagehead .breadcrumb-item + .breadcrumb-item::before{
    color: rgba(255,255,255,.25);
}

.pv-pagehead .breadcrumb a{
    color: rgba(255,255,255,.60) !important;
    text-decoration: none;
}

.pv-pagehead .breadcrumb a:hover{
    color: rgba(255,255,255,.92) !important;
    text-decoration: none;
}

.pv-pagehead .breadcrumb-item.active{
    color: rgba(255,255,255,.72);
}

/* Optional: a subtle title accent like index */
.pv-pagehead .pv-title-accent{
    display:inline-block;
    height: 3px;
    width: 52px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(255,45,149,.85), rgba(255,255,255,0));
    margin-top: .6rem;
}


/* Cards */
.pv-card{
    border-radius: 18px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 14px 45px rgba(0,0,0,.35);
    overflow: hidden;
    transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.pv-card:hover{
    transform: translateY(-2px);
    border-color: rgba(255,45,149,.22);
    background: rgba(255,255,255,.05);
}
.pv-card-thumb{ position: relative; aspect-ratio: 16/9; background: rgba(255,255,255,.03); }
.pv-card-thumb img{ width:100%; height:100%; object-fit: cover; display:block; }
.pv-badge{
    position:absolute; left:10px; bottom:10px;
    font-size: .78rem;
    padding: .25rem .55rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
}
.pv-badge-sub{ background: rgba(255,45,149,.22); color: #fff; }
.pv-badge-rent{ background: rgba(255,255,255,.14); color: rgba(255,255,255,.92); }

.pv-card-body{ padding: .75rem .85rem .9rem; }
.pv-card-title{
    color: rgba(255,255,255,.92);
    font-weight: 800;
    font-size: .98rem;
    line-height: 1.15;
    margin-bottom: .25rem;
}
.pv-card-desc{ color: rgba(255,255,255,.62); font-size: .86rem; }

/* Sidebar / filters */
.pv-panel{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 18px;
    box-shadow: 0 14px 45px rgba(0,0,0,.30);
}
.pv-panel h6{ color: rgba(255,255,255,.90); }
.pv-link{ color: rgba(255,255,255,.74); text-decoration: none; }
.pv-link:hover{ color: #fff; }
.pv-pill{
    display:inline-flex;
    align-items:center;
    gap:.4rem;
    padding: .3rem .6rem;
    border-radius: 999px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
    color: rgba(255,255,255,.82);
    font-size: .85rem;
    text-decoration:none;
}
.pv-pill.active{
    border-color: rgba(255,45,149,.45);
    background: rgba(255,45,149,.14);
    color: #fff;
}

/* Load more button */
.pv-loadmore{
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.92);
    padding: .7rem 1.1rem;
    font-weight: 800;
}
.pv-loadmore:hover{
    background: rgba(255,45,149,.12);
    border-color: rgba(255,45,149,.28);
    color:#fff;
}

/* Tiny skeleton */
.pv-skel{
    border-radius: 18px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    overflow:hidden;
}
.pv-skel .bar{
    height: 160px;
    background: linear-gradient(90deg, rgba(255,255,255,.03), rgba(255,255,255,.08), rgba(255,255,255,.03));
    background-size: 200% 100%;
    animation: pvShimmer 1.1s infinite;
}
@keyframes pvShimmer { 0%{background-position: 0% 0} 100%{background-position: 200% 0} }

/* =========================
   PV Sidebar v2 (premium)
   ========================= */

.pv-panel.pv-sidebar{
    padding: 14px 14px 10px !important;
}

.pv-sidebar .pv-section-title{
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
    margin: 6px 2px 10px;
}

.pv-sidebar .pv-subtitle{
    font-size: .95rem;
    font-weight: 700;
    color: rgba(255,255,255,.92);
    margin: 0 2px 10px;
}

/* Availability pills tighter */
.pv-sidebar .pv-pill{
    padding: .34rem .72rem;
    font-size: .86rem;
    border-radius: 999px;
}
.pv-sidebar .pv-pill + .pv-pill{ margin-left: 6px; }

/* Accordion rows: more “button-like” */
.pv-sidebar .accordion-item{ background: transparent; border: 0; }

.pv-sidebar .accordion-button{
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px !important;
    padding: .55rem .65rem;
    margin-bottom: 8px;
    color: rgba(255,255,255,.92);
    font-weight: 700;
    font-size: .93rem;
    box-shadow: none;
}
.pv-sidebar .accordion-button:hover{
    background: rgba(255,255,255,.07);
    border-color: rgba(255,255,255,.14);
}
.pv-sidebar .accordion-button:focus{
    box-shadow: 0 0 0 .2rem rgba(255,45,149,.18);
    border-color: rgba(255,45,149,.35);
}
.pv-sidebar .accordion-button::after{
    opacity: .55;
    transform: scale(.9);
}

/* Make the caret feel intentional */
.pv-sidebar .accordion-button:not(.collapsed)::after{
    opacity: .9;
}

/* Accordion body tighter */
.pv-sidebar .accordion-body{
    padding: 6px 6px 10px 6px;
    margin-top: -4px;
}

/* Sub links: compact, with active indicator */
.pv-sidebar .pv-cat-link{
    display: flex;
    align-items: center;
    gap: 8px;
    padding: .36rem .55rem;
    border-radius: 10px;
    font-size: .86rem;
    color: rgba(255,255,255,.78);
    text-decoration: none;
}
.pv-sidebar .pv-cat-link:hover{
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.92);
}

.pv-sidebar .pv-cat-link .dot{
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: rgba(255,255,255,.20);
    flex: 0 0 6px;
}

/* Active state */
.pv-sidebar .pv-cat-link.active{
    background: rgba(255,45,149,.10);
    color: #fff;
    border: 1px solid rgba(255,45,149,.25);
}
.pv-sidebar .pv-cat-link.active .dot{
    background: rgba(255,45,149,.95);
    box-shadow: 0 0 0 3px rgba(255,45,149,.18);
}

/* Divider */
.pv-sidebar .pv-divider{
    border-top: 1px solid rgba(255,255,255,.10);
    margin: 14px 2px;
}

/* Most watched list: compact + nicer */
.pv-sidebar .pv-mw{
    list-style: none;
    padding: 0;
    margin: 0;
}
.pv-sidebar .pv-mw li{
    display: grid;
    grid-template-columns: 26px 1fr;
    gap: 10px;
    padding: 10px 6px;
    border-radius: 12px;
}
.pv-sidebar .pv-mw li:hover{
    background: rgba(255,255,255,.05);
}

.pv-sidebar .pv-rank{
    width: 26px;
    height: 26px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: .82rem;
    color: rgba(255,255,255,.86);
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
}

.pv-sidebar .pv-mw a{
    color: rgba(255,255,255,.92);
    text-decoration: none;
    font-weight: 650;
    font-size: .90rem;
    line-height: 1.2;
}
.pv-sidebar .pv-mw a:hover{ color: #fff; }

.pv-sidebar .pv-mw .meta{
    margin-top: 3px;
    font-size: .75rem;
    color: rgba(255,255,255,.55);
}

/* optional: make sidebar stick a bit on desktop */
@media (min-width: 992px){
    .pv-sidebar-sticky{
        position: sticky;
        top: 92px; /* below your topbar */
    }
}

/* Category page: "Search within this category" input-group */
.pv-inputgroup{
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 999px;
    overflow: hidden;              /* makes pill edges clean */
}

.pv-inputgroup .input-group-text{
    background: transparent !important;
    border: 0 !important;
    color: rgba(255,255,255,.70);
    padding: .45rem .65rem;
}

.pv-inputgroup .form-control{
    background: transparent !important;
    border: 0 !important;
    color: rgba(255,255,255,.92);
    padding: .45rem .85rem;
    font-size: .95rem;
    box-shadow: none !important;
}

.pv-inputgroup .form-control::placeholder{
    color: rgba(255,255,255,.55);
}

.pv-inputgroup:focus-within{
    border-color: rgba(255,45,149,.45);
    box-shadow: 0 0 0 .2rem rgba(255,45,149,.15);
}

/* Fix Bootstrap input-group rounding quirks */
.pv-inputgroup .input-group-text:first-child{
    border-top-left-radius: 999px !important;
    border-bottom-left-radius: 999px !important;
}
.pv-inputgroup .form-control:last-child{
    border-top-right-radius: 999px !important;
    border-bottom-right-radius: 999px !important;
}

.pv-inputgroup{
    backdrop-filter: blur(10px);
}

/* ---------- Topbar live search results ---------- */
.pv-search { width: 100%; max-width: 340px; }
@media (max-width: 991.98px){ .pv-search{ max-width: 100%; } }

.pv-search-results{
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    z-index: 1060; /* above nav */
    background: rgba(11,15,23,.96);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 14px;
    box-shadow: 0 24px 70px rgba(0,0,0,.55);
    overflow: hidden;
    backdrop-filter: blur(12px);
}

.pv-search-results .pv-sr-scroll{
    max-height: min(56vh, 420px);
    overflow: auto;
    overscroll-behavior: contain;
}

.pv-search-results .pv-sr-scroll::-webkit-scrollbar{ width: 10px; }
.pv-search-results .pv-sr-scroll::-webkit-scrollbar-thumb{
    background: rgba(255,255,255,.16);
    border-radius: 999px;
}

.pv-search-results .sr-head{
    padding: .55rem .75rem;
    font-size: .72rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
    background: rgba(255,255,255,.03);
    border-bottom: 1px solid rgba(255,255,255,.08);
}

.pv-search-results .sr-item{
    display: flex;
    gap: .65rem;
    padding: .6rem .75rem;
    text-decoration: none;
    color: rgba(255,255,255,.90);
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.pv-search-results .sr-item:hover{
    background: rgba(255,255,255,.06);
    color: #fff;
}
.pv-search-results .sr-item:last-child{ border-bottom: 0; }

.pv-search-results .sr-thumb{
    width: 48px;
    height: 27px;
    border-radius: 8px;
    overflow: hidden;
    flex: 0 0 auto;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.10);
}
.pv-search-results .sr-thumb img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pv-search-results .sr-title{
    font-weight: 700;
    font-size: .92rem;
    line-height: 1.15;
}
.pv-search-results .sr-meta{
    margin-top: .15rem;
    font-size: .78rem;
    color: rgba(255,255,255,.62);
}

.pv-search-results .sr-pill{
    margin-left: auto;
    align-self: flex-start;
    font-size: .72rem;
    padding: .18rem .5rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.78);
}

.pv-search-results .sr-empty{
    padding: .9rem .85rem;
    color: rgba(255,255,255,.65);
}

.pv-search-results .sr-cat{
    padding: .55rem .75rem;
    text-decoration: none;
    display: block;
    color: rgba(255,255,255,.88);
}
.pv-search-results .sr-cat:hover{ background: rgba(255,255,255,.06); color: #fff; }
.pv-search-results .sr-cat small{
    display:block;
    color: rgba(255,255,255,.60);
    margin-top: .1rem;
}

/* Search results: category rows */
.sr-cat-row{
    display: flex;
    align-items: center;
    gap: .5rem;
}

.sr-cat-title{
    font-weight: 700;
    font-size: .92rem;
    color: rgba(255,255,255,.92);
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sr-cat-pill{
    font-size: .7rem;
    padding: .15rem .5rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.75);
    white-space: nowrap;
}

/* Search results footer (View more…) */
.sr-footer{
    position: sticky;
    bottom: 0;
    margin-top: .25rem;
    padding: .5rem .25rem .25rem;
    background: linear-gradient(
            to top,
            rgba(11,15,23,.96),
            rgba(11,15,23,.85) 60%,
            rgba(11,15,23,0)
    );
    backdrop-filter: blur(6px);
}

.sr-viewall{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    width: 100%;
    padding: .5rem .75rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 600;
    text-decoration: none;
    color: rgba(255,255,255,.88);
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
}

.sr-viewall:hover,
.sr-viewall:focus{
    color: #fff;
    background: rgba(255,255,255,.10);
    border-color: rgba(255,255,255,.20);
    text-decoration: none;
}

.sr-viewall .q{
    font-weight: 700;
    color: #fff;
}

.sr-viewall i{
    font-size: .9rem;
    opacity: .8;
}

.sr-viewall{
    animation: srPulse 2.8s ease-in-out infinite;
}

@keyframes srPulse{
    0%,100%{ box-shadow: 0 0 0 0 rgba(255,45,149,.0); }
    50%{ box-shadow: 0 0 0 6px rgba(255,45,149,.10); }
}

/* ---- Section row container (adds presence) ---- */
.pv-row{
    position: relative;
    border-radius: 22px;
    padding: 18px 18px 14px;
    margin-bottom: 18px;
    background:
            radial-gradient(1200px 300px at 12% 0%, rgba(255,45,149,.10), rgba(0,0,0,0) 55%),
            radial-gradient(900px 260px at 88% 20%, rgba(120,72,255,.08), rgba(0,0,0,0) 55%),
            rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 22px 70px rgba(0,0,0,.35);
}

/* optional: little “grain” vibe */
.pv-row::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    opacity:.06;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
    border-radius: 22px;
}

/* ---- Row header “bar” ---- */
.pv-rowhead{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.pv-rowtitle{
    position: relative;
    margin:0;
    font-size: 1.65rem;
    font-weight: 900;
    letter-spacing: .2px;
    color: rgba(255,255,255,.95);
    line-height: 1.05;
    padding-left: 14px;
}

/* pink accent rail */
.pv-rowtitle::before{
    content:"";
    position:absolute;
    left:0;
    top:.18em;
    bottom:.18em;
    width: 4px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255,45,149,1), rgba(255,45,149,.25));
    box-shadow: 0 0 0 6px rgba(255,45,149,.10);
}

/* tiny subline (optional) */
.pv-rowsub{
    color: rgba(255,255,255,.55);
    font-size: .92rem;
    margin-top: 6px;
    padding-left: 14px;
}

/* view-all link styled */
.pv-rowlink{
    color: rgba(255,255,255,.70);
    text-decoration: none;
    font-weight: 700;
    font-size: .95rem;
    padding: .35rem .6rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.04);
}
.pv-rowlink:hover{
    color:#fff;
    border-color: rgba(255,45,149,.35);
    background: rgba(255,45,149,.10);
}

/* tighten scroller inside the panel */
.pv-row .grid-scroller{ margin-bottom: 0 !important; }

/* responsive: less padding on mobile */
@media (max-width: 576px){
    .pv-row{ padding: 14px 14px 12px; border-radius: 18px; }
    .pv-rowtitle{ font-size: 1.35rem; }
}

/* WATCH: player + lock poster */
.pv-playerwrap{
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
}

.pv-iframe{
    width: 100%;
    aspect-ratio: 16 / 9;
    border: 0;
    display: block;
    background: #000;
}

.pv-lockposter{
    width: 100%;
    aspect-ratio: 16 / 9;
    background-size: cover;
    background-position: center;
    position: relative;
}

.pv-lockoverlay{
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75), rgba(0,0,0,.25));
    display: flex;
    align-items: flex-end;
    padding: 16px;
}

.pv-lockcard{
    width: 100%;
    max-width: 520px;
    border-radius: 16px;
    padding: 14px 14px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(11,15,23,.70);
    backdrop-filter: blur(10px);
}

.pv-locktitle{
    color: #fff;
    font-weight: 800;
    font-size: 1.05rem;
}

.pv-lockmeta{
    color: rgba(255,255,255,.70);
    font-size: .95rem;
    margin-top: 4px;
}

/* Right-rail mini pill */
.pv-mini-pill{
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: .78rem;
    font-weight: 800;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
}
.pv-mini-pill.sub{
    border-color: rgba(255,45,149,.35);
    background: rgba(255,45,149,.12);
}
.pv-mini-pill.rental{
    border-color: rgba(255,255,255,.16);
    background: rgba(255,255,255,.08);
}

/* Breadcrumb */
.pv-breadcrumb {
    margin: 10px 0 14px;
}

.pv-breadcrumb-list{
    display: flex;
    align-items: center;
    gap: 10px;
    list-style: none;
    padding: 0;
    margin: 0;
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
}
.pv-breadcrumb-list::-webkit-scrollbar{ display:none; }

.pv-breadcrumb-list li{
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: rgba(255,255,255,.45);
    font-size: .95rem;
}

.pv-breadcrumb-list li:not(:last-child)::after{
    content: "/";
    color: rgba(255,255,255,.25);
}

.pv-breadcrumb-list a{
    color: rgba(255,255,255,.60);
    text-decoration: none;
    transition: color .15s ease, opacity .15s ease;
}
.pv-breadcrumb-list a:hover{
    color: rgba(255,45,149,.95);
}

.pv-breadcrumb-list .active{
    color: rgba(255,255,255,.92);
}

.pv-watch-hero{
    padding: 14px;
}

.pv-player-wrap{
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.03);
}

.pv-watch-titlewrap{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap: 10px;
    margin-top: 14px;
}

.pv-watch-title{
    margin: 0;
    font-size: clamp(1.4rem, 2.6vw, 2.25rem);
    letter-spacing: -0.02em;
}

.pv-watch-sub{
    margin-top: 6px;
    color: rgba(255,255,255,.55);
}
.pv-watch-sub .dot{ opacity: .35; padding: 0 6px; }