/*
Theme Name: Cineverse
Theme URI: https://yoursite.com/cineverse
Author: Saheb
Author URI: https://yoursite.com
Description: A premium dark, cinematic movie & TV review theme. Glass UI, parallax hero, dense poster grid, rich single-review layouts, light/dark switch, scroll reveals, reading progress, multiple accent presets, fast performance and deep SEO schema (Movie/TVSeries/WebSite SearchAction/Organization). Integrates with Movie Review Manager + ReelRate, and works great as a standalone review blog.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cineverse
Tags: blog, news, entertainment, two-columns, right-sidebar, custom-menu, featured-images, threaded-comments, translation-ready, full-width-template, custom-colors
*/

/* ============================================================
   1. Design tokens
   ============================================================ */
:root{
    /* dark (default) */
    --cv-bg:        #07080c;
    --cv-bg-2:      #0d0f16;
    --cv-card:      #12151f;
    --cv-card-2:    #181c28;
    --cv-line:      rgba(255,255,255,.08);
    --cv-line-2:    rgba(255,255,255,.14);
    --cv-text:      #f3f5fa;
    --cv-muted:     #a3adbe;
    --cv-faint:     #6c768a;
    --cv-accent:    #f5b133;          /* cinematic gold */
    --cv-accent-2:  #ff6a3d;          /* warm flare */
    --cv-accent-rgb: 245,177,51;
    --cv-good:      #4ade80;
    --cv-glass:     rgba(16,19,28,.72);
    --cv-glass-brd: rgba(255,255,255,.09);

    --cv-radius:    18px;
    --cv-radius-sm: 12px;
    --cv-radius-xs: 9px;
    --cv-shadow:    0 24px 60px -12px rgba(0,0,0,.6);
    --cv-shadow-sm: 0 10px 28px -8px rgba(0,0,0,.5);
    --cv-glow:      0 0 0 1px rgba(var(--cv-accent-rgb),.35), 0 18px 50px -10px rgba(var(--cv-accent-rgb),.28);
    --cv-maxw:      1280px;

    --cv-font:      "Hanken Grotesk", system-ui, -apple-system, sans-serif;
    --cv-display:   "Bricolage Grotesque", var(--cv-font);
    --cv-ease:      cubic-bezier(.22,.61,.36,1);
    --cv-ease-out:  cubic-bezier(.16,1,.3,1);
}

/* light theme */
[data-cv-theme="light"]{
    --cv-bg:        #f4f1ea;
    --cv-bg-2:      #ffffff;
    --cv-card:      #ffffff;
    --cv-card-2:    #f6f4ee;
    --cv-line:      rgba(20,20,30,.10);
    --cv-line-2:    rgba(20,20,30,.16);
    --cv-text:      #16181f;
    --cv-muted:     #555f70;
    --cv-faint:     #8a93a3;
    --cv-glass:     rgba(255,255,255,.78);
    --cv-glass-brd: rgba(20,20,30,.08);
    --cv-shadow:    0 24px 60px -16px rgba(40,40,60,.22);
    --cv-shadow-sm: 0 10px 28px -10px rgba(40,40,60,.18);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
    margin:0; background:var(--cv-bg); color:var(--cv-text);
    font-family:var(--cv-font); font-size:16px; line-height:1.65;
    -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
    overflow-x:hidden;
    background-image:
        radial-gradient(1100px 560px at 82% -8%, rgba(var(--cv-accent-rgb),.10), transparent 60%),
        radial-gradient(900px 520px at -12% 2%, rgba(255,106,61,.07), transparent 55%);
    background-attachment:fixed;
    transition:background-color .4s var(--cv-ease), color .3s var(--cv-ease);
}
/* film grain */
body::before{
    content:""; position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.04; mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--cv-display); font-weight:800; line-height:1.1; letter-spacing:-.025em; margin:0 0 .5em; }
