/* ════════════════════════════════════════════════════════════════
   NIKASTREAM · APPLE LIQUID GLASS REDESIGN · UNIFIED STYLESHEET
   - Vanilla CSS, preserves every DOM hook required by the JS
   - Aurora background · deep purple→pink gradient · saturated glass
   ════════════════════════════════════════════════════════════════ */

:root{
    --p:#7c3aed;
    --p2:#a855f7;
    --p3:#c084fc;
    --pink:#ff4d8d;
    --a:#60a5fa;
    --a2:#22d3ee;
    --green:#4ade80;
    --orange:#fb923c;
    --gold:#fbbf24;

    --bg:#06060b;
    --bg2:#0c0c14;
    --bg3:#15151f;
    --bg4:#1c1c28;

    --glass:rgba(20,20,30,0.55);
    --glass-strong:rgba(14,14,22,0.78);
    --glass-soft:rgba(255,255,255,0.04);

    --border:rgba(255,255,255,0.08);
    --border-strong:rgba(255,255,255,0.14);
    --border-purple:rgba(168,85,247,0.30);

    --txt:#f5f5fa;
    --txt2:#9696b0;
    --txt3:#5a5a6e;

    --glow-p:0 0 24px rgba(124,58,237,0.45);
    --glow-pink:0 0 24px rgba(255,77,141,0.45);
    --shadow-card:0 12px 40px rgba(0,0,0,0.45);
    --shadow-glass:0 18px 60px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.06);

    --grad-brand:linear-gradient(135deg,#7c3aed 0%,#a855f7 45%,#ff4d8d 100%);
    --grad-brand-soft:linear-gradient(135deg,rgba(124,58,237,0.18),rgba(255,77,141,0.18));
    --grad-text:linear-gradient(135deg,#fff 0%,#e0c8ff 50%,#ffb6d9 100%);

    --ease:cubic-bezier(.22,.61,.36,1);
    --ease-spring:cubic-bezier(.175,.885,.32,1.275);
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{background:var(--bg);scroll-behavior:smooth;}
body{
    background:var(--bg);
    color:var(--txt);
    font-family:'Outfit',system-ui,-apple-system,sans-serif;
    font-weight:400;
    overflow-x:hidden;
    min-height:100vh;
    padding-bottom:calc(110px + env(safe-area-inset-bottom));
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    line-height:1.5;
    position:relative;
}
/* Aurora ambient blobs */
body::before{
    content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
    background:
        radial-gradient(ellipse 60% 50% at 15% 0%,rgba(124,58,237,0.22) 0%,transparent 60%),
        radial-gradient(ellipse 55% 45% at 85% 10%,rgba(255,77,141,0.18) 0%,transparent 60%),
        radial-gradient(ellipse 70% 50% at 50% 100%,rgba(96,165,250,0.10) 0%,transparent 65%),
        var(--bg);
}
body::after{
    content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
    background-image:
        radial-gradient(rgba(255,255,255,0.025) 1px,transparent 1px);
    background-size:3px 3px;
    opacity:0.35;
}

a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select,textarea{font-family:inherit;}

::selection{background:rgba(168,85,247,0.4);color:#fff;}
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--p),var(--pink));border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--p2),var(--pink));}

/* Bootstrap utility shims (so stripped Bootstrap calls still align right) */
.d-flex{display:flex !important;}
.align-items-center{align-items:center !important;}
.justify-content-center{justify-content:center !important;}
.justify-content-between{justify-content:space-between !important;}
.text-center{text-align:center !important;}
.text-decoration-none{text-decoration:none !important;}
.text-secondary{color:var(--txt2) !important;}
.text-white{color:#fff !important;}
.fw-bold{font-weight:700 !important;}
.gap-1{gap:.25rem !important;} .gap-2{gap:.5rem !important;} .gap-3{gap:.75rem !important;} .gap-4{gap:1rem !important;}
.ms-1{margin-left:.25rem !important;} .ms-2{margin-left:.5rem !important;} .me-1{margin-right:.25rem !important;} .me-2{margin-right:.5rem !important;}
.mb-2{margin-bottom:.5rem !important;} .mb-3{margin-bottom:.75rem !important;}
.small{font-size:.85rem;}
.container{max-width:1280px;margin:0 auto;padding:0 16px;}
.d-none{display:none !important;}
@media(min-width:992px){.d-lg-flex{display:flex !important;} .d-lg-none{display:none !important;}}
@media(min-width:1200px){.d-xl-none{display:none !important;}}

/* ════════════════════════════════════════════════════════════════
   HEADER · floating glass capsule
   ════════════════════════════════════════════════════════════════ */
#main-header{
    position:fixed;
    top:max(12px,env(safe-area-inset-top));
    left:50%;transform:translateX(-50%);
    width:calc(100% - 24px);max-width:1320px;height:60px;z-index:1000;
    background:var(--glass-strong);
    backdrop-filter:blur(22px) saturate(160%);
    -webkit-backdrop-filter:blur(22px) saturate(160%);
    border-radius:99px;
    border:1px solid var(--border-strong);
    box-shadow:var(--shadow-glass);
    display:flex;align-items:center;gap:12px;padding:0 14px;
    transition:background .3s var(--ease),box-shadow .3s var(--ease);
}
#main-header.scrolled{
    background:rgba(8,8,14,0.88);
    box-shadow:0 18px 60px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.08);
}
.header-icon-btn,.back-btn{
    width:40px;height:40px;flex-shrink:0;border-radius:50%;
    background:rgba(255,255,255,0.06);border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:.9rem;transition:.2s var(--ease);
    overflow:hidden;
}
.header-icon-btn:hover,.back-btn:hover{
    background:var(--grad-brand-soft);border-color:var(--border-purple);
    transform:translateY(-1px);
}
.logo-link{display:flex;align-items:center;flex-shrink:0;}
.logo-text{
    font-family:'Outfit',sans-serif;font-weight:800;font-size:1.05rem;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;
    color:transparent;letter-spacing:.5px;
}
.logo-box{
    background:var(--grad-brand);color:#fff;font-weight:800;
    padding:3px 9px;border-radius:8px;font-size:.7rem;letter-spacing:1.5px;
    margin-left:6px;box-shadow:var(--glow-p);
}

