/* ============================================================
 * Ghiền Phim Theme — main.css
 * Dark premium UI inspired by Ophim, structure from MTP.
 * ============================================================ */

:root{
	--primary:#ff7c1d;
	--primary-2:#ff9a4a;
	--primary-soft:rgba(255,124,29,.15);
	--accent:#1cd17b;
	--danger:#e53935;
	--bg:#0a0c11;
	--bg-2:#11141c;
	--bg-3:#161b25;
	--bg-4:#1d232f;
	--text:#e6e9ef;
	--text-muted:#8d97a7;
	--border:rgba(255,255,255,.06);
	--border-strong:rgba(255,255,255,.1);
	--radius:10px;
	--radius-lg:14px;
	--container:1320px;
	--header-h:64px;
	--shadow-sm:0 2px 8px rgba(0,0,0,.18);
	--shadow-lg:0 12px 30px rgba(0,0,0,.4);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;line-height:1.5;scroll-behavior:smooth}
body{margin:0;font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .15s}
a:hover{color:var(--primary)}
button{font:inherit;cursor:pointer}
.screen-reader-text{position:absolute!important;clip:rect(0 0 0 0);width:1px;height:1px;overflow:hidden;white-space:nowrap}
.skip-link{position:absolute;left:-9999px;top:0;background:#fff;color:#000;padding:.5rem 1rem;z-index:9999}
.skip-link:focus{left:0}

.container{max-width:var(--container);margin:0 auto;padding:0 16px}

/* =========================================================
 * HEADER + NAVBAR
 * ========================================================= */
.site-header{
	position:sticky;top:0;z-index:50;
	background:linear-gradient(180deg,rgba(10,12,17,.95) 0%,rgba(10,12,17,.85) 100%);
	backdrop-filter:saturate(180%) blur(12px);
	border-bottom:1px solid var(--border)
}
.header-inner{display:flex;align-items:center;gap:1.25rem;height:var(--header-h)}
.site-branding{flex:0 0 auto}
.site-title{
	display:inline-flex;align-items:center;gap:.5rem;
	font-weight:800;font-size:1.2rem;letter-spacing:.5px;
	color:#fff;
	white-space:nowrap
}
.site-title:hover{color:#fff}
.site-title-mark{
	display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;
	background:linear-gradient(135deg,var(--primary) 0%,var(--danger) 100%);
	border-radius:8px;color:#fff;font-size:.85rem;
	box-shadow:0 4px 12px rgba(255,124,29,.4)
}
.custom-logo{max-height:42px;width:auto}

.primary-nav{flex:1 1 auto;overflow:hidden}
.primary-menu{display:flex;list-style:none;margin:0;padding:0;gap:.15rem}
.primary-menu>li{position:relative}
.primary-menu>li>a{
	display:block;padding:.55rem .9rem;border-radius:6px;
	color:rgba(230,233,239,.85);font-weight:500;font-size:.92rem;
	transition:all .15s
}
.primary-menu>li>a:hover{background:var(--bg-3);color:var(--primary)}
.primary-menu>li.current-menu-item>a,.primary-menu>li.current-menu-parent>a{color:var(--primary)}
.primary-menu .sub-menu{
	position:absolute;left:0;top:100%;list-style:none;margin:0;padding:.5rem;
	background:var(--bg-2);border:1px solid var(--border);border-radius:8px;
	display:none;min-width:200px;z-index:51;
	box-shadow:var(--shadow-lg)
}
.primary-menu li:hover>.sub-menu{display:block}
.primary-menu .sub-menu a{display:block;padding:.5rem .75rem;border-radius:6px;font-size:.9rem;color:var(--text)}
.primary-menu .sub-menu a:hover{background:var(--primary-soft);color:var(--primary)}

.header-tools{display:flex;align-items:center;gap:.5rem;margin-left:auto}
.header-search{
	position:relative;display:flex;align-items:center;
	background:var(--bg-3);border:1px solid var(--border);
	border-radius:999px;height:40px;padding:0 .35rem 0 .85rem;
	transition:all .15s
}
.header-search:focus-within{border-color:var(--primary);background:var(--bg-2)}
.header-search input{
	background:transparent;border:0;color:var(--text);outline:none;
	padding:0 .5rem;width:240px;font-size:.92rem
}
.header-search input::placeholder{color:var(--text-muted)}
.header-search button{
	background:var(--primary);border:0;color:#fff;
	width:32px;height:32px;border-radius:50%;
	display:inline-flex;align-items:center;justify-content:center
}

.header-search-suggest{
	position:absolute;top:calc(100% + 8px);right:0;left:0;
	background:var(--bg-2);border:1px solid var(--border);border-radius:10px;
	max-height:420px;overflow:auto;
	box-shadow:var(--shadow-lg);
	z-index:60;
	padding:.4rem
}
.header-search-suggest:empty{display:none}
.search-suggest-item{
	display:flex;gap:.6rem;padding:.5rem;border-radius:6px;cursor:pointer;
	color:var(--text);transition:background .12s
}
.search-suggest-item:hover{background:var(--bg-3)}
.search-suggest-item img{width:50px;height:75px;object-fit:cover;border-radius:4px;flex:none;background:var(--bg-3)}
.search-suggest-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px}
.search-suggest-title{font-weight:600;font-size:.9rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-suggest-meta{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-suggest-meta .pill{display:inline-block;padding:1px 6px;border-radius:3px;background:var(--primary-soft);color:var(--primary);font-size:.7rem;margin-right:.3rem}
.search-suggest-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.85rem}

.mobile-menu-toggle{
	display:none;background:transparent;border:0;width:40px;height:40px;
	flex-direction:column;justify-content:center;gap:5px;align-items:center;
	color:var(--text)
}
.mobile-menu-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform .2s}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.mobile-menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:899px){
	.primary-nav{display:none}
	.mobile-menu-toggle{display:inline-flex;order:-1}
	.site-branding{flex:1}
	.header-search input{width:140px}
	.header-search-suggest{right:0;left:auto;width:calc(100vw - 32px);max-width:340px}
}