p{ margin:0 0 1em; }
::selection{ background:rgba(var(--cv-accent-rgb),.32); color:#fff; }

.cv-container{ width:100%; max-width:var(--cv-maxw); margin:0 auto; padding:0 clamp(16px,4vw,40px); position:relative; z-index:2; }
.cv-site-main{ display:block; min-height:60vh; position:relative; z-index:2; }
.cv-muted{ color:var(--cv-muted); }

/* skip link */
.cv-skip{ position:absolute; left:-999px; top:0; z-index:100; background:var(--cv-accent); color:#000; padding:10px 16px; border-radius:0 0 10px 0; font-weight:700; }
.cv-skip:focus{ left:0; }

/* reading progress bar */
.cv-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:60;
    background:linear-gradient(90deg, var(--cv-accent), var(--cv-accent-2)); box-shadow:0 0 12px rgba(var(--cv-accent-rgb),.6); transition:width .1s linear; }

/* ============================================================
   2. Header
   ============================================================ */
.cv-header{ position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(14px); -webkit-backdrop-filter:saturate(140%) blur(14px);
    background:linear-gradient(180deg, var(--cv-bg) 6%, var(--cv-glass)); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s, background .3s; }
.cv-header.is-stuck{ border-bottom-color:var(--cv-glass-brd); box-shadow:0 14px 40px -18px rgba(0,0,0,.6); }
.cv-header-inner{ display:flex; align-items:center; gap:22px; min-height:72px; }
.cv-logo{ display:inline-flex; align-items:center; gap:10px; font-family:var(--cv-display); font-weight:800; font-size:1.45rem; letter-spacing:-.03em; color:var(--cv-text); }
.cv-logo img{ max-height:46px; width:auto; }
.cv-logo-mark{ display:grid; place-items:center; width:34px; height:34px; border-radius:10px; font-size:.9rem;
    background:linear-gradient(135deg, var(--cv-accent), var(--cv-accent-2)); color:#1a1206; box-shadow:0 6px 18px -4px rgba(var(--cv-accent-rgb),.6); transform:translateZ(0); }

.cv-nav{ margin-left:6px; }
.cv-nav ul{ list-style:none; display:flex; gap:4px; margin:0; padding:0; }
.cv-nav a{ display:inline-block; padding:9px 14px; border-radius:10px; color:var(--cv-muted); font-weight:600; font-size:.95rem; position:relative; transition:color .2s, background .2s; }
.cv-nav a:hover, .cv-nav .current-menu-item > a{ color:var(--cv-text); background:var(--cv-card); }
.cv-nav .current-menu-item > a::after{ content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px; border-radius:2px; background:linear-gradient(90deg,var(--cv-accent),var(--cv-accent-2)); }

.cv-header-tools{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.cv-icon-btn{ display:grid; place-items:center; width:42px; height:42px; border-radius:12px; border:1px solid var(--cv-line); background:var(--cv-card);
    color:var(--cv-text); font-size:1.05rem; cursor:pointer; transition:transform .2s var(--cv-ease), border-color .2s, background .2s; }
.cv-icon-btn:hover{ transform:translateY(-2px); border-color:var(--cv-line-2); background:var(--cv-card-2); }
.cv-icon-btn:active{ transform:translateY(0) scale(.96); }
.cv-theme-toggle .cv-sun{ display:none; }
[data-cv-theme="light"] .cv-theme-toggle .cv-sun{ display:block; }
[data-cv-theme="light"] .cv-theme-toggle .cv-moon{ display:none; }
.cv-menu-toggle{ display:none; }

.cv-searchbar{ max-height:0; overflow:hidden; transition:max-height .35s var(--cv-ease); border-top:1px solid transparent; }
.cv-searchbar.open{ max-height:120px; border-top-color:var(--cv-glass-brd); }
.cv-searchbar .cv-container{ padding-top:14px; padding-bottom:16px; }

/* search form */
form[role="search"]{ display:flex; gap:10px; }
form[role="search"] input[type="search"]{ flex:1; padding:13px 16px; border-radius:12px; border:1px solid var(--cv-line);
    background:var(--cv-card); color:var(--cv-text); font-family:inherit; font-size:1rem; transition:border-color .2s, box-shadow .2s; }
form[role="search"] input[type="search"]:focus{ outline:none; border-color:var(--cv-accent); box-shadow:0 0 0 4px rgba(var(--cv-accent-rgb),.18); }
form[role="search"] button{ padding:0 22px; border-radius:12px; border:0; cursor:pointer; font-weight:700; font-family:inherit;
    background:linear-gradient(135deg,var(--cv-accent),var(--cv-accent-2)); color:#1a1206; transition:filter .2s, transform .2s; }
form[role="search"] button:hover{ filter:brightness(1.06); transform:translateY(-1px); }

/* ============================================================
   3. Buttons / pills
   ============================================================ */
.cv-btn{ display:inline-flex; align-items:center; gap:8px; padding:13px 22px; border-radius:12px; font-weight:700; font-family:inherit; cursor:pointer; border:0;
    background:linear-gradient(135deg,var(--cv-accent),var(--cv-accent-2)); color:#1a1206; transition:transform .2s var(--cv-ease), box-shadow .2s, filter .2s; }
.cv-btn:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(var(--cv-accent-rgb),.5); filter:brightness(1.04); }
.cv-btn:active{ transform:translateY(0); }
.cv-btn.is-ghost{ background:transparent; color:var(--cv-text); border:1px solid var(--cv-line-2); box-shadow:none; }
.cv-btn.is-ghost:hover{ background:var(--cv-card); border-color:var(--cv-accent); box-shadow:none; }

.cv-pills{ display:flex; flex-wrap:wrap; gap:8px; margin:16px 0; }
.cv-pill{ display:inline-flex; align-items:center; gap:6px; padding:7px 13px; border-radius:999px; font-size:.85rem; font-weight:600;
    background:var(--cv-card); border:1px solid var(--cv-line); color:var(--cv-muted); transition:border-color .2s, color .2s, transform .2s; }
a.cv-pill:hover{ color:var(--cv-text); border-color:var(--cv-accent); transform:translateY(-1px); }
.cv-pill.is-rating{ color:var(--cv-accent); border-color:rgba(var(--cv-accent-rgb),.4); background:rgba(var(--cv-accent-rgb),.08); font-weight:800; }

/* ============================================================
   4. Hero
   ============================================================ */
.cv-hero{ margin:26px 0 12px; }
.cv-hero-slide{ position:relative; border-radius:var(--cv-radius); overflow:hidden; min-height:clamp(360px,52vh,560px); display:flex; align-items:flex-end;
    border:1px solid var(--cv-line); box-shadow:var(--cv-shadow); isolation:isolate; }
.cv-hero-bg{ position:absolute; inset:0; background-size:cover; background-position:center; z-index:-2; transform:scale(1.08); animation:cv-kenburns 24s var(--cv-ease) infinite alternate; }
@keyframes cv-kenburns{ from{ transform:scale(1.08) translate(0,0); } to{ transform:scale(1.16) translate(-2%,-2%); } }
.cv-hero-slide::after{ content:""; position:absolute; inset:0; z-index:-1;
    background:linear-gradient(0deg, rgba(7,8,12,.96) 4%, rgba(7,8,12,.55) 42%, rgba(7,8,12,.15) 78%),
               linear-gradient(90deg, rgba(7,8,12,.85), transparent 60%); }
[data-cv-theme="light"] .cv-hero-slide::after{ background:linear-gradient(0deg, rgba(0,0,0,.88) 4%, rgba(0,0,0,.5) 45%, rgba(0,0,0,.12) 80%), linear-gradient(90deg, rgba(0,0,0,.7), transparent 60%); }
.cv-hero-content{ position:relative; padding:clamp(26px,5vw,52px); max-width:760px; }
.cv-hero-kicker{ display:inline-flex; align-items:center; gap:7px; padding:6px 14px; border-radius:999px; font-size:.78rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
    color:var(--cv-accent); background:rgba(var(--cv-accent-rgb),.14); border:1px solid rgba(var(--cv-accent-rgb),.4); margin-bottom:18px; backdrop-filter:blur(6px); }
.cv-hero-title{ font-size:clamp(2.1rem,5.2vw,3.6rem); margin:0 0 14px; color:#fff; text-shadow:0 4px 30px rgba(0,0,0,.5); }
.cv-hero-title a{ color:inherit; background-image:linear-gradient(var(--cv-accent),var(--cv-accent)); background-size:0 3px; background-repeat:no-repeat; background-position:0 100%; transition:background-size .35s var(--cv-ease); }
.cv-hero-title a:hover{ background-size:100% 3px; }
.cv-hero-meta{ display:flex; flex-wrap:wrap; gap:18px; color:#dfe5ef; font-weight:600; margin-bottom:14px; }
.cv-hero-meta strong{ color:var(--cv-accent); }
.cv-hero-excerpt{ color:#cdd5e2; font-size:1.06rem; max-width:60ch; margin:0; }

/* ============================================================
   5. Sections & grid
   ============================================================ */
.cv-section{ margin:46px 0; }
.cv-section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin:0 0 22px; }
.cv-section-head h2{ font-size:clamp(1.4rem,3vw,1.95rem); margin:0; position:relative; padding-left:16px; }
.cv-section-head h2::before{ content:""; position:absolute; left:0; top:.1em; bottom:.1em; width:5px; border-radius:3px; background:linear-gradient(var(--cv-accent),var(--cv-accent-2)); }
.cv-more{ color:var(--cv-muted); font-weight:700; font-size:.92rem; white-space:nowrap; transition:color .2s, transform .2s; }
.cv-more:hover{ color:var(--cv-accent); transform:translateX(3px); }

.cv-grid{ display:grid; gap:clamp(14px,2vw,24px); grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); }
.cv-grid.is-wide{ grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }

/* ============================================================
   6. Poster card
   ============================================================ */
.cv-card{ position:relative; border-radius:var(--cv-radius-sm); overflow:hidden; background:var(--cv-card); border:1px solid var(--cv-line);
    transition:transform .35s var(--cv-ease-out), box-shadow .35s, border-color .35s; will-change:transform; }
.cv-card:hover{ transform:translateY(-6px); box-shadow:var(--cv-shadow); border-color:var(--cv-line-2); }
.cv-poster{ position:relative; aspect-ratio:2/3; overflow:hidden; background:linear-gradient(135deg,var(--cv-card-2),var(--cv-card)); }
.cv-poster img{ width:100%; height:100%; object-fit:cover; transition:transform .55s var(--cv-ease-out), filter .4s; }
.cv-card:hover .cv-poster img{ transform:scale(1.07); }
.cv-poster::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(7,8,12,.85), transparent 45%); opacity:0; transition:opacity .35s; }
.cv-card:hover .cv-poster::after{ opacity:1; }
.cv-poster-empty{ position:absolute; inset:0; display:grid; place-items:center; font-size:2.4rem; opacity:.4; }
.cv-rating-badge{ position:absolute; top:10px; left:10px; z-index:3; padding:5px 10px; border-radius:999px; font-size:.8rem; font-weight:800;
    background:rgba(7,8,12,.7); color:var(--cv-accent); border:1px solid rgba(var(--cv-accent-rgb),.45); backdrop-filter:blur(6px); }
.cv-type-badge{ position:absolute; top:10px; right:10px; z-index:3; padding:5px 10px; border-radius:999px; font-size:.7rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em;
    background:rgba(7,8,12,.65); color:#fff; border:1px solid var(--cv-line-2); backdrop-filter:blur(6px); }
.cv-bookmark{ position:absolute; bottom:10px; right:10px; z-index:4; width:38px; height:38px; border-radius:11px; display:grid; place-items:center; cursor:pointer;
    background:rgba(7,8,12,.62); border:1px solid var(--cv-line-2); color:#fff; font-size:1rem; opacity:0; transform:translateY(6px); transition:opacity .3s, transform .3s, background .2s, color .2s; backdrop-filter:blur(6px); }
.cv-card:hover .cv-bookmark, .cv-bookmark.is-on{ opacity:1; transform:translateY(0); }
.cv-bookmark:hover{ background:var(--cv-accent); color:#1a1206; }
.cv-bookmark.is-on{ background:var(--cv-accent); color:#1a1206; border-color:transparent; }
.cv-card-body{ padding:13px 14px 15px; }
.cv-card-title{ font-size:1rem; line-height:1.25; margin:0 0 6px; }
.cv-card-title a{ color:var(--cv-text); transition:color .2s; }
.cv-card:hover .cv-card-title a{ color:var(--cv-accent); }
.cv-card-meta{ display:flex; flex-wrap:wrap; gap:6px 12px; color:var(--cv-faint); font-size:.83rem; font-weight:600; }
.cv-card-link{ position:absolute; inset:0; z-index:2; }
.cv-card .cv-bookmark{ z-index:5; }

/* ============================================================
   7. Layout (content + sidebar)
   ============================================================ */
.cv-layout{ display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:40px; margin:30px 0 60px; align-items:start; }
.cv-layout.is-full{ grid-template-columns:minmax(0,1fr); }
.cv-content{ min-width:0; }
.cv-sidebar{ position:sticky; top:96px; display:flex; flex-direction:column; gap:24px; }

.cv-breadcrumbs{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; padding:20px 0 4px; font-size:.86rem; color:var(--cv-faint); }
.cv-breadcrumbs a{ color:var(--cv-muted); transition:color .2s; }
.cv-breadcrumbs a:hover{ color:var(--cv-accent); }
.cv-breadcrumbs [aria-current="page"]{ color:var(--cv-text); font-weight:600; }

/* ============================================================
   8. Single — review
   ============================================================ */
.cv-single-hero{ position:relative; margin:18px 0 8px; border-radius:var(--cv-radius); overflow:hidden; isolation:isolate; }
.cv-single-backdrop{ position:absolute; inset:0; background-size:cover; background-position:center top; z-index:-2; transform:scale(1.05); }
.cv-single-hero::after{ content:""; position:absolute; inset:0; z-index:-1;
    background:linear-gradient(0deg, var(--cv-bg) 2%, rgba(7,8,12,.7) 40%, rgba(7,8,12,.35) 100%); }
[data-cv-theme="light"] .cv-single-hero::after{ background:linear-gradient(0deg, var(--cv-bg) 2%, rgba(0,0,0,.55) 45%, rgba(0,0,0,.25) 100%); }
.cv-single-hero-inner{ position:relative; display:grid; grid-template-columns:240px minmax(0,1fr); gap:clamp(20px,4vw,40px); padding:clamp(26px,5vw,52px); align-items:end; }
.cv-single-poster{ border-radius:var(--cv-radius-sm); overflow:hidden; box-shadow:var(--cv-shadow); aspect-ratio:2/3; background:var(--cv-card-2); border:1px solid var(--cv-line-2); }
.cv-single-poster img{ width:100%; height:100%; object-fit:cover; }
.cv-single-title{ font-size:clamp(1.9rem,4.6vw,3.2rem); color:#fff; margin:0 0 6px; text-shadow:0 4px 30px rgba(0,0,0,.45); }
[data-cv-theme="light"] .cv-single-title{ color:#fff; }
.cv-single-tagline{ color:#cfd6e2; font-style:italic; font-size:1.1rem; margin:0 0 6px; }
.cv-single-actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:18px; }

/* article body */
.cv-article{ font-size:1.07rem; line-height:1.8; color:var(--cv-text); max-width:74ch; }
.cv-article > *{ margin-bottom:1.1em; }
.cv-article h2,.cv-article h3{ margin-top:1.6em; }
.cv-article h2{ font-size:1.6rem; } .cv-article h3{ font-size:1.3rem; }
.cv-article a{ color:var(--cv-accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }
.cv-article img{ border-radius:var(--cv-radius-sm); margin:1.4em 0; box-shadow:var(--cv-shadow-sm); }
.cv-article blockquote{ margin:1.6em 0; padding:14px 22px; border-left:4px solid var(--cv-accent); background:var(--cv-card); border-radius:0 12px 12px 0; color:var(--cv-muted); font-style:italic; }
.cv-article ul,.cv-article ol{ padding-left:1.4em; }
.cv-article li{ margin-bottom:.5em; }
.cv-article code{ background:var(--cv-card-2); padding:2px 7px; border-radius:6px; font-size:.92em; }
.cv-article hr{ border:0; height:1px; background:var(--cv-line); margin:2em 0; }

.cv-post-head{ padding:18px 0 6px; }
.cv-post-head h1{ font-size:clamp(1.8rem,4.5vw,2.8rem); }
.cv-meta-line{ display:flex; flex-wrap:wrap; gap:8px 16px; color:var(--cv-faint); font-weight:600; font-size:.9rem; margin-bottom:12px; }
.cv-meta-line span:not(:last-child)::after{ content:"·"; margin-left:16px; color:var(--cv-line-2); }
.cv-post-featured{ border-radius:var(--cv-radius); overflow:hidden; margin:8px 0 26px; box-shadow:var(--cv-shadow-sm); }

/* share row + reading time */
.cv-article-foot{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin:30px 0 0; padding-top:22px; border-top:1px solid var(--cv-line); }
.cv-readtime{ display:inline-flex; align-items:center; gap:7px; color:var(--cv-faint); font-weight:600; font-size:.9rem; }
.cv-share{ display:flex; gap:8px; margin-left:auto; }
.cv-share a{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; background:var(--cv-card); border:1px solid var(--cv-line); color:var(--cv-muted); transition:transform .2s, color .2s, border-color .2s; }
.cv-share a:hover{ transform:translateY(-2px); color:var(--cv-accent); border-color:var(--cv-accent); }

/* ============================================================
   9. Sidebar widgets / mini rows
   ============================================================ */
.cv-widget{ background:var(--cv-card); border:1px solid var(--cv-line); border-radius:var(--cv-radius-sm); padding:18px; }
.cv-widget-title{ font-size:1.05rem; margin:0 0 14px; padding-bottom:12px; border-bottom:1px solid var(--cv-line); }
.cv-widget ul{ list-style:none; margin:0; padding:0; }
.cv-widget li{ padding:7px 0; border-bottom:1px solid var(--cv-line); }
.cv-widget li:last-child{ border-bottom:0; }
.cv-widget a{ color:var(--cv-muted); transition:color .2s; }
.cv-widget a:hover{ color:var(--cv-accent); }

.cv-mini{ display:grid; grid-template-columns:54px 1fr; gap:12px; padding:10px 0; border-bottom:1px solid var(--cv-line); }
.cv-mini:last-child{ border-bottom:0; padding-bottom:0; }
.cv-mini-poster{ display:block; border-radius:9px; overflow:hidden; aspect-ratio:2/3; background:var(--cv-card-2); }
.cv-mini-poster img{ width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.cv-mini:hover .cv-mini-poster img{ transform:scale(1.08); }
.cv-mini-title{ font-size:.95rem; line-height:1.3; margin:0 0 4px; }
.cv-mini-title a{ color:var(--cv-text); transition:color .2s; }
.cv-mini:hover .cv-mini-title a{ color:var(--cv-accent); }
.cv-mini-meta{ font-size:.8rem; color:var(--cv-faint); font-weight:600; }

/* ============================================================
   10. Filter toolbar (archive)
   ============================================================ */
.cv-toolbar{ display:flex; flex-wrap:wrap; gap:8px; margin:6px 0 22px; }
.cv-toolbar a{ padding:8px 15px; border-radius:999px; font-size:.85rem; font-weight:700; color:var(--cv-muted); background:var(--cv-card); border:1px solid var(--cv-line); transition:all .2s; }
.cv-toolbar a:hover{ color:var(--cv-text); border-color:var(--cv-line-2); }
.cv-toolbar a.is-active{ color:#1a1206; background:linear-gradient(135deg,var(--cv-accent),var(--cv-accent-2)); border-color:transparent; }

/* ============================================================
   11. Pagination / states
   ============================================================ */
.cv-pagination{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:44px 0 10px; }
.cv-pagination .page-numbers{ display:grid; place-items:center; min-width:44px; height:44px; padding:0 14px; border-radius:12px; font-weight:700;
    background:var(--cv-card); border:1px solid var(--cv-line); color:var(--cv-muted); transition:all .2s; }
.cv-pagination a.page-numbers:hover{ color:var(--cv-text); border-color:var(--cv-accent); transform:translateY(-2px); }
.cv-pagination .page-numbers.current{ color:#1a1206; background:linear-gradient(135deg,var(--cv-accent),var(--cv-accent-2)); border-color:transparent; }

.cv-state{ text-align:center; padding:80px 20px; }
.cv-state-emoji{ font-size:3.4rem; margin-bottom:12px; filter:drop-shadow(0 8px 20px rgba(0,0,0,.4)); }
.cv-state h1{ font-size:1.8rem; }
.cv-state p{ color:var(--cv-muted); }

/* ============================================================
   12. Footer
   ============================================================ */
.cv-footer{ margin-top:60px; background:var(--cv-bg-2); border-top:1px solid var(--cv-line); position:relative; z-index:2; }
.cv-footer-inner{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:36px; padding:52px 0 36px; }
.cv-footer h4{ font-size:1.05rem; margin:0 0 14px; }
.cv-footer ul{ list-style:none; margin:0; padding:0; }
.cv-footer li{ padding:5px 0; }
.cv-footer a{ color:var(--cv-muted); transition:color .2s; }
.cv-footer a:hover{ color:var(--cv-accent); }
.cv-footer-bottom{ border-top:1px solid var(--cv-line); padding:20px 0; color:var(--cv-faint); font-size:.88rem; }
.cv-footer-disclaimer{ margin-top:8px; max-width:760px; line-height:1.6; }

/* scroll-to-top */
.cv-totop{ position:fixed; right:22px; bottom:22px; z-index:55; width:48px; height:48px; border-radius:14px; display:grid; place-items:center; cursor:pointer; border:1px solid var(--cv-line-2);
    background:var(--cv-glass); backdrop-filter:blur(10px); color:var(--cv-text); font-size:1.2rem; opacity:0; transform:translateY(16px) scale(.9); pointer-events:none; transition:all .3s var(--cv-ease); }
.cv-totop.show{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.cv-totop:hover{ background:var(--cv-accent); color:#1a1206; border-color:transparent; }

/* ============================================================
   13. Trailer modal
   ============================================================ */
.cv-trailer-modal{ position:fixed; inset:0; z-index:100; display:none; align-items:center; justify-content:center; padding:20px;
    background:rgba(3,4,7,.86); backdrop-filter:blur(8px); }
.cv-trailer-modal.open{ display:flex; animation:cv-fade .25s var(--cv-ease); }
@keyframes cv-fade{ from{ opacity:0; } to{ opacity:1; } }
.cv-trailer-frame{ position:relative; width:min(960px,100%); aspect-ratio:16/9; border-radius:var(--cv-radius); overflow:hidden; box-shadow:var(--cv-shadow); animation:cv-pop .35s var(--cv-ease-out); }
@keyframes cv-pop{ from{ transform:scale(.94); opacity:0; } to{ transform:scale(1); opacity:1; } }
.cv-trailer-frame iframe{ width:100%; height:100%; border:0; }
.cv-trailer-close{ position:absolute; top:12px; right:12px; z-index:2; width:40px; height:40px; border-radius:50%; border:0; cursor:pointer;
    background:rgba(0,0,0,.6); color:#fff; font-size:1.4rem; line-height:1; }
.cv-trailer-close:hover{ background:var(--cv-accent); color:#1a1206; }

/* ============================================================
   14. Comments
   ============================================================ */
.cv-comments{ margin:46px 0 0; }
.cv-comments-inner{ background:var(--cv-card); border:1px solid var(--cv-line); border-radius:var(--cv-radius); padding:clamp(20px,3vw,32px); }
.comment-list{ list-style:none; margin:0 0 20px; padding:0; }
.comment-list ol{ list-style:none; padding-left:24px; }
.comment-list .comment{ padding:16px 0; border-bottom:1px solid var(--cv-line); }
.comment-list .comment-author{ font-weight:700; }
.comment-list .comment-meta{ font-size:.82rem; color:var(--cv-faint); margin-bottom:6px; }
.comment-list img.avatar{ border-radius:50%; float:left; margin-right:12px; }
.cv-comments input[type=text],.cv-comments input[type=email],.cv-comments input[type=url],.cv-comments textarea{
    width:100%; padding:12px 14px; border-radius:11px; border:1px solid var(--cv-line); background:var(--cv-bg-2); color:var(--cv-text); font-family:inherit; margin-bottom:12px; }
.cv-comments input:focus,.cv-comments textarea:focus{ outline:none; border-color:var(--cv-accent); box-shadow:0 0 0 4px rgba(var(--cv-accent-rgb),.16); }
.cv-comments .submit{ all:unset; cursor:pointer; padding:13px 24px; border-radius:12px; font-weight:700; background:linear-gradient(135deg,var(--cv-accent),var(--cv-accent-2)); color:#1a1206; }

/* ============================================================
   15. Scroll-reveal
   ============================================================ */
.cv-reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--cv-ease-out), transform .7s var(--cv-ease-out); }
.cv-reveal.is-in{ opacity:1; transform:none; }

.screen-reader-text{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; }
.cv-page-links{ margin:20px 0; display:flex; gap:8px; flex-wrap:wrap; }

/* ============================================================
   16. Responsive
   ============================================================ */
@media (max-width:980px){
    .cv-layout{ grid-template-columns:1fr; }
    .cv-sidebar{ position:static; }
    .cv-footer-inner{ grid-template-columns:1fr 1fr; }
    .cv-single-hero-inner{ grid-template-columns:160px 1fr; }
}
@media (max-width:720px){
    .cv-menu-toggle{ display:grid; }
    .cv-nav{ position:fixed; inset:72px 0 auto 0; margin:0; background:var(--cv-bg-2); border-bottom:1px solid var(--cv-line);
        max-height:0; overflow:hidden; transition:max-height .35s var(--cv-ease); z-index:49; }
    .cv-nav.open{ max-height:70vh; overflow-y:auto; box-shadow:var(--cv-shadow); }
    .cv-nav ul{ flex-direction:column; gap:0; padding:8px 16px 16px; }
    .cv-nav a{ display:block; padding:13px 12px; border-bottom:1px solid var(--cv-line); border-radius:0; }
    .cv-nav .current-menu-item > a::after{ display:none; }
    .cv-grid{ grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); }
    .cv-single-hero-inner{ grid-template-columns:1fr; }
    .cv-single-poster{ max-width:200px; }
    .cv-footer-inner{ grid-template-columns:1fr; gap:24px; }
}

/* ============================================================
   17. Motion / a11y
   ============================================================ */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
    .cv-hero-bg{ animation:none; }
    .cv-reveal{ opacity:1; transform:none; }
    html{ scroll-behavior:auto; }
}
:focus-visible{ outline:3px solid var(--cv-accent); outline-offset:2px; border-radius:4px; }

/* ============================================================
   v2.1 polish — button consistency, action row, a11y, print
   ============================================================ */

/* Equalise the hero action buttons so trailer + official site match height. */
.cv-single-actions .cv-btn{ min-height:48px; line-height:1.1; }
.cv-single-actions .cv-btn:focus-visible{ outline-offset:3px; }

/* Smoother, GPU-friendly button hover. */
.cv-btn{ will-change:transform; transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, background-color .18s ease, border-color .18s ease; }

/* Crisper poster + backdrop rendering on hi-dpi screens. */
.cv-single-poster img, .cv-card img{ image-rendering:auto; }

/* Keep an empty action row from leaving a phantom gap after de-dupe. */
.cv-single-actions:empty{ display:none; margin:0; }
.cv-pills:empty{ display:none; }

/* Tidy trailer/official-site buttons that may live inside the article body. */
.cv-article .cv-btn{ vertical-align:middle; }

/* Better tap targets on small screens. */
@media (max-width:600px){
    .cv-single-actions{ width:100%; }
    .cv-single-actions .cv-btn{ flex:1 1 auto; justify-content:center; }
}

/* Clean printout (reviews are share-worthy). */
@media print{
    .cv-header, .cv-progress, .cv-searchbar, .cv-share, .cv-trailer-modal,
    .cv-single-actions, .cv-icon-btn, .cv-footer, .cv-skip{ display:none !important; }
    body{ background:#fff; color:#000; }
    .cv-single-backdrop{ display:none; }
    a[href]:after{ content:" (" attr(href) ")"; font-size:.8em; color:#555; }
}