.desktop-nav{display:none;align-items:center;gap:4px;margin-left:8px;}
@media(min-width:992px){.desktop-nav{display:flex;}}
.nav-link-pill{
    color:var(--txt2);font-size:.85rem;font-weight:600;
    padding:7px 14px;border-radius:99px;
    transition:.2s var(--ease);
}
.nav-link-pill:hover{color:#fff;background:rgba(255,255,255,0.05);}
.nav-link-pill.active{
    color:#fff;background:var(--grad-brand-soft);
    border:1px solid var(--border-purple);
    box-shadow:var(--glow-p);
}

.header-right{display:flex;align-items:center;gap:8px;margin-left:auto;position:relative;}
.header-search-btn{font-size:.95rem;}
.header-user-btn{position:relative;overflow:hidden;}
#userAvatarImg{border-radius:50%;}
.user-dropdown-menu{
    position:absolute;top:48px;right:0;min-width:220px;
    background:var(--glass-strong);
    backdrop-filter:blur(22px) saturate(160%);
    border:1px solid var(--border-strong);
    border-radius:18px;padding:8px;display:none;
    box-shadow:var(--shadow-glass);z-index:1001;
}
.user-dropdown-menu.show{display:block;animation:fadeUp .25s var(--ease);}
.user-dropdown-menu a, .user-dropdown-menu button{
    display:flex;align-items:center;gap:10px;width:100%;
    padding:10px 12px;border-radius:12px;color:var(--txt);
    font-size:.85rem;font-weight:600;transition:.2s var(--ease);
    text-align:left;
}
.user-dropdown-menu a:hover, .user-dropdown-menu button:hover{
    background:var(--grad-brand-soft);color:#fff;
}

/* ── Popup sidebar (hamburger) ── */
#popup-sidebar{
    position:fixed;top:80px;left:12px;
    width:240px;
    background:var(--glass-strong);
    backdrop-filter:blur(22px) saturate(160%);
    border:1px solid var(--border-strong);
    border-radius:20px;padding:10px;display:none;z-index:999;
    box-shadow:var(--shadow-glass);
    animation:fadeUp .25s var(--ease);
}
#popup-sidebar.show{display:block;}
.sidebar-link{
    display:flex;align-items:center;gap:12px;padding:11px 14px;
    border-radius:14px;color:var(--txt);font-size:.82rem;font-weight:700;
    letter-spacing:.5px;transition:.2s var(--ease);
}
.sidebar-link:hover{background:var(--grad-brand-soft);transform:translateX(2px);}
.sidebar-divider{height:1px;background:var(--border);margin:6px 8px;}

/* ════════════════════════════════════════════════════════════════
   HERO · video banner + glass info panel
   ════════════════════════════════════════════════════════════════ */
#video-hero-banner{
    position:relative;width:100%;
    margin-top:max(86px,calc(env(safe-area-inset-top) + 86px));
    aspect-ratio:16/9;max-height:75vh;
    overflow:hidden;
}
@media(max-width:480px){
    #video-hero-banner{aspect-ratio:5/7;max-height:65vh;min-height:300px;}
}
@media(min-width:481px) and (max-width:768px){
    #video-hero-banner{aspect-ratio:1/1;max-height:70vh;min-height:360px;}
}
@media(min-width:769px) and (max-width:1024px){
    #video-hero-banner{aspect-ratio:16/10;max-height:72vh;}
}
@media(min-width:1025px){
    #video-hero-banner{aspect-ratio:16/9;max-height:75vh;}
}
#video-hero-banner > img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    transition:opacity .55s var(--ease),transform 8s var(--ease);
    transform:scale(1.05);
}
.vhero-gradient{
    position:absolute;inset:0;pointer-events:none;
    background:
        linear-gradient(180deg,transparent 0%,transparent 30%,rgba(6,6,11,0.9) 75%,var(--bg) 100%),
        linear-gradient(90deg,rgba(6,6,11,0.95) 0%,rgba(6,6,11,0.5) 50%,transparent 85%);
}
.vhero-overlay{
    position:absolute;inset:0;display:flex;flex-direction:column;
    justify-content:flex-end;padding:16px;z-index:2;gap:12px;
}
@media(min-width:481px){
    .vhero-overlay{padding:24px 28px;}
}
@media(min-width:769px){
    .vhero-overlay{padding:32px 48px;}
}
@media(min-width:1025px){
    .vhero-overlay{padding:48px 64px;}
}
.vhero-glass-panel{
    width:100%;max-width:100%;
    background:var(--glass-strong);
    backdrop-filter:blur(22px) saturate(160%);
    border:1px solid var(--border-strong);
    border-radius:12px;padding:14px 16px;
    box-shadow:var(--shadow-glass);
    animation:fadeUp .6s var(--ease);
}
@media(min-width:481px){
    .vhero-glass-panel{border-radius:16px;padding:18px 20px;}
}
@media(min-width:769px){
    .vhero-glass-panel{border-radius:20px;padding:20px 24px;max-width:580px;}
}
@media(min-width:1025px){
    .vhero-glass-panel{border-radius:24px;padding:22px 24px;max-width:620px;}
}
.vhero-badge{
    display:inline-flex;align-items:center;gap:4px;
    background:rgba(74,222,128,0.12);border:1px solid rgba(74,222,128,0.3);
    color:var(--green);font-size:.6rem;font-weight:700;
    padding:4px 8px;border-radius:99px;
    text-transform:uppercase;letter-spacing:.8px;
    margin-bottom:8px;
}
@media(min-width:481px){
    .vhero-badge{font-size:.65rem;padding:5px 10px;gap:5px;margin-bottom:10px;}
}
@media(min-width:769px){
    .vhero-badge{font-size:.7rem;padding:5px 11px;gap:6px;margin-bottom:12px;}
}
.vhero-title{
    font-size:clamp(1.4rem,5.5vw,3.2rem);font-weight:800;line-height:1.1;
    margin-bottom:8px;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
    letter-spacing:-0.5px;
}
@media(min-width:769px){
    .vhero-title{margin-bottom:12px;letter-spacing:-1px;}
}
.vhero-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
@media(min-width:769px){
    .vhero-meta{gap:8px;margin-bottom:18px;}
}
.vhero-rating-chip{
    display:inline-flex;align-items:center;gap:4px;
    background:rgba(251,191,36,0.15);color:var(--gold);
    border:1px solid rgba(251,191,36,0.3);
    padding:3px 8px;border-radius:99px;font-size:.65rem;font-weight:700;
}
@media(min-width:769px){
    .vhero-rating-chip{gap:5px;padding:4px 10px;font-size:.78rem;}
}
.vhero-meta-chip{color:var(--txt);font-size:.7rem;font-weight:500;}
@media(min-width:769px){
    .vhero-meta-chip{font-size:.8rem;}
}
.vhero-meta-dot{width:2px;height:2px;border-radius:50%;background:var(--txt3);display:inline-block;}
@media(min-width:769px){
    .vhero-meta-dot{width:3px;height:3px;}
}
.vhero-actions{display:flex;gap:8px;flex-wrap:wrap;}
@media(min-width:769px){
    .vhero-actions{gap:10px;}
}
.vhero-btn-play,.vhero-btn-info{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    padding:8px 16px;border-radius:8px;font-size:.75rem;font-weight:700;
    transition:.25s var(--ease);white-space:nowrap;
}
@media(min-width:481px){
    .vhero-btn-play,.vhero-btn-info{padding:9px 18px;border-radius:10px;font-size:.8rem;}
}
@media(min-width:769px){
    .vhero-btn-play,.vhero-btn-info{padding:11px 22px;border-radius:99px;font-size:.85rem;}
}
.vhero-btn-play{
    background:var(--grad-brand);color:#fff;
    box-shadow:0 8px 20px rgba(124,58,237,0.4);
}
.vhero-btn-play:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,77,141,0.5);}
.vhero-btn-play:active{transform:scale(.98);}
.vhero-btn-info{
    background:rgba(255,255,255,0.08);color:#fff;
    border:1px solid var(--border-strong);
    backdrop-filter:blur(8px);
}
.vhero-btn-info:hover{background:rgba(255,255,255,0.14);transform:translateY(-2px);}
.vhero-btn-info:active{transform:scale(.98);}
.vhero-pagination{display:flex;gap:6px;margin-top:10px;}
@media(min-width:769px){
    .vhero-pagination{gap:8px;margin-top:18px;}
}
.vhero-dot{
    width:20px;height:3px;border-radius:99px;
    background:rgba(255,255,255,0.18);cursor:pointer;
    transition:.3s var(--ease);
}
@media(min-width:481px){
    .vhero-dot{width:22px;height:3.5px;}
}
@media(min-width:769px){
    .vhero-dot{width:24px;height:4px;}
}
.vhero-dot.active{
    background:var(--grad-brand);width:38px;
    box-shadow:var(--glow-p);
}
@media(min-width:481px){
    .vhero-dot.active{width:40px;}
}
@media(min-width:769px){
    .vhero-dot.active{width:42px;}
}