.mobile-nav{
	position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
	background:var(--bg);padding:1rem;z-index:49;overflow:auto
}
.mobile-nav .mobile-menu{list-style:none;margin:0;padding:0}
.mobile-nav .mobile-menu a{display:block;padding:.85rem 1rem;border-bottom:1px solid var(--border);color:var(--text);font-weight:500}
.mobile-nav .mobile-menu .sub-menu{list-style:none;padding-left:1rem;margin:0}

/* =========================================================
 * BREADCRUMB
 * ========================================================= */
.breadcrumbs,.rank-math-breadcrumb{font-size:.88rem;color:var(--text-muted);padding:.85rem 0}
.breadcrumbs a,.rank-math-breadcrumb a{color:var(--text)}
.breadcrumbs a:hover,.rank-math-breadcrumb a:hover{color:var(--primary)}
.rank-math-breadcrumb p{margin:0}

/* =========================================================
 * LAYOUT GRIDS
 * ========================================================= */
.page-wrapper{padding:1rem 0 3rem}
.row{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.row:has(.sidebar){grid-template-columns:minmax(0,1fr) 320px}}
.content-col{min-width:0}

.movies-grid{display:grid;gap:14px}
.movies-grid.column-xs-2{grid-template-columns:repeat(2,1fr)}
.movies-grid.column-xs-3{grid-template-columns:repeat(3,1fr)}
@media(min-width:600px){
	.movies-grid.column-md-3{grid-template-columns:repeat(3,1fr)}
	.movies-grid.column-md-4{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:1024px){
	.movies-grid.column-xl-4{grid-template-columns:repeat(4,1fr)}
	.movies-grid.column-xl-5{grid-template-columns:repeat(5,1fr)}
	.movies-grid.column-xl-6{grid-template-columns:repeat(6,1fr)}
	.movies-grid.column-xl-7{grid-template-columns:repeat(7,1fr)}
}

/* =========================================================
 * MOVIE CARD (poster style — inspired by ophim)
 * ========================================================= */
.movie-item-3{position:relative}
.movie-poster{
	position:relative;border-radius:var(--radius);overflow:hidden;
	aspect-ratio:2/3;background:var(--bg-3);
	box-shadow:0 4px 14px rgba(0,0,0,.25);
	transition:transform .25s ease,box-shadow .25s ease
}
.movie-poster:hover{transform:translateY(-3px);box-shadow:0 8px 26px rgba(0,0,0,.45)}
.movie-poster img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .25s}
.movie-poster:hover img{transform:scale(1.06);filter:brightness(.7)}
.movie-link{display:block;height:100%}

