@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300..700&family=Be+Vietnam+Pro:wght@300;400;500;600;700&display=swap');

:root{
  --bg:#0a0a0f;--bg2:#111118;--bg3:#1a1a24;
  --surface:#16161f;--surface2:#1e1e2a;
  --border:rgba(255,255,255,0.07);
  --accent:#e50914;--gold:#f5c518;
  --text:#e8e8f0;--text2:#9999b3;--text3:#555570;
  --radius:8px;--nav-h:64px;
  --max-w:1500px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Be Vietnam Pro',sans-serif;font-size:14px;min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

.banner-bottom {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  background: var(--bg2);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  gap: 12px;
}
.banner-bottom a { display: flex; align-items: center; justify-content: center; max-width: 728px; width: 100%; }
.banner-bottom img { max-width: 100%; max-height: 80px; object-fit: contain; border-radius: 4px; display: block; }
.banner-bottom-close {
  flex-shrink: 0;
  width: 30px; height: 30px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--text2);
  font-size: 14px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.banner-bottom-close:hover { background: var(--accent); border-color: var(--accent); color: #fff; }


.banner-sidebar{position:fixed;top:var(--nav-h);bottom:0;width:130px;display:none;align-items:flex-start;justify-content:center;padding-top:25px;z-index:10;pointer-events:none}
.banner-sidebar-inner{width:120px;min-height:240px;pointer-events:auto}
.banner-sidebar.left{left:0}
.banner-sidebar.right{right:0}
@media(min-width:1780px){.banner-sidebar{display:flex}}




.site-wrap{max-width:var(--max-w);margin:0 auto;position:relative}


#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:linear-gradient(to bottom,rgba(10,10,15,.98),rgba(10,10,15,.7));backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .3s}
#navbar.scrolled{background:rgba(10,10,15,.99)}
.navbar-inner{max-width:var(--max-w);margin:0 auto;height:100%;display:flex;align-items:center;padding:0 24px;gap:16px}
.logo{font-family:'Space Grotesk',sans-serif;font-size:26px;color:var(--accent);letter-spacing:2px;cursor:pointer;white-space:nowrap;flex-shrink:0;text-shadow:0 0 20px rgba(229,9,20,.4);text-decoration:none}
.logo span{color:var(--text2);font-size:16px;margin-left:1px}
.nav-links{display:flex;align-items:center;gap:4px;flex:1}
.nav-btn{padding:7px 12px;border-radius:6px;color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;border:none;background:transparent;font-family:inherit}
.nav-btn:hover,.nav-btn.active{color:var(--text);background:var(--surface)}
.nav-dropdown{position:relative}
.nav-dropdown::after{content:'';position:absolute;bottom:0;left:0;right:0;height:16px;z-index:99}
.nav-dropdown>.nav-btn::after{content:'▾';margin-left:4px;font-size:10px;opacity:.6}
.dropdown-menu{position:absolute;top:100%;left:0;background:var(--bg2);border:1px solid var(--border);border-radius:10px;min-width:200px;padding:8px;display:none;box-shadow:0 20px 60px rgba(0,0,0,.6);z-index:100;max-height:400px;overflow-y:auto;padding-top:16px;margin-top:0}
.dropdown-menu.wide{min-width:540px;flex-wrap:wrap;gap:2px}
.nav-dropdown::after{content:'';position:absolute;top:100%;left:0;right:0;height:16px;z-index:99}
.nav-dropdown:hover .dropdown-menu{display:block}
.nav-dropdown:hover .dropdown-menu.wide{display:flex}
.dropdown-item{display:block;padding:8px 12px;color:var(--text2);border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s;white-space:nowrap}
.dropdown-item:hover{color:var(--text);background:var(--surface)}
.dropdown-menu.wide .dropdown-item{width:calc(33.33% - 2px)}


.search-wrap{position:relative;margin-left:auto}
.search-bar-inline{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:24px;overflow:hidden;transition:border-color .2s;width:280px}
.search-bar-inline:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px rgba(229,9,20,.15)}
.search-icon-inline{padding:0 10px 0 14px;color:var(--text2);font-size:14px;pointer-events:none;flex-shrink:0}
.search-input-inline{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;font-family:inherit;padding:9px 4px;min-width:0}
.search-input-inline::placeholder{color:var(--text3)}
.search-btn-inline{padding:9px 16px;background:var(--accent);color:#fff;border:none;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .2s;font-family:inherit;flex-shrink:0}
.search-btn-inline:hover{opacity:.85}
.search-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--bg2);border:1px solid var(--border);border-radius:10px;display:none;z-index:300;box-shadow:0 20px 60px rgba(0,0,0,.7);width:420px;max-height:480px;overflow-y:auto}
.search-dropdown.open{display:block}
.search-result-item{display:flex;gap:10px;padding:8px;border-radius:6px;cursor:pointer;transition:background .2s}
.search-result-item:hover{background:var(--surface)}
.search-result-item img{width:48px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--surface2)}
.search-result-info h4{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;line-height:1.3}
.search-result-info p{font-size:11px;color:var(--text2)}
.mobile-menu-btn{display:none;width:38px;height:38px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:18px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;margin-left:8px}


#mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1998;display:none;backdrop-filter:blur(4px)}
#mobile-overlay.open{display:block}
#mobile-drawer{position:fixed;top:0;right:-100%;width:min(340px,92vw);height:100vh;background:var(--bg2);z-index:1999;transition:right .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.5)}
#mobile-drawer.open{right:0}
.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1}
.mobile-close-btn{width:32px;height:32px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text2);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mobile-drawer-body{padding:12px}
.mobile-nav-link{padding:12px 14px;border-radius:8px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;margin-bottom:2px;display:flex;align-items:center;gap:8px}
.mobile-nav-link:hover{background:var(--surface)}
.mobile-section-title{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);font-weight:800;padding:16px 14px 8px;border-top:1px solid var(--border)}
.mobile-grid{display:flex;flex-wrap:wrap;gap:6px;padding:0 6px 12px}
.mobile-tag{padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s}
.mobile-tag:hover,.mobile-tag.selected{background:rgba(229,9,20,.12);border-color:rgba(229,9,20,.4);color:var(--accent)}


#app{padding-top:var(--nav-h);padding-bottom:var(--banner-h,92px)}
.page{display:none}
.page.active{display:block}


.hero{position:relative;height:520px;overflow:hidden;margin-bottom:40px}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0d0d1a 0%,#1a0a0f 50%,#0a0d1a 100%)}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(229,9,20,.12) 0%,transparent 60%)}
.hero-content{max-width:var(--max-w);margin:0 auto;position:relative;z-index:2;height:100%;display:flex;align-items:center;padding:0 60px;gap:40px}
.hero-text{flex:1}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(229,9,20,.15);border:1px solid rgba(229,9,20,.3);color:var(--accent);padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:16px}
.hero-title{font-family:'Space Grotesk',sans-serif;font-size:56px;line-height:.95;margin-bottom:12px;background:linear-gradient(135deg,#fff 0%,#ccc 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.hero-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.hero-meta span{font-size:12px;color:var(--text2)}
.hero-meta .year{color:var(--gold);font-weight:700}
.hero-meta .dot{color:var(--text3)}
.hero-desc{color:var(--text2);font-size:14px;line-height:1.7;max-width:480px;margin-bottom:24px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-actions{display:flex;gap:12px}
.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 28px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-primary:hover{background:#c8070f;transform:translateY(-1px);box-shadow:0 8px 24px rgba(229,9,20,.4)}
.btn-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;background:rgba(255,255,255,.1);color:var(--text);border:1px solid rgba(255,255,255,.15);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-secondary:hover{background:rgba(255,255,255,.15)}
.hero-img{width:240px;flex-shrink:0;border-radius:12px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.08)}
.hero-img img{width:100%;height:360px;object-fit:cover;display:block}


.section{padding:0 32px 40px;max-width:var(--max-w);margin:0 auto}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-title{font-family:'Space Grotesk',sans-serif;font-size:22px;letter-spacing:1px;display:flex;align-items:center;gap:10px}
.section-title::before{content:'';width:4px;height:22px;background:var(--accent);border-radius:2px;display:inline-block}
.see-more-btn{padding:7px 16px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}
.see-more-btn:hover{border-color:var(--accent);color:var(--accent)}


.film-row-wrap{position:relative;overflow:hidden}
.film-row{display:flex;gap:14px;transition:transform .35s cubic-bezier(.4,0,.2,1);will-change:transform}
.film-row .film-card{flex:0 0 calc(20% - 12px);min-width:0} /* 5 on desktop */
.row-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;background:rgba(0,0,0,.7);border:1px solid var(--border);border-radius:50%;color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:all .2s;backdrop-filter:blur(4px)}
.row-nav:hover{background:var(--accent);border-color:var(--accent)}
.row-nav.prev{left:5px}
.row-nav.next{right:5px}
.row-nav:disabled{opacity:.3;cursor:not-allowed}


.film-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:1400px){.film-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:1000px){.film-grid{grid-template-columns:repeat(3,1fr)}}


.film-card{border-radius:var(--radius);overflow:hidden;background:var(--surface);cursor:pointer;transition:transform .25s,box-shadow .25s;position:relative}
.film-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 20px 50px rgba(0,0,0,.6);z-index:2}
.film-card-thumb{position:relative;aspect-ratio:2/3;overflow:hidden;background:var(--surface2)}
.film-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block}
.film-card:hover .film-card-thumb img{transform:scale(1.06)}
.film-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.3) 50%,transparent 100%);opacity:0;transition:opacity .25s;display:flex;flex-direction:column;justify-content:flex-end;padding:12px}
.film-card:hover .film-card-overlay{opacity:1}
.film-card-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:rgba(229,9,20,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;margin-left:2px}
.episode-badge{position:absolute;top:8px;right:8px;background:rgba(229,9,20,.9);color:#fff;font-size:10px;font-weight:700;padding:3px 7px;border-radius:4px}
.quality-badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.7);color:var(--gold);font-size:9px;font-weight:800;padding:3px 6px;border-radius:4px;letter-spacing:.5px;border:1px solid rgba(245,197,24,.3)}
.film-card-info{padding:10px 10px 12px}
.film-card-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.film-card-sub{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);flex-wrap:wrap}
.film-card-year{color:var(--gold);font-weight:600}


