/*
 * StreamVault — public site stylesheet (Movie Gather inspired dark cinema theme).
 *
 * This file is the canonical stylesheet for the public-facing website (site.php).
 * The admin dashboard uses its own inline CSS in views/layouts/header.php.
 */

:root {
    /* Backgrounds — very dark with cool slate tint */
    --bg-deep:   #050912;
    --bg-base:   #0B1220;
    --bg-raised: #111B2E;
    --bg-card:   #15213A;
    --bg-elev:   #1B2A48;

    /* Text */
    --t-1: #E2E8F0;   /* primary */
    --t-2: #B4C2D5;   /* secondary */
    --t-3: #7E8CA3;   /* muted */
    --t-4: #4A5667;   /* very muted */

    /* Accents */
    --a-flame:   #0EA5E9;   /* nav flame / active */
    --a-orange:  #38BDF8;
    --a-amber:   #7DD3FC;
    --a-cream:   #FBF6E9;
    --a-imdb:    #F5C518;

    /* Status */
    --ok:    #22C55E;
    --bad:   #EF4444;
    --info:  #38BDF8;

    /* Lines / overlays */
    --line:        rgba(255, 240, 220, 0.08);
    --line-strong: rgba(255, 240, 220, 0.16);
    --shadow-card: 0 12px 40px rgba(0,0,0,0.5);
    --shadow-pop:  0 24px 60px rgba(0,0,0,0.7);

    /* Layout */
    --container: 1280px;
    --header-h:  74px;
    --radius-xl: 22px;
    --radius-lg: 16px;
    --radius:    12px;
    --radius-sm: 8px;
    --ease:      cubic-bezier(0.4, 0, 0.2, 1);
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    background:var(--bg-deep);
    color:var(--t-1);
    min-height:100vh;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}

/* Subtle cool radial glow underneath everything */
.site-bg-glow{
    position:fixed;inset:0;pointer-events:none;z-index:0;
    background:
        radial-gradient(ellipse at 50% -10%, rgba(14,165,233,0.14) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 30%, rgba(56,189,248,0.10) 0%, transparent 60%),
        radial-gradient(ellipse at 20% 80%, rgba(15,30,55,0.6) 0%, transparent 70%);
}

/* ========== Header ========== */
.site-header{
    position:sticky;top:0;z-index:50;
    height:var(--header-h);
    display:grid;
    grid-template-columns:auto auto 1fr auto auto;
    align-items:center;gap:24px;
    padding:0 36px;
    background:rgba(10,8,5,0.85);
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px;}
.brand-mark{
    width:34px;height:34px;border-radius:8px;
    display:grid;place-items:center;font-weight:700;font-size:18px;
    background:linear-gradient(135deg,#0EA5E9,#38BDF8);color:#0B1220;
    font-family:'Playfair Display',serif;
    box-shadow:0 4px 14px rgba(14,165,233,0.35);
}
.brand-name{display:flex;flex-direction:column;line-height:1;}
.brand-name strong{font-size:14px;letter-spacing:1.5px;font-weight:800;}
.brand-name span{font-size:11px;letter-spacing:2.5px;color:var(--t-3);font-weight:500;}

.main-nav{display:flex;align-items:center;gap:6px;}
.main-nav a{
    position:relative;display:inline-flex;align-items:center;gap:8px;
    padding:10px 16px;border-radius:8px;
    font-size:13px;font-weight:600;letter-spacing:1.5px;
    color:var(--t-3);
    transition:color .2s var(--ease), background .2s var(--ease);
}
.main-nav a:hover{color:var(--t-1);background:rgba(255,255,255,0.04);}
.main-nav a.active{color:var(--t-1);}
.main-nav a.active i{color:var(--a-flame);filter:drop-shadow(0 0 8px rgba(14,165,233,0.6));}
.main-nav a.active::after{
    content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
    width:24px;height:2px;border-radius:2px;
    background:linear-gradient(90deg,transparent,var(--a-flame),transparent);
    box-shadow:0 0 12px var(--a-flame);
}

.search{position:relative;justify-self:center;width:min(420px,40vw);}
.search i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--t-3);font-size:13px;}
.search input{
    width:100%;padding:10px 16px 10px 42px;
    border-radius:999px;border:1px solid var(--line);
    background:rgba(255,255,255,0.04);color:var(--t-1);
    font-size:14px;
    transition:all .2s var(--ease);
}
.search input:focus{
    outline:none;border-color:rgba(14,165,233,0.4);
    background:rgba(255,255,255,0.06);
    box-shadow:0 0 0 3px rgba(14,165,233,0.10);
}
.search input::placeholder{color:var(--t-3);}