.movie-poster::after{
	content:"▶";position:absolute;left:50%;top:50%;
	transform:translate(-50%,-50%) scale(.6);
	width:48px;height:48px;border-radius:50%;
	background:rgba(255,124,29,.95);color:#fff;
	display:flex;align-items:center;justify-content:center;
	font-size:1rem;padding-left:3px;
	opacity:0;transition:all .25s ease;
	box-shadow:0 0 30px rgba(255,124,29,.6);
	pointer-events:none
}
.movie-poster:hover::after{opacity:1;transform:translate(-50%,-50%) scale(1)}

.title-overlay{
	position:absolute;inset:auto 0 0 0;
	padding:34px 10px 8px;
	background:linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,0) 100%)
}
.movie-title{
	margin:0;font-size:13px;font-weight:600;line-height:1.3;color:#fff;
	display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.movie-original-title{margin-top:2px;font-size:11px;color:rgba(255,255,255,.65);font-style:italic;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

.movie-tag,.movie-quality,.movie-views{
	position:absolute;top:8px;left:8px;
	background:var(--primary);color:#fff;
	padding:2px 6px;font-size:10px;border-radius:4px;
	font-weight:700;letter-spacing:.4px
}
.movie-quality{left:auto;right:8px;background:#1976d2}
.movie-views{
	top:auto;left:8px;bottom:42px;
	background:rgba(0,0,0,.75);font-weight:600;
	display:inline-flex;align-items:center;gap:3px
}
.movie-views::before{content:"👁";font-size:.7rem}
.episode-pill{
	position:absolute;bottom:8px;right:8px;
	background:var(--primary);color:#fff;
	padding:2px 8px;font-size:11px;border-radius:4px;font-weight:600;
	box-shadow:0 2px 6px rgba(255,124,29,.5)
}
.year-overlay{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-weight:600}
.footer-ribbon{
	position:absolute;top:8px;left:50%;transform:translateX(-50%);
	font-size:10px;padding:2px 10px;border-radius:4px;color:#fff;
	font-weight:700;letter-spacing:.5px;text-transform:uppercase
}
.ribbon-red{background:var(--danger)}
.ribbon-live{background:var(--accent)}

/* =========================================================
 * SECTION HEAD (homepage block titles)
 * ========================================================= */
.section-head{
	display:flex;justify-content:space-between;align-items:center;
	margin:1.75rem 0 .85rem;
	border-bottom:2px solid var(--bg-4);padding-bottom:.65rem;
	position:relative
}
.section-head::before{
	content:"";position:absolute;left:0;bottom:-2px;
	width:80px;height:2px;background:var(--primary);
	border-radius:2px
}
.section-head .section-title{
	margin:0;font-size:1.15rem;font-weight:700;
	display:inline-flex;align-items:center;gap:.5rem
}
.section-head .section-title::before{
	content:"";width:4px;height:18px;background:var(--primary);
	border-radius:2px;margin-right:.25rem
}
.section-head .section-link{color:var(--text-muted);font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:.25rem}
.section-head .section-link:hover{color:var(--primary)}

.section-title{font-size:1.2rem;margin:1.5rem 0 1rem;font-weight:700}

/* =========================================================
 * SIDEBAR
 * ========================================================= */
.sidebar{align-self:start}
.is-sticky-column__inner{position:sticky;top:calc(var(--header-h) + 12px)}
.widget{
	background:var(--bg-2);border:1px solid var(--border);
	border-radius:var(--radius);padding:1rem;margin-bottom:1rem
}
.widget-title{
	margin:0 0 .85rem;font-size:.92rem;font-weight:700;
	color:var(--primary);text-transform:uppercase;letter-spacing:.6px;
	padding-bottom:.5rem;border-bottom:1px solid var(--border)
}

/* sidebar movie list (inspired by ophim hot list) */
.popular-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}
.popular-item{display:flex;gap:.6rem;align-items:flex-start;position:relative}
.popular-item::before{
	counter-increment:rank;content:counter(rank);
	position:absolute;left:-4px;top:-4px;z-index:2;
	width:22px;height:22px;border-radius:50%;
	background:var(--primary);color:#fff;
	display:flex;align-items:center;justify-content:center;
	font-size:.7rem;font-weight:800;
	box-shadow:0 2px 6px rgba(0,0,0,.4)
}
.popular-list{counter-reset:rank}
.popular-item:nth-child(n+4)::before{background:var(--bg-4);color:var(--text-muted)}
.popular-thumb{flex:0 0 70px;width:70px;aspect-ratio:2/3;border-radius:6px;overflow:hidden;background:var(--bg-3);position:relative}
.popular-thumb img{width:100%;height:100%;object-fit:cover}
.popular-meta{display:flex;flex-direction:column;gap:.2rem;min-width:0;padding-top:.2rem}
.popular-title{font-size:.88rem;font-weight:500;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}
.popular-title:hover{color:var(--primary)}
.popular-ep{font-size:.75rem;color:var(--primary);font-weight:600}

/* =========================================================
 * BUTTONS
 * ========================================================= */
.btn{
	display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
	padding:.65rem 1.3rem;border-radius:8px;font-weight:600;
	border:0;cursor:pointer;text-decoration:none;
	transition:all .18s ease;font-size:.92rem
}
.btn-primary{
	background:linear-gradient(135deg,var(--primary) 0%,var(--danger) 100%);
	color:#fff;
	box-shadow:0 4px 12px rgba(255,124,29,.35)
}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);color:#fff;box-shadow:0 6px 18px rgba(255,124,29,.5)}
.btn-ghost{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--bg-3);color:var(--primary);border-color:var(--primary)}
.btn-block{width:100%}