.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{border-radius:var(--radius);overflow:hidden}
.skeleton-thumb{aspect-ratio:2/3}
.skeleton-info{padding:10px}
.skeleton-line{height:13px;border-radius:4px;margin-bottom:6px}
.skeleton-line.short{width:60%}


#page-category .cat-header,#page-search .search-page-header{padding:32px 32px 20px;max-width:var(--max-w);margin:0 auto}
.cat-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.cat-title{font-family:'Space Grotesk',sans-serif;font-size:30px;letter-spacing:1px}
.sort-bar{display:flex;align-items:center;gap:10px}
.sort-label{font-size:12px;color:var(--text2);white-space:nowrap}
.sort-select{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:8px 12px;font-size:13px;font-family:inherit;cursor:pointer;outline:none}
.sort-select:focus{border-color:var(--accent)}


.filter-bar{display:flex;flex-wrap:wrap;gap:8px;padding:0 32px 20px;max-width:var(--max-w);margin:0 auto}
.filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.filter-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);font-weight:700;white-space:nowrap}
.filter-select{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text2);padding:6px 10px;font-size:12px;font-family:inherit;cursor:pointer;outline:none;transition:border-color .2s}
.filter-select:focus,.filter-select.active{border-color:rgba(229,9,20,.5);color:var(--text)}
.filter-select option{background:var(--bg2)}
.filter-btn{padding:6px 14px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s}
.filter-btn:hover{opacity:.85}
.filter-clear{padding:6px 14px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text2);font-size:12px;cursor:pointer;font-family:inherit;transition:all .2s}
.filter-clear:hover{border-color:var(--accent);color:var(--accent)}


.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:32px 0}
.page-btn{width:36px;height:36px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center}
.page-btn:hover{border-color:var(--accent);color:var(--accent)}
.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.page-btn:disabled{opacity:.3;cursor:not-allowed}