/* hide legacy bootstrap carousel — vhero replaces it */
#hero-section{display:none;}

/* ════════════════════════════════════════════════════════════════
   GENRE PILL ROW
   ════════════════════════════════════════════════════════════════ */
.genre-bar{
    display:flex;gap:8px;overflow-x:auto;padding:18px 16px 6px;
    max-width:1280px;margin:0 auto;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.genre-bar::-webkit-scrollbar{display:none;}
.genre-pill{
    flex-shrink:0;
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);
    color:var(--txt);
    padding:8px 16px;border-radius:99px;
    font-size:.78rem;font-weight:600;white-space:nowrap;
    transition:.2s var(--ease);
}
.genre-pill:hover{
    background:var(--grad-brand-soft);
    border-color:var(--border-purple);
    color:#fff;transform:translateY(-1px);
    box-shadow:var(--glow-p);
}

/* ════════════════════════════════════════════════════════════════
   PAGE LAYOUT (home: main + sidebar)
   ════════════════════════════════════════════════════════════════ */
.page-layout{
    display:grid;grid-template-columns:1fr;gap:24px;
    max-width:1280px;margin:0 auto;padding:8px 16px 24px;
}
@media(min-width:1200px){
    .page-layout{grid-template-columns:1fr 320px;gap:32px;}
}
.main-col{min-width:0;}
.sidebar-col{display:none;}
@media(min-width:1200px){.sidebar-col{display:block;}}