/* =========================================================
 * PAGINATION
 * ========================================================= */
.navigation.pagination{display:flex;justify-content:center;margin:2rem 0}
.nav-links{display:flex;flex-wrap:wrap;gap:.4rem}
.page-numbers{
	display:inline-flex;align-items:center;justify-content:center;
	min-width:40px;height:40px;padding:0 .65rem;border-radius:8px;
	background:var(--bg-2);color:var(--text);
	border:1px solid var(--border);font-weight:600;font-size:.9rem
}
.page-numbers:not(.dots):hover,.page-numbers.current{
	background:var(--primary);color:#fff;border-color:var(--primary);
	transform:translateY(-1px)
}

/* =========================================================
 * SEARCH
 * ========================================================= */
.search-form{
	display:flex;gap:.5rem;
	background:var(--bg-2);border:1px solid var(--border);
	border-radius:8px;padding:.4rem;margin-bottom:1rem
}
.search-form input{flex:1;background:transparent;border:0;color:var(--text);padding:.4rem .6rem;outline:none}
.search-submit{background:var(--primary);color:#fff;border:0;padding:.5rem 1rem;border-radius:6px;font-weight:600}

/* =========================================================
 * FOOTER
 * ========================================================= */
.site-footer{
	background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%);
	border-top:1px solid var(--border);
	margin-top:3rem;padding:2.5rem 0 1.25rem
}
.footer-widgets{display:grid;gap:1.5rem;grid-template-columns:1fr;margin-bottom:1.5rem}
@media(min-width:768px){.footer-widgets{grid-template-columns:repeat(4,1fr)}}
.footer-widget-title{margin:0 0 .75rem;color:var(--primary);font-size:.95rem;text-transform:uppercase;letter-spacing:.6px}
.footer-bottom{
	display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
	border-top:1px solid var(--border);padding-top:1rem;
	color:var(--text-muted);font-size:.88rem
}
.footer-menu{list-style:none;display:flex;gap:1.25rem;margin:0;padding:0;flex-wrap:wrap}
.footer-menu a{color:var(--text-muted)}
.footer-menu a:hover{color:var(--primary)}