.user-bar{display:flex;align-items:center;gap:10px;}
.icon-pill{
    width:38px;height:38px;border-radius:50%;
    background:rgba(255,255,255,0.04);border:1px solid var(--line);
    color:var(--t-2);font-size:14px;
    display:grid;place-items:center;
    transition:all .2s var(--ease);
}
.icon-pill:hover{color:var(--t-1);border-color:var(--line-strong);}
.profile-chip{
    display:flex;align-items:center;gap:10px;
    padding:4px 10px 4px 4px;border-radius:999px;
    background:rgba(255,255,255,0.04);border:1px solid var(--line);
}
.profile-chip .avatar{
    width:32px;height:32px;border-radius:50%;
    background:linear-gradient(135deg,#0EA5E9,#38BDF8);color:#0B1220;
    display:grid;place-items:center;font-weight:700;font-size:13px;
}
.profile-chip .meta{display:flex;flex-direction:column;line-height:1.1;}
.profile-chip .meta .name{font-size:13px;font-weight:600;}
.profile-chip .meta .tag{font-size:10px;letter-spacing:1.2px;color:var(--a-flame);font-weight:600;text-transform:uppercase;}
.profile-chip .chev{color:var(--t-3);font-size:11px;}

.mobile-toggle{
    display:none;
    width:38px;height:38px;border-radius:8px;
    background:rgba(255,255,255,0.04);border:1px solid var(--line);
    color:var(--t-1);
}

/* ========== Main container ========== */
.site-main{
    position:relative;z-index:1;
    max-width:var(--container);
    margin:0 auto;
    padding:32px 36px 60px;
}

/* ========== Hero section ========== */
.hero-row{
    display:grid;
    grid-template-columns:1fr 320px;
    gap:28px;
    margin-bottom:36px;
}
.hero{
    position:relative;
    border-radius:var(--radius-xl);
    overflow:hidden;
    aspect-ratio:16/9;
    background:linear-gradient(160deg,#0B1220 0%,#050912 100%);
    box-shadow:var(--shadow-pop);
}
.hero .slides{position:absolute;inset:0;}
.hero .slide{
    position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease);
    background-size:cover;background-position:center;
}
.hero .slide.active{opacity:1;}
.hero::after{
    content:'';position:absolute;inset:0;pointer-events:none;
    background:
        radial-gradient(ellipse at 80% 40%, transparent 0%, rgba(0,0,0,0.5) 100%),
        linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.85) 100%);
}
.hero-content{
    position:absolute;inset:0;z-index:2;
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:36px 40px;
}
.hero-year{
    font-family:'Playfair Display',serif;
    font-size:18px;font-weight:600;color:var(--a-amber);letter-spacing:2px;
}
.hero-title{
    font-family:'Playfair Display',serif;
    font-size:clamp(32px,5vw,52px);font-weight:700;line-height:1.05;letter-spacing:-1px;
    margin:6px 0 14px;text-shadow:0 4px 24px rgba(0,0,0,0.6);
}
.hero-meta{display:flex;align-items:center;gap:18px;font-size:13px;color:var(--t-2);}
.hero-meta span{display:inline-flex;align-items:center;gap:6px;}
.hero-meta .imdb{color:var(--a-imdb);font-weight:600;}