/* ── Content rail ── */
.content-rail{margin:24px 0 28px;}
.section-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:14px;padding:0 4px;
}
.section-title{
    font-size:1.1rem;font-weight:800;color:#fff;
    display:flex;align-items:center;gap:10px;
    letter-spacing:-.3px;
    position:relative;padding-left:14px;
}
.section-title::before{
    content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
    width:4px;height:22px;border-radius:99px;background:var(--grad-brand);
    box-shadow:var(--glow-p);
}
.section-title.green::before{background:linear-gradient(180deg,#4ade80,#22c55e);box-shadow:0 0 16px rgba(74,222,128,.4);}
.section-title.orange::before{background:linear-gradient(180deg,#fb923c,#f97316);box-shadow:0 0 16px rgba(251,146,60,.4);}
.section-title.blue::before{background:linear-gradient(180deg,#60a5fa,#3b82f6);box-shadow:0 0 16px rgba(96,165,250,.4);}
.see-all{
    color:var(--p2);font-size:.78rem;font-weight:700;
    transition:.2s var(--ease);
}
.see-all:hover{color:var(--pink);transform:translateX(2px);}

/* ── Rail wrapper (horizontal scroll) ── */
.rail-wrapper{
    display:flex;gap:14px;overflow-x:auto;
    padding:6px 4px 14px;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.rail-wrapper::-webkit-scrollbar{display:none;}

/* ════════════════════════════════════════════════════════════════
   ANIME CARDS
   ════════════════════════════════════════════════════════════════ */
.anime-card,.trending-card{
    flex:0 0 auto;width:148px;
    cursor:pointer;scroll-snap-align:start;
    transition:transform .3s var(--ease);
}
@media(min-width:768px){.anime-card,.trending-card{width:170px;}}
.anime-card:hover,.trending-card:hover{transform:translateY(-6px);}
.anime-card:active,.trending-card:active{transform:scale(.97);}

.card-img-wrapper{
    position:relative;width:100%;padding-top:150%;
    border-radius:14px;overflow:hidden;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
    border:1px solid var(--border);
    box-shadow:var(--shadow-card);
    background-size:200% 100%;
    animation:shimmer 1.6s infinite linear;
}
.card-img-wrapper::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(180deg,transparent 55%,rgba(6,6,11,.85) 100%);
}
.card-img-wrapper img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    opacity:0;transition:opacity .45s var(--ease),transform .5s var(--ease);
}
.card-img-wrapper img.loaded,.card-img-wrapper img[src]:not([src=""]){opacity:1;}
.card-img-wrapper:has(img.loaded),.card-img-wrapper:has(img[src]:not([src=""])){animation:none;}
.anime-card:hover .card-img-wrapper img,.trending-card:hover .card-img-wrapper img{transform:scale(1.06);}

.card-img-wrapper .ep-badge{
    position:absolute;top:8px;left:8px;z-index:2;
    background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);
    color:#fff;font-size:.65rem;font-weight:700;
    padding:3px 8px;border-radius:6px;
    border:1px solid rgba(255,255,255,0.1);
}
.card-img-wrapper .score-badge{
    position:absolute;top:8px;right:8px;z-index:2;
    background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);
    color:var(--gold);font-size:.65rem;font-weight:700;
    padding:3px 8px;border-radius:6px;
    border:1px solid rgba(251,191,36,0.25);
}
.card-img-wrapper .format-badge{
    position:absolute;bottom:8px;left:8px;z-index:2;
    background:var(--grad-brand);color:#fff;
    font-size:.62rem;font-weight:800;letter-spacing:.5px;
    padding:3px 8px;border-radius:6px;
    box-shadow:var(--glow-p);
}
.card-title{
    font-size:.85rem;font-weight:700;color:#fff;
    margin-top:9px;padding:0 2px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    transition:color .2s var(--ease);
}
.anime-card:hover .card-title,.trending-card:hover .card-title{
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.card-meta{
    font-size:.7rem;color:var(--txt2);padding:0 2px;margin-top:2px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* Trending card: large rank number */
.trending-card{position:relative;}
.trending-card .rank-num{
    position:absolute;left:-8px;bottom:34px;z-index:3;
    font-size:5rem;font-weight:900;line-height:.85;
    color:transparent;-webkit-text-stroke:2px rgba(168,85,247,.55);
    text-shadow:0 4px 24px rgba(0,0,0,.6);
    pointer-events:none;font-family:'Outfit',sans-serif;
}

/* ── Mood grid ── */
.mood-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
    padding:4px;
}
@media(min-width:640px){.mood-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:992px){.mood-grid{grid-template-columns:repeat(6,1fr);}}
.mood-btn{
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);
    color:var(--txt);font-size:.78rem;font-weight:700;
    padding:18px 12px;border-radius:18px;
    transition:.25s var(--ease);
    line-height:1.6;text-align:center;
}
.mood-btn:hover{
    background:var(--grad-brand-soft);
    border-color:var(--border-purple);
    transform:translateY(-3px);
    box-shadow:var(--shadow-card),var(--glow-p);
}

/* ── Schedule list ── */
.schedule-list{display:flex;flex-direction:column;gap:8px;padding:4px;}
.sch-sk{
    height:56px;border-radius:14px;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.sch-item{
    display:flex;align-items:center;gap:12px;
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);border-radius:14px;
    padding:10px 12px;transition:.2s var(--ease);
}
.sch-item:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);transform:translateX(3px);}
.sch-cover{width:42px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.sch-info{flex:1;min-width:0;}
.sch-name{font-size:.8rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sch-meta{font-size:.7rem;color:var(--txt2);margin-top:2px;}
.sch-time{
    font-size:.72rem;font-weight:800;color:var(--p2);
    background:rgba(168,85,247,0.12);
    padding:4px 10px;border-radius:8px;flex-shrink:0;
}

/* ── Top airing sidebar ── */
.top-airing-sidebar{
    background:var(--glass);
    backdrop-filter:blur(18px) saturate(160%);
    border:1px solid var(--border);
    border-radius:20px;padding:18px;
    box-shadow:var(--shadow-card);
}
.top-airing-title{
    font-size:1rem;font-weight:800;color:#fff;
    margin-bottom:14px;padding-left:12px;position:relative;
}
.top-airing-title::before{
    content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
    width:4px;height:18px;border-radius:99px;background:var(--grad-brand);
    box-shadow:var(--glow-p);
}
.top-airing-list{display:flex;flex-direction:column;gap:10px;}
.ta-skeleton{
    height:62px;border-radius:12px;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.ta-item{
    display:flex;align-items:center;gap:10px;
    padding:8px;border-radius:12px;cursor:pointer;
    transition:.2s var(--ease);background:rgba(255,255,255,0.02);
    border:1px solid transparent;
}
.ta-item:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);transform:translateX(3px);}
.ta-rank{
    font-size:1.1rem;font-weight:900;width:24px;text-align:center;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.ta-cover{width:38px;height:54px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.ta-info{flex:1;min-width:0;}
.ta-name{font-size:.8rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ta-meta{font-size:.7rem;color:var(--txt2);margin-top:2px;}

/* ════════════════════════════════════════════════════════════════
   LOADER
   ════════════════════════════════════════════════════════════════ */
#loader, .loader-overlay{
    position:fixed;inset:0;z-index:99999;
    display:flex;align-items:center;justify-content:center;
    background:radial-gradient(ellipse at center,rgba(124,58,237,0.15) 1%,var(--bg) 1%);
    transition:opacity .4s var(--ease);
}
.nika-loader{
    display:flex;flex-direction:column;align-items:center;gap:24px;
    color:#fff;font-weight:800;letter-spacing:3px;font-size:.9rem;
}
.nika-bounce-wrapper{
    width:200px;height:70px;position:relative;z-index:1;
    overflow:visible;
}
.bounce-circle{
    width:20px;height:20px;position:absolute;
    border-radius:50%;
    background:var(--grad-brand);
    box-shadow:var(--glow-p);
    left:15%;transform-origin:50%;
    animation:nikaCircleBounce .5s alternate infinite ease;
}
@keyframes nikaCircleBounce{
    0%{top:55px;height:5px;border-radius:50px 50px 25px 25px;transform:scaleX(1.7);}
    40%{height:20px;border-radius:50%;transform:scaleX(1);}
    100%{top:0;}
}
.bounce-circle:nth-child(2){left:45%;animation-delay:.2s;}
.bounce-circle:nth-child(3){left:auto;right:15%;animation-delay:.3s;}

.bounce-shadow{
    width:20px;height:4px;border-radius:1%;
    background:linear-gradient(90deg,var(--p),var(--pink));  /* brand gradient instead of dark rgba */
    position:absolute;top:60px;
    transform-origin:1%;z-index:-1;left:1%;
    filter:blur(3px);
    opacity:0.2;
    animation:nikaShadowBounce .5s alternate infinite ease;
}
@keyframes nikaShadowBounce{
    30%{transform:scaleX(1.5);opacity:.5;}
    40%{transform:scaleX(1);opacity:.35;}
    100%{transform:scaleX(.2);opacity:.2;}
}
.bounce-shadow:nth-child(4){left:45%;animation-delay:.2s;}
.bounce-shadow:nth-child(5){left:auto;right:15%;animation-delay:.3s;}
.nika-loader span{
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════ */
footer{
    margin-top:48px;padding:36px 16px 48px;text-align:center;
    border-top:1px solid var(--border);
    background:linear-gradient(180deg,transparent,rgba(124,58,237,0.05));
}
.footer-logo,.footer-brand .brand-name{
    font-size:1.4rem;font-weight:900;letter-spacing:3px;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
    margin-bottom:14px;display:inline-block;
}
.footer-desc{color:var(--txt2);font-size:.82rem;margin-bottom:14px;max-width:500px;margin-left:auto;margin-right:auto;}
.footer-links{display:flex;justify-content:center;gap:24px;margin-top:14px;flex-wrap:wrap;}
.footer-links a, .footer-link{
    color:var(--txt2);font-size:.82rem;font-weight:600;
    transition:.2s var(--ease);
}
.footer-links a:hover, .footer-link:hover{color:var(--p2);}
.footer-bottom, .footer-credit{font-size:.72rem;color:var(--txt3);margin-top:18px;display:block;}
.footer-credit a{color:var(--p2);}
.site-footer{padding:28px 16px;text-align:center;}

/* ════════════════════════════════════════════════════════════════
   BOTTOM DOCK NAV
   ════════════════════════════════════════════════════════════════ */
.bottom-nav{
    position:fixed;bottom:calc(18px + env(safe-area-inset-bottom));
    left:0;width:100%;z-index:9999;pointer-events:none;
    display:flex;justify-content:center;
}
.dock-container{
    pointer-events:auto;
    display:flex;justify-content:space-around;align-items:center;
    width:92%;max-width:360px;height:64px;padding:0 14px;
    background:var(--glass-strong);
    backdrop-filter:blur(28px) saturate(170%);
    -webkit-backdrop-filter:blur(28px) saturate(170%);
    border-radius:99px;border:1px solid var(--border-strong);
    box-shadow:var(--shadow-glass);
}
.dock-item{
    position:relative;display:flex;flex-direction:column;align-items:center;
    justify-content:center;width:56px;height:100%;
    color:rgba(255,255,255,0.42);transition:.3s var(--ease);
}
.dock-item .icon-box{font-size:1.2rem;transition:.3s var(--ease);}
.dock-label{
    position:absolute;bottom:6px;font-size:.58rem;font-weight:800;
    opacity:0;transform:translateY(8px);transition:.3s var(--ease);
    letter-spacing:.5px;
}
.dock-item.active{color:#fff;}
.dock-item.active .icon-box{
    transform:translateY(-8px);
    color:var(--p2);
    filter:drop-shadow(0 0 10px var(--p2)) drop-shadow(0 0 18px var(--pink));
}
.dock-item.active .dock-label{opacity:1;transform:translateY(0);}

/* ════════════════════════════════════════════════════════════════
   ANIME DETAIL PAGE (anime.html)
   ════════════════════════════════════════════════════════════════ */
.hero{
    position:relative;width:100%;
    padding-top:max(86px,calc(env(safe-area-inset-top) + 86px));
    padding-bottom:32px;overflow:hidden;
}
.hero-bg{
    position:absolute;inset:0;z-index:-1;
    background-size:cover;background-position:center;
    filter:blur(28px) saturate(180%) brightness(.55);
    transform:scale(1.18);
}
.hero-overlay{
    position:absolute;inset:0;z-index:-1;
    background:
        linear-gradient(180deg,rgba(6,6,11,0.55) 0%,rgba(6,6,11,0.85) 60%,var(--bg) 100%),
        radial-gradient(ellipse at 20% 30%,rgba(124,58,237,0.25) 0%,transparent 60%),
        radial-gradient(ellipse at 80% 70%,rgba(255,77,141,0.18) 0%,transparent 60%);
}
.anime-content{
    max-width:1280px;margin:0 auto;padding:0 16px;
    display:grid;grid-template-columns:1fr;gap:24px;
    align-items:start;
}
@media(min-width:768px){
    .anime-content{grid-template-columns:260px 1fr;gap:32px;padding:0 32px;}
}
.poster-wrap{
    position:relative;width:200px;margin:0 auto;
    border-radius:18px;overflow:hidden;
    box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 0 1px var(--border-strong);
    border:1px solid var(--border-strong);
}
@media(min-width:768px){.poster-wrap{width:100%;}}
.poster-wrap::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(135deg,rgba(255,255,255,0.10) 0%,transparent 50%);
}
.poster-wrap img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;}

.info-wrap{min-width:0;}
.title{
    font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;line-height:1.05;
    margin-bottom:8px;letter-spacing:-1px;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.meta-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.tag{
    background:rgba(255,255,255,0.06);backdrop-filter:blur(8px);
    border:1px solid var(--border);
    color:#fff;font-size:.7rem;font-weight:700;
    padding:4px 10px;border-radius:8px;letter-spacing:.5px;
}
.genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.genres span,.genres a{
    background:var(--grad-brand-soft);
    border:1px solid var(--border-purple);
    color:var(--p3);font-size:.7rem;font-weight:600;
    padding:4px 10px;border-radius:99px;
    transition:.2s var(--ease);
}
.genres a:hover{background:var(--grad-brand);color:#fff;}
.desc{
    color:var(--txt2);font-size:.88rem;line-height:1.65;
    margin-bottom:18px;max-height:170px;overflow-y:auto;padding-right:6px;
}
.desc::-webkit-scrollbar{width:3px;}
.desc::-webkit-scrollbar-thumb{background:var(--border-purple);border-radius:99px;}

.action-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.btn-play{
    display:inline-flex;align-items:center;gap:8px;
    padding:11px 22px;border-radius:99px;font-size:.85rem;font-weight:700;
    background:var(--grad-brand);color:#fff;
    box-shadow:0 10px 30px rgba(124,58,237,0.45),var(--glow-p);
    transition:.25s var(--ease);
    border:none;cursor:pointer;
}
.btn-play:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(255,77,141,0.55);color:#fff;}
.btn-play.disabled{opacity:.55;pointer-events:none;}
.btn-play:nth-child(2),#bookmark-btn{
    background:rgba(255,255,255,0.08);
    border:1px solid var(--border-strong);
    box-shadow:none;color:#fff;backdrop-filter:blur(10px);
}
.btn-play:nth-child(2):hover,#bookmark-btn:hover{background:rgba(255,255,255,0.14);box-shadow:0 8px 24px rgba(0,0,0,.4);}

#next-ep-banner{
    display:flex;align-items:center;gap:12px;
    background:var(--glass);
    backdrop-filter:blur(18px) saturate(160%);
    border:1px solid var(--border-purple);
    border-radius:14px;padding:11px 14px;margin-top:6px;max-width:420px;
    box-shadow:var(--glow-p);
}

/* ── Season switcher ── */
.ss-wrap{
    max-width:1280px;margin:24px auto 0;padding:0 16px;
}
.ss-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.ss-title{
    display:flex;align-items:center;gap:10px;
    font-size:1.15rem;font-weight:800;color:#fff;
    padding-left:14px;position:relative;
}
.ss-title::before{
    content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
    width:4px;height:22px;border-radius:99px;background:var(--grad-brand);box-shadow:var(--glow-p);
}
.ss-title i{color:var(--p2);}
.ss-total-badge{
    background:var(--grad-brand-soft);
    border:1px solid var(--border-purple);
    color:var(--p3);font-size:.78rem;font-weight:700;
    padding:5px 14px;border-radius:99px;
}
.ss-track{
    display:flex;gap:10px;overflow-x:auto;padding:6px 4px 14px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.ss-track::-webkit-scrollbar{display:none;}
.ss-btn{
    flex-shrink:0;min-width:96px;
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);border-radius:16px;
    padding:14px 16px 12px;cursor:pointer;text-align:center;
    transition:.25s var(--ease);position:relative;opacity:.8;
    display:flex;flex-direction:column;align-items:center;gap:4px;
}
.ss-btn:hover{
    opacity:1;transform:translateY(-2px);
    background:var(--grad-brand-soft);border-color:var(--border-purple);
    box-shadow:var(--glow-p);
}
.ss-btn.ss-active{
    opacity:1;
    background:linear-gradient(135deg,rgba(124,58,237,.32),rgba(255,77,141,.18));
    border-color:rgba(168,85,247,.7);
    box-shadow:0 0 0 1px rgba(168,85,247,.25),var(--glow-p),var(--shadow-card);
}
.ss-btn-label{font-size:.55rem;font-weight:700;letter-spacing:2.5px;color:var(--txt2);text-transform:uppercase;}
.ss-btn-num{
    font-size:2.2rem;font-weight:900;line-height:1;letter-spacing:-2px;color:#fff;
    text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.ss-btn.ss-active .ss-btn-num{
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.ss-btn-now{
    position:absolute;top:6px;right:6px;
    background:var(--grad-brand);color:#fff;
    font-size:.48rem;font-weight:900;letter-spacing:1.5px;
    padding:2px 6px;border-radius:99px;text-transform:uppercase;
    box-shadow:var(--glow-p);
}

/* ── Anime grid (related/recommended) ── */
.anime-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
    max-width:1280px;margin:0 auto;padding:0 16px;
}
@media(min-width:480px){.anime-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:640px){.anime-grid{grid-template-columns:repeat(4,1fr);}}
@media(min-width:900px){.anime-grid{grid-template-columns:repeat(5,1fr);}}
@media(min-width:1100px){.anime-grid{grid-template-columns:repeat(6,1fr);}}
.anime-grid .anime-card{width:100%;}

/* ════════════════════════════════════════════════════════════════
   EPISODE / PLAYER PAGE
   ════════════════════════════════════════════════════════════════ */
.player-shell{
    max-width:1280px;margin:0 auto;
    padding:max(86px,calc(env(safe-area-inset-top) + 86px)) 16px 24px;
}
@media(min-width:992px){
    .player-shell{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start;}
}
.player-main{min-width:0;}
.player-side{min-width:0;}

#video-container{
    position:relative;width:100%;
    background:#000;
    border-radius:18px;overflow:hidden;
    box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 0 1px var(--border-strong);
}
#video-wrapper{position:absolute;inset:0;background:#000;}
#loading-overlay{
    position:absolute;inset:0;z-index:10;
    display:flex;align-items:center;justify-content:center;
    background:radial-gradient(ellipse at center,rgba(124,58,237,0.18) 0%,#000 70%);
    color:#fff;
}

#anime-title{
    margin-top:18px;font-size:1.2rem;font-weight:800;color:#fff;line-height:1.2;
    letter-spacing:-.3px;
}
#ep-title{
    color:var(--p2);font-size:.9rem;font-weight:700;margin-top:6px;
}

/* Server controls */
#server-controls{
    margin:18px 0;
    background:var(--glass);
    backdrop-filter:blur(18px) saturate(160%);
    border:1px solid var(--border);
    border-radius:18px;padding:14px;
    box-shadow:var(--shadow-card);
    display:flex;flex-direction:column;gap:12px;
}
.control-group{
    display:flex;gap:8px;flex-wrap:wrap;
}
.control-group::-webkit-scrollbar{display:none;}
#server-controls button{
    flex-shrink:0;
    background:rgba(255,255,255,0.05);
    border:1px solid var(--border);
    color:var(--txt);font-size:.78rem;font-weight:700;
    padding:8px 14px;border-radius:99px;
    transition:.2s var(--ease);
    display:inline-flex;align-items:center;gap:6px;
}
#server-controls button:hover{
    background:var(--grad-brand-soft);
    border-color:var(--border-purple);color:#fff;
    transform:translateY(-1px);
}
#server-controls button.active{
    background:var(--grad-brand);color:#fff;border-color:transparent;
    box-shadow:var(--glow-p);
}
.nav-row{display:flex;gap:8px;width:100%;}
.nav-btn{
    flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;
    background:rgba(255,255,255,0.05);
    border:1px solid var(--border);
    color:var(--txt);font-size:.82rem;font-weight:700;
    padding:10px 16px;border-radius:12px;
    transition:.2s var(--ease);
}
.nav-btn:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);color:#fff;}
.nav-btn.disabled{opacity:.4;pointer-events:none;}