/* Back to top */
.back-to-top{
	position:fixed;right:18px;bottom:18px;width:46px;height:46px;
	background:var(--primary);color:#fff;border-radius:50%;
	display:none;align-items:center;justify-content:center;
	font-weight:700;font-size:1.2rem;z-index:40;
	box-shadow:0 6px 18px rgba(255,124,29,.45);
	transition:transform .15s
}
.back-to-top:hover{transform:translateY(-2px);color:#fff}
.back-to-top.visible{display:flex}

/* =========================================================
 * 404 + No results
 * ========================================================= */
.error-404{text-align:center;padding:3rem 0}
.error-code{font-size:7rem;font-weight:900;color:var(--primary);line-height:1;text-shadow:0 4px 24px rgba(255,124,29,.4)}
.error-title{font-size:1.7rem;margin:.5rem 0;font-weight:700}
.error-message{color:var(--text-muted);margin:0 auto 1.5rem;max-width:520px}
.error-search{max-width:440px;margin:1.5rem auto}
.error-suggestions{text-align:left;margin-top:2rem}

.no-results{padding:2.5rem 1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
.no-results-icon{font-size:3rem;margin-bottom:.5rem;opacity:.7}
.no-results h2{margin:.25rem 0;font-size:1.25rem}
.no-results-suggestions{margin-top:1rem;text-align:left;display:inline-block}
.no-results-suggestions ul{list-style:none;padding:0;margin:.5rem 0 0}
.no-results-suggestions a{color:var(--primary);font-weight:500}

/* =========================================================
 * ARCHIVE / SEARCH HEADERS
 * ========================================================= */
.archive-header{margin:1rem 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.archive-title{font-size:1.5rem;margin:0 0 .25rem;font-weight:700}
.archive-title span{color:var(--primary)}
.archive-description{color:var(--text-muted);margin-top:.4rem}
.search-header{margin-bottom:1.5rem}
.search-title{font-size:1.4rem;margin:0 0 .5rem;font-weight:700}
.search-title span{color:var(--primary)}
.search-count{color:var(--text-muted);font-size:.9rem;margin-top:.4rem}

/* =========================================================
 * HERO SLIDER (front page)
 * ========================================================= */
.hero-slider{position:relative;margin:1rem 0 1.5rem;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.hero-slider .swiper-wrapper{align-items:stretch}
.hero-slide{
	position:relative;aspect-ratio:24/9;
	display:flex;align-items:flex-end;padding:2rem 2.5rem;
	overflow:hidden
}
@media(max-width:768px){.hero-slide{aspect-ratio:16/10;padding:1.25rem}}
.hero-slide__bg{
	position:absolute;inset:0;width:100%;height:100%;
	object-fit:cover;object-position:center;
	transform:scale(1.05);
	transition:transform 8s ease-out
}
.swiper-slide-active .hero-slide__bg{transform:scale(1)}
.hero-slide::before{
	content:"";position:absolute;inset:0;
	background:linear-gradient(90deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.45) 50%,rgba(0,0,0,.1) 100%),
	           linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,rgba(0,0,0,.05) 100%);
	z-index:1
}
.hero-overlay{position:relative;z-index:2;color:#fff;max-width:60%}
@media(max-width:768px){.hero-overlay{max-width:100%}}
.hero-pills{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}
.hero-pills .pill{
	padding:.25rem .65rem;border-radius:14px;
	background:rgba(255,124,29,.85);color:#fff;
	font-size:.78rem;font-weight:600;
	backdrop-filter:blur(8px)
}
.hero-pills .pill.year{background:rgba(28,209,123,.85)}
.hero-title{font-size:2rem;margin:0 0 .65rem;font-weight:800;line-height:1.15;text-shadow:0 4px 18px rgba(0,0,0,.7)}
.hero-title a{color:#fff}
.hero-title a:hover{color:var(--primary-2)}
.hero-excerpt{margin-bottom:1rem;color:rgba(255,255,255,.85);max-width:600px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:768px){.hero-title{font-size:1.3rem}.hero-excerpt{-webkit-line-clamp:2;font-size:.92rem}}
.hero-cta{
	display:inline-flex;align-items:center;gap:.5rem;
	background:linear-gradient(135deg,var(--primary),var(--danger));color:#fff;
	padding:.75rem 1.5rem;border-radius:30px;font-weight:700;
	box-shadow:0 6px 22px rgba(255,124,29,.5);
	transition:all .2s
}
.hero-cta:hover{transform:translateY(-2px);color:#fff;box-shadow:0 10px 28px rgba(255,124,29,.6)}

/* Slider nav arrows */
.hero-slider .swiper-button-prev,
.hero-slider .swiper-button-next{
	position:absolute;top:50%;transform:translateY(-50%);
	width:48px;height:48px;border-radius:50%;
	background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.15);
	color:#fff;font-size:1.5rem;font-weight:700;line-height:1;
	display:flex;align-items:center;justify-content:center;
	z-index:10;opacity:0;
	transition:all .25s;
	backdrop-filter:blur(10px)
}
.hero-slider .swiper-button-prev{left:1rem;padding-right:3px}
.hero-slider .swiper-button-next{right:1rem;padding-left:3px}
.hero-slider:hover .swiper-button-prev,
.hero-slider:hover .swiper-button-next{opacity:1}
.hero-slider .swiper-button-prev:hover,
.hero-slider .swiper-button-next:hover{background:var(--primary);border-color:var(--primary);transform:translateY(-50%) scale(1.05)}
@media(max-width:768px){
	.hero-slider .swiper-button-prev,
	.hero-slider .swiper-button-next{width:38px;height:38px;font-size:1.2rem;opacity:1;background:rgba(0,0,0,.45)}
	.hero-slider .swiper-button-prev{left:.5rem}
	.hero-slider .swiper-button-next{right:.5rem}
}

/* Slider pagination dots */
.hero-slider .swiper-pagination{
	position:absolute;bottom:14px;left:0;right:0;z-index:10;
	display:flex;justify-content:center;gap:8px
}
.hero-slider .swiper-pagination-bullet{
	width:30px;height:4px;border-radius:2px;
	background:rgba(255,255,255,.4);cursor:pointer;
	transition:all .2s;border:0;padding:0
}
.hero-slider .swiper-pagination-bullet-active{background:var(--primary);width:50px}

/* =========================================================
 * FRONT PAGE
 * ========================================================= */
.front-page{padding:.5rem 0 3rem}
.home-block{margin-bottom:1.5rem}
.home-layout{display:grid;gap:1.5rem;grid-template-columns:1fr;margin-top:1rem}
@media(min-width:1024px){.home-layout{grid-template-columns:minmax(0,1fr) 320px}}
.home-sidebar{align-self:start}
@media(min-width:1024px){.home-sidebar{position:sticky;top:calc(var(--header-h) + 12px)}}

/* =========================================================
 * SINGLE MOVIE — hero info card (inspired by ophim)
 * ========================================================= */
.single-movie__hero{
	position:relative;
	margin:0 0 1.5rem;
	padding:2rem 0;
	overflow:hidden;
	border-radius:0
}
.single-movie__hero-bg{
	position:absolute;inset:0;z-index:0;
	background-size:cover;background-position:center;
	filter:blur(28px) brightness(.4);
	transform:scale(1.1)
}
.single-movie__hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,17,.6) 0%,rgba(10,12,17,.95) 100%)}
.single-movie__hero-inner{position:relative;z-index:1}

.movie-info{
	display:grid;grid-template-columns:280px 1fr;gap:2rem;
	align-items:start
}
@media(max-width:768px){.movie-info{grid-template-columns:1fr;gap:1rem}}
.movie-info__poster{
	border-radius:var(--radius-lg);overflow:hidden;
	aspect-ratio:2/3;background:var(--bg-3);
	box-shadow:0 14px 40px rgba(0,0,0,.55)
}
@media(max-width:768px){.movie-info__poster{max-width:240px;margin:0 auto}}
.movie-info__poster img,.movie-info__img{width:100%;height:100%;object-fit:cover}
.movie-info__title{font-size:2rem;line-height:1.15;margin:0 0 .35rem;font-weight:800;text-shadow:0 4px 16px rgba(0,0,0,.5)}
@media(max-width:768px){.movie-info__title{font-size:1.5rem;text-align:center}}
.movie-info__origin{color:var(--text-muted);margin-bottom:.85rem;font-size:.95rem}
@media(max-width:768px){.movie-info__origin{text-align:center}}

.movie-info__rating{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:600}
.rating-value{font-size:1.6rem;color:var(--primary);font-weight:800}
.rating-count{color:var(--text-muted);font-size:.85rem;font-weight:400}

.movie-info__pills{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.movie-info__pills .pill{
	padding:.25rem .65rem;border-radius:14px;
	background:var(--primary-soft);color:var(--primary);
	font-size:.78rem;font-weight:600
}
.movie-info__pills .pill.year{background:rgba(28,209,123,.15);color:var(--accent)}
.movie-info__pills .pill.duration{background:rgba(255,255,255,.08);color:var(--text-muted)}

.movie-info__facts{
	display:grid;grid-template-columns:120px 1fr;gap:.5rem 1rem;
	margin:.75rem 0 1.25rem;font-size:.92rem
}
.movie-info__facts dt{color:var(--text-muted);font-weight:500}
.movie-info__facts dd{margin:0}
.movie-info__facts dd a{color:var(--text);border-bottom:1px dashed transparent;transition:all .15s}
.movie-info__facts dd a:hover{color:var(--primary);border-color:currentColor}

.movie-info__actions{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}

.movie-info__excerpt{color:var(--text-muted);line-height:1.7;max-height:120px;overflow:hidden;position:relative;transition:max-height .35s ease}
.movie-info__excerpt.expanded{max-height:none}
.movie-info__excerpt:not(.expanded)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:50px;background:linear-gradient(0deg,var(--bg) 10%,transparent);pointer-events:none}
.view-more-btn{display:inline-block;margin-top:.4rem;background:transparent;color:var(--primary);border:0;padding:0;font-weight:600;font-size:.9rem}

/* Single layout grid */
.single-movie__layout,.single-series__layout,.single-episode__layout{
	display:grid;gap:1.5rem;grid-template-columns:1fr
}
@media(min-width:1024px){
	.single-movie__layout,.single-series__layout,.single-episode__layout{grid-template-columns:minmax(0,1fr) 320px}
}

/* =========================================================
 * EPISODE LIST
 * ========================================================= */
.episode-list{margin:1rem 0}
.episode-server{margin-bottom:1rem;padding:1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius)}
.episode-server__title{font-size:.95rem;color:var(--primary);margin:0 0 .85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.episode-server__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:6px}
.episode-server .episode-pill{
	position:static;display:flex;align-items:center;justify-content:center;
	background:var(--bg-3);color:var(--text);
	border:1px solid var(--border);min-height:38px;font-size:13px;
	border-radius:6px;font-weight:600;
	transition:all .15s;text-decoration:none;box-shadow:none
}
.episode-server .episode-pill:hover{background:var(--bg-4);color:var(--primary);border-color:var(--primary);transform:translateY(-1px)}
.episode-server .episode-pill.is-active{
	background:linear-gradient(135deg,var(--primary),var(--danger));
	color:#fff;border-color:var(--primary);
	box-shadow:0 4px 12px rgba(255,124,29,.4)
}