#page-detail .detail-hero{position:relative;min-height:420px;padding:40px 48px;display:flex;gap:40px;align-items:flex-start;overflow:hidden;max-width:var(--max-w);margin:0 auto}
#page-detail .detail-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0a0a0f 0%,#12080f 100%);z-index:0}
#page-detail .detail-hero-bg-img{position:absolute;inset:0;opacity:.08;background-size:cover;background-position:center;filter:blur(20px);z-index:0}
#page-detail .detail-hero>*{position:relative;z-index:1}
.detail-poster{width:220px;flex-shrink:0;border-radius:12px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.08)}
.detail-poster img{width:100%;display:block}
.detail-info{flex:1;min-width:0}
.detail-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.5px}
.badge-type{background:rgba(229,9,20,.15);color:var(--accent);border:1px solid rgba(229,9,20,.25)}
.badge-quality{background:rgba(245,197,24,.12);color:var(--gold);border:1px solid rgba(245,197,24,.25)}
.badge-status{background:rgba(39,174,96,.12);color:#2ecc71;border:1px solid rgba(46,204,113,.25)}
.badge-tmdb{background:rgba(1,180,228,.12);color:#01b4e4;border:1px solid rgba(1,180,228,.25)}
.detail-title{font-family:'Space Grotesk',sans-serif;font-size:42px;line-height:.95;margin-bottom:6px;word-break:break-word}
.detail-title-en{font-size:16px;color:var(--text2);font-weight:500;margin-bottom:16px;word-break:break-word}
.detail-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:20px}
.meta-item label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:3px;font-weight:700}
.meta-item span{font-size:13px;color:var(--text);font-weight:500;word-break:break-word}
.meta-item span.highlight{color:var(--gold)}
.detail-desc{color:var(--text2);font-size:14px;line-height:1.75;margin-bottom:20px;border-left:3px solid var(--accent);padding-left:16px}
.detail-genres{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.genre-tag{padding:5px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:11px;color:var(--text2);cursor:pointer;transition:all .2s}
.genre-tag:hover{border-color:var(--accent);color:var(--accent)}


.tmdb-section{padding:0 48px 24px;max-width:var(--max-w);margin:0 auto}
.tmdb-row{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:16px}
.tmdb-stat{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 20px;display:flex;flex-direction:column;gap:4px;min-width:120px}
.tmdb-stat label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);font-weight:700}
.tmdb-stat span{font-size:18px;font-weight:700;color:var(--gold)}