/* Episode list panel */
.ep-panel{
    background:var(--glass);
    backdrop-filter:blur(18px) saturate(160%);
    border:1px solid var(--border);
    border-radius:18px;padding:16px;margin-top:18px;
    box-shadow:var(--shadow-card);
}
.ep-panel-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:12px;gap:10px;flex-wrap:wrap;
}
.ep-panel-title{font-size:.95rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:8px;}
.ep-panel-title i{color:var(--p2);}
.ep-controls-row{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end;}
.ep-search-wrap{
    flex:1;max-width:220px;
    display:flex;align-items:center;gap:8px;
    background:rgba(255,255,255,0.05);border:1px solid var(--border);
    border-radius:99px;padding:6px 14px;height:36px;
    transition:.2s var(--ease);
}
.ep-search-wrap:focus-within{border-color:var(--border-purple);box-shadow:0 0 0 3px rgba(168,85,247,.15);}
.ep-search-wrap i{color:var(--txt2);font-size:.78rem;}
#ep-search{
    flex:1;background:none;border:none;outline:none;color:#fff;
    font-size:.84rem;font-family:inherit;
}
.ep-search-clear{
    color:var(--txt2);font-size:.75rem;display:none;
}
.ep-search-clear.show{display:block;}
.ep-ctrl-btn{
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,0.05);border:1px solid var(--border);
    color:var(--txt);transition:.2s var(--ease);
    display:flex;align-items:center;justify-content:center;
}
.ep-ctrl-btn:hover, .ep-ctrl-btn.active{background:var(--grad-brand);color:#fff;border-color:transparent;box-shadow:var(--glow-p);}

/* Episode grid */
.ep-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:8px;
    max-height:520px;overflow-y:auto;padding:4px;
}
.ep-grid::-webkit-scrollbar{width:3px;}
.ep-grid::-webkit-scrollbar-thumb{background:var(--border-purple);border-radius:99px;}
.ep-grid--list{grid-template-columns:1fr;}
.ep-link{
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,0.04);
    border:1px solid var(--border);
    color:var(--txt);font-size:.82rem;font-weight:700;
    padding:10px 6px;border-radius:10px;
    transition:.18s var(--ease);min-height:40px;
}
.ep-link:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);color:#fff;transform:translateY(-1px);}
.ep-link.active-ep{
    background:var(--grad-brand);color:#fff;border-color:transparent;
    box-shadow:var(--glow-p);
}
.ep-grid--list .ep-link{
    justify-content:flex-start;gap:10px;padding:11px 14px;text-align:left;
}
.ep-num-badge{
    background:rgba(168,85,247,0.18);color:var(--p2);
    font-size:.7rem;font-weight:800;padding:3px 8px;border-radius:6px;flex-shrink:0;
}
.ep-link.active-ep .ep-num-badge{background:rgba(255,255,255,0.22);color:#fff;}
.ep-title-text{
    flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    font-size:.82rem;font-weight:600;
}

/* Episode range chunk nav */
.ep-range-nav-wrap{margin-bottom:12px;}
.ep-range-nav{
    display:flex;align-items:center;gap:8px;
    background:rgba(255,255,255,0.04);
    border:1px solid var(--border);
    border-radius:99px;padding:4px;
}
.ep-range-arrow{
    width:34px;height:34px;border-radius:50%;
    background:rgba(255,255,255,0.06);
    color:#fff;font-size:.75rem;
    display:flex;align-items:center;justify-content:center;
    transition:.2s var(--ease);
}
.ep-range-arrow:not(:disabled):hover{background:var(--grad-brand);box-shadow:var(--glow-p);}
.ep-range-arrow:disabled{opacity:.3;cursor:not-allowed;}
.ep-range-center{
    flex:1;text-align:center;color:#fff;font-size:.84rem;font-weight:800;
    cursor:pointer;padding:6px 12px;border-radius:99px;
    transition:.2s var(--ease);
    display:flex;align-items:center;justify-content:center;gap:6px;
}
.ep-range-center:hover{background:var(--grad-brand-soft);}
.ep-range-chevron{font-size:.7rem;color:var(--p2);}

/* Sidebar episode list */
#ep-list{margin-top:6px;}

/* Episode skeleton loader */
.ep-skeleton-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:8px;
    padding:4px;
}
.ep-skeleton-grid--list{grid-template-columns:1fr;}
.ep-skeleton{
    height:40px;border-radius:10px;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.ep-skeleton-grid--list .ep-skeleton{
    height:45px;
}

#side-episodes-panel{
    background:var(--glass);
    backdrop-filter:blur(18px) saturate(160%);
    border:1px solid var(--border);
    border-radius:18px;padding:16px;
    box-shadow:var(--shadow-card);
    position:sticky;top:96px;
    max-height:calc(100vh - 120px);overflow:hidden;
    display:flex;flex-direction:column;
}