.play-fab{
    position:absolute;right:40px;bottom:40px;z-index:3;
    width:72px;height:72px;border-radius:50%;
    background:rgba(255,255,255,0.12);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,0.3);
    color:#fff;display:grid;place-items:center;
    font-size:22px;
    transition:all .25s var(--ease);
    box-shadow:0 12px 30px rgba(0,0,0,0.5);
}
.play-fab:hover{transform:scale(1.08);background:rgba(14,165,233,0.85);border-color:transparent;}
.hero-dots{
    position:absolute;top:24px;left:32px;z-index:3;
    display:flex;gap:6px;
}
.hero-dots button{
    width:24px;height:5px;border-radius:99px;background:rgba(255,255,255,0.25);
    transition:all .2s var(--ease);
}
.hero-dots button.active{background:#fff;width:32px;}

/* Now watching panel */
.now-watching{display:flex;flex-direction:column;gap:14px;}
.section-title{
    font-family:'Playfair Display',serif;
    font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0 0 14px;
}
.now-card{
    display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center;
    padding:8px;border-radius:var(--radius-lg);
    background:rgba(255,255,255,0.03);border:1px solid var(--line);
    transition:all .2s var(--ease);
}
.now-card:hover{background:rgba(255,255,255,0.05);border-color:var(--line-strong);}
.now-card .thumb{
    position:relative;width:96px;height:64px;border-radius:var(--radius);overflow:hidden;
    background:linear-gradient(135deg,#1B2A48,#050912);
}
.now-card .thumb img{width:100%;height:100%;object-fit:cover;}
.now-card .thumb .play{
    position:absolute;inset:0;display:grid;place-items:center;
    background:rgba(0,0,0,0.35);color:#fff;
    font-size:14px;
}
.now-card .thumb .badge-views{
    position:absolute;left:6px;bottom:6px;
    background:rgba(0,0,0,0.6);color:var(--t-1);
    font-size:10px;font-weight:600;padding:2px 6px;border-radius:99px;
    backdrop-filter:blur(4px);
    display:flex;align-items:center;gap:3px;
}
.now-card .info{display:flex;flex-direction:column;gap:6px;}
.now-card .info .t{font-size:14px;font-weight:600;}
.now-card .info .stats{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t-3);}
.now-card .info .stats .imdb{color:var(--a-imdb);}
.now-card .info .pills{display:flex;gap:4px;flex-wrap:wrap;}
.now-card .info .pills span{
    font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px;
    background:rgba(14,165,233,0.12);color:var(--a-flame);
}

/* ========== Genres ========== */
.genres-row{
    display:flex;align-items:center;gap:14px;
    padding:18px 0 26px;
    flex-wrap:wrap;
}
.genres-label{
    font-size:13px;color:var(--t-3);max-width:80px;line-height:1.3;
}
.genres-list{display:flex;gap:8px;flex-wrap:wrap;flex:1;}
.genre-pill{
    display:inline-flex;align-items:center;gap:8px;
    padding:9px 18px;border-radius:999px;
    background:rgba(255,255,255,0.04);border:1px solid var(--line);
    color:var(--t-2);font-size:13px;font-weight:600;
    transition:all .2s var(--ease);
}
.genre-pill:hover{color:var(--t-1);border-color:rgba(14,165,233,0.4);background:rgba(14,165,233,0.08);}
.genre-pill.active{
    background:linear-gradient(135deg,#0EA5E9,#38BDF8);
    color:#0B1220;border-color:transparent;
    box-shadow:0 6px 18px rgba(14,165,233,0.35);
}
.genre-pill i{font-size:13px;}

/* ========== Section / row of cards ========== */
.row-section{margin-bottom:42px;}
.row-head{
    display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;
}
.row-head h2{
    font-family:'Playfair Display',serif;
    font-size:26px;font-weight:700;letter-spacing:-.3px;margin:0;
}
.row-arrows{display:flex;gap:8px;}
.row-arrow{
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--t-2);
    display:grid;place-items:center;
    transition:all .2s var(--ease);font-size:13px;
}
.row-arrow:hover{color:var(--t-1);border-color:var(--line-strong);background:rgba(255,255,255,0.08);}

.h-scroll{
    display:flex;gap:18px;overflow-x:auto;padding-bottom:6px;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
}
.h-scroll::-webkit-scrollbar{display:none;}

/* Poster card */
.card-poster{
    flex:0 0 auto;width:148px;
    scroll-snap-align:start;
    display:flex;flex-direction:column;gap:10px;
    transition:transform .25s var(--ease);
}
.card-poster:hover{transform:translateY(-4px);}
.card-poster .poster{
    position:relative;
    width:100%;aspect-ratio:2/3;border-radius:var(--radius-lg);overflow:hidden;
    background:linear-gradient(135deg,#1B2A48,#050912);
    box-shadow:var(--shadow-card);
}
.card-poster .poster img{width:100%;height:100%;object-fit:cover;transition:transform .35s var(--ease);}
.card-poster:hover .poster img{transform:scale(1.05);}
.card-poster .poster .ph{
    position:absolute;inset:0;display:grid;place-items:center;
    color:var(--t-4);font-size:32px;
}
.card-poster .poster .play-mini{
    position:absolute;inset:0;display:grid;place-items:center;
    background:rgba(0,0,0,0);transition:background .25s var(--ease);
    opacity:0;
}
.card-poster:hover .poster .play-mini{background:rgba(0,0,0,0.4);opacity:1;}
.card-poster .poster .play-mini i{
    width:48px;height:48px;border-radius:50%;
    background:rgba(14,165,233,0.9);color:#0B1220;
    display:grid;place-items:center;font-size:16px;
    box-shadow:0 6px 18px rgba(0,0,0,0.4);
}
.card-poster .stats{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--t-3);}
.card-poster .stats .imdb{color:var(--a-imdb);font-weight:600;}
.card-poster .title{font-size:14px;font-weight:600;color:var(--t-1);line-height:1.3;}

/* Channel card (live) */
.card-channel{
    flex:0 0 auto;width:200px;
    background:linear-gradient(160deg,var(--bg-card),var(--bg-base));
    border:1px solid var(--line);
    border-radius:var(--radius-lg);
    padding:18px;display:flex;flex-direction:column;align-items:center;gap:12px;
    transition:all .25s var(--ease);
    scroll-snap-align:start;
}
.card-channel:hover{transform:translateY(-3px);border-color:var(--a-flame);box-shadow:0 12px 28px rgba(14,165,233,0.18);}
.card-channel .logo{
    width:80px;height:80px;border-radius:50%;
    background:rgba(255,255,255,0.06);border:1px solid var(--line);
    display:grid;place-items:center;overflow:hidden;
}
.card-channel .logo img{width:64px;height:64px;object-fit:contain;}
.card-channel .logo .ph{font-size:28px;color:var(--t-3);}
.card-channel .name{font-size:15px;font-weight:600;text-align:center;}
.card-channel .badge-live{
    display:inline-flex;align-items:center;gap:6px;
    background:rgba(239,68,68,0.16);color:#FCA5A5;
    font-size:10px;letter-spacing:1.5px;font-weight:700;
    padding:3px 10px;border-radius:99px;text-transform:uppercase;
}
.card-channel .badge-live .dot{
    width:6px;height:6px;border-radius:50%;background:var(--bad);
    animation:livePulse 1.4s ease-in-out infinite;
}
@keyframes livePulse{
    0%,100%{opacity:1;transform:scale(1);}
    50%{opacity:0.5;transform:scale(0.7);}
}

/* Page-level grid (Movies/Series/Live full pages) */
.page-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
    gap:24px;
}
.page-grid.channels{
    grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
}