#player-section{background:var(--bg2);border-top:1px solid var(--border)}
.player-wrap{max-width:960px;margin:0 auto;padding:24px}
.player-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.player-title{font-size:15px;font-weight:600}
.player-ep-label{font-size:13px;color:var(--accent)}
.video-container{background:#000;border-radius:10px;overflow:hidden;position:relative;aspect-ratio:16/9;border:1px solid var(--border);min-height:200px}
.video-container iframe{width:100%;height:100%;border:none;display:block}
.video-container video{width:100%;height:100%;display:block;background:#000}
/* ArtPlayer overrides — đảm bảo player fill container */
.video-container #art-wrap,.video-container .art-video-player{width:100%!important;height:100%!important;border-radius:10px;overflow:hidden}
.no-video{display:flex;align-items:center;justify-content:center;height:100%;flex-direction:column;gap:12px;color:var(--text2)}
.no-video .icon{font-size:48px;opacity:.3}

.episodes-section{padding:24px 48px 40px;max-width:var(--max-w);margin:0 auto}
.episodes-title{font-family:'Space Grotesk',sans-serif;font-size:22px;letter-spacing:1px;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.episodes-title::before{content:'';width:4px;height:22px;background:var(--accent);border-radius:2px}
.server-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.server-tab{padding:7px 16px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:700;color:var(--text2);cursor:pointer;transition:all .2s}
.server-tab.active,.server-tab:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.episode-list{display:flex;flex-wrap:wrap;gap:8px}
.ep-btn{padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .2s;min-width:56px;text-align:center;font-family:inherit}
.ep-btn:hover{border-color:var(--accent);color:var(--accent)}
.ep-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

.loading-spinner{display:flex;justify-content:center;align-items:center;padding:60px 0;flex-direction:column;gap:16px}
.spinner{width:36px;height:36px;border:3px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:var(--text2);font-size:13px}
.empty-state{text-align:center;padding:80px 20px;color:var(--text2)}
.empty-state .icon{font-size:56px;opacity:.3;margin-bottom:16px}
.empty-state h3{font-size:18px;font-weight:600;color:var(--text);margin-bottom:8px}

.toast{position:fixed;bottom:24px;right:24px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 20px;color:var(--text);font-size:13px;font-weight:500;z-index:9999;transform:translateY(100px);opacity:0;transition:all .3s;box-shadow:0 10px 40px rgba(0,0,0,.5)}
.toast.show{transform:translateY(0);opacity:1}

footer{border-top:1px solid var(--border);padding:32px;text-align:center;color:var(--text3);font-size:12px;margin-top:40px}
footer strong{color:var(--text2)}


.search-page-header{padding:32px 32px 8px}
.search-page-header h2{font-family:'Space Grotesk',sans-serif;font-size:28px;letter-spacing:1px}
.search-page-header p{color:var(--text2);font-size:13px;margin-top:4px}


.lazy-hidden{opacity:0;transform:translateY(20px);transition:opacity .4s,transform .4s}
.lazy-visible{opacity:1;transform:none}


@media(max-width:900px){
  .nav-links{display:none}
  .mobile-menu-btn{display:flex}
  .search-bar-inline{width:200px}
  .tmdb-section,.episodes-section{padding-left:20px;padding-right:20px}
}
@media(max-width:768px){
  .filter-bar{padding:0 16px 16px}
  .film-row .film-card{flex:0 0 calc(33.33% - 10px)}
}
@media(max-width:600px){
  .search-bar-inline{width:150px}
  .search-dropdown{
  position:fixed;
  left:12px;
  right:12px;
  width:auto;
  top:72px;
  border-radius:12px;
  max-height:70vh;
}
  .hero{height:auto}
  .hero-content{flex-direction:column;padding:32px 20px;text-align:center;align-items:flex-start}
  .hero-img{display:none}
  .hero-title{font-size:36px}
  .section{padding:0 16px 32px}
  .film-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .film-row .film-card{flex:0 0 calc(50% - 8px)}
  #page-detail .detail-hero{flex-direction:column;padding:24px 20px}
  .detail-poster{width:160px;margin:0 auto}
  .episodes-section{padding:24px 20px 40px}
  #page-category .cat-header,.search-page-header{padding:20px 16px 16px}
  .filter-bar{padding:0 16px 12px}
  .tmdb-section{padding:0 20px 20px}
  .row-nav{width:40px;height:40px;font-size:13px}
  .row-nav.prev{left:5px}
  .row-nav.next{right:5px}
}

.tag-filter-wrap{display:flex;flex-wrap:wrap;gap:6px}
.tag-filter{padding:5px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s;user-select:none}
.tag-filter:hover{border-color:rgba(229,9,20,.4);color:var(--text)}
.tag-filter.selected{background:rgba(229,9,20,.15);border-color:rgba(229,9,20,.5);color:var(--accent)}

.auth-nav { display: flex; align-items: center; gap: 10px; margin-left: 12px; flex-shrink: 0; }
.nav-auth-btn {
  padding: 7px 16px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s;
  font-family: inherit;
  white-space: nowrap;
}
.nav-auth-btn:hover { opacity: .85; }
.user-menu { position: relative; display: flex; align-items: center; }
.user-avatar-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .2s;
  font-family: inherit;
}
.user-avatar-btn:hover { border-color: var(--accent); }
#user-avatar-img { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }
#user-avatar-letter {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: #fff;
}
.user-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  min-width: 200px;
  padding: 8px;
  display: none;
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  z-index: 500;
}
.user-dropdown.open { display: block; }
.user-dropdown-header {
  font-size: 11px; color: var(--text3); padding: 6px 10px 10px;
  border-bottom: 1px solid var(--border); margin-bottom: 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.user-dropdown-item {
  padding: 9px 12px; border-radius: 6px; font-size: 13px;
  color: var(--text2); cursor: pointer; transition: all .2s;
}
.user-dropdown-item:hover { background: var(--surface); color: var(--text); }
.user-dropdown-item.danger:hover { color: var(--accent); background: rgba(229,9,20,.08); }
.user-dropdown-sep { height: 1px; background: var(--border); margin: 6px 0; }

.auth-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.7);
  z-index: 9000;
  display: none;
  align-items: center; justify-content: center;
  backdrop-filter: blur(6px);
  padding: 16px;
}
.auth-modal-backdrop.open { display: flex; }
.auth-modal {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 0;
  width: min(440px, 100%);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 30px 80px rgba(0,0,0,.7);
}
.auth-tabs {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
  gap: 4px;
  position: sticky; top: 0;
  background: var(--bg2); z-index: 1;
}
.auth-tab {
  padding: 14px 16px;
  background: transparent;
  border: none; border-bottom: 2px solid transparent;
  color: var(--text2);
  font-size: 14px; font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  font-family: inherit;
  margin-bottom: -1px;
}
.auth-tab:hover { color: var(--text); }
.auth-tab.active { color: var(--text); border-bottom-color: var(--accent); }
.auth-modal-close {
  margin-left: auto;
  width: 32px; height: 32px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 6px; color: var(--text2);
  font-size: 15px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s; font-family: inherit;
}
.auth-modal-close:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
#auth-form-login, #auth-form-register { padding: 24px 24px 28px; }
.auth-sub { color: var(--text2); font-size: 13px; margin-bottom: 20px; line-height: 1.6; }
.auth-form-group { margin-bottom: 14px; }
.auth-label { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .8px; color: var(--text3); font-weight: 700; margin-bottom: 6px; }
.auth-input {
  width: 100%; background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px; color: var(--text);
  font-size: 14px; outline: none; transition: border-color .2s; font-family: inherit;
}
.auth-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(229,9,20,.12); }
.auth-err { color: var(--accent); font-size: 12px; margin-bottom: 10px; display: none; padding: 8px 12px; background: rgba(229,9,20,.08); border-radius: 6px; border: 1px solid rgba(229,9,20,.2); }
.auth-btn-primary {
  width: 100%; padding: 12px; background: var(--accent); color: #fff;
  border: none; border-radius: 8px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: opacity .2s; font-family: inherit;
}
.auth-btn-primary:hover { opacity: .85; }
.auth-btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.auth-divider { display: flex; align-items: center; gap: 12px; margin: 16px 0; color: var(--text3); font-size: 12px; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.auth-btn-google {
  width: 100%; padding: 11px; background: var(--surface); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .2s; font-family: inherit;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.auth-btn-google:hover { border-color: rgba(66,133,244,.5); background: rgba(66,133,244,.06); }

.btn-fav {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 22px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text2);
  font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .2s;
  font-family: inherit;
}
.btn-fav:hover { border-color: rgba(229,9,20,.4); color: var(--accent); }
.btn-fav.active { background: rgba(229,9,20,.12); border-color: rgba(229,9,20,.5); color: var(--accent); }

.watch-progress-bar {
  position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: rgba(255,255,255,.2);
}
.watch-progress-bar div { height: 100%; background: var(--accent); }

.history-del-btn {
  position: absolute; top: 6px; right: 6px; width: 26px; height: 26px;
  background: rgba(0,0,0,.6); border: 1px solid rgba(255,255,255,.1);
  border-radius: 50%; color: var(--text2); font-size: 12px;
  cursor: pointer; display: none; align-items: center; justify-content: center;
  transition: all .2s;
}
.film-card:hover .history-del-btn { display: flex; }
.history-del-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

.user-page-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 32px 32px 20px; max-width: var(--max-w); margin: 0 auto;
  flex-wrap: wrap; gap: 12px;
}
.user-page-header h2 { font-family: 'Space Grotesk', sans-serif; font-size: 28px; letter-spacing: 1px; }
.btn-sm-danger {
  padding: 7px 16px; background: transparent; border: 1px solid rgba(229,9,20,.4);
  border-radius: 6px; color: var(--accent); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: all .2s; font-family: inherit;
}
.btn-sm-danger:hover { background: rgba(229,9,20,.1); }