/* ════════════════════════════════════════════════════════════════
   SEARCH PAGE
   ════════════════════════════════════════════════════════════════ */
.search-bar{
    flex:1;display:flex;align-items:center;gap:10px;
    background:rgba(255,255,255,0.05);
    border:1px solid var(--border);
    border-radius:99px;padding:0 16px;height:42px;
    transition:.2s var(--ease);
}
.search-bar:focus-within{
    background:rgba(255,255,255,0.09);
    border-color:var(--border-purple);
    box-shadow:0 0 0 3px rgba(168,85,247,.18);
}
.search-bar i{color:var(--txt2);font-size:.85rem;}
.search-bar input{
    background:none;border:none;outline:none;color:#fff;width:100%;
    font-size:16px;font-family:inherit;
}
.search-bar input::placeholder{color:var(--txt2);font-size:.88rem;}
.search-clear{color:var(--txt2);font-size:.8rem;display:none;}
.search-clear.show{display:block;}

.search-page{
    padding-top:max(96px,calc(env(safe-area-inset-top) + 96px));
    max-width:1280px;margin:0 auto;padding-left:16px;padding-right:16px;
}
.filter-section{margin-bottom:24px;}
.filter-label{
    font-size:.7rem;font-weight:800;color:var(--txt2);
    text-transform:uppercase;letter-spacing:1.5px;
    margin-bottom:12px;display:flex;align-items:center;gap:8px;
}
.filter-chips{
    display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.filter-chips::-webkit-scrollbar{display:none;}
.chip{
    flex-shrink:0;
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);
    color:var(--txt);
    padding:8px 16px;border-radius:99px;
    font-size:.78rem;font-weight:600;white-space:nowrap;
    transition:.2s var(--ease);font-family:inherit;
}
.chip:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);color:#fff;}
.chip.active{
    background:var(--grad-brand);color:#fff;border-color:transparent;
    box-shadow:var(--glow-p);
}