/* ========== Page header (sub-pages) ========== */
.page-banner{
    display:flex;justify-content:space-between;align-items:flex-end;
    padding-bottom:18px;border-bottom:1px solid var(--line);
    margin-bottom:28px;flex-wrap:wrap;gap:14px;
}
.page-banner h1{
    font-family:'Playfair Display',serif;
    font-size:36px;font-weight:700;letter-spacing:-.5px;margin:0;
}
.page-banner .sub{color:var(--t-3);font-size:14px;margin-top:6px;}

/* Filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;}

/* ========== Detail page ========== */
.detail-hero{
    position:relative;
    margin:-32px -36px 36px;
    padding:60px 36px 36px;
    overflow:hidden;
    border-bottom:1px solid var(--line);
}
.detail-hero .bg{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    filter:blur(20px) brightness(0.5);
    transform:scale(1.1);
}
.detail-hero::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(10,8,5,0.5) 0%,rgba(10,8,5,0.95) 100%);
}
.detail-hero .inner{
    position:relative;z-index:1;
    max-width:var(--container);margin:0 auto;
    display:grid;grid-template-columns:280px 1fr;gap:36px;
    align-items:flex-start;
}
.detail-hero .poster{
    border-radius:var(--radius-xl);overflow:hidden;
    aspect-ratio:2/3;
    background:linear-gradient(160deg,#1B2A48,#050912);
    box-shadow:var(--shadow-pop);
}
.detail-hero .poster img{width:100%;height:100%;object-fit:cover;}
.detail-hero .meta h1{
    font-family:'Playfair Display',serif;
    font-size:clamp(32px,5vw,48px);font-weight:700;letter-spacing:-.8px;line-height:1.05;
    margin:0 0 12px;
}
.detail-hero .meta .stats{display:flex;align-items:center;gap:16px;color:var(--t-2);font-size:14px;margin-bottom:18px;}
.detail-hero .meta .stats .imdb{color:var(--a-imdb);font-weight:600;}
.detail-hero .meta .pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.detail-hero .meta .description{font-size:15px;color:var(--t-2);line-height:1.7;max-width:680px;}
.detail-hero .actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;}

.btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:12px 22px;border-radius:99px;font-size:14px;font-weight:600;
    transition:all .2s var(--ease);
}
.btn-primary{
    background:linear-gradient(135deg,#0EA5E9,#38BDF8);color:#0B1220;
    box-shadow:0 8px 22px rgba(14,165,233,0.30);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(14,165,233,0.45);}
.btn-ghost{background:rgba(255,255,255,0.06);color:var(--t-1);border:1px solid var(--line);}
.btn-ghost:hover{background:rgba(255,255,255,0.1);border-color:var(--line-strong);}

/* Player */
.player-wrap{
    margin-bottom:32px;border-radius:var(--radius-xl);overflow:hidden;
    background:#000;box-shadow:var(--shadow-pop);
}
.player-wrap video{width:100%;display:block;background:#000;}
.player-wrap iframe{width:100%;aspect-ratio:16/9;border:none;display:block;background:#000;}

/* Episode list (anime detail) */
.episodes{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:14px;}
.ep-card{
    display:flex;align-items:center;gap:12px;padding:12px;
    background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);
    transition:all .2s var(--ease);
}
.ep-card:hover{border-color:var(--a-flame);background:var(--bg-elev);}
.ep-card .num{
    width:38px;height:38px;border-radius:10px;
    background:rgba(14,165,233,0.15);color:var(--a-flame);
    display:grid;place-items:center;font-weight:700;font-size:14px;
    flex-shrink:0;
}
.ep-card .ep-title{font-size:13px;font-weight:600;}
.ep-card .ep-sub{font-size:11px;color:var(--t-3);margin-top:2px;}

/* Empty state */
.empty{
    text-align:center;padding:60px 20px;
    color:var(--t-3);
    border:1px dashed var(--line);
    border-radius:var(--radius-xl);
    background:rgba(255,255,255,0.02);
}
.empty i{font-size:48px;color:var(--t-4);margin-bottom:14px;display:block;}
.empty h3{color:var(--t-1);margin:0 0 6px;font-family:'Playfair Display',serif;}

/* ========== Footer ========== */
.site-footer{
    margin-top:60px;
    border-top:1px solid var(--line);
    padding:48px 36px 24px;
    background:rgba(0,0,0,0.5);
    position:relative;z-index:1;
}
.footer-cols{
    max-width:var(--container);margin:0 auto;
    display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:28px;
    margin-bottom:32px;
}
.site-footer h4{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--t-3);margin:0 0 14px;}
.site-footer a{display:block;color:var(--t-2);font-size:14px;margin-bottom:8px;transition:color .15s var(--ease);}
.site-footer a:hover{color:var(--t-1);}
.site-footer .muted{color:var(--t-3);font-size:13px;line-height:1.6;margin:12px 0 0;}
.footer-bottom{
    max-width:var(--container);margin:0 auto;
    border-top:1px solid var(--line);padding-top:18px;
    color:var(--t-3);font-size:12px;text-align:center;
}

/* ========== Responsive ========== */
@media (max-width: 1100px){
    .hero-row{grid-template-columns:1fr;}
    .now-watching{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;}
    .detail-hero .inner{grid-template-columns:200px 1fr;}
}
@media (max-width: 880px){
    .site-header{grid-template-columns:auto auto auto;padding:0 16px;}
    .main-nav,.search,.user-bar{display:none;}
    .mobile-toggle{display:grid;}
    body.nav-open .main-nav{
        display:flex;flex-direction:column;
        position:absolute;top:var(--header-h);left:0;right:0;
        background:var(--bg-base);padding:16px;border-bottom:1px solid var(--line);
        gap:4px;
    }
    .site-main{padding:18px 16px 40px;}
    .detail-hero{margin:-18px -16px 28px;padding:40px 16px 28px;}
    .detail-hero .inner{grid-template-columns:1fr;}
    .detail-hero .poster{width:60%;margin:0 auto;}
    .footer-cols{grid-template-columns:1fr 1fr;}
}
@media (max-width: 520px){
    .hero-content{padding:24px 22px;}
    .play-fab{right:22px;bottom:22px;width:58px;height:58px;font-size:18px;}
    .footer-cols{grid-template-columns:1fr;}
}