.episode-prev-next{
	display:flex;justify-content:space-between;gap:.5rem;
	margin:1rem 0;flex-wrap:wrap;
	padding:1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius)
}

/* =========================================================
 * PLAYER
 * ========================================================= */
.player-wrap{margin:1rem 0;background:#000;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
#video-player{width:100%;aspect-ratio:16/9;background:#000}
.server-buttons{display:flex;flex-wrap:wrap;gap:.5rem;padding:.85rem;background:var(--bg-2);border-top:1px solid var(--border)}
.server-button{font-size:.9rem;padding:.5rem 1rem;background:var(--bg-3);color:var(--text);border:1px solid var(--border);border-radius:6px;font-weight:600;transition:all .15s;display:inline-flex;align-items:center;gap:.4rem}
.server-button::before{content:"●";color:var(--accent);font-size:.7rem}
.server-button:hover,.server-button.is-active{background:var(--primary);color:#fff;border-color:var(--primary)}
.server-button.is-active::before{color:#fff}
.player-empty{padding:3rem;text-align:center;background:var(--bg-2);color:var(--text-muted);font-size:.95rem}

/* =========================================================
 * RELATED MOVIES
 * ========================================================= */
.related-movies{margin-top:2rem}

/* =========================================================
 * SINGLE BLOG POST
 * ========================================================= */
.single-post__layout{display:grid;gap:1.5rem;grid-template-columns:1fr;padding:1rem 0 3rem}
@media(min-width:1024px){.single-post__layout{grid-template-columns:minmax(0,1fr) 320px}}
.single-post__main{min-width:0}
.single-post__cats{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}
.single-post__cat{background:var(--primary);color:#fff;padding:.25rem .7rem;border-radius:4px;font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.5px}
.single-post__cat:hover{filter:brightness(1.1);color:#fff}
.single-post .entry-title{font-size:2rem;line-height:1.2;margin:.5rem 0 .85rem;font-weight:800}
@media(max-width:768px){.single-post .entry-title{font-size:1.5rem}}
.single-post__meta{display:flex;flex-wrap:wrap;gap:1rem;color:var(--text-muted);font-size:.86rem;border-bottom:1px solid var(--border);padding-bottom:.85rem;margin-bottom:1.25rem}
.single-post__meta span{display:inline-flex;align-items:center;gap:.35rem}
.single-post__meta svg{flex:none;opacity:.7}

.single-post__featured{margin:0 0 1.5rem;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-3)}
.single-post__featured img{width:100%;height:auto;display:block}

.single-post__content{font-size:1.02rem;line-height:1.78}
.single-post__content > *{margin-bottom:1rem}
.single-post__content h2{font-size:1.45rem;margin:2rem 0 .85rem;border-left:4px solid var(--primary);padding-left:.7rem;line-height:1.3;font-weight:700}
.single-post__content h3{font-size:1.18rem;margin-top:1.6rem;color:var(--primary)}
.single-post__content h4{font-size:1.06rem;margin-top:1.3rem}
.single-post__content p{margin:.6rem 0 1rem}
.single-post__content a{color:var(--primary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.single-post__content a:hover{filter:brightness(1.2)}
.single-post__content ul,.single-post__content ol{padding-left:1.5rem;margin:.5rem 0 1rem}
.single-post__content li{margin-bottom:.4rem}
.single-post__content blockquote{margin:1.25rem 0;padding:.85rem 1rem;border-left:4px solid var(--primary);background:var(--bg-2);font-style:italic;border-radius:0 8px 8px 0}
.single-post__content img{margin:1rem auto;border-radius:10px;max-width:100%;height:auto}
.single-post__content figure{margin:1.5rem 0}
.single-post__content figure figcaption{font-size:.85rem;color:var(--text-muted);text-align:center;margin-top:.4rem}
.single-post__content table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.95rem}
.single-post__content table th,.single-post__content table td{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}
.single-post__content table th{background:var(--bg-3);color:var(--primary)}
.single-post__content code{background:var(--bg-3);padding:.1rem .35rem;border-radius:4px;font-size:.92em}
.single-post__content pre{background:var(--bg-3);padding:1rem;border-radius:8px;overflow:auto;font-size:.86em}
.single-post__content iframe{max-width:100%;border-radius:10px;aspect-ratio:16/9;width:100%}

.single-post__tags{margin:1.5rem 0;padding:.85rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.single-post__tags strong{color:var(--text-muted);margin-right:.25rem}
.single-post__tags a{background:var(--bg-3);color:var(--text);padding:.3rem .7rem;border-radius:14px;font-size:.85rem;border:1px solid var(--border)}
.single-post__tags a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

.single-post__pn{display:grid;gap:1rem;grid-template-columns:1fr;margin:2rem 0}
@media(min-width:600px){.single-post__pn{grid-template-columns:1fr 1fr}}
.single-post__pn a{display:flex;flex-direction:column;gap:.25rem;background:var(--bg-2);padding:.85rem 1rem;border-radius:8px;border:1px solid var(--border);transition:all .2s}
.single-post__pn a:hover{border-color:var(--primary);transform:translateY(-1px)}
.single-post__pn span{font-size:.78rem;color:var(--text-muted)}
.single-post__pn strong{color:var(--text);font-size:.95rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.single-post__pn .pn-next{text-align:right}

.related-posts-grid{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}
@media(min-width:768px){.related-posts-grid{grid-template-columns:repeat(4,1fr)}}
.related-post{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s}
.related-post:hover{transform:translateY(-3px);border-color:var(--primary)}
.related-post__thumb{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--bg-3)}
.related-post__thumb img{width:100%;height:100%;object-fit:cover}
.related-post__title{margin:.65rem .8rem .25rem;font-size:.92rem;line-height:1.35}
.related-post__title a{color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-post__title a:hover{color:var(--primary)}
.related-post__date{display:block;margin:0 .8rem .8rem;font-size:.78rem;color:var(--text-muted)}
.single-post__sidebar{align-self:start}
@media(min-width:1024px){.single-post__sidebar{position:sticky;top:calc(var(--header-h) + 12px)}}

/* =========================================================
 * COMMENTS
 * ========================================================= */
.single-movie__comments,.single-episode__comments,.single-series__comments,.single-post__comments{margin-top:2rem}

/* =========================================================
 * UTILITIES
 * ========================================================= */
.text-muted{color:var(--text-muted)}
.text-primary{color:var(--primary)}
.mt-2{margin-top:1rem}
.mb-2{margin-bottom:1rem}

/* Light theme override (optional) */
[data-theme="light"]{
	--bg:#f5f7fb;--bg-2:#fff;--bg-3:#fff;--bg-4:#f0f2f6;
	--text:#1a1a1a;--text-muted:#5f6b7a;
	--border:#e5e9f0;--border-strong:#cdd4de
}