.results-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:18px;flex-wrap:wrap;gap:8px;
}
.results-title{font-size:1.05rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:10px;}
.results-title span{
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.results-count{font-size:.78rem;color:var(--txt2);font-weight:600;}

/* Search card */
.s-card{
    cursor:pointer;display:flex;flex-direction:column;height:100%;min-width:0;
    transition:transform .25s var(--ease);
}
.s-card:hover{transform:translateY(-5px);}
.s-card:active{transform:scale(.96);}
.s-img-wrap{
    position:relative;width:100%;padding-top:150%;
    border-radius:14px;overflow:hidden;
    background:linear-gradient(135deg,var(--bg3),var(--bg4));
    border:1px solid var(--border);
    box-shadow:var(--shadow-card);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.s-img-wrap img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    opacity:0;transition:opacity .4s var(--ease);
}
.s-img-wrap img.loaded{opacity:1;}
.s-img-wrap:has(img.loaded){animation:none;}
.s-img-wrap::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(180deg,transparent 55%,rgba(6,6,11,.85) 100%);
}
.s-score{
    position:absolute;top:8px;right:8px;z-index:2;
    background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);
    color:var(--gold);font-size:.65rem;font-weight:700;
    padding:3px 8px;border-radius:6px;
    border:1px solid rgba(251,191,36,.2);
}
.s-format{
    position:absolute;bottom:8px;left:8px;z-index:2;
    background:var(--grad-brand);color:#fff;
    font-size:.62rem;font-weight:800;letter-spacing:.5px;
    padding:3px 8px;border-radius:6px;
    box-shadow:var(--glow-p);
}
.s-title{
    font-size:.88rem;color:#fff;margin-top:9px;padding:0 2px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700;
}
.s-meta{font-size:.7rem;color:var(--txt2);padding:0 2px;margin-top:2px;}
.s-skel-text{height:9px;background:var(--bg3);border-radius:6px;margin-top:9px;}
.s-skel-meta{height:7px;background:var(--bg3);border-radius:6px;margin-top:5px;width:60%;}