.account-page { max-width: 800px; margin: 0 auto; padding: 32px; }
.account-hero {
  display: flex; gap: 24px; align-items: center;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 16px; padding: 32px; margin-bottom: 24px;
}
.account-avatar img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }
.avatar-big {
  width: 80px; height: 80px; border-radius: 50%; background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; font-weight: 800; color: #fff;
}
.account-name { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.account-email { color: var(--text2); font-size: 13px; margin-bottom: 8px; }
.account-role { font-size: 12px; color: var(--text3); font-weight: 600; }
.account-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.account-card {
  background: var(--bg2); border: 1px solid var(--border); border-radius: 12px;
  padding: 24px; cursor: pointer; transition: all .2s; text-align: center;
}
.account-card:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: 0 12px 40px rgba(0,0,0,.4); }
.account-card-icon { font-size: 36px; margin-bottom: 12px; }
.account-card-title { font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.account-card-desc { font-size: 12px; color: var(--text2); }


.comment-section-wrap { padding: 0 48px 48px; max-width: var(--max-w); margin: 0 auto; }
@media(max-width:768px) { .comment-section-wrap { padding: 0 20px 40px; } }
.cmt-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.cmt-title { font-family: 'Space Grotesk', sans-serif; font-size: 20px; letter-spacing: .5px; display: flex; align-items: center; gap: 10px; }
.cmt-title::before { content: ''; width: 4px; height: 20px; background: var(--accent); border-radius: 2px; }
.cmt-compose { display: flex; gap: 12px; margin-bottom: 24px; }
.cmt-compose-right { flex: 1; }
.cmt-avatar-sm {
  width: 36px; height: 36px; border-radius: 50%; background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.cmt-textarea {
  width: 100%; background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px; color: var(--text);
  font-size: 13px; outline: none; resize: vertical; transition: border-color .2s;
  font-family: inherit; line-height: 1.6;
}
.cmt-textarea:focus { border-color: var(--accent); }
.cmt-send-btn {
  padding: 7px 18px; background: var(--accent); color: #fff;
  border: none; border-radius: 6px; font-size: 12px; font-weight: 700;
  cursor: pointer; transition: opacity .2s; font-family: inherit;
}
.cmt-send-btn:hover { opacity: .85; }
.cmt-guest-bar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px 20px; margin-bottom: 24px;
}
.cmt-item { display: flex; gap: 12px; margin-bottom: 20px; }
.cmt-reply { margin-top: 12px; padding-left: 16px; border-left: 2px solid var(--border); }
.cmt-body { flex: 1; min-width: 0; }
.cmt-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.cmt-author { font-size: 13px; font-weight: 700; color: var(--text); }
.cmt-admin-badge {
  padding: 2px 7px; background: rgba(229,9,20,.12); color: var(--accent);
  border: 1px solid rgba(229,9,20,.25); border-radius: 10px; font-size: 10px; font-weight: 700;
}
.cmt-time { font-size: 11px; color: var(--text3); }
.cmt-content {
  font-size: 14px; color: var(--text2); line-height: 1.65;
  word-break: break-word; margin-bottom: 8px;
  white-space: pre-wrap;
}
.cmt-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.cmt-action-btn {
  padding: 4px 10px; background: transparent; border: 1px solid var(--border);
  border-radius: 6px; color: var(--text3); font-size: 12px; cursor: pointer;
  transition: all .2s; font-family: inherit;
}
.cmt-action-btn:hover { border-color: rgba(229,9,20,.3); color: var(--accent); }
.cmt-action-btn.liked { color: var(--accent); border-color: rgba(229,9,20,.4); }
.cmt-action-btn.danger:hover { color: #ff4444; border-color: rgba(255,68,68,.3); }
.cmt-replies { margin-top: 12px; }
.reply-form-wrap { margin-top: 10px; }

@media(max-width:600px) {
  .auth-nav { margin-left: 8px; }
  #user-display-name { display: none; }
  .user-page-header { padding: 20px 16px; }
  .account-page { padding: 20px 16px; }
  .account-hero { flex-direction: column; text-align: center; padding: 20px; }
}

.footer-movies {
    background-color: #1a1a1a;
    color: #ccc;
    padding: 40px 0 20px;
    font-family: Space Grotesk, sans-serif;
}

.footer-container {
    display: flex;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    justify-content: space-between;
}

.footer-column {
    flex: 1;
    min-width: 200px;
    margin-bottom: 20px;
}

.footer-column h3, .footer-column h4 {
    color: #fff;
    margin-bottom: 15px;
    font-size: 1.2rem;
}

.footer-column ul {
    list-style: none;
    padding: 0;
}

.footer-column ul li {
    margin-bottom: 8px;
}

.footer-column ul li a {
    color: #ccc;
    text-decoration: none;
    transition: color 0.3s;
}

.footer-column ul li a:hover {
    color: #ffad06;
}

.footer-column strong {
    color: #fff;
}

.footer-bottom {
    text-align: center;
    border-top: 1px solid #333;
    margin-top: 30px;
    padding-top: 20px;
    font-size: 0.9rem;
}

@media (max-width: 768px) {
    .footer-column {
        flex: 1 1 50%;
    }
}