/* Anime detail page skeletons */
.ep-skeleton-card{
    height:54px;border-radius:10px;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.season-skel-button{
    height:44px;min-width:120px;border-radius:10px;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.anime-grid-skeleton{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;
}
.anime-skel-card{
    display:flex;flex-direction:column;
    border-radius:14px;overflow:hidden;
}
.anime-skel-card .skel-img{
    width:100%;padding-top:150%;
    background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite linear;
}
.anime-skel-card .skel-text{
    height:8px;width:80%;background:var(--bg3);border-radius:4px;
    margin-top:8px;margin-left:6px;
}

.no-results{text-align:center;padding:80px 20px;}
.no-results i{font-size:2.5rem;color:var(--txt2);margin-bottom:16px;display:block;}
.no-results h5{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:8px;}
.no-results p{font-size:.85rem;color:var(--txt2);}

.load-more-btn{
    display:block;margin:32px auto 0;
    background:var(--grad-brand-soft);
    border:1px solid var(--border-purple);
    color:#fff;border-radius:99px;
    padding:12px 36px;font-size:.85rem;font-weight:700;
    transition:.25s var(--ease);font-family:inherit;
}
.load-more-btn:hover{background:var(--grad-brand);box-shadow:var(--glow-p);transform:translateY(-2px);}

.genre-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media(min-width:480px){.genre-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:768px){.genre-grid{grid-template-columns:repeat(4,1fr);}}
.genre-card{
    background:var(--glass);
    backdrop-filter:blur(14px) saturate(160%);
    border:1px solid var(--border);
    border-radius:14px;padding:16px 14px;cursor:pointer;
    display:flex;align-items:center;gap:10px;
    transition:.2s var(--ease);font-size:.85rem;font-weight:600;color:var(--txt);
}
.genre-card:hover{background:var(--grad-brand-soft);border-color:var(--border-purple);color:#fff;transform:translateY(-2px);}
.genre-card i{width:18px;text-align:center;color:var(--p2);}

/* ════════════════════════════════════════════════════════════════
   RGB POPUP / "WHAT'S NEW"
   ════════════════════════════════════════════════════════════════ */
.rgb-popup-overlay{
    position:fixed;inset:0;z-index:10000;
    display:flex;align-items:center;justify-content:center;
    background:rgba(0,0,0,.7);backdrop-filter:blur(10px);
    padding:20px;
}
.rgb-popup-box{
    position:relative;width:100%;max-width:440px;
    background:var(--glass-strong);
    backdrop-filter:blur(28px) saturate(170%);
    border:1px solid var(--border-strong);
    border-radius:24px;overflow:hidden;
    box-shadow:var(--shadow-glass);
    animation:popIn .35s var(--ease-spring);
}
.rgb-border{
    position:absolute;inset:0;border-radius:24px;pointer-events:none;
    background:var(--grad-brand);opacity:.18;
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    padding:1px;
}
.popup-content{padding:24px;}
.popup-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.popup-header h3{
    font-size:1.1rem;font-weight:800;
    background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.close-btn{color:var(--txt2);font-size:1.4rem;line-height:1;padding:0 4px;}
.close-btn:hover{color:#fff;}
.popup-body ul{list-style:none;padding:0;}
.popup-body li{
    color:var(--txt);font-size:.86rem;padding:8px 0;
    border-bottom:1px solid var(--border);line-height:1.5;
}
.popup-body li:last-child{border-bottom:none;}
.popup-body strong{color:var(--p2);}
.popup-footer{margin-top:16px;}
.action-btn{
    width:100%;background:var(--grad-brand);color:#fff;
    border-radius:14px;padding:13px;font-size:.92rem;font-weight:700;
    box-shadow:var(--glow-p);transition:.25s var(--ease);
}
.action-btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(255,77,141,.55);}

/* Hide cloudflare email decode artifacts */
.__cf_email__{display:none;}

/* ════ HI-ANIME LAYOUT ENGINE ════ */
.hi-main-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 20px;
}

.hi-content-column {
    flex: 1;
    min-width: 0; /* Prevents flex items from breaking layout */
}

.hi-sidebar-column {
    width: 320px;
}

@media (max-width: 1100px) {
    .hi-sidebar-column { width: 100%; display: none; } /* Hide sidebar on small tablets/mobile if desired */
}

/* SECTION HEADERS */
.hi-section { margin-bottom: 40px; }
.hi-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.hi-section-title {
    font-size: 1.3rem;
    font-weight: 800;
    color: #fff;
    padding-left: 15px;
    position: relative;
    text-transform: capitalize;
}

.hi-section-title::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 80%;
    border-radius: 10px;
}

/* Accent Colors */
.accent-yellow::before { background: #ffc107; box-shadow: 0 0 10px #ffc107; }
.accent-blue::before { background: #60a5fa; box-shadow: 0 0 10px #60a5fa; }
.accent-green::before { background: #cae962; box-shadow: 0 0 10px #cae962; }

.hi-view-all {
    color: #aaa;
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s;
}
.hi-view-all:hover { color: #ffc107; }

/* HI-ANIME GRID SYSTEM (The most important part) */
.hi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 15px;
}

@media (max-width: 600px) {
    .hi-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 items on mobile */
        gap: 10px;
    }
}

/* SIDEBAR WIDGETS */
.hi-sidebar-widget {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 8px;
    padding: 20px;
}

.hi-widget-title {
    color: #ffc107;
    font-size: 1.1rem;
    font-weight: 800;
    margin-bottom: 20px;
}

/* RANKED LIST STYLE */
.hi-ranked-list .ta-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}

.hi-ranked-list .ta-rank {
    font-size: 1.5rem;
    font-weight: 900;
    font-style: italic;
    color: #444;
    width: 30px;
}

/* Color first 3 ranks */
.hi-ranked-list .ta-item:nth-child(1) .ta-rank { color: #ffc107; }
.hi-ranked-list .ta-item:nth-child(2) .ta-rank { color: #aaa; }
.hi-ranked-list .ta-item:nth-child(3) .ta-rank { color: #cd7f32; }

.hi-date-label {
    font-size: 0.7rem;
    color: #888;
    background: #222;
    padding: 2px 8px;
    border-radius: 4px;
}

/* ════ HI-ANIME HERO ENGINE ════ */
.hi-hero {
    position: relative;
    width: 100%;
    height: 580px; /* Perfect desktop height */
    margin-top: 70px;
    background: #000;
    overflow: hidden;
}

#heroImg {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: opacity 0.6s ease-in-out;
}

/* The "HiAnime" Shadow: Dark on bottom and left so text is readable */
.hi-vhero-overlay-shadow {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, #0b0b0b 5%, transparent 60%),
                linear-gradient(90deg, #0b0b0b 0%, transparent 80%);
    z-index: 2;
}

.hi-vhero-content {
    position: relative;
    z-index: 10;
    height: 100%;
    max-width: 1300px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 60px 20px;
}

.hi-spotlight-label {
    color: #ffc107;
    font-weight: 800;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 1px;
    margin-bottom: 10px;
    display: block;
}

.hi-vhero-title {
    font-size: 3.5rem;
    font-weight: 900;
    color: #fff;
    line-height: 1.1;
    max-width: 700px;
    margin-bottom: 15px;
    /* Clean text, no gradient like HiAnime */
}

.hi-vhero-meta {
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #fff;
    margin-bottom: 20px;
}

.hi-vhero-meta i { color: #ffc107; }

.hi-vhero-description {
    color: #ccc;
    font-size: 0.95rem;
    line-height: 1.6;
    max-width: 600px;
    margin-bottom: 30px;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* Limit text to 3 lines */
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* BUTTONS */
.hi-vhero-actions { display: flex; gap: 12px; }

.hi-btn-play {
    background: #ffc107;
    color: #000 !important;
    padding: 12px 30px;
    border-radius: 4px;
    font-weight: 800;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: 0.3s;
}

.hi-btn-detail {
    background: rgba(255,255,255,0.15);
    color: #fff;
    padding: 12px 30px;
    border-radius: 4px;
    font-weight: 800;
    border: none;
    transition: 0.3s;
}

.hi-btn-play:hover { background: #fff; transform: translateY(-2px); }
.hi-btn-detail:hover { background: rgba(255,255,255,0.25); }

/* DOTS */
.hi-vhero-pagination {
    display: flex;
    gap: 8px;
    margin-top: 30px;
}

.vhero-dot {
    width: 12px;
    height: 12px;
    background: rgba(255,255,255,0.2);
    border-radius: 50%;
    cursor: pointer;
    transition: 0.3s;
}

.vhero-dot.active {
    background: #ffc107;
    width: 30px;
    border-radius: 10px;
}

/* 📱 MOBILE RESPONSIVENESS */
@media (max-width: 768px) {
    .hi-hero { height: 650px; } /* Taller for mobile to see the art */
    .hi-vhero-content { padding-bottom: 40px; text-align: center; align-items: center; }
    .hi-vhero-title { font-size: 2.2rem; }
    .hi-vhero-description { font-size: 0.85rem; -webkit-line-clamp: 2; }
    .hi-vhero-actions { width: 100%; flex-direction: column; }
    .hi-btn-play, .hi-btn-detail { width: 100%; justify-content: center; }
    .hi-vhero-overlay-shadow {
        background: linear-gradient(0deg, #0b0b0b 40%, transparent 100%);
    }
}
